summaryrefslogtreecommitdiff
path: root/src/management/builder/mail.cpp
diff options
context:
space:
mode:
authorclaiff <claiff@mail.ru>2022-10-05 16:02:06 +0300
committerclaiff <claiff@mail.ru>2022-10-05 16:02:06 +0300
commit3f1f70a3b945605c6abb7d23f46042b963db243a (patch)
treec7ae9c113d29aa3350eca04f27a933bd3b5f769c /src/management/builder/mail.cpp
parent9ed43c1057eeec6a01b8fdfd4d2ee54f9df39670 (diff)
parent43e721305c866ad4b2c4c35d1133f169e41dd49b (diff)
downloadobmc-sila-smtp-refactor/3009.tar.xz
Merge branch 'devtool' into refactor/3009refactor/3009
Diffstat (limited to 'src/management/builder/mail.cpp')
-rw-r--r--src/management/builder/mail.cpp20
1 files changed, 14 insertions, 6 deletions
diff --git a/src/management/builder/mail.cpp b/src/management/builder/mail.cpp
index a301f5b..a96fd33 100644
--- a/src/management/builder/mail.cpp
+++ b/src/management/builder/mail.cpp
@@ -1,19 +1,27 @@
#include "mail.hpp"
-#include "file/mail.hpp"
#include "checker/errors/mail/empty.hpp"
#include "checker/errors/mail/at_sign.hpp"
+#include "file/mail/file_decorator.hpp"
+#include "file/mail/checker_decorator.hpp"
+#include "file/mail/sort_decorator.hpp"
+
namespace smtp::manage::builder
{
smtp::manage::Mail Mail::Build() const
{
- static const std::string PATH = {"/var/lib/smtp/mails.txt"};
+ return smtp::manage::Mail{BuildFileManipulator()};
+ }
- auto registrator = BuildErrorRegistrator();
- file::Mail file_manipulator{PATH, registrator};
- return smtp::manage::Mail{file_manipulator};
- }
+ file::mail::types::IFileManipulatorPtr Mail::BuildFileManipulator() const
+ {
+ static const std::string PATH = {"/var/lib/smtp/mails.txt"};
+ auto result = std::make_shared<file::mail::SortDecorator>() ;
+ result->Apply(std::make_shared<file::mail::CheckerDecorator>( BuildErrorRegistrator() ))
+ .Apply(std::make_shared<file::mail::FileDecorator>( PATH ));
+ return result;
+ }
checker::RegistratorMails Mail::BuildErrorRegistrator() const
{