diff options
author | eportnov <eportnov@ibs.ru> | 2022-09-09 11:10:14 +0300 |
---|---|---|
committer | eportnov <eportnov@ibs.ru> | 2022-09-09 12:41:59 +0300 |
commit | 9fa4addff6f90a8b5697a594e034f5517d64dd25 (patch) | |
tree | b429545eba770ea5aadd030b40f62ca8ab5b208a /src/message_builder | |
download | obmc-sila-smtp-9fa4addff6f90a8b5697a594e034f5517d64dd25.tar.xz |
first comit
Diffstat (limited to 'src/message_builder')
-rw-r--r-- | src/message_builder/cc.cpp | 31 | ||||
-rw-r--r-- | src/message_builder/cc.hpp | 21 | ||||
-rw-r--r-- | src/message_builder/date.cpp | 16 | ||||
-rw-r--r-- | src/message_builder/date.hpp | 17 | ||||
-rw-r--r-- | src/message_builder/from.cpp | 22 | ||||
-rw-r--r-- | src/message_builder/from.hpp | 19 | ||||
-rw-r--r-- | src/message_builder/mail_to.cpp | 23 | ||||
-rw-r--r-- | src/message_builder/mail_to.hpp | 21 | ||||
-rw-r--r-- | src/message_builder/subject.cpp | 21 | ||||
-rw-r--r-- | src/message_builder/subject.hpp | 19 | ||||
-rw-r--r-- | src/message_builder/text.cpp | 24 | ||||
-rw-r--r-- | src/message_builder/text.hpp | 19 | ||||
-rw-r--r-- | src/message_builder/types/idecorator.hpp | 82 | ||||
-rw-r--r-- | src/message_builder/types/imessage_build.hpp | 14 |
14 files changed, 349 insertions, 0 deletions
diff --git a/src/message_builder/cc.cpp b/src/message_builder/cc.cpp new file mode 100644 index 0000000..c686ef2 --- /dev/null +++ b/src/message_builder/cc.cpp @@ -0,0 +1,31 @@ +#include "cc.hpp" + +namespace smtp::message_builder +{ + Cc::Cc( std::list<std::string> const& mail_to ) + : mMailTo( mail_to ) + { + + } + + std::string Cc::Get() const + { + std::string result; + if( mBase ) + { + result = mBase->Get(); + } + + if( mMailTo.empty() ) + { + return result; + } + + for(const auto& cc : mMailTo) + { + result += "Cc: " + cc + "\r\n"; + } + + return result; + } +} diff --git a/src/message_builder/cc.hpp b/src/message_builder/cc.hpp new file mode 100644 index 0000000..5062c37 --- /dev/null +++ b/src/message_builder/cc.hpp @@ -0,0 +1,21 @@ +#pragma once + +#include <list> + +#include "types/idecorator.hpp" +#include "types/imessage_build.hpp" + +namespace smtp::message_builder +{ + class Cc : public types::IDecorator<types::IMessageBuilder> + { + public: + explicit Cc( std::list<std::string> const& mail_to ); + ~Cc() override = default; + + std::string Get() const override; + private: + std::list<std::string> const& mMailTo; + }; +} + diff --git a/src/message_builder/date.cpp b/src/message_builder/date.cpp new file mode 100644 index 0000000..96ee2e1 --- /dev/null +++ b/src/message_builder/date.cpp @@ -0,0 +1,16 @@ +#include "date.hpp" + +namespace smtp::message_builder +{ + std::string Date::Get() const + { + std::string result; + + if( mBase ) + { + result = mBase->Get(); + } + result += "Date: Mon, 29 Nov 2010 21:54:29 +1100\r\n"; + return result; + } +} diff --git a/src/message_builder/date.hpp b/src/message_builder/date.hpp new file mode 100644 index 0000000..00fb6cb --- /dev/null +++ b/src/message_builder/date.hpp @@ -0,0 +1,17 @@ +#pragma once + +#include "types/idecorator.hpp" +#include "types/imessage_build.hpp" + +namespace smtp::message_builder +{ + class Date : public types::IDecorator<types::IMessageBuilder> + { + public: + Date() = default; + ~Date() override = default; + + std::string Get() const override; + }; +} + diff --git a/src/message_builder/from.cpp b/src/message_builder/from.cpp new file mode 100644 index 0000000..094e1a2 --- /dev/null +++ b/src/message_builder/from.cpp @@ -0,0 +1,22 @@ +#include "from.hpp" + +namespace smtp::message_builder +{ + + From::From( std::string const& mail_to ) + :mMailTo( mail_to ) + { + + } + + std::string From::Get() const + { + std::string result; + if( mBase ) + { + result = mBase->Get(); + } + result += "From: " + mMailTo + "\r\n"; + return result; + } +} diff --git a/src/message_builder/from.hpp b/src/message_builder/from.hpp new file mode 100644 index 0000000..4605469 --- /dev/null +++ b/src/message_builder/from.hpp @@ -0,0 +1,19 @@ +#pragma once + +#include "types/idecorator.hpp" +#include "types/imessage_build.hpp" + +namespace smtp::message_builder +{ + class From : public types::IDecorator<types::IMessageBuilder> + { + public: + explicit From( std::string const& mail_to ); + ~From() override = default; + + std::string Get() const override; + private: + std::string const& mMailTo; + }; +} + diff --git a/src/message_builder/mail_to.cpp b/src/message_builder/mail_to.cpp new file mode 100644 index 0000000..c73e2a7 --- /dev/null +++ b/src/message_builder/mail_to.cpp @@ -0,0 +1,23 @@ +#include "mail_to.hpp" + +namespace smtp::message_builder +{ + MailTo::MailTo( std::string const& mail_to) + : mMailTo( mail_to ) + { + + } + + std::string MailTo::Get() const + { + std::string result; + if( mBase ) + { + result = mBase->Get(); + } + + result += "To: " + mMailTo +"\r\n"; + + return result; + } +} diff --git a/src/message_builder/mail_to.hpp b/src/message_builder/mail_to.hpp new file mode 100644 index 0000000..0245fd6 --- /dev/null +++ b/src/message_builder/mail_to.hpp @@ -0,0 +1,21 @@ +#pragma once + +#include <list> + +#include "types/idecorator.hpp" +#include "types/imessage_build.hpp" + +namespace smtp::message_builder +{ + class MailTo : public types::IDecorator<types::IMessageBuilder> + { + public: + explicit MailTo( std::string const& mail_to ); + ~MailTo() override = default; + + std::string Get() const override; + private: + std::string const& mMailTo; + }; +} + diff --git a/src/message_builder/subject.cpp b/src/message_builder/subject.cpp new file mode 100644 index 0000000..84e7e43 --- /dev/null +++ b/src/message_builder/subject.cpp @@ -0,0 +1,21 @@ +#include "subject.hpp" + +namespace smtp::message_builder +{ + Subject::Subject( std::string const& subject ) + : mSubject(subject) + { + + } + + std::string Subject::Get() const + { + std::string result; + if( mBase ) + { + result = mBase->Get(); + } + result += "Subject: " + mSubject + "\r\n"; + return result; + } +} diff --git a/src/message_builder/subject.hpp b/src/message_builder/subject.hpp new file mode 100644 index 0000000..bf8bfab --- /dev/null +++ b/src/message_builder/subject.hpp @@ -0,0 +1,19 @@ +#pragma once + +#include "types/idecorator.hpp" +#include "types/imessage_build.hpp" + +namespace smtp::message_builder +{ + class Subject : public types::IDecorator<types::IMessageBuilder> + { + public: + explicit Subject( std::string const& subject ); + ~Subject() override = default; + + std::string Get() const override; + private: + std::string const& mSubject; + }; +} + diff --git a/src/message_builder/text.cpp b/src/message_builder/text.cpp new file mode 100644 index 0000000..e5e6bf0 --- /dev/null +++ b/src/message_builder/text.cpp @@ -0,0 +1,24 @@ +#include "text.hpp" + +namespace smtp::message_builder +{ + Text::Text( std::string const& text) + : mText( text ) + { + + } + + std::string Text::Get() const + { + std::string result; + if( mBase ) + { + result = mBase->Get(); + } + + result += "\r\n"; + result += mText + "\r\n"; + + return result; + } +} diff --git a/src/message_builder/text.hpp b/src/message_builder/text.hpp new file mode 100644 index 0000000..4df90e1 --- /dev/null +++ b/src/message_builder/text.hpp @@ -0,0 +1,19 @@ +#pragma once + +#include "types/idecorator.hpp" +#include "types/imessage_build.hpp" + +namespace smtp::message_builder +{ + class Text : public types::IDecorator<types::IMessageBuilder> + { + public: + explicit Text( std::string const& text ); + ~Text() override = default; + + std::string Get() const override; + private: + std::string const& mText; + }; +} + diff --git a/src/message_builder/types/idecorator.hpp b/src/message_builder/types/idecorator.hpp new file mode 100644 index 0000000..3fabcd4 --- /dev/null +++ b/src/message_builder/types/idecorator.hpp @@ -0,0 +1,82 @@ +#pragma once
+
+#include <memory>
+
+namespace smtp::message_builder::types
+{
+
+/**
+ * @brief Базовый интерфейс описания декоратора
+ * @details См. https://refactoring.guru/ru/design-patterns/decorator
+ * @tparam T Тип декорируемого класса, T должен обладать возможностью наследования (в том числе виртуальный деструктор)
+ */
+ template < typename T, typename TPointerType = std::shared_ptr<T> > class IDecorator : public T
+ {
+ public:
+ using PointerType = TPointerType;
+ using Type = IDecorator<T, TPointerType>;
+
+ ~IDecorator() override = default;
+
+ /**
+ * @brief Установить указатель на декорируемый класс
+ * @details По возможности используйте метод Apply() как наиболее универсальный
+ * @param base Указатель на декорируемый класс
+ */
+ void SetBase( PointerType const& base ) noexcept
+ {
+ mBase = base;
+ }
+
+ void SetBase( PointerType&& base ) noexcept
+ {
+ mBase = std::move( base );
+ }
+
+ /**
+ * @brief Установить указатель на декорируемый класс (цепочка обязанностей)
+ * @details См. https://refactoring.guru/ru/design-patterns/chain-of-responsibility/cpp/example
+ * @details Цепь вызовов: декоратор1 -> декоратор2 -> базовый класс
+ * @param base_or_decorator Указатель на декорируемый класс или целевой декоратор
+ */
+ Type& Apply( PointerType const& base_or_decorator ) noexcept
+ {
+ if( !base_or_decorator )
+ {
+ return *this;
+ }
+
+ SetBase( base_or_decorator );
+ return GetApplyResult();
+ }
+
+ Type& Apply( PointerType&& base_or_decorator ) noexcept
+ {
+ if( !base_or_decorator )
+ {
+ return *this;
+ }
+
+ SetBase( std::move( base_or_decorator ) );
+ return GetApplyResult();
+ }
+
+ private:
+ Type& GetApplyResult() noexcept
+ {
+ auto as_decorator = dynamic_cast< Type * >( mBase.get() );
+ if( as_decorator )
+ {
+ return *as_decorator;
+ }
+
+ return *this;
+ }
+
+ protected:
+ PointerType mBase;
+ };
+
+ template < typename T, typename TDeleter = std::default_delete<T> > using IDecoratorUnique = IDecorator<T, std::unique_ptr<T, TDeleter> >;
+
+} // namespace sbis::devices::generic::types
diff --git a/src/message_builder/types/imessage_build.hpp b/src/message_builder/types/imessage_build.hpp new file mode 100644 index 0000000..4c4f1b8 --- /dev/null +++ b/src/message_builder/types/imessage_build.hpp @@ -0,0 +1,14 @@ +#pragma once + +#include <string> + +namespace smtp::message_builder::types +{ + class IMessageBuilder + { + public: + virtual ~IMessageBuilder() = default; + + virtual std::string Get() const = 0; + }; +} |