diff options
author | claiff <claiff@mail.ru> | 2022-10-05 16:02:06 +0300 |
---|---|---|
committer | claiff <claiff@mail.ru> | 2022-10-05 16:02:06 +0300 |
commit | 3f1f70a3b945605c6abb7d23f46042b963db243a (patch) | |
tree | c7ae9c113d29aa3350eca04f27a933bd3b5f769c /src/management/builder/mail.cpp | |
parent | 9ed43c1057eeec6a01b8fdfd4d2ee54f9df39670 (diff) | |
parent | 43e721305c866ad4b2c4c35d1133f169e41dd49b (diff) | |
download | obmc-sila-smtp-3f1f70a3b945605c6abb7d23f46042b963db243a.tar.xz |
Merge branch 'devtool' into refactor/3009refactor/3009
Diffstat (limited to 'src/management/builder/mail.cpp')
-rw-r--r-- | src/management/builder/mail.cpp | 20 |
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 { |