{"id":560,"date":"2026-05-06T12:28:50","date_gmt":"2026-05-06T08:58:50","guid":{"rendered":"https:\/\/masoudbahrami.com\/academy\/?p=560"},"modified":"2026-05-27T21:12:45","modified_gmt":"2026-05-27T17:42:45","slug":"evolution-of-software-architecture","status":"publish","type":"post","link":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/","title":{"rendered":"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &#038; Adapters"},"content":{"rendered":"<p><strong><span style=\"color: #f2617a;\">\u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &amp; Adapters<\/span><\/strong><\/p>\n<p>&nbsp;<\/p>\n<h2>\u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0647\u0646\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627<\/h2>\n<p>\u062f\u0631 \u062a\u0648\u0633\u0639\u0647 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u060c \u0645\u0639\u0645\u0627\u0631\u06cc \u0686\u06cc\u0632\u06cc \u0646\u06cc\u0633\u062a \u062c\u0632 \u00a0<strong>\u062a\u0635\u0645\u06cc\u0645\u0627\u062a\u06cc \u06a9\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646\u200c\u0647\u0627 \u0633\u062e\u062a \u0627\u0633\u062a.<\/strong> \u0647\u062f\u0641 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0648 \u06a9\u0646\u062a\u0631\u0644 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 (Dependencies) \u0627\u0633\u062a. \u062f\u0631 \u0637\u0648\u0644 \u062f\u0647\u0647\u200c\u0647\u0627\u06cc \u06af\u0630\u0634\u062a\u0647\u060c \u0645\u0627 \u0627\u0632 \u0633\u0627\u062e\u062a\u0627\u0631\u0647\u0627\u06cc \u0633\u0627\u062f\u0647\u200c\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0628\u0627 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631 \u0648 \u0641\u0636\u0627\u06cc \u0645\u0633\u0626\u0644\u0647\u060c \u06a9\u0645 \u0622\u0648\u0631\u062f\u0646\u062f \u0648 \u0628\u0647 \u0633\u0645\u062a \u0645\u062f\u0644\u200c\u0647\u0627\u06cc\u06cc \u062d\u0631\u06a9\u062a \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0633\u06cc\u0633\u062a\u0645 (Domain) \u0631\u0627 \u0627\u0632 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u06cc (Database, UI, External APIs) \u062c\u062f\u0627 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u0645\u0627 \u0686\u0631\u0627 \u0627\u06cc\u0646 \u0633\u0641\u0631 \u0637\u0648\u0644\u0627\u0646\u06cc \u0631\u0627 \u0637\u06cc \u06a9\u0631\u062f\u06cc\u0645\u061f \u0648 \u0622\u06cc\u0627 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0648\u0627\u0642\u0639\u0627\u064b \u0631\u0627\u0647 \u062d\u0644 \u0647\u0633\u062a\u0646\u062f \u06cc\u0627 \u0641\u0642\u0637 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0631\u0627 \u062f\u0631 \u062c\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0647\u200c\u0627\u0646\u062f\u061f<\/p>\n<p>&nbsp;<\/p>\n<p><strong>\u0628\u06cc\u0634 \u0627\u0632 \u0627\u062f\u0627\u0645\u0647 \u062f\u0631 \u0646\u0638\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong><\/p>\n<p><em>\u0633\u0628\u06a9 \u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc(<\/em><em>Layered-Style Software Architecture<\/em><em>) \u0631\u0627 \u0628\u0627 \u0645\u0639\u0645\u0627\u0631\u06cc 3 \u06cc\u0627 4 \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0627\u0634\u062a\u0628\u0627\u0647 \u0646\u06af\u06cc\u0631\u06cc\u062f. \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0627\u0633\u062a\u0627\u06cc\u0644 \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 \u0646\u0648\u0639\u06cc \u0627\u0632 \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u062f\u0627\u0631\u062f \u06a9\u0647 \u0644\u0627\u06cc\u0647\u200c\u0628\u0646\u062f\u06cc \u0628\u0631 \u0627\u0633\u0627\u0633 \u0645\u0633\u0626\u0648\u0644\u06cc\u062a\u200c\u0647\u0627 \u0646\u0642\u0634 \u06a9\u0644\u06cc\u062f\u06cc \u062f\u0631 \u0622\u0646 \u062f\u0627\u0631\u062f. <\/em><em>\u0627\u0632 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0627\u06cc \u0627\u06cc\u0646 \u0633\u0628\u06a9 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646 \u0628\u0647 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9\u200c\u062a\u0631 \u0645\u062b\u0644 3 \u06cc\u0627 4 \u0644\u0627\u06cc\u0647\u060c \u0648 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646\u200c\u062a\u0631 \u06a9\u0647 \u0645\u0631\u06a9\u0632 \u062b\u0642\u0644 \u0622\u0646\u0647\u0627 \u062f\u0648\u0645\u06cc\u0646 (<\/em><em>domain centric<\/em><em>) \u0647\u0633\u062a\u0646\u062f\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 <\/em><em>hexagonal\/ports &amp; adapters<\/em><em> \u06cc\u0627 <\/em><em>clean architecture<\/em><em> \u06cc\u0627 <\/em><em>onion<\/em><em> \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f. \u062f\u0631 \u0627\u062f\u0627\u0645\u0647 \u0627\u06cc\u0646 \u0646\u0648\u0634\u062a\u0647 \u0645\u0646 \u0641\u0642\u0637 \u0627\u0632 <\/em><em>hexagonal\/ports &amp; adapter<\/em><em> \u0635\u062d\u0628\u062a \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0627\u0645\u0627 \u062f\u0631 \u0646\u0638\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0639\u0645\u0644 \u0647\u0631 \u0633\u0647 \u0645\u0639\u0645\u0627\u0631\u06cc <\/em><em>hexagonal\/ports &amp; adapters<\/em><em> \u0648 <\/em><em>clean architecture<\/em><em> \u0648 <\/em><em>onion<\/em><em> \u0647\u06cc\u0686 \u062a\u0641\u0627\u0648\u062a\u06cc \u0628\u0627 \u0647\u0645 \u0646\u062f\u0627\u0631\u0646\u062f\u060c \u062c\u0632 \u062f\u0631 \u062c\u0632\u0626\u06cc\u0627\u062a\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0646\u0627\u0686\u06cc\u0632 \u0648 \u0642\u0627\u0628\u0644 \u0686\u0634\u0645\u200c\u067e\u0648\u0634\u06cc \u0627\u0633\u062a. \u0634\u06cc\u0637\u0627\u0646 \u062f\u0631 \u062c\u0632\u0626\u06cc\u0627\u062a \u0627\u0633\u062a!<\/em><\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2>\u0639\u0635\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc (Traditional Layered-Style Software Architectures)<\/h2>\n<p>&nbsp;<\/p>\n<p>\u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc \u06a9\u0647 \u062f\u0631 \u062f\u0647\u0647\u200c\u0647\u0627\u06cc \u06f9\u06f0 \u0648 \u06f2\u06f0\u06f0\u06f0 \u0645\u06cc\u0644\u0627\u062f\u06cc \u0634\u06a9\u0648\u0641\u0627 \u0634\u062f\u060c \u0628\u0631 \u067e\u0627\u06cc\u0647 \u0627\u0635\u0644 <strong>\u062a\u0642\u0633\u06cc\u0645 \u0648\u0638\u0627\u06cc\u0641<\/strong><strong> (Separation of Concerns)<\/strong> \u0628\u0646\u0627 \u0634\u062f\u0647 \u0628\u0648\u062f. \u0627\u06cc\u062f\u0647\u200c\u0647\u0627\u06cc \u0644\u0627\u06cc\u0647\u200c\u0628\u0646\u062f\u06cc \u062c\u0647\u062a \u06a9\u0646\u062a\u0631\u0644 \u06a9\u0631\u062f\u0646 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0648 \u062c\u0632\u0626\u06cc\u0627\u062a\u060c \u0628\u0627 \u0627\u06cc\u0646 \u0634\u0631\u0627\u06cc\u0637 \u06a9\u0647 \u0647\u0631 \u0686\u0647 \u0627\u0632 \u0633\u0644\u0633\u0644\u0647 \u0645\u0631\u0627\u062a\u0628 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0628\u0647 \u0633\u0645\u062a \u0628\u0627\u0644\u0627 \u062d\u0631\u06a9\u062a \u06a9\u0646\u06cc\u062f\u060c \u062c\u0632\u0626\u06cc\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u067e\u0648\u0634\u06cc\u062f\u0647 \u0634\u062f\u0647 \u0648\u0645\u0641\u0627\u0647\u06cc\u0645 abstract \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0686\u06cc\u0632 \u062c\u062f\u06cc\u062f\u06cc \u062d\u062f\u0627\u0642\u0644 \u062f\u0631 \u062f\u0646\u06cc\u0627\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u0648 \u0634\u0628\u06a9\u0647 \u0646\u0628\u0648\u062f \u0648 \u0645\u0633\u0628\u0648\u0642 \u0628\u0647 \u0633\u0627\u0628\u0642\u0647 \u0628\u0648\u062f. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646 \u0628\u0647 \u0645\u062f\u0644 \u0645\u0639\u0631\u0648\u0641 \u0634\u0628\u06a9\u0647 7 \u0644\u0627\u06cc\u0647 \u0648 \u0645\u062f\u0644 \u0645\u0648\u062e\u0631\u200c\u062a\u0631 \u0622\u0646 \u06cc\u0639\u0646\u06cc \u0645\u062f\u0644 4\u0644\u0627\u06cc\u0647 \u0634\u0628\u06a9\u0647 \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f.<\/p>\n<p>\u0627\u0635\u0648\u0644 \u06cc\u06a9\u0633\u0627\u0646 \u0648 \u0633\u0627\u062f\u0647 \u0628\u0648\u062f. \u062c\u0647\u062a \u06a9\u0646\u062a\u0631\u0644 \u0648 \u0633\u0648\u0627\u0631 \u0634\u062f\u0646 \u0628\u0631 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc\u060c \u062a\u0642\u0633\u06cc\u0645 \u0648\u0638\u0627\u06cc\u0641\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u0634\u062f. \u0647\u0631 \u0644\u0627\u06cc\u0647 \u0628\u062e\u0634\u06cc \u0627\u0632 \u0648\u0638\u0627\u06cc\u0641 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0627\u062f. \u0627\u0632 \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc \u0644\u0627\u06cc\u0647 \u062f\u0642\u06cc\u0642\u0627 \u067e\u0627\u06cc\u06cc\u0646\u200c\u062a\u0631 \u062e\u0648\u062f(\u0628\u062c\u0632 \u0622\u062e\u0631\u06cc\u0646 \u0644\u0627\u06cc\u0647) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0631\u062f \u0648 \u0628\u0627 \u0622\u0646 \u062a\u0639\u0627\u0645\u0644 \u062f\u0627\u0634\u062a \u0648 \u0628\u0647 \u0644\u0627\u06cc\u0647 \u0628\u0627\u0644\u0627\u062a\u0631 \u062e\u0648\u062f(\u0628\u0647 \u063a\u06cc\u0631 \u0627\u0632 \u0628\u0627\u0644\u0627\u062a\u0631\u06cc\u0646\u0645 \u0644\u0627\u06cc\u0647) \u0633\u0631\u0648\u06cc\u0633 \u0645\u06cc\u200c\u062f\u0627\u062f. \u0633\u0631\u0648\u06cc\u0633\u200c\u062f\u0647\u06cc \u0648 \u062a\u0639\u0627\u0645\u0644\u0627\u062a \u0647\u0631 \u0644\u0627\u06cc\u0647 \u0628\u0627 \u0644\u0627\u06cc\u0647 \u0628\u0627\u0644\u0627 \u0648 \u067e\u0627\u06cc\u06cc\u0646 \u062e\u0648\u062f\u0634 \u0628\u0631 \u0627\u0633\u0627\u0633 \u06cc\u06a9\u0633\u0631\u06cc \u0642\u0631\u0627\u0631\u062f\u0627\u062f(contract) \u0628\u0648\u062f. \u0627\u06cc\u0646 \u0642\u0631\u0627\u0631\u062f\u0647\u0627 \u0627\u0632 \u0633\u0631\u0627\u0632\u06cc\u0631 \u0634\u062f\u0646 \u062c\u0632\u0626\u06cc\u0627\u062a(Leaking Unwanted Details) \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u06cc\u06a9 \u0644\u0627\u06cc\u0647 \u0628\u0647 \u0644\u0627\u06cc\u0647 \u062f\u06cc\u06af\u0631 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0645\u06cc\u200c\u06a9\u0631\u062f. \u0628\u062f\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0628\u0627 \u067e\u0627\u06cc\u0628\u0646\u062f \u0628\u0648\u062f\u0646 \u0628\u0647 \u0642\u0631\u0627\u0631\u062f\u0627\u062f \u0648 \u0628\u062f\u0648\u0646 \u062f\u0631\u06af\u06cc\u0631 \u0634\u062f\u0646 \u0628\u0627 \u062c\u0632\u0626\u06cc\u0627\u062a \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u062f \u06a9\u0627\u0631 \u062e\u0648\u062f \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0646\u062f.<\/p>\n<p>\u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc \u0634\u0627\u0645\u0644 \u06f3 \u06cc\u0627 \u06f4 \u0644\u0627\u06cc\u0647 \u0628\u0648\u062f \u0648 \u0627\u0644\u0628\u062a\u0647 \u0647\u0633\u062a:<\/p>\n<ol>\n<li><span style=\"color: #f2617a;\"><strong>Presentation Layer (UI):<\/strong> <\/span>\u0645\u0633\u0626\u0648\u0644 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0648 \u062f\u0631\u06cc\u0627\u0641\u062a \u0648\u0631\u0648\u062f\u06cc \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631.<\/li>\n<li><span style=\"color: #f2617a;\"><strong>Application\/Service Layer:<\/strong> <\/span>\u0645\u0633\u0626\u0648\u0644 \u0647\u0645\u0627\u0647\u0646\u06af\u06cc \u062c\u0631\u06cc\u0627\u0646 \u06a9\u0627\u0631 (Workflow) \u0648 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062a\u0631\u0627\u06a9\u0646\u0634\u200c\u0647\u0627.<\/li>\n<li><span style=\"color: #f2617a;\"><strong>Domain\/Business Layer:<\/strong><\/span> \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0642\u0648\u0627\u0646\u06cc\u0646 \u0628\u06cc\u0632\u0646\u0633 \u0642\u0631\u0627\u0631 \u062f\u0627\u0634\u062a\u0646\u062f. \u0645\u0639\u0631\u0648\u0641 \u0628\u0648\u062f \u0628\u0647 \u0644\u0627\u06cc\u0647 BAL.<\/li>\n<li><span style=\"color: #f2617a;\"><strong>Data Access\/Persistence\/Infrastructure Layer:<\/strong> <\/span>\u0645\u0633\u0626\u0648\u0644 \u062a\u0639\u0627\u0645\u0644 \u0628\u0627 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647. \u0645\u0639\u0631\u0648\u0641 \u0628\u0648\u062f \u0628\u0647 \u0644\u0627\u06cc\u0647 DAL.<\/li>\n<\/ol>\n<p><em><span style=\"color: #003d4f;\">\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/span> \u0648\u0642\u062a\u06cc \u0627\u0632 \u0644\u0627\u06cc\u0647 \u0686\u0647\u0627\u0631\u0645 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0648 \u062f\u0631 \u0627\u062f\u0627\u0645\u0647 \u0635\u062d\u0628\u062a \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645\u060c \u0645\u0646\u0638\u0648\u0631 \u0641\u0642\u0637 \u0644\u0627\u06cc\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0646\u0628\u0648\u062f. \u062f\u0631 \u062d\u0642\u06cc\u0642\u062a \u062a\u0645\u0627\u0645\u06cc \u06a9\u0627\u0631\u0647\u0627 \u0648\u00a0 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0627 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u060c \u0648 \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc \u0632\u06cc\u0631\u200c\u0633\u0627\u062e\u062a\u06cc \u0647\u0645\u200c\u0633\u0637\u062d \u0647\u0645\u062f\u06cc\u06af\u0631 \u062f\u0631 \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06af\u06cc\u0631\u0646\u062f. \u062f\u0631 \u0627\u062f\u0627\u0645\u0647 \u0647\u0631\u062c\u0627 \u0627\u0632 <\/em><em>data access layer<\/em><em> \u0635\u062d\u0628\u062a \u0634\u062f\u060c \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u06a9\u0647 \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc\u06cc \u0627\u0632 \u062c\u0645\u0644\u0647 <\/em><em>notification<\/em><em> \u0646\u06cc\u0632 \u062f\u0631 \u0647\u0645\u06cc\u0646 \u0633\u0637\u062d \u062f\u0631 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0645\u0639\u0645\u0627\u0631\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9\u200c \u0644\u0627\u06cc\u0647 \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06a9\u06cc\u0631\u0646\u062f.<\/em><\/p>\n<p>&nbsp;<\/p>\n<h4><strong>\u0645\u0632\u0627\u06cc\u0627<\/strong><\/h4>\n<p>\u0645\u0632\u0627\u06cc\u0627\u06cc \u0628\u0633\u06cc\u0627\u0631\u06cc \u0645\u06cc\u200c\u062a\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0633\u0628\u06a9 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627 \u0628\u0631\u0634\u0645\u0631\u062f. \u0627\u0632 \u062c\u0645\u0644\u0647:<\/p>\n<ul>\n<li><strong>\u0633\u0627\u062f\u06af\u06cc \u0648 \u06cc\u0627\u062f\u06af\u06cc\u0631\u06cc \u0633\u0631\u06cc\u0639:<\/strong> \u0628\u0631\u0627\u06cc \u0627\u06a9\u062b\u0631 \u067e\u0631\u0648\u0698\u0647\u200c\u0647\u0627\u060c \u0627\u06cc\u0646 \u0633\u0627\u062e\u062a\u0627\u0631 \u0628\u0633\u06cc\u0627\u0631 \u0634\u0647\u0648\u062f\u06cc \u0627\u0633\u062a.<\/li>\n<li><strong>\u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u0627\u0648\u0644\u06cc\u0647: <\/strong>\u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u0645\u0646\u0637\u0642 \u0646\u0645\u0627\u06cc\u0634 \u0627\u0632 \u0645\u0646\u0637\u0642 \u0630\u062e\u06cc\u0631\u0647\u200c\u0633\u0627\u0632\u06cc\u060c \u0627\u0648\u0644\u06cc\u0646 \u0642\u062f\u0645 \u0628\u0631\u0627\u06cc \u0646\u0638\u0645 \u0628\u062e\u0634\u06cc\u062f\u0646 \u0628\u0647 \u06a9\u062f \u0628\u0648\u062f.<\/li>\n<li><strong>\u0633\u0631\u0639\u062a \u062a\u0648\u0633\u0639\u0647 \u0627\u0648\u0644\u06cc\u0647:<\/strong> \u062f\u0631 \u067e\u0631\u0648\u0698\u0647\u200c\u0647\u0627\u06cc \u06a9\u0648\u0686\u06a9\u060c \u0633\u0631\u0639\u062a \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u0645\u062f\u0644 \u0628\u0633\u06cc\u0627\u0631 \u0628\u0627\u0644\u0627\u0633\u062a.<\/li>\n<li><strong>\u062a\u0633\u062a \u067e\u0630\u06cc\u0631 \u0628\u0648\u062f\u0646 \u0647\u0631 \u0644\u0627\u06cc\u0647 \u0628\u0635\u0648\u0631\u062a \u0645\u0633\u062a\u0642\u0644: <\/strong>\u06cc\u06a9\u06cc \u0627\u0632 \u0627\u06cc\u062f\u0647\u200c\u0647\u0627\u06cc \u0628\u0646\u06cc\u0627\u062f\u06cc\u0646 \u0627\u06cc\u0646 \u0633\u0628\u06a9 \u0627\u0632 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627 \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0628\u0627\u0644\u0627 \u0627\u0634\u0627\u0631\u0647 \u0634\u062f\u060c \u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u0645\u0633\u0626\u0648\u0644\u06cc\u062a\u200c\u0647\u0627 \u0648 \u0627\u0633\u062a\u0642\u0644\u0627\u0644 \u062f\u0627\u062f\u0646\u0628\u0647 \u0647\u0631 \u0644\u0627\u06cc\u0647 \u0628\u0648\u062f. \u062a\u0627 \u0627\u06cc\u0646\u06a9\u0647 \u0647\u0631 \u0644\u0627\u06cc\u0647 \u0628\u062a\u0648\u0627\u0646\u062f \u0648 \u0628\u0635\u0648\u0631\u062a \u0645\u0633\u062a\u0642\u0644 \u0648 \u0628\u062f\u0648\u0646 \u0627\u062c\u0628\u0627\u0631 \u0628\u0647 \u062f\u0627\u0646\u0633\u062a\u0646 \u062c\u0632\u0626\u06cc\u0627\u062a \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0628\u0627\u0644\u0627\u062a\u0631 \u0648 \u067e\u0627\u06cc\u06cc\u0646\u200c\u062a\u0631 \u062e\u0648\u062f \u0639\u0645\u0644 \u06a9\u0646\u062f. \u0647\u0645\u06cc\u0646 \u0627\u06cc\u062f\u0647 \u0628\u0627\u0639\u062b \u0645\u06cc\u200c\u0634\u062f \u06a9\u0647 \u0644\u0627\u06cc\u0647 \u067e\u062a\u0627\u0646\u0633\u06cc\u0644 \u062a\u0633\u062a \u0645\u0633\u062a\u0642\u0644 \u0628\u0631\u0627\u06cc \u062e\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<h2><strong>\u0686\u0627\u0644\u0634\u200c\u0647\u0627 \u0648 \u0646\u0642\u0627\u0637 \u0636\u0639\u0641 \u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc<\/strong><\/h2>\n<p>\u0628\u0632\u0631\u06af\u062a\u0631\u06cc\u0646 \u0645\u0634\u06a9\u0644 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9 \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc\u060c <strong>\u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc<\/strong><strong> (Dependency Direction) <\/strong>\u0628\u0648\u062f. \u062f\u0631 \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9\u060c \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0628\u0647 \u0633\u0645\u062a \u067e\u0627\u06cc\u06cc\u0646 (\u0646\u0647\u0627\u06cc\u062a\u0627 \u0628\u0647 \u0633\u0645\u062a \u0644\u0627\u06cc\u0647 \u062f\u06cc\u062a\u0627) \u062c\u0631\u06cc\u0627\u0646 \u062f\u0627\u0634\u062a\u0646\u062f. \u0627\u062c\u0627\u0632\u0647 \u0628\u062f\u06cc\u062f \u0627\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639 \u0631\u0627 \u06a9\u0645\u06cc \u0628\u06cc\u0634\u062a\u0631 \u0628\u0627\u0632 \u0628\u06a9\u0646\u0645. \u0634\u0627\u0647 \u06a9\u0644\u06cc\u062f \u0641\u0631\u06af\u0634\u062a \u062f\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc \u0633\u0628\u06a9 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc\u060c \u0648 \u062d\u0631\u06a9\u062a \u0627\u0632 \u0645\u062f\u0644\u200c\u0647\u0627\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9\u200c\u062a\u0631 \u0628\u0647 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646\u200c\u062a\u0631 \u0628\u0627 \u0645\u062d\u0648\u0631\u06cc\u062a \u062f\u0648\u0645\u06cc\u0646\u060c \u062f\u0631 \u0647\u0645\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639 \u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0646\u0647\u0641\u062a\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u0645\u0627 \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u0646\u0638\u0648\u0631 \u0627\u0632 \u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0686\u06cc\u0633\u062a\u061f \u062e\u0628 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f\u0645 \u06a9\u0647 \u0627\u0635\u0644 \u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u0648 \u062a\u0642\u0633\u06cc\u0645 \u0645\u0633\u0626\u0648\u0644\u06cc\u062a\u200c\u0647\u0627 \u0628\u06cc\u0646 \u0644\u0627\u06cc\u0647\u200c \u0628\u062f\u06cc\u0646 \u0635\u0648\u0631\u062a \u0628\u0648\u062f \u06a9\u0647 \u0647\u0631 \u0644\u0627\u06cc\u0647 \u06cc\u06a9 \u0645\u0633\u0626\u0648\u0644\u06cc\u062a \u0645\u0634\u062e\u0635\u06cc \u0628\u0631 \u0639\u0647\u062f\u0647 \u062f\u0627\u0634\u062a\u060c \u0648 \u062a\u0645\u0627\u0645\u06cc \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0647\u0645 \u0627\u0632 \u0627\u06cc\u0646 \u0642\u0627\u0646\u0648\u0646 \u067e\u06cc\u0631\u0648\u06cc \u0645\u06cc\u200c\u06a9\u0631\u062f\u0646\u062f \u06a9\u0647 \u0647\u0631 \u0644\u0627\u06cc\u0647 \u062a\u0646\u0647\u0627 \u0648 \u0641\u0642\u0637 \u0627\u0632 \u0644\u0627\u06cc\u0647 \u062f\u0642\u06cc\u0642\u0627 \u0632\u06cc\u0631\u06cc\u0646 \u062e\u0648\u062f \u0631\u0627 \u0633\u0631\u0648\u06cc\u0633 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f\u060c \u0648 \u0647\u0645\u06cc\u0646\u0637\u0648\u0631 \u0628\u0647 \u062a\u0646\u0647\u0627\u06cc\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u06a9\u0647 \u0633\u0631\u0648\u06cc\u0633 \u0645\u06cc\u200c\u062f\u0647\u062f \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u06a9\u0647 \u0628\u0627\u0644\u0627 \u0633\u0631 \u0622\u0646 \u0644\u0627\u06cc\u0647 \u0627\u0633\u062a. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u0644\u0627\u06cc\u0647 \u062f\u0648\u0645\u06cc\u0646 \u0641\u0642\u0637 \u0627\u0632 \u0644\u0627\u06cc\u0647 \u0632\u06cc\u0631 \u062e\u0648\u062f \u06cc\u0639\u0646\u06cc \u062f\u06cc\u062a\u0627\u0627\u06a9\u0633\u0633 \u0633\u0631\u0648\u06cc\u0633 \u0645\u06cc\u200c\u06af\u0631\u0641\u062a\u060c \u0648 \u062a\u0646\u0647\u0627 \u0628\u0647 \u0644\u0627\u06cc\u0647\u200c\u06cc \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0633\u0631\u0648\u06cc\u0633\u060c \u0633\u0631\u0648\u06cc\u0633 \u0645\u06cc\u200c\u062f\u0627\u062f. \u0627\u06cc\u0646 \u0642\u0627\u0646\u0648\u0646 \u0633\u062e\u062a\u200c\u06af\u06cc\u0631\u0627\u0646\u0647 \u06cc\u06a9 \u0627\u0633\u062a\u062b\u0646\u0627 \u062f\u0627\u0634\u062a \u06a9\u0647 \u062f\u0631 \u0627\u062f\u0627\u0645\u0647 \u0647\u0645\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0627\u0634\u0627\u0631\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u062c\u0627\u0632\u0647 \u0628\u062f\u06cc\u062f \u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645. \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u0627\u0632 \u0633\u0645\u062a \u06a9\u0627\u0631\u0628\u0631 \u0628\u0631\u0627\u06cc \u062b\u0628\u062a \u06cc\u06a9 \u0633\u0641\u0627\u0631\u0634 \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u0627\u0633\u062a. \u062f\u0631\u062e\u0648\u0627\u0633\u062a http request \u0627\u0628\u062a\u062f\u0627 \u0648\u0627\u0631\u062f \u0644\u0627\u06cc\u0647 presentation \u0645\u06cc\u200c\u0634\u0648\u062f. \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u067e\u0633 \u0627\u0632 \u062f\u0631\u06cc\u0627\u0641\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0627\u0631\u0628\u0631 \u0648 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u0645\u0646 \u0628\u0648\u062f\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u060c http request \u0631\u0627 \u0628\u0647 \u0645\u062f\u0644 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0628\u0631\u0627\u06cc \u0644\u0627\u06cc\u0647 application service \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u062f\u0647\u060c \u0648 \u0633\u0631\u0648\u06cc\u0633 \u0645\u0648\u0631\u062f \u0646\u0638\u0631 \u062f\u0631 \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u0631\u0627 \u0635\u062f\u0627 \u0645\u06cc\u0632\u0646\u062f. Application service \u0648\u0638\u06cc\u0641\u0647 \u0627\u062c\u0631\u0627\u06cc \u0627\u0644\u06af\u0648\u0631\u06cc\u062a\u0645 \u062b\u0628\u062a \u0633\u0641\u0627\u0631\u0634 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0647\u062f\u060c \u0634\u0628\u06cc\u0647 \u06cc\u06a9 \u0631\u0647\u0628\u0631 \u0627\u0631\u06a9\u0633\u062a\u0631(orchestrator). \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u0645 \u062a\u0645\u0627\u0645 \u0642\u0648\u0627\u0646\u06cc\u0646 \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631 \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0639\u0627\u06cc\u062a \u0634\u062f\u0647\u200c\u0627\u0646\u062f\u060c entity \u0627\u0632 \u0644\u0627\u06cc\u0647 domain \u0635\u062f\u0627 \u0632\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f(\u06cc\u0627 \u062e\u0648\u062f order \u0648 \u06cc\u0627 \u06cc\u06a9 domain service \u06cc\u0627 \u06cc\u06a9 factory \u062f\u0631 \u0644\u0627\u06cc\u0647 \u062f\u0648\u0645\u06cc\u0646). \u062f\u0631 \u0647\u0631 \u0635\u0648\u0631\u062a \u067e\u0633 \u0627\u0632 \u062f\u0631\u06cc\u0627\u0641\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062a\u0648\u0633\u0637 \u0644\u0627\u06cc\u0647 domain \u0648 \u0627\u0639\u0645\u0627\u0644 \u062a\u0645\u0627\u0645 \u0642\u0648\u0627\u0646\u06cc\u0646 \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631\u06cc\u060c \u06cc\u06a9 order \u00a0\u0628\u0627 \u0648\u0636\u0639\u06cc\u062a \u0635\u062d\u06cc\u062d(\u0645\u062b\u0644\u0627 Placed) \u0628\u0647 \u0644\u0627\u06cc\u0647 application service \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f. \u062d\u0627\u0644\u0627 \u0646\u0648\u0628\u062a \u0628\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0633\u0641\u0627\u0631\u0634 \u062f\u0631\u0648\u0646 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0627\u0633\u062a.<\/p>\n<p>\u0628\u0631 \u0627\u0633\u0627\u0633 \u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u0648\u0638\u06cc\u0641\u0647\u200c\u0647\u0627\u060c \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0628\u0631 \u0639\u0647\u062f\u0647 \u067e\u0627\u06cc\u06cc\u0646\u200c\u062a\u0631\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u06cc\u0639\u0646\u06cc data access \u06af\u0630\u0627\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a. \u0645\u06cc\u200c\u062f\u0627\u0646\u06cc\u0645 \u06a9\u0647 \u0642\u0627\u0646\u0648\u0646 \u0633\u062e\u062a\u200c\u06af\u06cc\u0631\u0627\u0646\u0647 \u0627\u0631\u0628\u062a\u0627\u0637 \u0628\u06cc\u0646 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u060c \u0627\u062c\u0627\u0632\u0647 \u0646\u0645\u06cc\u200c\u062f\u0627\u062f \u06a9\u0647 \u06cc\u06a9 \u0644\u0627\u06cc\u0647 \u0645\u0633\u062a\u0642\u06cc\u0645\u0627 \u062f\u0648\u0644\u0627\u06cc\u0647 \u0632\u06cc\u0631\u06cc\u0646 \u062e\u0648\u062f \u0631\u0627 \u0635\u062f\u0627 \u0628\u0632\u0646\u062f. \u0628\u0647\u0645\u06cc\u0646\u00a0 \u062f\u0644\u06cc\u0644 Application service \u0645\u062c\u062f\u062f \u0633\u0631\u0648\u06cc\u0633\u06cc \u0645\u062b\u0644 <em>saveOrderBusinessLogic<\/em> \u0627\u0632 \u0644\u0627\u06cc\u0647 domain service \u0635\u062f\u0627 \u0645\u06cc\u200c\u0632\u062f \u062a\u0627 order \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u062f. <em>saveOrderBusinessLogic<\/em> \u0628\u0627\u06cc\u062f \u0627\u0628\u062a\u062f\u0627 order \u06a9\u0647 \u0628\u0627 \u0645\u062f\u0644 \u0648 \u0632\u0628\u0627\u0646 \u0644\u0627\u06cc\u0647 \u062f\u0648\u0645\u06cc\u0646 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0631\u062f\u0647 \u0627\u0633\u062a\u060c \u0631\u0627 \u0628\u0647 \u06a9\u0644\u0627\u0633 orderDb \u062f\u0631 \u0644\u0627\u06cc\u0647 Data access \u06a9\u0647 \u0646\u06af\u0627\u0634\u062a \u062c\u062f\u0648\u0644 order \u062f\u0631 \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u0627\u0633\u062a \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u062f. \u0633\u067e\u0633 \u0628\u0627\u06cc\u062f \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u0628\u0627 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0631\u0627 \u0645\u0633\u062a\u0642\u06cc\u0645 \u0627\u0632 \u0644\u0627\u06cc\u0647 data access \u0635\u062f\u0627 \u0628\u0632\u0646\u062f.<\/p>\n<p>\u0627\u0645\u0627 \u0686\u0627\u0644\u0634 \u0686\u0647 \u0628\u0648\u062f\u061f \u0644\u0627\u06cc\u0647 domain \u0628\u0627\u06cc\u062f \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u060c \u06a9\u0644\u0627\u0633 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0646\u0646\u062f\u0647 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0647 \u06cc\u06a9 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0648 \u0648\u0646\u062f\u0648\u0631 \u062e\u0627\u0635 (concrete implementation) \u0631\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0631\u062f. \u0634\u0645\u0627 \u0646\u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u06cc\u062f \u06a9\u0647 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0644\u0627\u06cc\u0647 domain \u0631\u0627 \u0628\u0635\u0648\u0631\u062a \u0627\u0646\u062a\u0632\u0627\u0639 \u0627\u0632 \u0622\u0646 \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f. \u0627\u06af\u0631 interface \u0648 \u06cc\u0627 abstract class\u06cc \u0645\u062b\u0644 <em>IOrderDataAccess<\/em> \u06cc\u0627 <em>OrderAccessAbstract<\/em> \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0632\u0627\u0639 \u0627\u0632 \u062c\u0632\u0626\u06cc\u0627\u062a \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u062e\u0627\u0635\u06cc \u0645\u06cc\u200c\u0646\u0648\u0634\u062a\u06cc\u062f\u060c \u0645\u062c\u0628\u0648\u0631 \u0628\u0648\u062f\u06cc\u062f \u06a9\u0647 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0647\u0645\u0627\u0646 \u0644\u0627\u06cc\u0647 data access \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f. \u0686\u0631\u0627 \u06a9\u0647 \u0644\u0627\u06cc\u0647 data access \u0637\u0628\u0642 \u0642\u0627\u0646\u0648\u0646 \u0627\u0631\u062a\u0628\u0627\u0637 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u062d\u0642 \u0627\u06cc\u0646 \u0631\u0627 \u0646\u062f\u0627\u0634\u062a \u06a9\u0647 \u0628\u0647 \u0644\u0627\u06cc\u0647 \u0628\u0627\u0644\u0627\u062a\u0631 \u0627\u0632 \u062e\u0648\u062f \u0631\u0641\u0631\u0646\u0633 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f. \u062d\u062a\u06cc \u0627\u06af\u0631 \u0627\u06cc\u0646\u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0627\u062f\u06cc\u062f \u0634\u0645\u0627 \u062f\u0686\u0627\u0631 \u062a\u0633\u0644\u0633\u0644 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c (circular dependency) \u0645\u06cc\u200c\u0634\u062f\u06cc\u062f. \u0645\u062b\u0644\u0627 \u0627\u06af\u0631 \u0627\u06cc\u0646 <em>IOrderDataAccess<\/em> \u0631\u0627 \u0631 \u0644\u0627\u06cc\u0647 application service \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u062f\u0627\u062f\u06cc\u062f\u060c \u062e\u0637\u0627\u06cc \u062a\u0633\u0644\u0633\u0644 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0628\u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u0631\u062e \u0645\u06cc\u200c\u062f\u0627\u062f:<\/p>\n<p style=\"text-align: left;\"><strong><span style=\"color: #f2617a;\"><em>Application service =&gt; domain\/business logic =&gt; data access =&gt; application service<\/em><\/span><\/strong><\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2><strong>Data Access<\/strong> <strong>\u0648<\/strong> <strong>Infrastructure<\/strong> \u062a\u0628\u062f\u06cc\u0644 \u0628\u0647 \u0646\u0642\u0637\u0647 \u062b\u0642\u0644 \u0645\u0639\u0645\u0627\u0631\u06cc \u0634\u062f\u0647 \u0628\u0648\u062f\u0646\u062f<\/h2>\n<p>\u0627\u06af\u0631 \u0633\u0646\u0627\u0631\u06cc\u0648 \u0645\u0637\u0631\u062d \u0634\u062f\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0631\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0646\u06cc\u062f\u060c \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f\u060c \u06a9\u0647 \u062a\u0645\u0627\u0645 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0628\u0635\u0648\u0631\u062a \u0645\u0633\u062a\u0642\u06cc\u0645 \u0645\u062b\u0644 domain layer \u0648 \u06cc\u0627 \u063a\u06cc\u0631 \u0645\u0633\u062a\u0642\u06cc\u0645 \u0645\u062b\u0644 application service \u0628\u0647 data access layer \u0648\u0627\u0628\u0633\u062a\u0647 \u0647\u0633\u062a\u0646\u062f. \u0647\u0631 \u062a\u063a\u06cc\u06cc\u0631 \u06a9\u0648\u0686\u06a9 \u06cc\u0627 \u0628\u0632\u0631\u06af \u062f\u0631 \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647\u060c \u0645\u062b\u0644\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633\u060c \u06cc\u0627 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u062f\u0631 \u0627\u0633\u06a9\u06cc\u0645\u0627\u06cc \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0648 \u06cc\u0627 \u0628\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0648 \u06cc\u0627 \u062a\u063a\u06cc\u06cc\u0631 ORM \u0628\u0635\u0648\u0631\u062a \u0645\u0633\u062a\u0642\u06cc\u0645 \u0628\u0627\u0639\u062b \u0634\u06a9\u0633\u062a\u06af\u06cc(fragility) \u0633\u0627\u06cc\u0631 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0645\u06cc\u200c\u0634\u0648\u062f. \u0628\u0647 \u0639\u0628\u0627\u0631\u062a \u062f\u06cc\u06af\u0631\u060c \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u062f\u0631 \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u0628\u0647\u200c\u062f\u0644\u06cc\u0644 \u062d\u0633\u0627\u0633\u06cc\u062a \u0628\u0633\u06cc\u0627\u0631 \u0628\u0627\u0644\u0627\u06cc \u0633\u0627\u06cc\u0631 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0646\u0633\u0628\u062a \u0628\u0647 \u062e\u0648\u062f\u060c \u0628\u0647 \u06cc\u06a9 \u0633\u0637\u062d \u0633\u06a9\u0648\u0646 \u0634\u062f\u06cc\u062f\u06cc \u0645\u06cc\u200c\u0631\u0633\u06cc\u062f.<\/p>\n<p>\u0686\u0627\u0644\u0634 \u0628\u0632\u0631\u06af\u062a\u0631 \u0627\u0645\u0627 \u0627\u06cc\u0646 \u0628\u0648\u062f \u06a9\u0647 \u0627\u06cc\u0646 \u0645\u0631\u06a9\u0632 \u062b\u0642\u0644 \u0634\u062f\u0646 data access \u0628\u0647 \u0627\u06cc\u0646 \u0646\u062a\u06cc\u062c\u0647 \u0645\u0646\u062c\u0631 \u0645\u06cc\u200c\u0634\u062f \u06a9\u0647 \u06cc\u06a9\u06cc \u0627\u0632 \u0645\u0647\u0645\u062a\u0631\u06cc\u0646 \u0645\u0632\u06cc\u062a\u200c\u0647\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u06cc\u0639\u0646\u06cc \u0645\u0633\u062a\u0642\u0644 \u0628\u0648\u062f\u0646 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0648 \u0647\u0645\u06cc\u0646\u0637\u0648\u0631 \u062a\u0633\u062a\u200c\u067e\u0630\u06cc\u0631 \u0628\u0648\u062f\u0646 \u0622\u0646\u0647\u0627\u060c \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u0627\u0632 \u062f\u0633\u062a \u0628\u0631\u0648\u062f. \u062f\u0631 \u06cc\u06a9 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc\u200c\u0647\u0627\u06cc \u0647\u0631 \u0641\u06cc\u0686\u0631 \u0631\u0648 \u0628\u0647 \u062f\u0648 \u0628\u062e\u0634 \u0628\u0647\u200c\u0647\u0645 \u0645\u0631\u062a\u0628\u0637 \u0648\u0644\u06cc \u0645\u0633\u062a\u0642\u0644 \u062a\u0642\u0633\u06cc\u0645 \u06a9\u0646\u06cc\u0645. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u062f\u0631 \u0633\u0646\u0627\u0631\u06cc\u0648\u06cc \u062b\u0628\u062a \u0633\u0641\u0627\u0631\u0634 \u06a9\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u0634\u0627\u0631\u0647 \u0634\u062f\u060c \u0628\u062e\u0634\u06cc \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647\u200c\u200c\u0633\u0627\u0632\u06cc \u06a9\u0647 \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u0633\u0641\u0627\u0631\u0634 \u0648 \u062d\u0635\u0648\u0644 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u062a\u0645\u0627\u0645 \u0642\u0648\u0627\u0646\u06cc\u0646 \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631\u06cc \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0639\u0627\u06cc\u062a \u0634\u062f\u0647\u200c\u0627\u0646\u062f. \u0627\u06cc\u0646\u0647\u0627 \u06a9\u0627\u0645\u0644\u0627 \u0628\u0647 \u062f\u0648\u0645\u06cc\u0646 \u0648\u0627\u0628\u0633\u062a\u0647(domain dependent) \u0647\u0633\u062a\u0646\u062f\u060c \u0648 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u062e\u06cc\u0644\u06cc \u06a9\u0645\u06cc \u062f\u0627\u0631\u0646\u062f. \u062f\u0631 \u0645\u0642\u0627\u0628\u0644 \u0628\u062e\u0634\u06cc \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0647 \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a http request \u06a9\u0627\u0631\u0628\u0631 \u0648 \u06cc\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0648 \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0633\u0641\u0627\u0631\u0634 \u062f\u0631 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0627\u0633\u062a\u060c \u063a\u06cc\u0631 \u0648\u0627\u0628\u0633\u062a\u0647 \u0628\u0647 \u062f\u0648\u0645\u06cc\u0646(domain independent) \u0647\u0633\u062a\u0646\u062f(\u0627\u06cc\u0646 \u062c\u0645\u0644\u0647 \u0631\u0627 \u0628\u0627 \u0627\u062d\u062a\u06cc\u0627\u0637 \u0627\u0644\u0628\u062a\u0647 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f!). \u0627\u06cc\u0646 \u0628\u062e\u0634\u200c\u0647\u0627 \u06a9\u0647 \u0648\u0638\u0627\u06cc\u0641\u06cc \u06a9\u0647 \u062a\u0648\u0633\u0637 data access layer \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u0631\u06a9\u0632 \u062b\u0642\u0644 \u0645\u0639\u0645\u0627\u0631\u06cc \u0647\u0645 \u0634\u0627\u0645\u0644 \u0622\u0646\u0647\u0627 \u0645\u06cc\u200c\u0634\u0648\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0631\u0627\u062d\u062a\u06cc \u062f\u0633\u062a\u062e\u0648\u0634 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0634\u0648\u0646\u062f. \u0648 \u0646\u0627\u0686\u0627\u0631\u0627 \u06af\u0627\u0647\u0627 \u0645\u0646\u062c\u0631 \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a\u06cc \u0646\u0627\u062e\u0648\u0627\u062a\u0633\u0647 \u0648 \u0627\u062c\u0628\u0627\u0631\u06cc \u062f\u0631 \u0633\u0627\u06cc\u0631 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0646\u06cc\u0632 \u0645\u06cc\u200c\u0634\u062f.<\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2><strong>Sinkhole Anti-Pattern<\/strong><\/h2>\n<p>\u0627\u06cc\u0646 \u062f\u0631 \u0648\u0627\u0642\u0639 \u06cc\u06a9 \u0627\u062b\u0631 \u062c\u0627\u0646\u0628\u06cc \u0642\u0648\u0627\u0646\u06cc\u0646 \u0633\u062e\u062a\u200c\u06af\u06cc\u0631\u0627\u0646\u0647 \u0627\u0631\u062a\u0628\u0627\u0637 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0628\u0648\u062f. \u06af\u0627\u0647\u0627 \u062f\u06cc\u062f\u0647 \u0645\u06cc\u200c\u0634\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u062e\u06cc \u0627\u0632 \u0633\u0646\u0627\u0631\u06cc\u0648\u0647\u0627\u060c \u0628\u0631\u062e\u06cc \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0641\u0642\u0637 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u0631\u0627 \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u06cc \u0628\u0627\u0644\u0627\u062a\u0631 \u06af\u0631\u0641\u062a\u0647 \u0648 \u0628\u062f\u0648\u0646 \u0627\u06cc\u0646\u06a9\u0647 \u06a9\u0627\u0631\u06cc \u0628\u0631 \u0631\u0648\u06cc \u0622\u0646 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0646\u062f\u060c \u062a\u062d\u0648\u06cc\u0644 \u0644\u0627\u06cc\u0647 \u067e\u0627\u06cc\u06cc\u0646\u200c\u062a\u0631 \u0645\u06cc\u200c\u062f\u0627\u062f\u0646\u062f. \u0645\u062b\u0644\u0627 \u0627\u0641\u0631\u0627\u062f \u0628\u0647 \u0627\u06cc\u0646 \u0646\u062a\u06cc\u062c\u0647 \u0631\u0633\u06cc\u062f\u0647 \u0628\u0648\u062f\u0646\u062f \u06a9\u0647 \u0628\u0647\u062a\u0631 \u0627\u0633\u062a \u0644\u0627\u06cc\u0647 domain \u0645\u0633\u062a\u0642\u06cc\u0645\u0627 \u0628\u0627 data access \u0627\u0631\u062a\u0628\u0627\u0637 \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f \u0648 application service \u0648\u0638\u06cc\u0641\u0647 \u0648\u0627\u06a9\u0634\u06cc(fetch) \u0648 \u0630\u062e\u06cc\u0631\u0647(save) \u0631\u0627 \u0628\u0631 \u0639\u0647\u062f\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f. \u0627\u0645\u0627 \u0627\u06af\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0646\u0648\u06cc\u0633 \u0642\u0635\u062f \u062f\u0627\u0634\u062f \u06a9\u0647 \u0642\u0648\u0627\u0646\u06cc\u0646 \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0631\u0627 \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0628\u06cc\u0627\u0646 \u0634\u062f\u0647 \u0628\u0648\u062f\u0646\u062f(as-is) \u062f\u0646\u0628\u0627\u0644 \u06a9\u0646\u062f\u060c \u0644\u0627\u06cc\u0647 application service \u0627\u062c\u0627\u0632\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 data access \u0631\u0648 \u0646\u062f\u0627\u0634\u062a \u0648 \u0646\u0627\u0686\u0627\u0631\u0627 \u0628\u0627\u06cc\u062f \u0627\u0632 \u0637\u0631\u06cc\u0642 domain layer \u0627\u06cc\u0646\u200c\u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0627\u062f. \u062f\u0631 \u0627\u06cc\u0646\u062d\u0627\u0644\u062a \u0648 \u062f\u0631 \u0627\u06cc\u0646 \u0633\u0646\u0627\u0631\u06cc\u0648 domain layer \u0647\u06cc\u0686 \u06a9\u0627\u0631 \u0627\u0646\u062c\u0627\u0645 \u0646\u0645\u06cc\u200c\u062f\u0627\u062f \u062c\u0632 \u062f\u0631\u06cc\u0627\u0641\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u0632 \u0644\u0627\u06cc\u0647 \u0628\u0627\u0644\u0627\u062a\u0631 \u0648 \u062a\u062d\u0648\u06cc\u0644 \u0648 \u0635\u062f\u0627 \u0632\u062f\u0646 \u0633\u0631\u0648\u06cc\u0633 \u0645\u0648\u0631\u062f \u0646\u0638\u0631 \u0627\u0632 data access. \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0639\u0645\u0644\u06cc \u0628\u06cc\u062e\u0648\u062f \u0648 \u0632\u0645\u0627\u0646\u200c\u0628\u0631 \u0628\u0648\u062f.<\/p>\n<p>\u0628\u0647\u200c\u0647\u0645\u06cc\u0646 \u062e\u0627\u0637\u0631 \u06cc\u06a9 \u0628\u0627\u0632\u0646\u06af\u0631\u06cc \u062f\u0631 \u0642\u0627\u0646\u0648\u0646 \u0627\u0631\u062a\u0628\u0627\u0637 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u0628\u062f\u06cc\u0646 \u0635\u0648\u0631\u062a \u06a9\u0647:<\/p>\n<p>\u0647\u0645\u0686\u0646\u0627\u0646 \u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 \u0628\u06cc\u0646 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0627\u0632 \u0628\u0627\u0644\u0627 \u0628\u0647 \u067e\u0627\u06cc\u06cc\u0646 \u0627\u0633\u062a \u0648 \u0647\u06cc\u0686 \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u062d\u0642 \u0646\u062f\u0627\u0631\u062f \u0628\u0647 \u0644\u0627\u06cc\u0647 \u0628\u0627\u0644\u0627\u062a\u0631 \u0627\u0632 \u062e\u0648\u062f\u0634 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f. \u0627\u0645\u0627 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u0646\u062f \u062f\u0631 \u0635\u0648\u0631\u062a \u0646\u06cc\u0627\u0632 \u062f\u0648\u0644\u0627\u06cc\u0647 \u067e\u0627\u06cc\u06cc\u0646\u200c\u062a\u0631 \u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0646\u06cc\u0632 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0645\u0633\u062a\u0642\u06cc\u0645(direct dependency) \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f. \u062a\u0641\u0633\u06cc\u0631\u0647\u0627\u06cc \u0628\u0639\u062f\u06cc \u0627\u0632 \u0647\u0645\u06cc\u0646 \u0628\u0627\u0632 \u06af\u0630\u0627\u0634\u062a\u0646 \u062f\u0633\u062a \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0645\u0646\u062c\u0631 \u0634\u062f \u0628\u0647 \u0627\u06cc\u0646\u06a9\u0647\u060c \u0627\u0641\u0631\u0627\u062f \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u0646\u062f \u0627\u0632 \u0644\u0627\u06cc\u0647 presentation \u0647\u0645 \u0644\u0627\u06cc\u0647\u200c\u06cc data access \u0631\u0627 \u0635\u062f\u0627 \u0628\u0632\u0646\u062f. \u06cc\u0627 \u0627\u0632 \u0644\u0627\u06cc\u0647 presentation \u0644\u0627\u06cc\u0647 domain \u0631\u0627 \u0635\u062f\u0627 \u0628\u0632\u0646\u0646\u062f \u0648 \u0639\u0645\u0644\u0627 \u0644\u0627\u06cc\u0647 application service \u0631\u0648 \u062d\u0630\u0641 \u06a9\u0646\u0646\u062f! \u0627\u06cc\u0646\u06a9\u0627\u0631 \u0622\u0646\u0642\u062f\u0631\u06cc \u062f\u0631 \u0648\u0647\u0644\u0647 \u0627\u0648\u0644 \u062c\u0630\u0627\u0628 \u0628\u0648\u062f \u06a9\u0647 \u062d\u062a\u06cc \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc domain \u0646\u06cc\u0632 \u062d\u0630\u0641 \u0645\u06cc\u200c\u0634\u062f \u0648 presentation \u0645\u0633\u062a\u0642\u06cc\u0645\u0627 \u062a\u0645\u0627\u0645\u06cc \u0645\u0646\u0637\u0642 \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0648 \u0646\u0647\u0627\u06cc\u062a\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 data access layer \u0628\u0627 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0631\u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0631\u062f.<\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2>\u067e\u0627\u0631\u0627\u062f\u0648\u06a9\u0633 DDD \u0648 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647<\/h2>\n<p>\u06cc\u06a9 \u067e\u0631\u0633\u0634 \u0628\u0633\u06cc\u0627\u0631 \u0647\u0648\u0634\u0645\u0646\u062f\u0627\u0646\u0647 \u0648 \u0646\u0642\u0627\u062f\u0627\u0646\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f: \u0627\u06af\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0645\u0627\u0646\u0646\u062f Hexagonal \u0628\u0631\u0627\u06cc \u062d\u0644 \u0645\u0634\u06a9\u0644\u0627\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0628\u0647 \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc \u0632\u06cc\u0631\u0633\u0627\u062e\u062a\u06cc(Infrastructure Services) \u0627\u0632 \u062c\u0645\u0644\u0647 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0622\u0645\u062f\u0647\u200c\u0627\u0646\u062f\u060c \u067e\u0633 \u0686\u0631\u0627 \u062e\u0648\u062f\u0650 \u0627\u0631\u06cc\u06a9 \u0627\u0648\u0646\u0633 \u062f\u0631 \u06a9\u062a\u0627\u0628 \u0627\u0648\u0644\u06cc\u0647 DDD \u0627\u0632 \u0647\u0645\u0627\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0631\u062f\u061f<\/p>\n<p>\u0648\u0627\u0642\u0639\u06cc\u062a \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0633\u0627\u0644\u200c\u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0638\u0647\u0648\u0631 DDD\u060c \u062a\u0645\u0631\u06a9\u0632 \u0628\u06cc\u0634\u062a\u0631 \u0628\u0631 \u0645\u062f\u0644\u200c\u0633\u0627\u0632\u06cc \u062f\u0627\u0645\u0646\u0647 \u00a0(Modeling) \u0628\u0648\u062f \u062a\u0627 \u0633\u0627\u062e\u062a\u0627\u0631 \u0641\u0646\u06cc. \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc\u200c\u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 \u00a0DDD\u060c \u0627\u0632 \u0647\u0645\u0627\u0646 \u0633\u0627\u062e\u062a\u0627\u0631 `Controller -&gt; Service -&gt; Repository -&gt; Entity` \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0631\u062f\u0646\u062f.<\/p>\n<p>&nbsp;<\/p>\n<p>\u0627\u0645\u0627 \u0633\u0648\u0627\u0644 \u062f\u06cc\u06af\u0631\u06cc \u06a9\u0647 \u0627\u06cc\u0646\u062c\u0627 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u0637\u0631\u062d \u0634\u0648\u062f \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0686\u0631\u0627 \u0627\u06cc\u0646 \u0627\u062a\u0641\u0627\u0642 \u0627\u0641\u062a\u0627\u062f\u061f \u062f\u0644\u06cc\u0644 \u0627\u06cc\u0646 \u0627\u0645\u0631 \u0627\u06cc\u0646 \u0628\u0648\u062f \u06a9\u0647\u060c\u0686\u0648\u0646 \u062f\u0631 \u0622\u0646 \u0632\u0645\u0627\u0646\u060c \u0647\u062f\u0641 \u0627\u0635\u0644\u06cc\u060c \u062f\u0631\u06a9 \u0645\u0641\u0627\u0647\u06cc\u0645 `Aggregate` \u0648 `Value Object` \u0628\u0648\u062f. \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0641\u06a9\u0631 \u0645\u06cc\u200c\u06a9\u0631\u062f\u0646\u062f \u0628\u0627 \u062c\u062f\u0627 \u06a9\u0631\u062f\u0646 \u0644\u0627\u06cc\u0647 Domain\u060c \u0645\u0634\u06a9\u0644 \u062d\u0644 \u0634\u062f\u0647 \u0627\u0633\u062a. \u0627\u0645\u0627 \u0622\u0646\u200c\u0647\u0627 \u0645\u062a\u0648\u062c\u0647 \u0634\u062f\u0646\u062f \u06a9\u0647 \u0627\u06af\u0631 \u0644\u0627\u06cc\u0647 Domain \u0647\u0645\u0686\u0646\u0627\u0646 \u0628\u0647 `Repository` (\u06a9\u0647 \u0645\u0627\u0647\u06cc\u062a \u0622\u0646 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0628\u0647 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0627\u0633\u062a) \u0648\u0627\u0628\u0633\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0627\u0633\u062a\u0642\u0644\u0627\u0644 \u062f\u0627\u0645\u0646\u0647 (Domain Autonomy) \u06cc\u06a9 \u062a\u0648\u0647\u0645 \u0627\u0633\u062a. \u062f\u0631 \u0648\u0627\u0642\u0639\u060c DDD \u00a0\u062f\u0631 \u0622\u0646\u200c \u0631\u0648\u0632\u0647\u0627 \u06cc\u0639\u0646\u06cc \u0627\u0648\u0627\u06cc\u0644 2003 \u0628\u06cc\u0634\u062a\u0631 <strong>\u0645\u062d\u062a\u0648\u0627<\/strong> \u0631\u0627 \u0627\u0635\u0644\u0627\u062d \u06a9\u0631\u062f\u060c \u0627\u0645\u0627 \u0633\u0627\u062e\u062a\u0627\u0631 \u0648 \u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u0646\u062f\u0627\u062f. \u0627\u06cc\u0646 \u0647\u0645\u0627\u0646 \u0646\u0642\u0637\u0647\u200c\u0627\u06cc \u0628\u0648\u062f \u06a9\u0647 \u0628\u0627\u0639\u062b \u0634\u062f \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646\u200c\u062a\u0631 \u0627\u062d\u0633\u0627\u0633 \u0634\u0648\u062f.<\/p>\n<p>\u0627\u0644\u0628\u062a\u0647 \u062e\u06cc\u0644\u06cc \u0647\u0645 \u0646\u0628\u0627\u06cc\u062f \u0633\u062e\u062a \u06af\u0631\u0641\u062a. \u06cc\u06a9\u06cc \u0627\u0632 \u062f\u0644\u0627\u06cc\u0644 \u0645\u0647\u0645 \u062f\u06cc\u06af\u0631 \u0627\u06cc\u0646 \u0628\u0648\u062f \u06a9\u0647 \u0628\u0631 \u0631\u0648\u06cc \u0632\u0645\u0627\u06cc\u0646 \u062f\u0631 \u0622\u0646 \u0632\u0645\u0627\u0646\u060c \u0645\u0639\u0645\u0627\u0631\u06cc \u063a\u0627\u0644\u0628 \u0648 \u062c\u0627\u0627\u0641\u062a\u0627\u062f\u0647 \u0648 \u0627\u0644\u0628\u062a\u0647 \u0645\u062d\u0628\u0648\u0628 \u0647\u0645\u0627\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9 \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0628\u0648\u062f. \u0627\u06a9\u062b\u0631 \u0645\u0646\u0627\u0628\u0639 \u0648 \u06a9\u062a\u0627\u0628\u200c\u0647\u0627 \u0647\u0645 \u062c\u0647\u062a \u0627\u0631\u0627\u0626\u0647 \u0645\u062b\u0627\u0644\u200c\u0647\u0627 \u0627\u0632 \u0647\u0645\u0627\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0631\u062f\u0646\u062f. \u0637\u0628\u06cc\u0639\u06cc \u0628\u0648\u062f \u06a9\u0647 \u06a9\u062a\u0627\u0628 DDD \u0647\u0645 \u0627\u0632 \u0627\u06cc\u0646 \u0642\u0627\u0639\u062f\u0647 \u0645\u0633\u062a\u062b\u0646\u0627 \u0646\u0628\u0627\u0634\u062f.<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2>\u0627\u0646\u0642\u0644\u0627\u0628 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 (Ports &amp; Adapters \/ Hexagonal)<\/h2>\n<p>\u0622\u0644\u06cc\u0633\u062a\u0631 \u06a9\u0648\u06a9\u0628\u0631\u0646 (Alistair Cockburn) &#8211;<em>\u0627\u0632 \u0646\u0648\u06cc\u0633\u0646\u062f\u06af\u0627\u0646 \u0628\u06cc\u0627\u0646\u06cc\u0647 \u0686\u0627\u0628\u06a9\u06cc<\/em>\u060c \u0628\u0627 \u0645\u0639\u0631\u0641\u06cc Hexagonal Architecture \u06a9\u0647 \u0628\u0639\u062f\u0647\u0627 \u0628\u0646\u0627 \u0628\u0647 \u062f\u0644\u06cc\u0644 \u0627\u06cc\u0646\u06a9\u0647 \u0634\u06a9\u0644 \u0634\u0634 \u06af\u0648\u0634\u0647 \u0628\u06cc\u0634 \u0627\u0632 \u0645\u0648\u0631\u062f \u062a\u0648\u062c\u0647 \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a \u0628\u0647 \u0645\u0639\u0645\u0627\u0631\u06cc Ports &amp; Adapters \u00a0\u0646\u06cc\u0632 \u0645\u0639\u0631\u0648\u0641 \u0627\u0633\u062a\u060c \u0633\u0639\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u062f\u0627\u0634\u062a \u06a9\u0647 \u0645\u0631\u06a9\u0632 \u062b\u0642\u0644 \u0645\u0639\u0645\u0627\u0631\u06cc \u0631\u0627 \u0627\u0632 \u0634\u0631 data access \u0648 \u0628\u0635\u0648\u0631\u062a \u06a9\u0644\u06cc \u0647\u0631 \u0645\u0633\u0626\u0648\u0644\u06cc\u062a\u06cc \u06a9\u0647 \u0628\u0647 \u0646\u0648\u0639\u06cc \u062f\u0631 \u062a\u0642\u0633\u06cc\u0645 \u0628\u0646\u062f\u06cc \u0628\u0627\u0644\u0627 domain dependent \u0646\u0628\u0648\u062f\u0647 \u0648 \u062c\u0631\u0626\u06cc\u0627\u062a \u0645\u062d\u0633\u0648\u0628 \u0645\u06cc\u200c\u0634\u062f\u060c \u0622\u0632\u0627\u062f \u06a9\u0646\u062f. \u0627\u0648 \u067e\u06cc\u0634\u0646\u0647\u0627\u062f \u062f\u0627\u062f \u06a9\u0647 \u0645\u0627 \u0646\u0628\u0627\u06cc\u062f \u062e\u06cc\u0644\u06cc \u0628\u0647 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0648 \u0642\u0648\u0627\u0646\u06cc\u0646 \u0633\u062e\u062a\u200c\u06af\u06cc\u0631\u0627\u0646\u0647 \u0622\u0646 \u0641\u06a9\u0631 \u06a9\u0646\u06cc\u0645\u060c \u0628\u0644\u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0645\u0631\u0632\u0647\u0627 (Boundaries) \u0641\u06a9\u0631 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0622\u0644\u06cc\u0633\u062a\u0631 \u0628\u0631 \u0647\u0645\u06cc\u0646 \u0645\u0628\u0646\u0627\u060c \u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u0645\u0633\u0626\u0648\u0644\u06cc\u062a(separation of concern) \u0631\u0627 \u062e\u06cc\u0644\u06cc \u0633\u0627\u062f\u0647 \u0648\u0644\u06cc \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f. \u0627\u0648 \u067e\u06cc\u0634\u0646\u0647\u0627\u062f \u062f\u0627\u062f \u06a9\u0647 \u0635\u0631\u0641\u0646\u0638\u0631 \u0627\u0632 \u062a\u0639\u062f\u0627\u062f \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0628\u0647 \u0627\u0632\u0627\u06cc \u0647\u0631 \u0633\u0646\u0627\u0631\u06cc\u0648\/\u0641\u06cc\u0686\u0631 \u06a9\u0647 \u0628\u0647 use case \u0647\u0645 \u0645\u0639\u0631\u0648\u0641 \u0627\u0633\u062a\u060c \u0628\u062e\u0634\u06cc \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0622\u0646 \u06a9\u0647 \u0648\u0627\u0628\u0633\u062a\u0647 \u0628\u0647 \u062f\u0648\u0645\u06cc\u0646(domain dependent) \u0627\u0633\u062a \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062f\u0646\u06cc\u0627\u06cc \u062f\u0627\u062e\u0644\u06cc(Inside World) \u0648 \u0645\u0627\u0628\u0642\u06cc\u060c \u0647\u0645\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062f\u0646\u06cc\u0627\u06cc \u062e\u0627\u0631\u062c(Outside World) \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a. \u062c\u0647\u062a \u0627\u0631\u062a\u0628\u0627\u0637 \u0627\u06cc\u0646 \u062f\u0648 \u062f\u0646\u06cc\u0627\u060c \u0642\u0631\u0627\u062f\u0627\u062f() \u062f\u0631 \u0642\u0627\u0644\u0628 interface \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc\u200c\u0634\u062f\u060c \u06a9\u0647 \u062e\u0648\u062f interface \u062f\u0631 \u062f\u0646\u06cc\u0627\u06cc \u062f\u0627\u062e\u0644\u06cc \u0648 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0622\u0646 \u062f\u0631 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u0634\u062f. \u0628\u062f\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646 \u0639\u0645\u0644\u0627 \u0628\u0647 \u062f\u0646\u06cc\u0627\u06cc \u062f\u0627\u062e\u0644 \u0648\u0627\u0628\u0633\u062a\u0647 \u0645\u06cc\u200c\u0634\u062f. \u0628\u0631\u0627\u06cc \u0645\u0634\u062e\u0635 \u0634\u062f\u0646 \u0645\u0631\u0632\u0628\u0646\u062f\u06cc \u0628\u06cc\u0646 \u0627\u06cc\u0646 \u062f\u0646\u06cc\u0627\u060c \u0622\u0644\u06cc\u0633\u062a\u0631 \u0627\u0632 \u0634\u06a9\u0644 \u0648 \u0645\u062a\u0627\u0641\u0648\u0631 \u0634\u0634\u200c\u06af\u0648\u0634\u0647(Hexagon) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f. \u0627\u0636\u0644\u0627\u0639 \u0627\u06cc\u0646 \u0634\u06a9\u0644 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0647\u0645\u0627\u0646 \u0642\u0631\u0627\u0631\u062f\u0627\u062f\u0647\u0627 \u06cc\u0627 \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645\u200c\u0647\u0627\u06cc \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u062f\u0646\u06cc\u0627\u06cc \u062f\u0627\u062e\u0644 \u0648 \u0628\u06cc\u0631\u0648\u0646 \u0628\u0648\u062f\u0646\u062f. \u0628\u062f\u0644\u06cc\u0644 \u0627\u06cc\u0646\u06a9\u0647 \u0634\u0634 \u0636\u0644\u0639\u060c \u0627\u06cc\u0646 \u062a\u0644\u0642\u06cc(\u0628\u06cc\u0634\u062a\u0631 \u0645\u0633\u062e\u0631\u0647) \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0628\u0648\u062f \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0647\u0645\u06cc\u0634\u0647 6 \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645 \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645\u060c \u06cc\u0627 \u062d\u062f\u0627\u06a9\u062b\u0631 \u062a\u0639\u062f\u0627\u062f interface\u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u0631\u062a\u0628\u0627\u0637 \u062f\u0646\u06cc\u0627\u06cc \u062f\u0627\u062e\u0644 \u0648 \u0628\u06cc\u0631\u0648\u0646 \u0628\u0627\u06cc\u062f 6\u062a\u0627 \u0628\u0627\u0634\u062f\u060c \u0628\u0639\u062f\u0647\u0627 \u0622\u0644\u06cc\u0633\u062a\u0631 \u0627\u0633\u0645 \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc \u0631\u0627 \u0628\u0647 Ports &amp; Adapters \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f. \u0627\u062a\u0641\u0627\u0642\u0627 \u0645\u062a\u0627\u0641\u0648\u0631 \u0628\u0647\u062a\u0631\u06cc \u0646\u06cc\u0632 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0631\u062f\u0647 \u0628\u0648\u062f.<\/p>\n<p>\u0627\u0645\u0627 \u062f\u0631 \u0645\u0648\u0631\u062f \u062c\u0632\u0626\u06cc\u0627\u062a \u062f\u0646\u0628\u0627\u06cc \u062f\u0627\u062e\u0644\u060c \u0647\u06cc\u0686 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0634\u062a. \u0645\u062a\u062f\u0627\u0648\u0644 \u0627\u06cc\u0646 \u0628\u0648\u062f \u06a9\u0647 \u0634\u0627\u0645\u0644 \u062f\u0648 \u0644\u0627\u06cc\u0647 Application Service \u0648 Domain \u0628\u0627\u0634\u062f.<\/p>\n<p>\u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646 \u0647\u0645 \u0647\u0631 \u0622\u0646 \u0686\u06cc\u0632\u06cc \u06a9\u0647 \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0627\u0631\u062a\u0628\u0627\u0637 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646 \u0628\u0627 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646\u060c \u06cc\u0627 \u0633\u0627\u06cc\u0631 \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627 \u06cc\u0627 \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645\u0647\u0627 \u0630\u062e\u06cc\u0631\u0647\u200c\u0633\u0627\u0632\u06cc \u0648 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0628\u0648\u062f \u0631\u0627 \u0634\u0627\u0645\u0644 \u0645\u06cc\u200c\u0634\u062f. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u06a9\u0646\u062a\u0631\u0644\u0631\u0647\u0627\u06cc REST\u060c \u06cc\u0627 Data Access\u0647\u0627 \u06cc\u0627 Notification Service \u0648 Message Broker \u0647\u0627 \u0648 &#8230;<\/p>\n<p>\u062c\u0647\u062a \u0627\u0631\u062a\u0628\u0627\u0637 \u0647\u0645 \u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 \u0628\u06cc\u0631\u0648\u0646\u060c \u06cc\u0627 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u060c \u0628\u0647 \u062f\u0627\u062e\u0644\u060c \u06cc\u0627 \u062f\u0646\u06cc\u0627\u06cc \u062f\u0627\u062e\u0644 \u0628\u0648\u062f. \u0628\u062f\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0645\u0631\u06a9\u0632 \u062b\u0642\u0644 \u0628\u0631\u0646\u0627\u0645\u0647\u060c \u0628\u0647 \u0644\u0627\u06cc\u0647 domain \u062a\u0641\u0648\u06cc\u0636 \u0634\u062f\u0647 \u0628\u0648\u062f. \u0627\u06cc\u0646 \u0644\u0627\u06cc\u0647 \u0647\u0645 \u0627\u0632 \u062c\u0632\u0626\u06cc\u0627\u062a \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc\u200c\u0647\u0627\u06cc \u0633\u0631\u0648\u06cc\u0633\u200c\u0647\u0627\u06cc \u0632\u06cc\u0631\u0633\u0627\u062e\u062a\u06cc \u0622\u0632\u0627\u062f \u0645\u06cc\u200c\u0634\u062f. \u0646\u062a\u06cc\u062c\u0647 \u0627\u06cc\u0646\u06a9\u0647 \u0634\u0645\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u06cc\u062f \u0628\u0631\u0627\u062d\u062a\u06cc \u06a9\u0644 \u0645\u0646\u0637\u0642 \u0628\u0631\u0646\u0627\u0645\u0647 \u062a\u0633\u062a \u06a9\u0627\u0645\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2><strong>\u0645\u0641\u0647\u0648\u0645 \u0627\u0635\u0644\u06cc: \u0647\u0633\u062a\u0647 \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062c\u0632\u0626\u06cc\u0627\u062a \u0648 \u0645\u062d\u06cc\u0637 \u067e\u06cc\u0631\u0627\u0645\u0648\u0646\u06cc<\/strong><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0628\u062e\u0634 \u0628\u0635\u0648\u0631\u062a \u062e\u06cc\u0644\u06cc \u06a9\u0644\u06cc \u0648 \u062e\u0644\u0627\u0635\u0647\u060c \u0628\u0647 \u0645\u0639\u0631\u0641\u06cc \u0645\u0641\u0627\u0647\u06cc\u0645 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc Ports &amp; Adapters \u062e\u0648\u0627\u0647\u0645 \u067e\u0631\u062f\u0627\u062e\u062a.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0647\u0633\u062a\u0647 \u0633\u06cc\u0633\u062a\u0645 (Domain) \u06a9\u0627\u0645\u0644\u0627\u064b \u0628\u06cc\u200c\u0637\u0631\u0641 \u0648 \u0628\u06cc\u200c\u0646\u06cc\u0627\u0632 \u0627\u0632 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646 \u0627\u0633\u062a. \u0647\u0633\u062a\u0647 \u0646\u0645\u06cc\u200c\u062f\u0627\u0646\u062f \u0622\u06cc\u0627 \u0648\u0631\u0648\u062f\u06cc \u0627\u0632 \u0637\u0631\u06cc\u0642 HTTP \u00a0\u0627\u0633\u062a \u06cc\u0627 CLI\u060c \u0648 \u0646\u0645\u06cc\u200c\u062f\u0627\u0646\u062f \u0622\u06cc\u0627 \u062e\u0631\u0648\u062c\u06cc \u062f\u0631 SQL \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f \u06cc\u0627 \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0645\u062a\u0646\u06cc.<\/p>\n<p>&nbsp;<\/p>\n<ul>\n<li><strong>The Core (Domain)<\/strong>: \u0634\u0627\u0645\u0644 \u062a\u0645\u0627\u0645 \u0645\u0646\u0637\u0642 \u0628\u06cc\u0632\u0646\u0633\u060c \u0642\u0648\u0627\u0646\u06cc\u0646 \u0648 \u0645\u062f\u0644\u200c\u0647\u0627. \u0627\u06cc\u0646 \u0628\u062e\u0634 \u0647\u06cc\u0686 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0628\u0647 \u0647\u06cc\u0686 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062e\u0627\u0631\u062c\u06cc (\u062d\u062a\u06cc ORM\u0647\u0627) \u062f\u0627\u0631\u062f.<\/li>\n<li><strong>Ports (Interfaces)<\/strong><strong>:<\/strong> \u067e\u0648\u0631\u062a\u200c\u0647\u0627 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0642\u0631\u0627\u0631\u062f\u0627\u062f\u0647\u0627 (Interfaces) \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u062f\u0631 \u0647\u0633\u062a\u0647 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f.<\/li>\n<li><strong>Driving Ports (Inbound)<\/strong><strong>:<\/strong> \u0627\u06cc\u0646\u062a\u0631\u0641\u06cc\u0633\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0622\u0646\u200c\u0647\u0627 \u0628\u0627 \u0647\u0633\u062a\u0647 \u0635\u062d\u0628\u062a \u0645\u06cc\u200c\u06a9\u0646\u062f \u060c \u0645\u062b\u0644 `OrderService`.<\/li>\n<li><strong>Driven Ports (Outbound)<\/strong><strong>:<\/strong> \u0627\u06cc\u0646\u062a\u0631\u0641\u06cc\u0633\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0647\u0633\u062a\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u06a9\u0627\u0631\u0647\u0627\u06cc \u062c\u0627\u0646\u0628\u06cc \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0645\u062b\u0644 `OrderRepository`.<\/li>\n<li><strong>Adapters (Implementation)<\/strong><strong>:<\/strong> \u0622\u062f\u0627\u067e\u062a\u0648\u0631\u0647\u0627 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc\u200c\u0647\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u062f\u0631 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646 \u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u0646\u062f.<\/li>\n<li><strong>Driving Adapters<\/strong><strong>:<\/strong> \u0645\u062b\u0644 \u06cc\u06a9 `REST Controller` \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0631\u0627 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f\u060c \u0628\u0647 \u067e\u0648\u0631\u062a \u062a\u0628\u062f\u06cc\u0644 \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u0628\u0647 \u0647\u0633\u062a\u0647 \u0645\u06cc\u200c\u0641\u0631\u0633\u062a\u062f.<\/li>\n<li><strong>Driven Adapters<\/strong><strong>:<\/strong> \u0645\u062b\u0644 \u06cc\u06a9 `SqlOrderRepository` \u06a9\u0647 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u067e\u0648\u0631\u062a\u0650 \u0630\u062e\u06cc\u0631\u0647\u200c\u0633\u0627\u0632\u06cc \u0627\u0633\u062a \u0648 \u0628\u0627 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u062d\u0631\u0641 \u0645\u06cc\u200c\u0632\u0646\u062f.<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<h3><strong>\u0686\u0631\u0627 \u0627\u06cc\u0646 \u0645\u062f\u0644 \u0645\u0634\u06a9\u0644\u0627\u062a \u0633\u0646\u062a\u06cc \u0631\u0627 \u062d\u0644 \u0645\u06cc\u200c\u06a9\u0646\u062f\u061f<\/strong><\/h3>\n<p><strong>Inversion of Control (IoC)<\/strong><strong>:<\/strong> \u00a0\u062f\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc \u06a9\u0644\u0627\u0633\u06cc\u06a9 \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc\u060c \u0647\u0633\u062a\u0647 \u0628\u0647 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0648\u0627\u0628\u0633\u062a\u0647 \u0628\u0648\u062f. \u062f\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc \u00a0Hexagonal\u060c \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0628\u0647 \u0647\u0633\u062a\u0647 \u0648\u0627\u0628\u0633\u062a\u0647 \u0627\u0633\u062a. \u0647\u0633\u062a\u0647 \u06cc\u06a9 \u0627\u06cc\u0646\u062a\u0631\u0641\u06cc\u0633 (Port) \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0628\u0627\u06cc\u062f \u0622\u0646 \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u062f \u0628\u0627 \u0633\u06cc\u0633\u062a\u0645 \u06a9\u0627\u0631 \u06a9\u0646\u062f.<\/p>\n<p><strong>\u062a\u0633\u062a\u200c\u067e\u0630\u06cc\u0631\u06cc 100\u062f\u0631\u0635\u062f<\/strong><strong> (Testability)<\/strong>: \u062d\u0627\u0644\u0627 \u0634\u0645\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0633\u062a\u0647 \u0631\u0627 \u0628\u062f\u0648\u0646 \u0647\u06cc\u0686 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u060c \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <strong>\u0622\u062f\u0627\u067e\u062a\u0648\u0631\u0647\u0627\u06cc \u062f\u0631\u0648\u0646\u06cc<\/strong> (In-memory Adapters) \u00a0\u062a\u0633\u062a \u06a9\u0646\u06cc\u062f. \u062a\u0633\u062a\u200c\u0647\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0631\u06cc\u0639\u060c \u0633\u0628\u06a9 \u0648 \u0648\u0627\u0642\u0639\u06cc \u0647\u0633\u062a\u0646\u062f.<\/p>\n<p><strong>\u0642\u0627\u0628\u0644\u06cc\u062a \u062a\u0639\u0648\u06cc\u0636<\/strong><strong> (Replaceability)<\/strong>: \u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0633\u06cc\u0633\u062a\u0645 \u0631\u0627 \u0627\u0632 REST \u0628\u0647 GraphQL \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f\u060c \u0634\u0645\u0627 \u0641\u0642\u0637 \u06cc\u06a9 \u0622\u062f\u0627\u067e\u062a\u0648\u0631 \u0631\u0627 \u0639\u0648\u0636 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f\u061b \u0647\u0633\u062a\u0647 \u062d\u062a\u06cc \u0645\u062a\u0648\u062c\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0647\u0645 \u0646\u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2>\u0645\u0642\u0627\u06cc\u0633\u0647 \u062a\u062d\u0644\u06cc\u0644\u06cc \u0648 \u0646\u0642\u062f \u0645\u0646\u0635\u0641\u0627\u0646\u0647<\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0627 \u0646\u06af\u0627\u0647\u06cc \u0628\u06cc\u200c\u0637\u0631\u0641\u0627\u0646\u0647\u060c \u0627\u06cc\u0646 \u062f\u0648 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0631\u0627 \u0645\u0642\u0627\u06cc\u0633\u0647 \u06a9\u0646\u06cc\u0645:<\/p>\n<table>\n<tbody>\n<tr>\n<td width=\"156\">\u0648\u06cc\u0698\u06af\u06cc<\/td>\n<td width=\"156\">\u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc<\/td>\n<td width=\"156\">\u0645\u0639\u0645\u0627\u0631\u06cc Ports &amp; Adapters<\/td>\n<\/tr>\n<tr>\n<td width=\"156\">\u0645\u0631\u06a9\u0632 \u062b\u0642\u0644<\/td>\n<td width=\"156\">\u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 (Data-Centric)<\/td>\n<td width=\"156\">\u062f\u0648\u0645\u06cc\u0646 \u00a0(Domain-Centric)<\/td>\n<\/tr>\n<tr>\n<td width=\"156\">\u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc<\/td>\n<td width=\"156\">\u0627\u0632 \u0628\u0627\u0644\u0627 \u0628\u0647 \u067e\u0627\u06cc\u06cc\u0646 (Top-Down)<\/td>\n<td width=\"156\">\u0628\u0647 \u0633\u0645\u062a \u0645\u0631\u06a9\u0632 (Inward)<\/td>\n<\/tr>\n<tr>\n<td width=\"156\">\u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u06a9\u062f<\/td>\n<td width=\"156\">\u067e\u0627\u06cc\u06cc\u0646 (\u06a9\u062f \u06a9\u0645\u062a\u0631\u060c Boilerplate \u06a9\u0645\u062a\u0631<\/td>\n<td width=\"156\">\u0628\u0627\u0644\u0627\u062a\u0631 (\u0646\u06cc\u0627\u0632 \u0628\u0647 \u067e\u0648\u0631\u062a\u200c\u0647\u0627\u060c \u0622\u062f\u0627\u067e\u062a\u0648\u0631\u0647\u0627 \u0648 \u0646\u06af\u0627\u0634\u062a\u200c\u0647\u0627)<\/td>\n<\/tr>\n<tr>\n<td width=\"156\">\u062a\u0633\u062a\u200c\u067e\u0630\u06cc\u0631\u06cc<\/td>\n<td width=\"156\">\u062f\u0634\u0648\u0627\u0631 (\u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0628\u0647 \u0632\u06cc\u0631\u0633\u0627\u062e\u062a)<\/td>\n<td width=\"156\">\u0628\u0633\u06cc\u0627\u0631 \u0622\u0633\u0627\u0646 (\u0627\u0633\u062a\u0642\u0644\u0627\u0644 \u06a9\u0627\u0645\u0644)<\/td>\n<\/tr>\n<tr>\n<td width=\"156\">\u0645\u0646\u0627\u0633\u0628 \u0628\u0631\u0627\u06cc&#8230;<\/td>\n<td width=\"156\">\u067e\u0631\u0648\u0698\u0647\u200c\u0647\u0627\u06cc CRUD \u0648 \u0633\u0627\u062f\u0647<\/td>\n<td width=\"156\">\u0633\u06cc\u0633\u062a\u0645\u200c\u0647\u0627\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0648 \u0628\u06cc\u0632\u0646\u0633\u200c\u0645\u062d\u0648\u0631<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h1><\/h1>\n<hr \/>\n<h2>\u0646\u0642\u062f\u06cc \u0628\u0631\u06cc \u0645\u0639\u0645\u0627\u0631\u06cc Ports and Adapters: \u0622\u06cc\u0627 \u0647\u0645\u06cc\u0634\u0647 \u0628\u0647\u062a\u0631 \u0627\u0633\u062a\u061f<\/h2>\n<p>\u0647\u06cc\u0686 \u0645\u0641\u0647\u0648\u0645 \u0648 \u0645\u0648\u0636\u0648\u0639\u06cc \u062f\u0631 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u0628\u062f\u0648\u0646 \u0633\u0628\u06a9 \u0633\u0646\u06af\u06cc\u0646 \u06a9\u0631\u062f\u0646(Trade-Off) \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f. \u0645\u0639\u0645\u0627\u0631\u06cc Ports &amp; Adapter\u0647\u0645 \u0627\u0632 \u0627\u06cc\u0646 \u0642\u0627\u0639\u062f\u0647 \u0645\u0633\u062a\u062b\u0646\u0627 \u0646\u06cc\u0633\u062a \u0648 \u062f\u0631 \u0647\u0645\u0647 \u0633\u0646\u0627\u0631\u06cc\u0648\u200c\u0647\u0627 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0627\u0646\u062a\u062e\u0627\u0628 \u0628\u0631\u0627\u06cc \u0645\u0639\u0645\u0627\u0631\u06cc \u0633\u06cc\u0633\u062a\u0645 \u0646\u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f. \u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0645\u06cc \u0627\u0632 \u062c\u0646\u0628\u0647 \u0646\u0642\u0627\u062f\u0627\u0646\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u06af\u0627\u0647 \u06a9\u0631\u062f\u060c \u0645\u06cc\u200e\u062a\u0648\u0627\u0646 \u0628\u0647 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u0627\u0634\u0627\u0631\u0647 \u06a9\u0631\u062f.<\/p>\n<p><strong>\u062a\u0639\u062f\u062f \u06a9\u0644\u0627\u0633\u200c\u0647\u0627<\/strong><strong> (Boilerplate)<\/strong>: \u0634\u0645\u0627 \u0628\u0631\u0627\u06cc \u0647\u0631 \u0645\u0648\u062c\u0648\u062f\u06cc\u062a\u060c \u0646\u06cc\u0627\u0632 \u0628\u0647 \u06cc\u06a9 \u0645\u062f\u0644 \u062f\u0627\u0645\u0646\u0647\u060c \u06cc\u06a9 \u0645\u062f\u0644 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633\u060c \u06cc\u06a9 \u0645\u062f\u0644 API \u0648 \u0686\u0646\u062f\u06cc\u0646 \u0646\u06af\u0627\u0634\u062a\u06af\u0631 (Mapper) \u0628\u06cc\u0646 \u0622\u0646\u200c\u0647\u0627 \u062f\u0627\u0631\u06cc\u062f. \u0627\u06cc\u0646 \u06cc\u0639\u0646\u06cc \u0646\u0648\u0634\u062a\u0646 \u06a9\u062f \u0628\u0633\u06cc\u0627\u0631 \u0628\u06cc\u0634\u062a\u0631.<\/p>\n<p><strong>\u0645\u0646\u062d\u0646\u06cc \u06cc\u0627\u062f\u06af\u06cc\u0631\u06cc:<\/strong> \u062a\u06cc\u0645\u200c\u0647\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0628\u0627\u06cc\u062f \u062f\u0631\u06a9 \u0639\u0645\u06cc\u0642\u06cc \u0627\u0632 \u0645\u0641\u0647\u0648\u0645 Inversion of Control \u0648 \u062a\u0641\u06a9\u06cc\u06a9 \u0645\u062f\u0644\u200c\u0647\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f.<\/p>\n<p><strong>\u00a0<\/strong><strong>\u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u062f\u0631 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u062f: <\/strong>\u067e\u06cc\u062f\u0627 \u06a9\u0631\u062f\u0646 \u0645\u0633\u06cc\u0631 \u0627\u062c\u0631\u0627\u06cc \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062f\u0631 \u0645\u06cc\u0627\u0646 \u067e\u0648\u0631\u062a\u200c\u0647\u0627 \u0648 \u0622\u062f\u0627\u067e\u062a\u0648\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 \u062a\u0627\u0632\u0647\u200c\u06a9\u0627\u0631 \u0628\u0633\u06cc\u0627\u0631 \u062f\u0634\u0648\u0627\u0631 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u0645\u0627 \u0628\u0627\u06cc\u062f \u062a\u0627\u06a9\u06cc\u062f \u06a9\u0631\u062f \u06a9\u0647 \u0645\u0627 \u0627\u0632 \u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc \u0628\u0647 \u0633\u0645\u062a \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u062d\u0631\u06a9\u062a \u06a9\u0631\u062f\u06cc\u0645\u060c \u0646\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u06a9\u0647 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627 \u0628\u062f \u0628\u0648\u062f\u0646\u062f\u060c \u0628\u0644\u06a9\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u06a9\u0647 \u062c\u0647\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u062f\u0631 \u0622\u0646\u200c\u0647\u0627 \u0627\u0634\u062a\u0628\u0627\u0647 \u0628\u0648\u062f.<\/p>\n<p>&nbsp;<\/p>\n<hr \/>\n<h2>\u0686\u0647 \u0632\u0645\u0627\u0646\u06cc \u0627\u0632 \u06a9\u062f\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645\u061f<\/h2>\n<p>&nbsp;<\/p>\n<p><strong>\u0627\u0632 \u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c\u0627\u06cc \u0633\u0646\u062a\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0627\u06af\u0631:<\/strong><\/p>\n<p>\u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627 \u0639\u0645\u062f\u062a\u0627\u064b \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u0633\u062a (CRUD)\u060c \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0628\u06cc\u0632\u0646\u0633 \u0646\u0627\u0686\u06cc\u0632 \u0627\u0633\u062a \u0648 \u0633\u0631\u0639\u062a \u062a\u0648\u0633\u0639\u0647 \u0627\u0648\u0644\u0648\u06cc\u062a \u0627\u0648\u0644 \u0627\u0633\u062a. \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u0633\u0639\u06cc \u0646\u06a9\u0646\u06cc\u062f \u0686\u0631\u062e \u0631\u0627 \u062f\u0648\u0628\u0627\u0631\u0647 \u0627\u062e\u062a\u0631\u0627\u0639 \u06a9\u0646\u06cc\u062f\u061b \u0627\u0632 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u062f\u0648\u0631\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<p><strong>\u0627\u0632 \u0645\u0639\u0645\u0627\u0631\u06cc<\/strong><strong> Ports &amp; Adapters <\/strong><strong>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0627\u06af\u0631:<\/strong><\/p>\n<p>\u0634\u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0645\u062d\u0635\u0648\u0644 \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u0642\u0648\u0627\u0646\u06cc\u0646 \u0628\u06cc\u0632\u0646\u0633 \u0622\u0646 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0627\u0633\u062a\u060c \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u0633\u0627\u0644\u200c\u0647\u0627 \u0639\u0645\u0631 \u06a9\u0646\u062f\u060c \u0648 \u0627\u062d\u062a\u0645\u0627\u0644 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0631 \u0632\u06cc\u0631\u0633\u0627\u062e\u062a\u200c\u0647\u0627 (\u062f\u06cc\u062a\u0627\u0628\u06cc\u0633\u060c \u067e\u0631\u0648\u062a\u06a9\u0644\u200c\u0647\u0627\u06cc \u0627\u0631\u062a\u0628\u0627\u0637\u06cc) \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f. \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u0647\u0632\u06cc\u0646\u0647 \u0627\u0636\u0627\u0641\u06cc \u06a9\u062f\u0646\u0648\u06cc\u0633\u06cc (Boilerplate)\u060c \u062f\u0631 \u0639\u0648\u0636 \u0628\u0627 \u0627\u0645\u0646\u06cc\u062a\u060c \u062a\u0633\u062a\u200c\u067e\u0630\u06cc\u0631\u06cc \u0648 \u067e\u0627\u06cc\u062f\u06af\u06cc \u062f\u0631 \u0628\u0644\u0646\u062f\u0645\u062f\u062a \u062c\u0628\u0631\u0627\u0646 \u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<p>&nbsp;<\/p>\n<blockquote>\n<p style=\"text-align: center;\"><span style=\"color: #f2617a;\">\u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u06cc\u06a9 \u0646\u0633\u062e\u0647 \u0648\u0627\u062d\u062f \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 (One-size-fits-all) \u0646\u06cc\u0633\u062a. \u0645\u0639\u0645\u0627\u0631\u06cc \u0639\u0627\u0644\u06cc\u060c \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0627\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0647\u0632\u06cc\u0646\u0647 (Cost) \u0631\u0627 \u0628\u0627 \u0645\u0646\u0641\u0639\u062a (Benefit) \u062f\u0631 \u0633\u0637\u062d \u062f\u0631\u0633\u062a \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u062f. \u0647\u062f\u0641 \u0645\u0627 \u062d\u0630\u0641 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0628\u0647 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0646\u06cc\u0633\u062a\u060c \u0647\u062f\u0641 \u0645\u0627 \u0645\u062d\u0627\u0641\u0638\u062a \u0627\u0632 <strong>\u0627\u0631\u0632\u0634 \u0627\u0635\u0644\u06cc \u0633\u0627\u0632\u0645\u0627\u0646<\/strong> \u06cc\u0639\u0646\u06cc <strong>Domain Knowledge<\/strong> \u0627\u0633\u062a. \u0627\u06af\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc \u0634\u0645\u0627 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u06a9\u0647 \u0628\u06cc\u0632\u0646\u0633 \u0628\u062f\u0648\u0646 \u062f\u0631\u06af\u06cc\u0631 \u0634\u062f\u0646 \u0628\u0627 \u062c\u0632\u0626\u06cc\u0627\u062a \u062a\u06a9\u0646\u0648\u0644\u0648\u0698\u06cc \u0631\u0634\u062f \u06a9\u0646\u062f\u060c \u0634\u0645\u0627 \u0628\u0647 \u0645\u0639\u0645\u0627\u0631\u06cc \u0631\u0633\u06cc\u062f\u0647 \u0627\u06cc\u062f.<\/span><\/p>\n<\/blockquote>\n","protected":false},"excerpt":{"rendered":"<p>\u062f\u0631 \u062a\u0648\u0633\u0639\u0647 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u060c \u0645\u0639\u0645\u0627\u0631\u06cc \u0686\u06cc\u0632\u06cc \u0646\u06cc\u0633\u062a \u062c\u0632 \u00a0\u062a\u0635\u0645\u06cc\u0645\u0627\u062a\u06cc \u06a9\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646\u200c\u0647\u0627 \u0633\u062e\u062a \u0627\u0633\u062a. \u0647\u062f\u0641 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0648 \u06a9\u0646\u062a\u0631\u0644 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 (Dependencies) \u0627\u0633\u062a. \u062f\u0631 \u0637\u0648\u0644 \u062f\u0647\u0647\u200c\u0647\u0627\u06cc \u06af\u0630\u0634\u062a\u0647\u060c \u0645\u0627 \u0627\u0632 \u0633\u0627\u062e\u062a\u0627\u0631\u0647\u0627\u06cc \u0633\u0627\u062f\u0647\u200c\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0628\u0627 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631 \u0648 \u0641\u0636\u0627\u06cc \u0645\u0633\u0626\u0644\u0647\u060c \u06a9\u0645 \u0622\u0648\u0631\u062f\u0646\u062f \u0648 \u0628\u0647 \u0633\u0645\u062a \u0645\u062f\u0644\u200c\u0647\u0627\u06cc\u06cc \u062d\u0631\u06a9\u062a \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0633\u06cc\u0633\u062a\u0645 (Domain) \u0631\u0627 \u0627\u0632 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u06cc (Database, UI, External APIs) \u062c\u062f\u0627 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u0645\u0627 \u0686\u0631\u0627 \u0627\u06cc\u0646 \u0633\u0641\u0631 \u0637\u0648\u0644\u0627\u0646\u06cc \u0631\u0627 \u0637\u06cc \u06a9\u0631\u062f\u06cc\u0645\u061f \u0648 \u0622\u06cc\u0627 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0648\u0627\u0642\u0639\u0627\u064b \u0631\u0627\u0647 \u062d\u0644 \u0647\u0633\u062a\u0646\u062f \u06cc\u0627 \u0641\u0642\u0637 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0631\u0627 \u062f\u0631 \u062c\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0647\u200c\u0627\u0646\u062f\u061f<\/p>\n","protected":false},"author":1,"featured_media":551,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"episode_type":"","audio_file":"","podmotor_file_id":"","podmotor_episode_id":"","cover_image":"","cover_image_id":"","duration":"","filesize":"","filesize_raw":"","date_recorded":"","explicit":"","block":"","itunes_episode_number":"","itunes_title":"","itunes_season_number":"","itunes_episode_type":"","footnotes":""},"categories":[92,118,119],"tags":[125,127,126,121,123,122,124,128,120],"class_list":["post-560","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-ddd","category-software-architecture","category-software-design","tag-cleanarchitecture","tag-layered-architecture","tag-onion-architecture","tag-software-architecture","tag--hexagonal","tag--ports-and-adapters","tag-124","tag-128","tag-120"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.7 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &amp; Adapters - \u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/\" \/>\n<meta property=\"og:locale\" content=\"fa_IR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &amp; Adapters - \u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\" \/>\n<meta property=\"og:description\" content=\"\u062f\u0631 \u062a\u0648\u0633\u0639\u0647 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u060c \u0645\u0639\u0645\u0627\u0631\u06cc \u0686\u06cc\u0632\u06cc \u0646\u06cc\u0633\u062a \u062c\u0632 \u00a0\u062a\u0635\u0645\u06cc\u0645\u0627\u062a\u06cc \u06a9\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646\u200c\u0647\u0627 \u0633\u062e\u062a \u0627\u0633\u062a. \u0647\u062f\u0641 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0648 \u06a9\u0646\u062a\u0631\u0644 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 (Dependencies) \u0627\u0633\u062a. \u062f\u0631 \u0637\u0648\u0644 \u062f\u0647\u0647\u200c\u0647\u0627\u06cc \u06af\u0630\u0634\u062a\u0647\u060c \u0645\u0627 \u0627\u0632 \u0633\u0627\u062e\u062a\u0627\u0631\u0647\u0627\u06cc \u0633\u0627\u062f\u0647\u200c\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0628\u0627 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631 \u0648 \u0641\u0636\u0627\u06cc \u0645\u0633\u0626\u0644\u0647\u060c \u06a9\u0645 \u0622\u0648\u0631\u062f\u0646\u062f \u0648 \u0628\u0647 \u0633\u0645\u062a \u0645\u062f\u0644\u200c\u0647\u0627\u06cc\u06cc \u062d\u0631\u06a9\u062a \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0633\u06cc\u0633\u062a\u0645 (Domain) \u0631\u0627 \u0627\u0632 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u06cc (Database, UI, External APIs) \u062c\u062f\u0627 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u0645\u0627 \u0686\u0631\u0627 \u0627\u06cc\u0646 \u0633\u0641\u0631 \u0637\u0648\u0644\u0627\u0646\u06cc \u0631\u0627 \u0637\u06cc \u06a9\u0631\u062f\u06cc\u0645\u061f \u0648 \u0622\u06cc\u0627 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0648\u0627\u0642\u0639\u0627\u064b \u0631\u0627\u0647 \u062d\u0644 \u0647\u0633\u062a\u0646\u062f \u06cc\u0627 \u0641\u0642\u0637 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0631\u0627 \u062f\u0631 \u062c\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0647\u200c\u0627\u0646\u062f\u061f\" \/>\n<meta property=\"og:url\" content=\"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\" \/>\n<meta property=\"article:published_time\" content=\"2026-05-06T08:58:50+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2026-05-27T17:42:45+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/p1.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"972\" \/>\n\t<meta property=\"og:image:height\" content=\"648\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\" \/>\n\t<meta name=\"twitter:data2\" content=\"17 \u062f\u0642\u06cc\u0642\u0647\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/\"},\"author\":{\"name\":\"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#\\\/schema\\\/person\\\/ee37cd3f5f4faef34a49fffc8d31e635\"},\"headline\":\"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &#038; Adapters\",\"datePublished\":\"2026-05-06T08:58:50+00:00\",\"dateModified\":\"2026-05-27T17:42:45+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/\"},\"wordCount\":361,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/p1.jpg\",\"keywords\":[\"CleanArchitecture\",\"Layered Architecture\",\"Onion Architecture\",\"Software Architecture\",\"\u0645\u0639\u0645\u0627\u0631\u06cc Hexagonal\",\"\u0645\u0639\u0645\u0627\u0631\u06cc Ports and Adapters\",\"\u0645\u0639\u0645\u0627\u0631\u06cc \u06a9\u0644\u06cc\u0646\",\"\u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c \u0627\u06cc\",\"\u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631\"],\"articleSection\":[\"DDD\",\"Software Architecture\",\"Software Design\"],\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/\",\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/\",\"name\":\"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports & Adapters - \u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/p1.jpg\",\"datePublished\":\"2026-05-06T08:58:50+00:00\",\"dateModified\":\"2026-05-27T17:42:45+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#breadcrumb\"},\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#primaryimage\",\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/p1.jpg\",\"contentUrl\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/p1.jpg\",\"width\":972,\"height\":648},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/evolution-of-software-architecture\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &#038; Adapters\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#website\",\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/\",\"name\":\"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\",\"description\":\"\",\"publisher\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"fa-IR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#organization\",\"name\":\"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\",\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/logo.svg\",\"contentUrl\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/logo.svg\",\"width\":236,\"height\":64,\"caption\":\"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\"},\"image\":{\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/#\\\/schema\\\/person\\\/ee37cd3f5f4faef34a49fffc8d31e635\",\"name\":\"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/img-100x100.webp\",\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/img-100x100.webp\",\"contentUrl\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/wp-content\\\/uploads\\\/2025\\\/12\\\/img-100x100.webp\",\"caption\":\"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc\"},\"description\":\"I\u2019m Masoud Barhami. a software architect, developer, and writer with over a decade of experience designing meaningful, maintainable software systems. My career began in hands-on coding, but quickly grew into a deeper exploration of architecture, modeling, and the language of software itself. My central focus has always been clarity: how to understand real-world domains, how to design with intent, and how to build systems that reflect purpose, not just requirements. I\u2019ve found that truly great software isn\u2019t just well-written, it\u2019s well-discovered: shaped around the right problems, approached with the right mindset, and realized through careful design. This philosophy has guided much of my work, and continues to evolve through experimentation, reflection, and practice. Today, I work as a software architect and independent consultant, collaborating with teams to navigate complex domains and align systems with real-world goals. I also train and mentor developers and architects who want to level up in their thinking and design fluency.\",\"sameAs\":[\"https:\\\/\\\/masoudbahrami.com\\\/academy\"],\"url\":\"https:\\\/\\\/masoudbahrami.com\\\/academy\\\/author\\\/alfapress\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports & Adapters - \u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/","og_locale":"fa_IR","og_type":"article","og_title":"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports & Adapters - \u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","og_description":"\u062f\u0631 \u062a\u0648\u0633\u0639\u0647 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u060c \u0645\u0639\u0645\u0627\u0631\u06cc \u0686\u06cc\u0632\u06cc \u0646\u06cc\u0633\u062a \u062c\u0632 \u00a0\u062a\u0635\u0645\u06cc\u0645\u0627\u062a\u06cc \u06a9\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646\u200c\u0647\u0627 \u0633\u062e\u062a \u0627\u0633\u062a. \u0647\u062f\u0641 \u0627\u0635\u0644\u06cc \u0647\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0648 \u06a9\u0646\u062a\u0631\u0644 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 (Dependencies) \u0627\u0633\u062a. \u062f\u0631 \u0637\u0648\u0644 \u062f\u0647\u0647\u200c\u0647\u0627\u06cc \u06af\u0630\u0634\u062a\u0647\u060c \u0645\u0627 \u0627\u0632 \u0633\u0627\u062e\u062a\u0627\u0631\u0647\u0627\u06cc \u0633\u0627\u062f\u0647\u200c\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0628\u0627 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u06a9\u0633\u0628\u200c\u0648\u200c\u06a9\u0627\u0631 \u0648 \u0641\u0636\u0627\u06cc \u0645\u0633\u0626\u0644\u0647\u060c \u06a9\u0645 \u0622\u0648\u0631\u062f\u0646\u062f \u0648 \u0628\u0647 \u0633\u0645\u062a \u0645\u062f\u0644\u200c\u0647\u0627\u06cc\u06cc \u062d\u0631\u06a9\u062a \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0647\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0633\u06cc\u0633\u062a\u0645 (Domain) \u0631\u0627 \u0627\u0632 \u062f\u0646\u06cc\u0627\u06cc \u0628\u06cc\u0631\u0648\u0646\u06cc (Database, UI, External APIs) \u062c\u062f\u0627 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u0645\u0627 \u0686\u0631\u0627 \u0627\u06cc\u0646 \u0633\u0641\u0631 \u0637\u0648\u0644\u0627\u0646\u06cc \u0631\u0627 \u0637\u06cc \u06a9\u0631\u062f\u06cc\u0645\u061f \u0648 \u0622\u06cc\u0627 \u0645\u0639\u0645\u0627\u0631\u06cc\u200c\u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0648\u0627\u0642\u0639\u0627\u064b \u0631\u0627\u0647 \u062d\u0644 \u0647\u0633\u062a\u0646\u062f \u06cc\u0627 \u0641\u0642\u0637 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0631\u0627 \u062f\u0631 \u062c\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0647\u200c\u0627\u0646\u062f\u061f","og_url":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/","og_site_name":"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","article_published_time":"2026-05-06T08:58:50+00:00","article_modified_time":"2026-05-27T17:42:45+00:00","og_image":[{"width":972,"height":648,"url":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/p1.jpg","type":"image\/jpeg"}],"author":"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","twitter_card":"summary_large_image","twitter_misc":{"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a":"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646":"17 \u062f\u0642\u06cc\u0642\u0647"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#article","isPartOf":{"@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/"},"author":{"name":"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","@id":"https:\/\/masoudbahrami.com\/academy\/#\/schema\/person\/ee37cd3f5f4faef34a49fffc8d31e635"},"headline":"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &#038; Adapters","datePublished":"2026-05-06T08:58:50+00:00","dateModified":"2026-05-27T17:42:45+00:00","mainEntityOfPage":{"@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/"},"wordCount":361,"commentCount":0,"publisher":{"@id":"https:\/\/masoudbahrami.com\/academy\/#organization"},"image":{"@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#primaryimage"},"thumbnailUrl":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/p1.jpg","keywords":["CleanArchitecture","Layered Architecture","Onion Architecture","Software Architecture","\u0645\u0639\u0645\u0627\u0631\u06cc Hexagonal","\u0645\u0639\u0645\u0627\u0631\u06cc Ports and Adapters","\u0645\u0639\u0645\u0627\u0631\u06cc \u06a9\u0644\u06cc\u0646","\u0645\u0639\u0645\u0627\u0631\u06cc \u0644\u0627\u06cc\u0647\u200c \u0627\u06cc","\u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631"],"articleSection":["DDD","Software Architecture","Software Design"],"inLanguage":"fa-IR","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/","url":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/","name":"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports & Adapters - \u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","isPartOf":{"@id":"https:\/\/masoudbahrami.com\/academy\/#website"},"primaryImageOfPage":{"@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#primaryimage"},"image":{"@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#primaryimage"},"thumbnailUrl":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/p1.jpg","datePublished":"2026-05-06T08:58:50+00:00","dateModified":"2026-05-27T17:42:45+00:00","breadcrumb":{"@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#breadcrumb"},"inLanguage":"fa-IR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/"]}]},{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#primaryimage","url":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/p1.jpg","contentUrl":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/p1.jpg","width":972,"height":648},{"@type":"BreadcrumbList","@id":"https:\/\/masoudbahrami.com\/academy\/evolution-of-software-architecture\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/masoudbahrami.com\/academy\/"},{"@type":"ListItem","position":2,"name":"\u0641\u0631\u06af\u0634\u062a \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u061b \u0627\u0632 \u0644\u0627\u06cc\u0647\u200c\u0647\u0627\u06cc \u0633\u0646\u062a\u06cc \u062a\u0627 \u0627\u0646\u0642\u0644\u0627\u0628 \u00a0Ports &#038; Adapters"}]},{"@type":"WebSite","@id":"https:\/\/masoudbahrami.com\/academy\/#website","url":"https:\/\/masoudbahrami.com\/academy\/","name":"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","description":"","publisher":{"@id":"https:\/\/masoudbahrami.com\/academy\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/masoudbahrami.com\/academy\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"fa-IR"},{"@type":"Organization","@id":"https:\/\/masoudbahrami.com\/academy\/#organization","name":"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","url":"https:\/\/masoudbahrami.com\/academy\/","logo":{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/masoudbahrami.com\/academy\/#\/schema\/logo\/image\/","url":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/logo.svg","contentUrl":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/logo.svg","width":236,"height":64,"caption":"\u0622\u06a9\u0627\u062f\u0645\u06cc \u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc"},"image":{"@id":"https:\/\/masoudbahrami.com\/academy\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/masoudbahrami.com\/academy\/#\/schema\/person\/ee37cd3f5f4faef34a49fffc8d31e635","name":"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc","image":{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/img-100x100.webp","url":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/img-100x100.webp","contentUrl":"https:\/\/masoudbahrami.com\/academy\/wp-content\/uploads\/2025\/12\/img-100x100.webp","caption":"\u0645\u0633\u0639\u0648\u062f \u0628\u0647\u0631\u0627\u0645\u06cc"},"description":"I\u2019m Masoud Barhami. a software architect, developer, and writer with over a decade of experience designing meaningful, maintainable software systems. My career began in hands-on coding, but quickly grew into a deeper exploration of architecture, modeling, and the language of software itself. My central focus has always been clarity: how to understand real-world domains, how to design with intent, and how to build systems that reflect purpose, not just requirements. I\u2019ve found that truly great software isn\u2019t just well-written, it\u2019s well-discovered: shaped around the right problems, approached with the right mindset, and realized through careful design. This philosophy has guided much of my work, and continues to evolve through experimentation, reflection, and practice. Today, I work as a software architect and independent consultant, collaborating with teams to navigate complex domains and align systems with real-world goals. I also train and mentor developers and architects who want to level up in their thinking and design fluency.","sameAs":["https:\/\/masoudbahrami.com\/academy"],"url":"https:\/\/masoudbahrami.com\/academy\/author\/alfapress\/"}]}},"_links":{"self":[{"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/posts\/560","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/comments?post=560"}],"version-history":[{"count":3,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/posts\/560\/revisions"}],"predecessor-version":[{"id":841,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/posts\/560\/revisions\/841"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/media\/551"}],"wp:attachment":[{"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/media?parent=560"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/categories?post=560"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/masoudbahrami.com\/academy\/wp-json\/wp\/v2\/tags?post=560"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}