diff --git a/.c4builder b/.c4builder
index 7660d04..20da7bb 100644
--- a/.c4builder
+++ b/.c4builder
@@ -29,13 +29,6 @@
"hasRun": true,
"checksums": [
"eff025a09817785485a7c3cd9c62fb1dbd79c5682e01e362ca2cc0ea1942d5b4",
- "a2eedf6c5abeeca7f8b53f0cd9cb65eaac03604ec92ef3ac629236029f969237",
- "3837a4607372c49d01edf97f7b326201ed285e5f892c9c92e464f50088d9923a",
- "8250c7ad340f312f4f0cd143d02fec9f91d485ac2fa2f723632d3eb054ff7f05",
- "f57402710ac6c2b5ef571bdf22e1032dbb638d9b389c8bb9603bfa248eb1f41c",
- "ea4010458811a2daf2d4deb96f5345434f4ea7e7a98abb9a244e2f1c31ff8a18",
- "59fe5d9d4b0a242920e837fcae655661e7a27e8adc70b9d077a804c147786bc5",
- "0fc8404e9339eec0b40b3f6feca250c908c9340069527790c6f4bb4ceb549900",
- "4cb917a45c22e48cce813cf8dbf5ee42a19da8c490233c03d79ded4ed6d210ef"
+ "8b44a66306857c99d88d1445be9d9636c1d5003b7a0cf39caf480e04ccb53d2b"
]
}
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/1 Internet Banking System.pdf b/docs/1 Internet Banking System/1 Internet Banking System.pdf
deleted file mode 100644
index bf31a3b..0000000
Binary files a/docs/1 Internet Banking System/1 Internet Banking System.pdf and /dev/null differ
diff --git a/docs/1 Internet Banking System/API Application/API Application.pdf b/docs/1 Internet Banking System/API Application/API Application.pdf
deleted file mode 100644
index 28ab30a..0000000
Binary files a/docs/1 Internet Banking System/API Application/API Application.pdf and /dev/null differ
diff --git a/docs/1 Internet Banking System/API Application/HOME.md b/docs/1 Internet Banking System/API Application/HOME.md
deleted file mode 100644
index f93ea90..0000000
--- a/docs/1 Internet Banking System/API Application/HOME.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# API Application
-
-
-![container](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1073px" preserveAspectRatio="none" style="width:500px;height:1073px;background:#FFFFFF;" version="1.1" viewBox="0 0 500 1073" width="500px" zoomAndPan="magnify"><defs/><g><!--MD5=[7442f3b126ee602ae02566c1a49e158a]
cluster api--><g id="cluster_api"><rect height="421" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="487" x="7" y="228"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="192.5" y="246.6094">API Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="219" y="262.582">[Container]</text></g><!--MD5=[30860e21ba0e39165c540f9e23fe2d63]
entity sign--><g id="elem_sign"><rect fill="#85BBF0" height="108.0469" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="207" x="24.5" y="301"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="133" x="61.5" y="327.6094">Sign In Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="113" x="71.5" y="343.582">[MVC Rest Controlle]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="360.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="38.5" y="378.3613">Allows users to sign in to the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="150" x="53" y="395.9707">internet banking system</text></g><!--MD5=[4d2c1095686cc4272d4556037dedae14]
entity accounts--><g id="elem_accounts"><rect fill="#85BBF0" height="145.7813" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="192" x="277" y="282"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="150" x="296" y="308.6094">Accounts Summary</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="76" x="335" y="328.7344">Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="113" x="316.5" y="344.707">[MVC Rest Controlle]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="361.877"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="164" x="291" y="379.4863">Provides customers with a</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="301" y="397.0957">summory of their bank</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="57" x="344.5" y="414.7051">accounts</text></g><!--MD5=[6f1da96282e479ff2a49312c7753703d]
entity security--><g id="elem_security"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="23" y="506"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="49.5" y="532.6094">Security Component</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="91" y="548.582">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="565.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="37" y="583.3613">Provides functionality related</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="142" x="55" y="600.9707">to singing in, changing</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="79" y="618.5801">passwords, etc.</text></g><!--MD5=[8f94240328f985b36a3be06efd5d45ef]
entity mbsfacade--><g id="elem_mbsfacade"><rect fill="#85BBF0" height="128.1719" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="268" y="505"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="297.5" y="531.6094">Mainframe Banking</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="314.5" y="551.7344">System Facade</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="336" y="567.707">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="584.877"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="282" y="602.4863">A facade onto the mainframe</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="102" x="322" y="620.0957">banking system.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="29.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="39.5" y="33.6094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="112" x="74" y="49.582">[javascript and react]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="128" y="66.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="55.5" y="84.3613">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="55.5" y="101.9707">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="119.5801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="103" y="137.1895">browser.</text></g><!--MD5=[99c5416311fbf9d118be657efd773f39]
entity ma--><g id="elem_ma"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="268" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="328.5" y="33.6094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="344.5" y="49.582">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="369" y="66.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="284.5" y="84.3613">Provides a limited subset ot</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="306" y="101.9707">the internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="278" y="119.5801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="287.5" y="137.1895">their mobile mobile device.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="190" x="33" y="727"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="92" y="753.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="44" y="769.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="786.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="804.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="63.5" y="821.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="43" y="839.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="75.5" y="857.1895">access logs, etc.</text></g><!--MD5=[caf83f36d3620b5db28366bd7d249751]
entity mbs--><g id="elem_mbs"><rect fill="#999999" height="130.6875" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="213" x="266.5" y="733"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="297.5" y="759.6094">Mainframe Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="57" x="344.5" y="779.7344">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="797.7832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="185" x="280.5" y="815.3926">Stores all of the core banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="279.5" y="833.002">information about customers,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="286.5" y="850.6113">accounts, transactions, etc.</text></g><!--MD5=[95dadc5fd8c5c901d6969e2e98c70c21]
link sign to security--><g id="link_sign_security"><path d="M128,409.22 C128,436.02 128,468.85 128,497.7 " fill="none" id="sign-to-security" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,505.72,131,497.72,125,497.72,128,505.72" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="129" y="471.457">Uses</text></g><!--MD5=[42d8fcfb42dec18b2b51d602409b2c47]
link accounts to mbsfacade--><g id="link_accounts_mbsfacade"><path d="M373,428.07 C373,450.31 373,474.77 373,496.94 " fill="none" id="accounts-to-mbsfacade" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="373,504.99,376,496.99,370,496.99,373,504.99" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="374" y="471.457">Uses</text></g><!--MD5=[2f3b256d614db35f96be6b3c1201bf4f]
link security to db--><g id="link_security_db"><path d="M128,632.17 C128,658.87 128,690.38 128,718.69 " fill="none" id="security-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,726.98,131,718.98,125,718.98,128,726.98" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="87" x="129" y="678.457">Read &amp; write to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="153.5" y="693.5508">[JDBC]</text></g><!--MD5=[db502886685a38a9fde1816e185dd0e0]
link mbsfacade to mbs--><g id="link_mbsfacade_mbs"><path d="M373,633.07 C373,661.44 373,695.09 373,724.54 " fill="none" id="mbsfacade-to-mbs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="373,732.72,376,724.72,370,724.72,373,732.72" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="395.5" y="678.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="374" y="693.5508">[XML/HTTPS]</text></g><!--MD5=[c99bcb02a7404ff7207e229366f7705a]
link spa to sign--><g id="link_spa_sign"><path d="M77.48,150.07 C72.39,159.73 68,169.84 65,180 C53.71,218.24 68.18,260.3 86.08,293.49 " fill="none" id="spa-to-sign" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="90.19,300.86,88.9097,292.4125,83.6709,295.3372,90.19,300.86" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="91.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="66" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[cadaf8a8a3c36cf6631f6dffced8899b]
link spa to accounts--><g id="link_spa_accounts"><path d="M145.43,150.34 C153.94,173.4 167.01,196.92 187,212 C209.18,228.74 224.31,207.26 249,220 C274.88,233.35 298.15,254.37 317.36,275.84 " fill="none" id="spa-to-accounts" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="322.66,281.9,319.643,273.9064,315.1308,277.8612,322.66,281.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="213.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="188" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[f21b9bec839c07106b83575f200b93d2]
link ma to sign--><g id="link_ma_sign"><path d="M327.09,150.06 C311.66,171.52 293.1,194.13 273,212 C267.64,216.76 264.67,215.62 259,220 C230.4,242.1 201.95,270.26 178.91,295.05 " fill="none" id="ma-to-sign" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="173.48,300.94,181.1091,297.0933,176.6986,293.0254,173.48,300.94" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="328.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="303" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[334addda0037abd6e432739e1785e7cb]
link ma to accounts--><g id="link_ma_accounts"><path d="M390.08,150.23 C392.11,160.16 393.86,170.29 395,180 C398.6,210.54 395.93,244.07 391.38,273.47 " fill="none" id="ma-to-accounts" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="390.05,281.65,394.2831,274.2283,388.3593,273.275,390.05,281.65" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="422.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="397" y="208.5508">[JSON/HTTPS]</text></g><rect height="174.4844" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="144" x="334" y="883.2656"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="340" y="905.7988">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="393" y="905.7988"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="908.875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="344" y="923.4082">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="926.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="344" y="941.0176">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="944.0938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="344" y="958.627">container</text><rect fill="#85BBF0" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="961.7031"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="344" y="976.2363">component</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="979.3125"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="344" y="993.8457">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="996.9219"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="344" y="1011.4551">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="1014.5313"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="344" y="1029.0645">external container</text><rect fill="#CCCCCC" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="1032.1406"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="344" y="1046.6738">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="891.2656" y2="891.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="908.875" y2="908.875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="926.4844" y2="926.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="944.0938" y2="944.0938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="961.7031" y2="961.7031"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="979.3125" y2="979.3125"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="996.9219" y2="996.9219"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1014.5313" y2="1014.5313"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1032.1406" y2="1032.1406"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1049.75" y2="1049.75"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="340" y1="891.2656" y2="1049.75"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="472" x2="472" y1="891.2656" y2="1049.75"/><!--MD5=[97230ba690e1599ca29f1f3298fa8193]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

LAYOUT_WITH_LEGEND()

Container(spa, "Single Page Application", "javascript and react", "Provides all the internet banking functionality to customers via their web browser.")
Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")

Container_Boundary(api, "API Application") {
    Component(sign, "Sign In Controller", "MVC Rest Controlle", "Allows users to sign in to the internet banking system")
    Component(accounts, "Accounts Summary Controller", "MVC Rest Controlle", "Provides customers with a summory of their bank accounts")
    Component(security, "Security Component", "Spring Bean", "Provides functionality related to singing in, changing passwords, etc.")
    Component(mbsfacade, "Mainframe Banking System Facade", "Spring Bean", "A facade onto the mainframe banking system.")

    Rel(sign, security, "Uses")
    Rel(accounts, mbsfacade, "Uses")
    Rel(security, db, "Read & write to", "JDBC")
    Rel(mbsfacade, mbs, "Uses", "XML/HTTPS")
}

Rel(spa, sign, "Uses", "JSON/HTTPS")
Rel(spa, accounts, "Uses", "JSON/HTTPS")

Rel(ma, sign, "Uses", "JSON/HTTPS")
Rel(ma, accounts, "Uses", "JSON/HTTPS")
@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}











hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#85BBF0> component |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
|<#CCCCCC> external component |
endlegend

rectangle "==Single Page Application\n//<size:12>[javascript and react]</size>//\n\n Provides all the internet banking functionality to customers via their web browser." <<container>> as spa
rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device." <<container>> as ma
rectangle "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
rectangle "==Mainframe Banking System\n\n Stores all of the core banking information about customers, accounts, transactions, etc." <<external_system>> as mbs

rectangle "==API Application\n<size:12>[Container]</size>" <<boundary>> as api {
    rectangle "==Sign In Controller\n//<size:12>[MVC Rest Controlle]</size>//\n\n Allows users to sign in to the internet banking system" <<component>> as sign
    rectangle "==Accounts Summary Controller\n//<size:12>[MVC Rest Controlle]</size>//\n\n Provides customers with a summory of their bank accounts" <<component>> as accounts
    rectangle "==Security Component\n//<size:12>[Spring Bean]</size>//\n\n Provides functionality related to singing in, changing passwords, etc." <<component>> as security
    rectangle "==Mainframe Banking System Facade\n//<size:12>[Spring Bean]</size>//\n\n A facade onto the mainframe banking system." <<component>> as mbsfacade

sign - ->> security : **Uses**
accounts - ->> mbsfacade : **Uses**
security - ->> db : **Read & write to**\n//<size:12>[JDBC]</size>//
mbsfacade - ->> mbs : **Uses**\n//<size:12>[XML/HTTPS]</size>//
}

spa - ->> sign : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
spa - ->> accounts : **Uses**\n//<size:12>[JSON/HTTPS]</size>//

ma - ->> sign : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
ma - ->> accounts : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download container diagram](container.svg ':ignore')
-
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/API Application/README.md b/docs/1 Internet Banking System/API Application/README.md
deleted file mode 100644
index fede92b..0000000
--- a/docs/1 Internet Banking System/API Application/README.md
+++ /dev/null
@@ -1,34 +0,0 @@
-# API Application
-
-`\1 Internet Banking System\API Application`
-
-* [PySocial Project](../../README.md)
- * [1 Internet Banking System](../../1%20Internet%20Banking%20System/README.md)
- * [**API Application**](../../1%20Internet%20Banking%20System/API%20Application/README.md)
- * [Single Page Application](../../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [Dynamic Diagram](../../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [Extended Docs](../../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [2 Deployment](../../2%20Deployment/README.md)
-
----
-
-[1 Internet Banking System (up)](../../1%20Internet%20Banking%20System/README.md)
-
----
-
-
-![container](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1073px" preserveAspectRatio="none" style="width:500px;height:1073px;background:#FFFFFF;" version="1.1" viewBox="0 0 500 1073" width="500px" zoomAndPan="magnify"><defs/><g><!--MD5=[7442f3b126ee602ae02566c1a49e158a]
cluster api--><g id="cluster_api"><rect height="421" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="487" x="7" y="228"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="192.5" y="246.6094">API Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="219" y="262.582">[Container]</text></g><!--MD5=[30860e21ba0e39165c540f9e23fe2d63]
entity sign--><g id="elem_sign"><rect fill="#85BBF0" height="108.0469" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="207" x="24.5" y="301"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="133" x="61.5" y="327.6094">Sign In Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="113" x="71.5" y="343.582">[MVC Rest Controlle]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="360.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="38.5" y="378.3613">Allows users to sign in to the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="150" x="53" y="395.9707">internet banking system</text></g><!--MD5=[4d2c1095686cc4272d4556037dedae14]
entity accounts--><g id="elem_accounts"><rect fill="#85BBF0" height="145.7813" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="192" x="277" y="282"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="150" x="296" y="308.6094">Accounts Summary</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="76" x="335" y="328.7344">Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="113" x="316.5" y="344.707">[MVC Rest Controlle]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="361.877"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="164" x="291" y="379.4863">Provides customers with a</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="301" y="397.0957">summory of their bank</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="57" x="344.5" y="414.7051">accounts</text></g><!--MD5=[6f1da96282e479ff2a49312c7753703d]
entity security--><g id="elem_security"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="23" y="506"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="49.5" y="532.6094">Security Component</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="91" y="548.582">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="565.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="37" y="583.3613">Provides functionality related</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="142" x="55" y="600.9707">to singing in, changing</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="79" y="618.5801">passwords, etc.</text></g><!--MD5=[8f94240328f985b36a3be06efd5d45ef]
entity mbsfacade--><g id="elem_mbsfacade"><rect fill="#85BBF0" height="128.1719" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="268" y="505"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="297.5" y="531.6094">Mainframe Banking</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="314.5" y="551.7344">System Facade</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="336" y="567.707">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="584.877"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="282" y="602.4863">A facade onto the mainframe</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="102" x="322" y="620.0957">banking system.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="29.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="39.5" y="33.6094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="112" x="74" y="49.582">[javascript and react]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="128" y="66.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="55.5" y="84.3613">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="55.5" y="101.9707">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="119.5801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="103" y="137.1895">browser.</text></g><!--MD5=[99c5416311fbf9d118be657efd773f39]
entity ma--><g id="elem_ma"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="268" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="328.5" y="33.6094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="344.5" y="49.582">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="369" y="66.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="284.5" y="84.3613">Provides a limited subset ot</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="306" y="101.9707">the internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="278" y="119.5801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="287.5" y="137.1895">their mobile mobile device.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="190" x="33" y="727"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="92" y="753.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="44" y="769.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="786.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="804.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="63.5" y="821.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="43" y="839.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="75.5" y="857.1895">access logs, etc.</text></g><!--MD5=[caf83f36d3620b5db28366bd7d249751]
entity mbs--><g id="elem_mbs"><rect fill="#999999" height="130.6875" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="213" x="266.5" y="733"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="297.5" y="759.6094">Mainframe Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="57" x="344.5" y="779.7344">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="797.7832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="185" x="280.5" y="815.3926">Stores all of the core banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="279.5" y="833.002">information about customers,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="286.5" y="850.6113">accounts, transactions, etc.</text></g><!--MD5=[95dadc5fd8c5c901d6969e2e98c70c21]
link sign to security--><g id="link_sign_security"><path d="M128,409.22 C128,436.02 128,468.85 128,497.7 " fill="none" id="sign-to-security" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,505.72,131,497.72,125,497.72,128,505.72" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="129" y="471.457">Uses</text></g><!--MD5=[42d8fcfb42dec18b2b51d602409b2c47]
link accounts to mbsfacade--><g id="link_accounts_mbsfacade"><path d="M373,428.07 C373,450.31 373,474.77 373,496.94 " fill="none" id="accounts-to-mbsfacade" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="373,504.99,376,496.99,370,496.99,373,504.99" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="374" y="471.457">Uses</text></g><!--MD5=[2f3b256d614db35f96be6b3c1201bf4f]
link security to db--><g id="link_security_db"><path d="M128,632.17 C128,658.87 128,690.38 128,718.69 " fill="none" id="security-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,726.98,131,718.98,125,718.98,128,726.98" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="87" x="129" y="678.457">Read &amp; write to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="153.5" y="693.5508">[JDBC]</text></g><!--MD5=[db502886685a38a9fde1816e185dd0e0]
link mbsfacade to mbs--><g id="link_mbsfacade_mbs"><path d="M373,633.07 C373,661.44 373,695.09 373,724.54 " fill="none" id="mbsfacade-to-mbs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="373,732.72,376,724.72,370,724.72,373,732.72" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="395.5" y="678.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="374" y="693.5508">[XML/HTTPS]</text></g><!--MD5=[c99bcb02a7404ff7207e229366f7705a]
link spa to sign--><g id="link_spa_sign"><path d="M77.48,150.07 C72.39,159.73 68,169.84 65,180 C53.71,218.24 68.18,260.3 86.08,293.49 " fill="none" id="spa-to-sign" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="90.19,300.86,88.9097,292.4125,83.6709,295.3372,90.19,300.86" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="91.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="66" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[cadaf8a8a3c36cf6631f6dffced8899b]
link spa to accounts--><g id="link_spa_accounts"><path d="M145.43,150.34 C153.94,173.4 167.01,196.92 187,212 C209.18,228.74 224.31,207.26 249,220 C274.88,233.35 298.15,254.37 317.36,275.84 " fill="none" id="spa-to-accounts" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="322.66,281.9,319.643,273.9064,315.1308,277.8612,322.66,281.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="213.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="188" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[f21b9bec839c07106b83575f200b93d2]
link ma to sign--><g id="link_ma_sign"><path d="M327.09,150.06 C311.66,171.52 293.1,194.13 273,212 C267.64,216.76 264.67,215.62 259,220 C230.4,242.1 201.95,270.26 178.91,295.05 " fill="none" id="ma-to-sign" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="173.48,300.94,181.1091,297.0933,176.6986,293.0254,173.48,300.94" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="328.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="303" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[334addda0037abd6e432739e1785e7cb]
link ma to accounts--><g id="link_ma_accounts"><path d="M390.08,150.23 C392.11,160.16 393.86,170.29 395,180 C398.6,210.54 395.93,244.07 391.38,273.47 " fill="none" id="ma-to-accounts" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="390.05,281.65,394.2831,274.2283,388.3593,273.275,390.05,281.65" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="422.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="397" y="208.5508">[JSON/HTTPS]</text></g><rect height="174.4844" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="144" x="334" y="883.2656"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="340" y="905.7988">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="393" y="905.7988"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="908.875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="344" y="923.4082">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="926.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="344" y="941.0176">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="944.0938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="344" y="958.627">container</text><rect fill="#85BBF0" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="961.7031"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="344" y="976.2363">component</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="979.3125"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="344" y="993.8457">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="996.9219"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="344" y="1011.4551">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="1014.5313"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="344" y="1029.0645">external container</text><rect fill="#CCCCCC" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="1032.1406"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="344" y="1046.6738">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="891.2656" y2="891.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="908.875" y2="908.875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="926.4844" y2="926.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="944.0938" y2="944.0938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="961.7031" y2="961.7031"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="979.3125" y2="979.3125"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="996.9219" y2="996.9219"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1014.5313" y2="1014.5313"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1032.1406" y2="1032.1406"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1049.75" y2="1049.75"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="340" y1="891.2656" y2="1049.75"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="472" x2="472" y1="891.2656" y2="1049.75"/><!--MD5=[97230ba690e1599ca29f1f3298fa8193]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

LAYOUT_WITH_LEGEND()

Container(spa, "Single Page Application", "javascript and react", "Provides all the internet banking functionality to customers via their web browser.")
Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")

Container_Boundary(api, "API Application") {
    Component(sign, "Sign In Controller", "MVC Rest Controlle", "Allows users to sign in to the internet banking system")
    Component(accounts, "Accounts Summary Controller", "MVC Rest Controlle", "Provides customers with a summory of their bank accounts")
    Component(security, "Security Component", "Spring Bean", "Provides functionality related to singing in, changing passwords, etc.")
    Component(mbsfacade, "Mainframe Banking System Facade", "Spring Bean", "A facade onto the mainframe banking system.")

    Rel(sign, security, "Uses")
    Rel(accounts, mbsfacade, "Uses")
    Rel(security, db, "Read & write to", "JDBC")
    Rel(mbsfacade, mbs, "Uses", "XML/HTTPS")
}

Rel(spa, sign, "Uses", "JSON/HTTPS")
Rel(spa, accounts, "Uses", "JSON/HTTPS")

Rel(ma, sign, "Uses", "JSON/HTTPS")
Rel(ma, accounts, "Uses", "JSON/HTTPS")
@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}











hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#85BBF0> component |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
|<#CCCCCC> external component |
endlegend

rectangle "==Single Page Application\n//<size:12>[javascript and react]</size>//\n\n Provides all the internet banking functionality to customers via their web browser." <<container>> as spa
rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device." <<container>> as ma
rectangle "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
rectangle "==Mainframe Banking System\n\n Stores all of the core banking information about customers, accounts, transactions, etc." <<external_system>> as mbs

rectangle "==API Application\n<size:12>[Container]</size>" <<boundary>> as api {
    rectangle "==Sign In Controller\n//<size:12>[MVC Rest Controlle]</size>//\n\n Allows users to sign in to the internet banking system" <<component>> as sign
    rectangle "==Accounts Summary Controller\n//<size:12>[MVC Rest Controlle]</size>//\n\n Provides customers with a summory of their bank accounts" <<component>> as accounts
    rectangle "==Security Component\n//<size:12>[Spring Bean]</size>//\n\n Provides functionality related to singing in, changing passwords, etc." <<component>> as security
    rectangle "==Mainframe Banking System Facade\n//<size:12>[Spring Bean]</size>//\n\n A facade onto the mainframe banking system." <<component>> as mbsfacade

sign - ->> security : **Uses**
accounts - ->> mbsfacade : **Uses**
security - ->> db : **Read & write to**\n//<size:12>[JDBC]</size>//
mbsfacade - ->> mbs : **Uses**\n//<size:12>[XML/HTTPS]</size>//
}

spa - ->> sign : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
spa - ->> accounts : **Uses**\n//<size:12>[JSON/HTTPS]</size>//

ma - ->> sign : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
ma - ->> accounts : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download container diagram](container.svg ':ignore')
-
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/API Application/container.svg b/docs/1 Internet Banking System/API Application/container.svg
deleted file mode 100644
index e726157..0000000
--- a/docs/1 Internet Banking System/API Application/container.svg
+++ /dev/null
@@ -1,368 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/HOME.md b/docs/1 Internet Banking System/HOME.md
deleted file mode 100644
index 3499431..0000000
--- a/docs/1 Internet Banking System/HOME.md
+++ /dev/null
@@ -1,20 +0,0 @@
-# 1 Internet Banking System
-
-
-![system](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1232px" preserveAspectRatio="none" style="width:939px;height:1232px;background:#FFFFFF;" version="1.1" viewBox="0 0 939 1232" width="939px" zoomAndPan="magnify"><defs/><g><!--MD5=[ba4347344a0e48752a561a8e7e2333c9]
cluster ibs--><g id="cluster_ibs"><rect height="901.5" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="475" x="229" y="163"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="126" x="403.5" y="181.6094">Internet Banking</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="51" x="441" y="197.582">[System]</text></g><!--MD5=[fe2e87a9fbde6b36e5fa52b641d8fb64]
entity wa--><g id="elem_wa"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="416.5" y="217"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="124" x="464" y="243.6094">Web Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="121" x="465.5" y="259.582">[java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="524" y="276.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="430.5" y="294.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="440.5" y="311.9707">the internet banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="472" y="329.5801">page application.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="486.5" y="452.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="496.5" y="479.1094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="127" x="523.5" y="495.082">[javascript and angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="585" y="512.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="512.5" y="529.8613">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="512.5" y="547.4707">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="511" y="565.0801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="560" y="582.6895">browser.</text></g><!--MD5=[99c5416311fbf9d118be657efd773f39]
entity ma--><g id="elem_ma"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="245" y="452.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="305.5" y="479.1094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="321.5" y="495.082">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="346" y="512.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="261.5" y="529.8613">Provides a limited subset ot</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="283" y="547.4707">the internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="255" y="565.0801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="264.5" y="582.6895">their mobile mobile device.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="190" x="487" y="905.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="546" y="932.1094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="498" y="948.082">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="580" y="965.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="508" y="982.8613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="517.5" y="1000.4707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="497" y="1018.0801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="529.5" y="1035.6895">access logs, etc.</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="212" x="476" y="687.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="524" y="714.1094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="117" x="523.5" y="730.082">[java and String MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="580" y="747.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="161" x="501.5" y="764.8613">Provides internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="486" y="782.4707">functionality via a JSON/HTTP</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="25" x="569.5" y="800.0801">API.</text></g><!--MD5=[055880c5ddffda0f84a4901cdc35d67e]
entity pbc--><g id="elem_pbc"><rect fill="#08427B" height="161.0781" rx="2.5" ry="2.5" style="stroke:#073B6F;stroke-width:0.5;" width="206" x="7" y="199.5"/><image height="48" width="48" x="86" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAIAAADYYG7QAAACD0lEQVR4Xu2YoU4EMRCGT+4j8Ai8AhaH4QHgAUjQuFMECUgMIUgwJAgMhgQsAYUiJCiQIBBY+EITsjfTdme6V24v4c8vyGbb+ZjOtN0bNcvjQXmkH83WvYBWto6PLm6v7p7uH1/w2fXD+PBycX1Pv2l3IdDm/vn7x+dXQiAubRzoURa7gRZWd0iGRIiJbOnhnfYBQZNJjNbuyY2eJG8fkDE3bbG4ep6MHUAsgYxmE3nVs6VsBWJSGccsOlFPmLIViMzLOB7pCVO2AtHJMohH7Fh6zqitQK7m0rJvAVYgGcEpe//PLdDz65sM4pF9N7ICcXDKIB5Nv6j7tD0NoSdM2QrU9Gg0ewE1LqBhHR3BBdvj2vapnidjHxD/q6vd7Pvhr31AwcY8eXMTXAKECZZJFXuEq27aLgQK5uLMohCenGGuGewOxSjBvYBqeG6B+Nqiblggdjnc+ZXDy+FNFpFzw76O3UBAROuXh6FoiAcf5g9eTvUgzy0nWg6I8cXHRUpg5bOVBCo+KDpFajOf23GgPme7RSQ+lacIENUgJ6gg1k6HjgOlqnLqip4tEuhv0hNEMXUD0clyXE3p6pZA0S2nnvTlXwLJEZWlb7cTQH1+USgTN4VhAenm/wea1OCAOmqo6fE1WCb9WSKBah+rbUWPWAmE2Rvk0ApiB45eOyNAzU8xcTvj8KvkKEoOaIYeHNA3ZuygAvFMUO0AAAAASUVORK5CYII=" y="209.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="136" x="40" y="274.1094">Personal Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="75" x="72.5" y="294.2344">Customer</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="108" y="312.2832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="21" y="329.8926">A customer of the bank, with</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="155" x="32.5" y="347.502">personal bank accounts.</text></g><!--MD5=[ded6a69210fbbc7961dee7b773232267]
entity es--><g id="elem_es"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="176" x="338" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="373" y="33.6094">E-mail system</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="424" y="51.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="137" x="357.5" y="69.2676">The internal Microsoft</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="156" x="348" y="86.877">Exchange e-mail system.</text></g><!--MD5=[caf83f36d3620b5db28366bd7d249751]
entity mbs--><g id="elem_mbs"><rect fill="#999999" height="130.6875" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="213" x="720.5" y="911.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="751.5" y="938.1094">Mainframe Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="57" x="798.5" y="958.2344">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="825" y="976.2832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="185" x="734.5" y="993.8926">Stores all of the core banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="733.5" y="1011.502">information about customers,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="740.5" y="1029.1113">accounts, transactions, etc.</text></g><!--MD5=[e9c20127f585181a79dab89266001537]
link api to es--><g id="link_api_es"><path d="M652.28,687.36 C675.2,661.74 696.86,629.97 705,595.5 C750.29,403.64 774.42,310.31 653,155 C620.81,113.83 568.19,89.11 521.72,74.5 " fill="none" id="api-to-es" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="514.02,72.15,520.7895,77.3629,522.5479,71.6264,514.02,72.15" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="81" x="742" y="403.957">Sends e-mails</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="763.5" y="419.0508">[SMTP]</text></g><!--MD5=[058ef8e85ab64ed7b349259f69e8bfb6]
link api to mbs--><g id="link_api_mbs"><path d="M658.88,813.73 C670.46,823.53 682.15,833.67 693,843.5 C714.72,863.17 737.65,885.3 758.28,905.76 " fill="none" id="api-to-mbs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="764.03,911.48,760.4651,903.7153,756.2385,907.9739,764.03,911.48" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="749.5" y="856.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="728" y="872.0508">[XML/HTTPS]</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M582,813.74 C582,839.6 582,869.92 582,897.31 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="582,905.32,585,897.32,579,897.32,582,905.32" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="101" x="583" y="856.957">Reads &amp; writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="614.5" y="872.0508">[JDBC]</text></g><!--MD5=[61eecc891977d187ae935fece35ea030]
link wa to spa--><g id="link_wa_spa"><path d="M541.63,343.01 C549.41,373.86 558.89,411.5 567.18,444.36 " fill="none" id="wa-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="569.14,452.16,570.0918,443.6692,564.2741,445.137,569.14,452.16" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="46" x="561" y="411.457">Delivers</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M585.42,595.73 C584.83,622.4 584.16,652.71 583.56,679.33 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="583.38,687.47,586.5507,679.5361,580.5521,679.4076,583.38,687.47" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="610.5" y="638.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="585" y="654.0508">[JSON/HTTPS]</text></g><!--MD5=[efcb8ef56d3c96dbd54ad0916bef4ec1]
link ma to api--><g id="link_ma_api"><path d="M421.72,595.73 C450.36,623.2 483.03,654.55 511.37,681.73 " fill="none" id="ma-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="517.35,687.47,513.6581,679.7648,509.502,684.0923,517.35,687.47" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="511.5" y="638.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="486" y="654.0508">[JSON/HTTPS]</text></g><!--MD5=[7acc9246d326cc0ca04f231532551af9]
link pbc to wa--><g id="link_pbc_wa"><path d="M213.1,280 C272.28,280 346.81,280 408.28,280 " fill="none" id="pbc-to-wa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="416.48,280,408.48,277,408.48,283,416.48,280" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="300.25" y="258.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="45" x="292.25" y="273.5508">[HTTPS]</text></g><!--MD5=[b09e1e3c9017f3791a48d778fd7ab8a5]
link pbc to spa--><g id="link_pbc_spa"><path d="M213.01,351.78 C218.36,354.83 223.7,357.76 229,360.5 C330.46,413 366.25,402.57 469,452.5 C472.29,454.1 475.61,455.76 478.94,457.46 " fill="none" id="pbc-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="486.25,461.27,480.542,454.9125,477.7691,460.2333,486.25,461.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="396" y="411.457">Uses</text></g><!--MD5=[2d531d403c1ff55482e84426773c64ad]
link pbc to ma--><g id="link_pbc_ma"><path d="M188.26,360.58 C215.45,388.23 245.88,419.16 272.82,446.55 " fill="none" id="pbc-to-ma" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="278.51,452.34,275.0434,444.5308,270.7634,448.7358,278.51,452.34" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="244" y="411.457">Uses</text></g><!--MD5=[8b7693a20d41c2a1fa27d9f6a96ec3b6]
link es to pbc--><g id="link_es_pbc"><path d="M337.98,91.64 C302.55,108.52 262.29,130.27 229,155 C213.7,166.36 198.63,179.78 184.62,193.51 " fill="none" id="es-to-pbc" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="178.68,199.41,186.4671,195.8941,182.2352,191.6408,178.68,199.41" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="95" x="265" y="143.457">Sends e-mails to</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="784.5" y="1077.5"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="790.5" y="1100.0332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="843.5" y="1100.0332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1103.1094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="794.5" y="1117.6426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1120.7188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="794.5" y="1135.252">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1138.3281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="794.5" y="1152.8613">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1155.9375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="794.5" y="1170.4707">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1173.5469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="794.5" y="1188.0801">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1191.1563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="794.5" y="1205.6895">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1085.5" y2="1085.5"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1103.1094" y2="1103.1094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1120.7188" y2="1120.7188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1138.3281" y2="1138.3281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1155.9375" y2="1155.9375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1173.5469" y2="1173.5469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1191.1563" y2="1191.1563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1208.7656" y2="1208.7656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="790.5" y1="1085.5" y2="1208.7656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="911.5" x2="911.5" y1="1085.5" y2="1208.7656"/><!--MD5=[b6997e2e3bb5d4f6be4be230d598b248]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml

LAYOUT_WITH_LEGEND()

Person(pbc, "Personal Banking Customer", "A customer of the bank, with personal bank accounts.")
System_Ext(es, "E-mail system", "The internal Microsoft Exchange e-mail system.")
System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")
System_Boundary(ibs, "Internet Banking") {
    Container(wa, "Web Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")
    Container(spa, "Single Page Application", "javascript and angular", "Provides all the internet banking functionality to customers via their web browser.")
    Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
    Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
    Container(api, "API Application", "java and String MVC", "Provides internet banking functionality via a JSON/HTTP API.")

    Rel(api, es, "Sends e-mails", "SMTP")
    Rel(api, mbs, "Uses", "XML/HTTPS")
    Rel(api, db, "Reads & writes to", "JDBC")
    Rel(wa, spa, "Delivers")
    Rel(spa, api, "Uses", "JSON/HTTPS")
    Rel(ma, api, "Uses", "JSON/HTTPS")
}

Rel(pbc, wa, "Uses", "HTTPS")
Rel(pbc, spa, "Uses")
Rel(pbc, ma, "Uses")
Rel(es, pbc, "Sends e-mails to")
@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}













hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "<$person>\n==Personal Banking Customer\n\n A customer of the bank, with personal bank accounts." <<person>> as pbc
rectangle "==E-mail system\n\n The internal Microsoft Exchange e-mail system." <<external_system>> as es
rectangle "==Mainframe Banking System\n\n Stores all of the core banking information about customers, accounts, transactions, etc." <<external_system>> as mbs
rectangle "==Internet Banking\n<size:12>[System]</size>" <<boundary>> as ibs {
    rectangle "==Web Application\n//<size:12>[java and Spring MVC]</size>//\n\n Delivers the static content and the internet banking single page application." <<container>> as wa
    rectangle "==Single Page Application\n//<size:12>[javascript and angular]</size>//\n\n Provides all the internet banking functionality to customers via their web browser." <<container>> as spa
    rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device." <<container>> as ma
    rectangle "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
    rectangle "==API Application\n//<size:12>[java and String MVC]</size>//\n\n Provides internet banking functionality via a JSON/HTTP API." <<container>> as api

api - ->> es : **Sends e-mails**\n//<size:12>[SMTP]</size>//
api - ->> mbs : **Uses**\n//<size:12>[XML/HTTPS]</size>//
api - ->> db : **Reads & writes to**\n//<size:12>[JDBC]</size>//
wa - ->> spa : **Delivers**
spa - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
ma - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
}

pbc - ->> wa : **Uses**\n//<size:12>[HTTPS]</size>//
pbc - ->> spa : **Uses**
pbc - ->> ma : **Uses**
es - ->> pbc : **Sends e-mails to**
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download system diagram](system.svg ':ignore')
-
-**Level 2: Container diagram**
-
-Once you understand how your system fits in to the overall IT environment, a really useful next step is to zoom-in to the system boundary with a Container diagram. A "container" is something like a server-side web application, single-page application, desktop application, mobile app, database schema, file system, etc. Essentially, a container is a separately runnable/deployable unit (e.g. a separate process space) that executes code or stores data.
-
-The Container diagram shows the high-level shape of the software architecture and how responsibilities are distributed across it. It also shows the major technology choices and how the containers communicate with one another. It's a simple, high-level technology focussed diagram that is useful for software developers and support/operations staff alike.
-
-**Scope**: A single software system.
-
-**Primary elements**: Containers within the software system in scope.
-Supporting elements: People and software systems directly connected to the containers.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
-
-**Notes**: This diagram says nothing about deployment scenarios, clustering, replication, failover, etc.
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/README.md b/docs/1 Internet Banking System/README.md
deleted file mode 100644
index 76e9f55..0000000
--- a/docs/1 Internet Banking System/README.md
+++ /dev/null
@@ -1,40 +0,0 @@
-# 1 Internet Banking System
-
-`\1 Internet Banking System`
-
-* [PySocial Project](../README.md)
- * [**1 Internet Banking System**](../1%20Internet%20Banking%20System/README.md)
- * [API Application](../1%20Internet%20Banking%20System/API%20Application/README.md)
- * [Single Page Application](../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [Dynamic Diagram](../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [Extended Docs](../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [2 Deployment](../2%20Deployment/README.md)
-
----
-
-[PySocial Project (up)](../README.md)
-
-- [API Application](../1%20Internet%20Banking%20System/API%20Application/README.md)
-
-- [Single Page Application](../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
-
----
-
-
-![system](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1232px" preserveAspectRatio="none" style="width:939px;height:1232px;background:#FFFFFF;" version="1.1" viewBox="0 0 939 1232" width="939px" zoomAndPan="magnify"><defs/><g><!--MD5=[ba4347344a0e48752a561a8e7e2333c9]
cluster ibs--><g id="cluster_ibs"><rect height="901.5" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="475" x="229" y="163"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="126" x="403.5" y="181.6094">Internet Banking</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="51" x="441" y="197.582">[System]</text></g><!--MD5=[fe2e87a9fbde6b36e5fa52b641d8fb64]
entity wa--><g id="elem_wa"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="416.5" y="217"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="124" x="464" y="243.6094">Web Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="121" x="465.5" y="259.582">[java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="524" y="276.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="430.5" y="294.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="440.5" y="311.9707">the internet banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="472" y="329.5801">page application.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="486.5" y="452.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="496.5" y="479.1094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="127" x="523.5" y="495.082">[javascript and angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="585" y="512.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="512.5" y="529.8613">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="512.5" y="547.4707">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="511" y="565.0801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="560" y="582.6895">browser.</text></g><!--MD5=[99c5416311fbf9d118be657efd773f39]
entity ma--><g id="elem_ma"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="245" y="452.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="305.5" y="479.1094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="321.5" y="495.082">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="346" y="512.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="261.5" y="529.8613">Provides a limited subset ot</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="283" y="547.4707">the internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="255" y="565.0801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="264.5" y="582.6895">their mobile mobile device.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="190" x="487" y="905.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="546" y="932.1094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="498" y="948.082">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="580" y="965.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="508" y="982.8613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="517.5" y="1000.4707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="497" y="1018.0801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="529.5" y="1035.6895">access logs, etc.</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="212" x="476" y="687.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="524" y="714.1094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="117" x="523.5" y="730.082">[java and String MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="580" y="747.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="161" x="501.5" y="764.8613">Provides internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="486" y="782.4707">functionality via a JSON/HTTP</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="25" x="569.5" y="800.0801">API.</text></g><!--MD5=[055880c5ddffda0f84a4901cdc35d67e]
entity pbc--><g id="elem_pbc"><rect fill="#08427B" height="161.0781" rx="2.5" ry="2.5" style="stroke:#073B6F;stroke-width:0.5;" width="206" x="7" y="199.5"/><image height="48" width="48" x="86" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAIAAADYYG7QAAACD0lEQVR4Xu2YoU4EMRCGT+4j8Ai8AhaH4QHgAUjQuFMECUgMIUgwJAgMhgQsAYUiJCiQIBBY+EITsjfTdme6V24v4c8vyGbb+ZjOtN0bNcvjQXmkH83WvYBWto6PLm6v7p7uH1/w2fXD+PBycX1Pv2l3IdDm/vn7x+dXQiAubRzoURa7gRZWd0iGRIiJbOnhnfYBQZNJjNbuyY2eJG8fkDE3bbG4ep6MHUAsgYxmE3nVs6VsBWJSGccsOlFPmLIViMzLOB7pCVO2AtHJMohH7Fh6zqitQK7m0rJvAVYgGcEpe//PLdDz65sM4pF9N7ICcXDKIB5Nv6j7tD0NoSdM2QrU9Gg0ewE1LqBhHR3BBdvj2vapnidjHxD/q6vd7Pvhr31AwcY8eXMTXAKECZZJFXuEq27aLgQK5uLMohCenGGuGewOxSjBvYBqeG6B+Nqiblggdjnc+ZXDy+FNFpFzw76O3UBAROuXh6FoiAcf5g9eTvUgzy0nWg6I8cXHRUpg5bOVBCo+KDpFajOf23GgPme7RSQ+lacIENUgJ6gg1k6HjgOlqnLqip4tEuhv0hNEMXUD0clyXE3p6pZA0S2nnvTlXwLJEZWlb7cTQH1+USgTN4VhAenm/wea1OCAOmqo6fE1WCb9WSKBah+rbUWPWAmE2Rvk0ApiB45eOyNAzU8xcTvj8KvkKEoOaIYeHNA3ZuygAvFMUO0AAAAASUVORK5CYII=" y="209.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="136" x="40" y="274.1094">Personal Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="75" x="72.5" y="294.2344">Customer</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="108" y="312.2832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="21" y="329.8926">A customer of the bank, with</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="155" x="32.5" y="347.502">personal bank accounts.</text></g><!--MD5=[ded6a69210fbbc7961dee7b773232267]
entity es--><g id="elem_es"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="176" x="338" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="373" y="33.6094">E-mail system</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="424" y="51.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="137" x="357.5" y="69.2676">The internal Microsoft</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="156" x="348" y="86.877">Exchange e-mail system.</text></g><!--MD5=[caf83f36d3620b5db28366bd7d249751]
entity mbs--><g id="elem_mbs"><rect fill="#999999" height="130.6875" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="213" x="720.5" y="911.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="751.5" y="938.1094">Mainframe Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="57" x="798.5" y="958.2344">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="825" y="976.2832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="185" x="734.5" y="993.8926">Stores all of the core banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="733.5" y="1011.502">information about customers,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="740.5" y="1029.1113">accounts, transactions, etc.</text></g><!--MD5=[e9c20127f585181a79dab89266001537]
link api to es--><g id="link_api_es"><path d="M652.28,687.36 C675.2,661.74 696.86,629.97 705,595.5 C750.29,403.64 774.42,310.31 653,155 C620.81,113.83 568.19,89.11 521.72,74.5 " fill="none" id="api-to-es" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="514.02,72.15,520.7895,77.3629,522.5479,71.6264,514.02,72.15" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="81" x="742" y="403.957">Sends e-mails</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="763.5" y="419.0508">[SMTP]</text></g><!--MD5=[058ef8e85ab64ed7b349259f69e8bfb6]
link api to mbs--><g id="link_api_mbs"><path d="M658.88,813.73 C670.46,823.53 682.15,833.67 693,843.5 C714.72,863.17 737.65,885.3 758.28,905.76 " fill="none" id="api-to-mbs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="764.03,911.48,760.4651,903.7153,756.2385,907.9739,764.03,911.48" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="749.5" y="856.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="728" y="872.0508">[XML/HTTPS]</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M582,813.74 C582,839.6 582,869.92 582,897.31 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="582,905.32,585,897.32,579,897.32,582,905.32" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="101" x="583" y="856.957">Reads &amp; writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="614.5" y="872.0508">[JDBC]</text></g><!--MD5=[61eecc891977d187ae935fece35ea030]
link wa to spa--><g id="link_wa_spa"><path d="M541.63,343.01 C549.41,373.86 558.89,411.5 567.18,444.36 " fill="none" id="wa-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="569.14,452.16,570.0918,443.6692,564.2741,445.137,569.14,452.16" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="46" x="561" y="411.457">Delivers</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M585.42,595.73 C584.83,622.4 584.16,652.71 583.56,679.33 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="583.38,687.47,586.5507,679.5361,580.5521,679.4076,583.38,687.47" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="610.5" y="638.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="585" y="654.0508">[JSON/HTTPS]</text></g><!--MD5=[efcb8ef56d3c96dbd54ad0916bef4ec1]
link ma to api--><g id="link_ma_api"><path d="M421.72,595.73 C450.36,623.2 483.03,654.55 511.37,681.73 " fill="none" id="ma-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="517.35,687.47,513.6581,679.7648,509.502,684.0923,517.35,687.47" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="511.5" y="638.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="486" y="654.0508">[JSON/HTTPS]</text></g><!--MD5=[7acc9246d326cc0ca04f231532551af9]
link pbc to wa--><g id="link_pbc_wa"><path d="M213.1,280 C272.28,280 346.81,280 408.28,280 " fill="none" id="pbc-to-wa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="416.48,280,408.48,277,408.48,283,416.48,280" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="300.25" y="258.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="45" x="292.25" y="273.5508">[HTTPS]</text></g><!--MD5=[b09e1e3c9017f3791a48d778fd7ab8a5]
link pbc to spa--><g id="link_pbc_spa"><path d="M213.01,351.78 C218.36,354.83 223.7,357.76 229,360.5 C330.46,413 366.25,402.57 469,452.5 C472.29,454.1 475.61,455.76 478.94,457.46 " fill="none" id="pbc-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="486.25,461.27,480.542,454.9125,477.7691,460.2333,486.25,461.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="396" y="411.457">Uses</text></g><!--MD5=[2d531d403c1ff55482e84426773c64ad]
link pbc to ma--><g id="link_pbc_ma"><path d="M188.26,360.58 C215.45,388.23 245.88,419.16 272.82,446.55 " fill="none" id="pbc-to-ma" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="278.51,452.34,275.0434,444.5308,270.7634,448.7358,278.51,452.34" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="244" y="411.457">Uses</text></g><!--MD5=[8b7693a20d41c2a1fa27d9f6a96ec3b6]
link es to pbc--><g id="link_es_pbc"><path d="M337.98,91.64 C302.55,108.52 262.29,130.27 229,155 C213.7,166.36 198.63,179.78 184.62,193.51 " fill="none" id="es-to-pbc" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="178.68,199.41,186.4671,195.8941,182.2352,191.6408,178.68,199.41" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="95" x="265" y="143.457">Sends e-mails to</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="784.5" y="1077.5"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="790.5" y="1100.0332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="843.5" y="1100.0332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1103.1094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="794.5" y="1117.6426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1120.7188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="794.5" y="1135.252">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1138.3281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="794.5" y="1152.8613">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1155.9375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="794.5" y="1170.4707">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1173.5469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="794.5" y="1188.0801">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1191.1563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="794.5" y="1205.6895">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1085.5" y2="1085.5"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1103.1094" y2="1103.1094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1120.7188" y2="1120.7188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1138.3281" y2="1138.3281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1155.9375" y2="1155.9375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1173.5469" y2="1173.5469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1191.1563" y2="1191.1563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1208.7656" y2="1208.7656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="790.5" y1="1085.5" y2="1208.7656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="911.5" x2="911.5" y1="1085.5" y2="1208.7656"/><!--MD5=[b6997e2e3bb5d4f6be4be230d598b248]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml

LAYOUT_WITH_LEGEND()

Person(pbc, "Personal Banking Customer", "A customer of the bank, with personal bank accounts.")
System_Ext(es, "E-mail system", "The internal Microsoft Exchange e-mail system.")
System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")
System_Boundary(ibs, "Internet Banking") {
    Container(wa, "Web Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")
    Container(spa, "Single Page Application", "javascript and angular", "Provides all the internet banking functionality to customers via their web browser.")
    Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
    Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
    Container(api, "API Application", "java and String MVC", "Provides internet banking functionality via a JSON/HTTP API.")

    Rel(api, es, "Sends e-mails", "SMTP")
    Rel(api, mbs, "Uses", "XML/HTTPS")
    Rel(api, db, "Reads & writes to", "JDBC")
    Rel(wa, spa, "Delivers")
    Rel(spa, api, "Uses", "JSON/HTTPS")
    Rel(ma, api, "Uses", "JSON/HTTPS")
}

Rel(pbc, wa, "Uses", "HTTPS")
Rel(pbc, spa, "Uses")
Rel(pbc, ma, "Uses")
Rel(es, pbc, "Sends e-mails to")
@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}













hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "<$person>\n==Personal Banking Customer\n\n A customer of the bank, with personal bank accounts." <<person>> as pbc
rectangle "==E-mail system\n\n The internal Microsoft Exchange e-mail system." <<external_system>> as es
rectangle "==Mainframe Banking System\n\n Stores all of the core banking information about customers, accounts, transactions, etc." <<external_system>> as mbs
rectangle "==Internet Banking\n<size:12>[System]</size>" <<boundary>> as ibs {
    rectangle "==Web Application\n//<size:12>[java and Spring MVC]</size>//\n\n Delivers the static content and the internet banking single page application." <<container>> as wa
    rectangle "==Single Page Application\n//<size:12>[javascript and angular]</size>//\n\n Provides all the internet banking functionality to customers via their web browser." <<container>> as spa
    rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device." <<container>> as ma
    rectangle "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
    rectangle "==API Application\n//<size:12>[java and String MVC]</size>//\n\n Provides internet banking functionality via a JSON/HTTP API." <<container>> as api

api - ->> es : **Sends e-mails**\n//<size:12>[SMTP]</size>//
api - ->> mbs : **Uses**\n//<size:12>[XML/HTTPS]</size>//
api - ->> db : **Reads & writes to**\n//<size:12>[JDBC]</size>//
wa - ->> spa : **Delivers**
spa - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
ma - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
}

pbc - ->> wa : **Uses**\n//<size:12>[HTTPS]</size>//
pbc - ->> spa : **Uses**
pbc - ->> ma : **Uses**
es - ->> pbc : **Sends e-mails to**
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download system diagram](system.svg ':ignore')
-
-**Level 2: Container diagram**
-
-Once you understand how your system fits in to the overall IT environment, a really useful next step is to zoom-in to the system boundary with a Container diagram. A "container" is something like a server-side web application, single-page application, desktop application, mobile app, database schema, file system, etc. Essentially, a container is a separately runnable/deployable unit (e.g. a separate process space) that executes code or stores data.
-
-The Container diagram shows the high-level shape of the software architecture and how responsibilities are distributed across it. It also shows the major technology choices and how the containers communicate with one another. It's a simple, high-level technology focussed diagram that is useful for software developers and support/operations staff alike.
-
-**Scope**: A single software system.
-
-**Primary elements**: Containers within the software system in scope.
-Supporting elements: People and software systems directly connected to the containers.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
-
-**Notes**: This diagram says nothing about deployment scenarios, clustering, replication, failover, etc.
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/2020-01-10-16-21-41.png b/docs/1 Internet Banking System/Single Page Application/2020-01-10-16-21-41.png
deleted file mode 100644
index ea176bb..0000000
Binary files a/docs/1 Internet Banking System/Single Page Application/2020-01-10-16-21-41.png and /dev/null differ
diff --git a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/Dynamic Diagram.pdf b/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/Dynamic Diagram.pdf
deleted file mode 100644
index b18d5b4..0000000
Binary files a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/Dynamic Diagram.pdf and /dev/null differ
diff --git a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/HOME.md b/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/HOME.md
deleted file mode 100644
index b172474..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/HOME.md
+++ /dev/null
@@ -1,15 +0,0 @@
-# Dynamic Diagram
-
-
-![dynamic](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="973px" preserveAspectRatio="none" style="width:280px;height:973px;background:#FFFFFF;" version="1.1" viewBox="0 0 280 973" width="280px" zoomAndPan="magnify"><defs/><g><!--MD5=[9327bfcb173f1b9645ad568e29f29f90]
cluster bc--><g id="cluster_bc"><rect height="448" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="242" x="7" y="246"/><text fill="#444444" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="76" x="90" y="262.5332">«boundary»</text><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="70" y="282.2188">API Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="96.5" y="298.1914">[Container]</text></g><!--MD5=[7d31e0ad99682b9efa7ed3dbba05f561]
entity signin--><g id="elem_signin"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="207" x="23.5" y="317"/><text fill="#000000" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="86" x="84" y="341.5332">«component»</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="133" x="60.5" y="361.2188">Sign In Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="156" x="49" y="377.1914">[Spring MVC Rest Controller]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="125" y="394.3613"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="37.5" y="411.9707">Allows users to sign in to the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="153" x="50.5" y="429.5801">internet Banking System</text></g><!--MD5=[6f1da96282e479ff2a49312c7753703d]
entity security--><g id="elem_security"><rect fill="#85BBF0" height="143.2656" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="23" y="535"/><text fill="#000000" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="86" x="85" y="559.5332">«component»</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="49.5" y="579.2188">Security Component</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="91" y="595.1914">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="612.3613"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="37" y="629.9707">Provides functionality related</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="142" x="55" y="647.5801">to signing in, changing</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="79" y="665.1895">passwords, etc.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="160.875" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="26.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="75" x="89.5" y="31.5332">«container»</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="36.5" y="51.2188">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="128" x="63" y="67.1914">[javascript and Angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="125" y="84.3613"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="52.5" y="101.9707">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="52.5" y="119.5801">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="51" y="137.1895">customers via thier web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="100" y="154.7988">browser.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><path d="M33,797 C33,787 128,787 128,787 C128,787 223,787 223,797 L223,946.875 C223,956.875 128,956.875 128,956.875 C128,956.875 33,956.875 33,946.875 L33,797 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M33,797 C33,807 128,807 128,807 C128,807 223,807 223,797 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="75" x="90.5" y="825.5332">«container»</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="92" y="845.2188">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="148" x="54" y="861.1914">[Oracle Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="878.3613"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="895.9707">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="121" x="65.5" y="913.5801">information hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="43" y="931.1895">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="75.5" y="948.7988">access logs, etc.</text></g><!--MD5=[a3715e1b0eb5ea6f4ea74782513c7fba]
link spa to signin--><g id="link_spa_signin"><path d="M127,168.26 C127,212.29 127,266.47 127,308.86 " fill="none" id="spa-to-signin" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="127,316.91,130,308.91,124,308.91,127,316.91" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="141" x="128" y="211.457">1: Submits credentials to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="158.5" y="226.5508">[JSON/HTTPS]</text></g><!--MD5=[34ef625f00519263ae52d116cb2c43c2]
link signin to security--><g id="link_signin_security"><path d="M127.28,443.24 C127.39,469.1 127.53,499.42 127.65,526.81 " fill="none" id="signin-to-security" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="127.69,534.82,130.6471,526.804,124.6472,526.8362,127.69,534.82" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="141" x="128" y="486.457">2: Calls isAuthenticated()</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="14" x="193" y="501.5508">on</text></g><!--MD5=[2f3b256d614db35f96be6b3c1201bf4f]
link security to db--><g id="link_security_db"><path d="M128,678.11 C128,708.89 128,745.39 128,778.31 " fill="none" id="security-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,786.59,131,778.59,125,778.59,128,786.59" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="122" x="129" y="723.457">3: select * from users</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="133" y="738.5508">where username = ?</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="172.5" y="753.6445">[JDBC]</text></g><!--MD5=[84dcae9ff33dd327841b0a8f7a5f76d5]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Dynamic.puml

Container(spa, "Single Page Application", "javascript and Angular", "Provides all the internet banking functionality to customers via thier web browser.")
ContainerDb(db, "Database", "Oracle Database Schema", "Stores user registration information hashed authentication credentials, access logs, etc.")
Container_Boundary(bc, "API Application"){
    Component(signin, "Sign In Controller", "Spring MVC Rest Controller", "Allows users to sign in to the internet Banking System")
    Component(security, "Security Component", "Spring Bean", "Provides functionality related to signing in, changing passwords, etc.")
}

Rel(spa, signin, "Submits credentials to", "JSON/HTTPS")
Rel(signin, security, "Calls isAuthenticated() on")
Rel(security, db, "select * from users where username = ?", "JDBC")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}






























rectangle "==Single Page Application\n//<size:12>[javascript and Angular]</size>//\n\n Provides all the internet banking functionality to customers via thier web browser." <<container>> as spa
database "==Database\n//<size:12>[Oracle Database Schema]</size>//\n\n Stores user registration information hashed authentication credentials, access logs, etc." <<container>> as db
rectangle "==API Application\n<size:12>[Container]</size>" <<boundary>> as bc{
    rectangle "==Sign In Controller\n//<size:12>[Spring MVC Rest Controller]</size>//\n\n Allows users to sign in to the internet Banking System" <<component>> as signin
    rectangle "==Security Component\n//<size:12>[Spring Bean]</size>//\n\n Provides functionality related to signing in, changing passwords, etc." <<component>> as security
}

spa - ->> signin : **1: Submits credentials to**\n//<size:12>[JSON/HTTPS]</size>//
signin - ->> security : **2: Calls isAuthenticated() on**
security - ->> db : **3: select * from users where username = ?**\n//<size:12>[JDBC]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download dynamic diagram](dynamic.svg ':ignore')
-
-**Dynamic diagram**
-
-A simple dynamic diagram can be useful when you want to show how elements in a static model collaborate at runtime to implement a user story, use case, feature, etc. This dynamic diagram is based upon a UML communication diagram (previously known as a "UML collaboration diagram"). It is similar to a UML sequence diagram although it allows a free-form arrangement of diagram elements with numbered interactions to indicate ordering.
-
-**Scope**: An enterprise, software system or container.
-
-**Primary and supporting elements**: Depends on the diagram scope; enterprise (see System Landscape diagram), software system (see System Context or Container diagrams), container (see Component diagram).
-
-**Intended audience**: Technical and non-technical people, inside and outside of the software development team.
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/README.md b/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/README.md
deleted file mode 100644
index e352c9a..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/README.md
+++ /dev/null
@@ -1,31 +0,0 @@
-# Dynamic Diagram
-
-`\1 Internet Banking System\Single Page Application\Dynamic Diagram`
-
-* [PySocial Project](../../../README.md)
- * [1 Internet Banking System](../../../1%20Internet%20Banking%20System/README.md)
- * [API Application](../../../1%20Internet%20Banking%20System/API%20Application/README.md)
- * [Single Page Application](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [**Dynamic Diagram**](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [Extended Docs](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [2 Deployment](../../../2%20Deployment/README.md)
-
----
-
-[Single Page Application (up)](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
-
----
-
-
-![dynamic](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="973px" preserveAspectRatio="none" style="width:280px;height:973px;background:#FFFFFF;" version="1.1" viewBox="0 0 280 973" width="280px" zoomAndPan="magnify"><defs/><g><!--MD5=[9327bfcb173f1b9645ad568e29f29f90]
cluster bc--><g id="cluster_bc"><rect height="448" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="242" x="7" y="246"/><text fill="#444444" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="76" x="90" y="262.5332">«boundary»</text><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="70" y="282.2188">API Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="96.5" y="298.1914">[Container]</text></g><!--MD5=[7d31e0ad99682b9efa7ed3dbba05f561]
entity signin--><g id="elem_signin"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="207" x="23.5" y="317"/><text fill="#000000" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="86" x="84" y="341.5332">«component»</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="133" x="60.5" y="361.2188">Sign In Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="156" x="49" y="377.1914">[Spring MVC Rest Controller]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="125" y="394.3613"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="37.5" y="411.9707">Allows users to sign in to the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="153" x="50.5" y="429.5801">internet Banking System</text></g><!--MD5=[6f1da96282e479ff2a49312c7753703d]
entity security--><g id="elem_security"><rect fill="#85BBF0" height="143.2656" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="23" y="535"/><text fill="#000000" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="86" x="85" y="559.5332">«component»</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="49.5" y="579.2188">Security Component</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="91" y="595.1914">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="612.3613"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="37" y="629.9707">Provides functionality related</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="142" x="55" y="647.5801">to signing in, changing</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="79" y="665.1895">passwords, etc.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="160.875" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="26.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="75" x="89.5" y="31.5332">«container»</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="36.5" y="51.2188">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="128" x="63" y="67.1914">[javascript and Angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="125" y="84.3613"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="52.5" y="101.9707">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="52.5" y="119.5801">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="51" y="137.1895">customers via thier web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="100" y="154.7988">browser.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><path d="M33,797 C33,787 128,787 128,787 C128,787 223,787 223,797 L223,946.875 C223,956.875 128,956.875 128,956.875 C128,956.875 33,956.875 33,946.875 L33,797 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M33,797 C33,807 128,807 128,807 C128,807 223,807 223,797 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="75" x="90.5" y="825.5332">«container»</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="92" y="845.2188">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="148" x="54" y="861.1914">[Oracle Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="878.3613"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="895.9707">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="121" x="65.5" y="913.5801">information hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="43" y="931.1895">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="75.5" y="948.7988">access logs, etc.</text></g><!--MD5=[a3715e1b0eb5ea6f4ea74782513c7fba]
link spa to signin--><g id="link_spa_signin"><path d="M127,168.26 C127,212.29 127,266.47 127,308.86 " fill="none" id="spa-to-signin" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="127,316.91,130,308.91,124,308.91,127,316.91" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="141" x="128" y="211.457">1: Submits credentials to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="158.5" y="226.5508">[JSON/HTTPS]</text></g><!--MD5=[34ef625f00519263ae52d116cb2c43c2]
link signin to security--><g id="link_signin_security"><path d="M127.28,443.24 C127.39,469.1 127.53,499.42 127.65,526.81 " fill="none" id="signin-to-security" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="127.69,534.82,130.6471,526.804,124.6472,526.8362,127.69,534.82" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="141" x="128" y="486.457">2: Calls isAuthenticated()</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="14" x="193" y="501.5508">on</text></g><!--MD5=[2f3b256d614db35f96be6b3c1201bf4f]
link security to db--><g id="link_security_db"><path d="M128,678.11 C128,708.89 128,745.39 128,778.31 " fill="none" id="security-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,786.59,131,778.59,125,778.59,128,786.59" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="122" x="129" y="723.457">3: select * from users</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="133" y="738.5508">where username = ?</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="172.5" y="753.6445">[JDBC]</text></g><!--MD5=[84dcae9ff33dd327841b0a8f7a5f76d5]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Dynamic.puml

Container(spa, "Single Page Application", "javascript and Angular", "Provides all the internet banking functionality to customers via thier web browser.")
ContainerDb(db, "Database", "Oracle Database Schema", "Stores user registration information hashed authentication credentials, access logs, etc.")
Container_Boundary(bc, "API Application"){
    Component(signin, "Sign In Controller", "Spring MVC Rest Controller", "Allows users to sign in to the internet Banking System")
    Component(security, "Security Component", "Spring Bean", "Provides functionality related to signing in, changing passwords, etc.")
}

Rel(spa, signin, "Submits credentials to", "JSON/HTTPS")
Rel(signin, security, "Calls isAuthenticated() on")
Rel(security, db, "select * from users where username = ?", "JDBC")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}






























rectangle "==Single Page Application\n//<size:12>[javascript and Angular]</size>//\n\n Provides all the internet banking functionality to customers via thier web browser." <<container>> as spa
database "==Database\n//<size:12>[Oracle Database Schema]</size>//\n\n Stores user registration information hashed authentication credentials, access logs, etc." <<container>> as db
rectangle "==API Application\n<size:12>[Container]</size>" <<boundary>> as bc{
    rectangle "==Sign In Controller\n//<size:12>[Spring MVC Rest Controller]</size>//\n\n Allows users to sign in to the internet Banking System" <<component>> as signin
    rectangle "==Security Component\n//<size:12>[Spring Bean]</size>//\n\n Provides functionality related to signing in, changing passwords, etc." <<component>> as security
}

spa - ->> signin : **1: Submits credentials to**\n//<size:12>[JSON/HTTPS]</size>//
signin - ->> security : **2: Calls isAuthenticated() on**
security - ->> db : **3: select * from users where username = ?**\n//<size:12>[JDBC]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download dynamic diagram](dynamic.svg ':ignore')
-
-**Dynamic diagram**
-
-A simple dynamic diagram can be useful when you want to show how elements in a static model collaborate at runtime to implement a user story, use case, feature, etc. This dynamic diagram is based upon a UML communication diagram (previously known as a "UML collaboration diagram"). It is similar to a UML sequence diagram although it allows a free-form arrangement of diagram elements with numbered interactions to indicate ordering.
-
-**Scope**: An enterprise, software system or container.
-
-**Primary and supporting elements**: Depends on the diagram scope; enterprise (see System Landscape diagram), software system (see System Context or Container diagrams), container (see Component diagram).
-
-**Intended audience**: Technical and non-technical people, inside and outside of the software development team.
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.svg b/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.svg
deleted file mode 100644
index 993760c..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.svg
+++ /dev/null
@@ -1,341 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/Extended Docs/Extended Docs.pdf b/docs/1 Internet Banking System/Single Page Application/Extended Docs/Extended Docs.pdf
deleted file mode 100644
index eaabd3b..0000000
Binary files a/docs/1 Internet Banking System/Single Page Application/Extended Docs/Extended Docs.pdf and /dev/null differ
diff --git a/docs/1 Internet Banking System/Single Page Application/Extended Docs/HOME.md b/docs/1 Internet Banking System/Single Page Application/Extended Docs/HOME.md
deleted file mode 100644
index b0d2b2d..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Extended Docs/HOME.md
+++ /dev/null
@@ -1,19 +0,0 @@
-# Extended Docs
-
-
-![class](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="221px" preserveAspectRatio="none" style="width:395px;height:221px;background:#FFFFFF;" version="1.1" viewBox="0 0 395 221" width="395px" zoomAndPan="magnify"><defs/><g><!--MD5=[728d23d58e22fa55ea5a0544ed140874]
cluster net.dummy--><g id="cluster_net.dummy"><path d="M8.5,6 L85.5,6 A3.75,3.75 0 0 1 88,8.5 L95,29.6094 L117.5,29.6094 A2.5,2.5 0 0 1 120,32.1094 L120,211.5 A2.5,2.5 0 0 1 117.5,214 L8.5,214 A2.5,2.5 0 0 1 6,211.5 L6,8.5 A2.5,2.5 0 0 1 8.5,6 " fill="#DDDDDD" style="stroke:#000000;stroke-width:1.5;"/><line style="stroke:#000000;stroke-width:1.5;" x1="6" x2="95" y1="29.6094" y2="29.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="76" x="10" y="22.5332">net.dummy</text></g><!--MD5=[33e59a955278c32565a5bf6f302dc15e]
cluster net.foo--><g id="cluster_net.foo"><path d="M146.5,114 L197.5,114 A3.75,3.75 0 0 1 200,116.5 L207,137.6094 L251.5,137.6094 A2.5,2.5 0 0 1 254,140.1094 L254,211.5 A2.5,2.5 0 0 1 251.5,214 L146.5,214 A2.5,2.5 0 0 1 144,211.5 L144,116.5 A2.5,2.5 0 0 1 146.5,114 " style="stroke:#000000;stroke-width:1.5;fill:none;"/><line style="stroke:#000000;stroke-width:1.5;fill:none;" x1="144" x2="207" y1="137.6094" y2="137.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="50" x="148" y="130.5332">net.foo</text></g><!--MD5=[a192a6f29c441cea5ef200ac5f138a29]
cluster net.unused--><g id="cluster_net.unused"><path d="M280.5,114 L361.5,114 A3.75,3.75 0 0 1 364,116.5 L371,137.6094 L385.5,137.6094 A2.5,2.5 0 0 1 388,140.1094 L388,211.5 A2.5,2.5 0 0 1 385.5,214 L280.5,214 A2.5,2.5 0 0 1 278,211.5 L278,116.5 A2.5,2.5 0 0 1 280.5,114 " style="stroke:#000000;stroke-width:1.5;fill:none;"/><line style="stroke:#000000;stroke-width:1.5;fill:none;" x1="278" x2="371" y1="137.6094" y2="137.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="80" x="282" y="130.5332">net.unused</text></g><!--MD5=[cb3a15f9f15e1ea33d1c370015e332c8]
class net.dummy.Person--><g id="elem_net.dummy.Person"><rect fill="#F1F1F1" height="48" id="net.dummy.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="26.5" y="150"/><ellipse cx="41.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M44.2656,161.875 Q44.4219,161.6563 44.6094,161.5469 Q44.7969,161.4375 45.0156,161.4375 Q45.3906,161.4375 45.625,161.7031 Q45.8594,161.9531 45.8594,162.5625 L45.8594,164.0156 Q45.8594,164.625 45.625,164.8906 Q45.3906,165.1563 45.0156,165.1563 Q44.6719,165.1563 44.4688,164.9531 Q44.2656,164.7656 44.1563,164.25 Q44.1094,163.8906 43.9219,163.7031 Q43.5938,163.3281 42.9844,163.1094 Q42.375,162.8906 41.75,162.8906 Q40.9844,162.8906 40.3438,163.2188 Q39.7188,163.5469 39.2188,164.2969 Q38.7344,165.0469 38.7344,166.0781 L38.7344,167.1719 Q38.7344,168.4063 39.625,169.2344 Q40.5156,170.0469 42.1094,170.0469 Q43.0469,170.0469 43.7031,169.7969 Q44.0938,169.6406 44.5156,169.2031 Q44.7813,168.9375 44.9219,168.8594 Q45.0781,168.7813 45.2813,168.7813 Q45.6094,168.7813 45.8594,169.0469 Q46.125,169.2969 46.125,169.6406 Q46.125,169.9844 45.7813,170.3906 Q45.2813,170.9688 44.4844,171.2969 Q43.4063,171.75 42.1094,171.75 Q40.5938,171.75 39.3906,171.125 Q38.4063,170.625 37.7188,169.5625 Q37.0313,168.4844 37.0313,167.2031 L37.0313,166.0469 Q37.0313,164.7188 37.6406,163.5781 Q38.2656,162.4219 39.3594,161.8125 Q40.4531,161.1875 41.6875,161.1875 Q42.4219,161.1875 43.0625,161.3594 Q43.7188,161.5156 44.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="55.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="27.5" x2="102.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="27.5" x2="102.5" y1="190" y2="190"/></g><!--MD5=[8ac4e197c3b047d8b0ccbf03414837ae]
class net.dummy.Meeting--><g id="elem_net.dummy.Meeting"><rect fill="#F1F1F1" height="48" id="net.dummy.Meeting" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="82" x="22" y="42"/><ellipse cx="37" cy="58" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M39.7656,53.875 Q39.9219,53.6563 40.1094,53.5469 Q40.2969,53.4375 40.5156,53.4375 Q40.8906,53.4375 41.125,53.7031 Q41.3594,53.9531 41.3594,54.5625 L41.3594,56.0156 Q41.3594,56.625 41.125,56.8906 Q40.8906,57.1563 40.5156,57.1563 Q40.1719,57.1563 39.9688,56.9531 Q39.7656,56.7656 39.6563,56.25 Q39.6094,55.8906 39.4219,55.7031 Q39.0938,55.3281 38.4844,55.1094 Q37.875,54.8906 37.25,54.8906 Q36.4844,54.8906 35.8438,55.2188 Q35.2188,55.5469 34.7188,56.2969 Q34.2344,57.0469 34.2344,58.0781 L34.2344,59.1719 Q34.2344,60.4063 35.125,61.2344 Q36.0156,62.0469 37.6094,62.0469 Q38.5469,62.0469 39.2031,61.7969 Q39.5938,61.6406 40.0156,61.2031 Q40.2813,60.9375 40.4219,60.8594 Q40.5781,60.7813 40.7813,60.7813 Q41.1094,60.7813 41.3594,61.0469 Q41.625,61.2969 41.625,61.6406 Q41.625,61.9844 41.2813,62.3906 Q40.7813,62.9688 39.9844,63.2969 Q38.9063,63.75 37.6094,63.75 Q36.0938,63.75 34.8906,63.125 Q33.9063,62.625 33.2188,61.5625 Q32.5313,60.4844 32.5313,59.2031 L32.5313,58.0469 Q32.5313,56.7188 33.1406,55.5781 Q33.7656,54.4219 34.8594,53.8125 Q35.9531,53.1875 37.1875,53.1875 Q37.9219,53.1875 38.5625,53.3594 Q39.2188,53.5156 39.7656,53.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="51" y="63.7285">Meeting</text><line style="stroke:#181818;stroke-width:0.5;" x1="23" x2="103" y1="74" y2="74"/><line style="stroke:#181818;stroke-width:0.5;" x1="23" x2="103" y1="82" y2="82"/></g><!--MD5=[39b7869a7bbdf1e166c12fc90d8f21cb]
class net.foo.Person--><g id="elem_net.foo.Person"><rect fill="#F1F1F1" height="48" id="net.foo.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="160.5" y="150"/><ellipse cx="175.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M178.2656,161.875 Q178.4219,161.6563 178.6094,161.5469 Q178.7969,161.4375 179.0156,161.4375 Q179.3906,161.4375 179.625,161.7031 Q179.8594,161.9531 179.8594,162.5625 L179.8594,164.0156 Q179.8594,164.625 179.625,164.8906 Q179.3906,165.1563 179.0156,165.1563 Q178.6719,165.1563 178.4688,164.9531 Q178.2656,164.7656 178.1563,164.25 Q178.1094,163.8906 177.9219,163.7031 Q177.5938,163.3281 176.9844,163.1094 Q176.375,162.8906 175.75,162.8906 Q174.9844,162.8906 174.3438,163.2188 Q173.7188,163.5469 173.2188,164.2969 Q172.7344,165.0469 172.7344,166.0781 L172.7344,167.1719 Q172.7344,168.4063 173.625,169.2344 Q174.5156,170.0469 176.1094,170.0469 Q177.0469,170.0469 177.7031,169.7969 Q178.0938,169.6406 178.5156,169.2031 Q178.7813,168.9375 178.9219,168.8594 Q179.0781,168.7813 179.2813,168.7813 Q179.6094,168.7813 179.8594,169.0469 Q180.125,169.2969 180.125,169.6406 Q180.125,169.9844 179.7813,170.3906 Q179.2813,170.9688 178.4844,171.2969 Q177.4063,171.75 176.1094,171.75 Q174.5938,171.75 173.3906,171.125 Q172.4063,170.625 171.7188,169.5625 Q171.0313,168.4844 171.0313,167.2031 L171.0313,166.0469 Q171.0313,164.7188 171.6406,163.5781 Q172.2656,162.4219 173.3594,161.8125 Q174.4531,161.1875 175.6875,161.1875 Q176.4219,161.1875 177.0625,161.3594 Q177.7188,161.5156 178.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="189.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="161.5" x2="236.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="161.5" x2="236.5" y1="190" y2="190"/></g><!--MD5=[5f30d223f747d8ac33b5eb84f5743c2a]
class net.unused.Person--><g id="elem_net.unused.Person"><rect fill="#F1F1F1" height="48" id="net.unused.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="294.5" y="150"/><ellipse cx="309.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M312.2656,161.875 Q312.4219,161.6563 312.6094,161.5469 Q312.7969,161.4375 313.0156,161.4375 Q313.3906,161.4375 313.625,161.7031 Q313.8594,161.9531 313.8594,162.5625 L313.8594,164.0156 Q313.8594,164.625 313.625,164.8906 Q313.3906,165.1563 313.0156,165.1563 Q312.6719,165.1563 312.4688,164.9531 Q312.2656,164.7656 312.1563,164.25 Q312.1094,163.8906 311.9219,163.7031 Q311.5938,163.3281 310.9844,163.1094 Q310.375,162.8906 309.75,162.8906 Q308.9844,162.8906 308.3438,163.2188 Q307.7188,163.5469 307.2188,164.2969 Q306.7344,165.0469 306.7344,166.0781 L306.7344,167.1719 Q306.7344,168.4063 307.625,169.2344 Q308.5156,170.0469 310.1094,170.0469 Q311.0469,170.0469 311.7031,169.7969 Q312.0938,169.6406 312.5156,169.2031 Q312.7813,168.9375 312.9219,168.8594 Q313.0781,168.7813 313.2813,168.7813 Q313.6094,168.7813 313.8594,169.0469 Q314.125,169.2969 314.125,169.6406 Q314.125,169.9844 313.7813,170.3906 Q313.2813,170.9688 312.4844,171.2969 Q311.4063,171.75 310.1094,171.75 Q308.5938,171.75 307.3906,171.125 Q306.4063,170.625 305.7188,169.5625 Q305.0313,168.4844 305.0313,167.2031 L305.0313,166.0469 Q305.0313,164.7188 305.6406,163.5781 Q306.2656,162.4219 307.3594,161.8125 Q308.4531,161.1875 309.6875,161.1875 Q310.4219,161.1875 311.0625,161.3594 Q311.7188,161.5156 312.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="323.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="295.5" x2="370.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="295.5" x2="370.5" y1="190" y2="190"/></g><!--MD5=[8e57f1f895cc705ad5645d1ac73dc0a2]
class BaseClass--><g id="elem_BaseClass"><rect codeLine="7" fill="#F1F1F1" height="48" id="BaseClass" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="99" x="144.5" y="42"/><ellipse cx="159.5" cy="58" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M162.2656,53.875 Q162.4219,53.6563 162.6094,53.5469 Q162.7969,53.4375 163.0156,53.4375 Q163.3906,53.4375 163.625,53.7031 Q163.8594,53.9531 163.8594,54.5625 L163.8594,56.0156 Q163.8594,56.625 163.625,56.8906 Q163.3906,57.1563 163.0156,57.1563 Q162.6719,57.1563 162.4688,56.9531 Q162.2656,56.7656 162.1563,56.25 Q162.1094,55.8906 161.9219,55.7031 Q161.5938,55.3281 160.9844,55.1094 Q160.375,54.8906 159.75,54.8906 Q158.9844,54.8906 158.3438,55.2188 Q157.7188,55.5469 157.2188,56.2969 Q156.7344,57.0469 156.7344,58.0781 L156.7344,59.1719 Q156.7344,60.4063 157.625,61.2344 Q158.5156,62.0469 160.1094,62.0469 Q161.0469,62.0469 161.7031,61.7969 Q162.0938,61.6406 162.5156,61.2031 Q162.7813,60.9375 162.9219,60.8594 Q163.0781,60.7813 163.2813,60.7813 Q163.6094,60.7813 163.8594,61.0469 Q164.125,61.2969 164.125,61.6406 Q164.125,61.9844 163.7813,62.3906 Q163.2813,62.9688 162.4844,63.2969 Q161.4063,63.75 160.1094,63.75 Q158.5938,63.75 157.3906,63.125 Q156.4063,62.625 155.7188,61.5625 Q155.0313,60.4844 155.0313,59.2031 L155.0313,58.0469 Q155.0313,56.7188 155.6406,55.5781 Q156.2656,54.4219 157.3594,53.8125 Q158.4531,53.1875 159.6875,53.1875 Q160.4219,53.1875 161.0625,53.3594 Q161.7188,53.5156 162.2656,53.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="67" x="173.5" y="63.7285">BaseClass</text><line style="stroke:#181818;stroke-width:0.5;" x1="145.5" x2="242.5" y1="74" y2="74"/><line style="stroke:#181818;stroke-width:0.5;" x1="145.5" x2="242.5" y1="82" y2="82"/></g><!--MD5=[38d283ab138c7dee77115f9fbc859330]
reverse link BaseClass to net.dummy.Person--><g id="link_BaseClass_net.dummy.Person"><path codeLine="10" d="M148.27,102.54 C146.83,103.71 145.4,104.86 144,106 C126.42,120.3 107.01,136.75 91.83,149.78 " fill="none" id="BaseClass-backto-net.dummy.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="143.94,97.04,163.97,90.11,152.64,108.01,143.94,97.04" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3aad075c01a5f1f4921d0fd2481fc4e0]
reverse link net.dummy.Meeting to net.dummy.Person--><g id="link_net.dummy.Meeting_net.dummy.Person"><path codeLine="11" d="M63.69,103.34 C63.98,118.68 64.3,136.1 64.56,149.68 " fill="none" id="net.dummy.Meeting-backto-net.dummy.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="63.43,90,59.5428,96.0737,63.6541,101.9979,67.5414,95.9242,63.43,90" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[5b94dd299fdb64f5042d8ccdd246a8aa]
reverse link BaseClass to net.dummy.Meeting--><g id="link_BaseClass_net.dummy.Meeting"><path codeLine="13" d="M123.88,66 C117.32,66 110.75,66 104.19,66 " fill="none" id="BaseClass-backto-net.dummy.Meeting" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="124.19,59,144.19,66,124.19,73,124.19,59" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[b57b6e1cdce0b532ba1371e9c7d07ce1]
reverse link net.dummy.Person to net.foo.Person--><g id="link_net.dummy.Person_net.foo.Person"><path codeLine="18" d="M124.06,174 C136.14,174 148.22,174 160.3,174 " fill="none" id="net.dummy.Person-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="123.73,181,103.73,174,123.73,167,123.73,181" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3949315fc233572465e48cd9e3f6e864]
reverse link BaseClass to net.foo.Person--><g id="link_BaseClass_net.foo.Person"><path codeLine="19" d="M196.03,110.02 C196.67,123.58 197.35,138.04 197.9,149.68 " fill="none" id="BaseClass-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="189.04,110.31,195.08,90,203.02,109.65,189.04,110.31" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[736f19012fcb2f75c0b04526aeb93c2d]
reverse link net.dummy.Meeting to net.foo.Person--><g id="link_net.dummy.Meeting_net.foo.Person"><path codeLine="21" d="M108.83,97.74 C112.65,100.49 116.41,103.26 120,106 C138.3,119.96 158.05,136.71 173.23,149.97 " fill="none" id="net.dummy.Meeting-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="98.07,90.16,100.6619,96.8892,107.8703,97.0849,105.2784,90.3557,98.07,90.16" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[20bb99b6116bfc237a0342da45d84df8]
reverse link BaseClass to net.unused.Person--><g id="link_BaseClass_net.unused.Person"><path codeLine="24" d="M248.15,101.74 C250.14,103.16 252.09,104.58 254,106 C272.47,119.74 292.22,136.49 307.35,149.81 " fill="none" id="BaseClass-backto-net.unused.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="243.86,107.28,231.31,90.2,251.77,95.73,243.86,107.28" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3e360cf55433805d5b9245322ea53bd9]
@startuml
' Split into 4 pages
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

class BaseClass

namespace net.dummy #DDDDDD {
	.BaseClass <|- - Person
	Meeting o- - Person
	
	.BaseClass <|- Meeting

}

namespace net.foo {
  net.dummy.Person  <|- Person
  .BaseClass <|- - Person

  net.dummy.Meeting o- - Person
}

BaseClass <|- - net.unused.Person
@enduml

@startuml
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

class BaseClass

namespace net.dummy #DDDDDD {
	.BaseClass <|- - Person
	Meeting o- - Person
	
	.BaseClass <|- Meeting

}

namespace net.foo {
  net.dummy.Person  <|- Person
  .BaseClass <|- - Person

  net.dummy.Meeting o- - Person
}

BaseClass <|- - net.unused.Person
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download class diagram](class.svg ':ignore')
-
-
-![sequence](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="276px" preserveAspectRatio="none" style="width:363px;height:276px;background:#FFFFFF;" version="1.1" viewBox="0 0 363 276" width="363px" zoomAndPan="magnify"><defs/><g><rect fill="#FFFFFF" height="151.7578" style="stroke:#181818;stroke-width:1.0;" width="10" x="92.5" y="69.9609"/><rect fill="#FFFFFF" height="91.0547" style="stroke:#181818;stroke-width:1.0;" width="10" x="245.5" y="100.3125"/><rect fill="#FFFFFF" height="30.3516" style="stroke:#181818;stroke-width:1.0;" width="10" x="340.5" y="130.6641"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="26" x2="26" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="97" x2="97" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="250" x2="250" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="345.5" x2="345.5" y1="37.6094" y2="239.7188"/><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="43" x="5" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="29" x="12" y="26.5332">User</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="43" x="5" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="29" x="12" y="260.252">User</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="86" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="93" y="26.5332">A</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="86" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="93" y="260.252">A</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="239" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="246" y="26.5332">B</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="239" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="246" y="260.252">B</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="24" x="333.5" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="10" x="340.5" y="26.5332">C</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="24" x="333.5" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="10" x="340.5" y="260.252">C</text><rect fill="#FFFFFF" height="151.7578" style="stroke:#181818;stroke-width:1.0;" width="10" x="92.5" y="69.9609"/><rect fill="#FFFFFF" height="91.0547" style="stroke:#181818;stroke-width:1.0;" width="10" x="245.5" y="100.3125"/><rect fill="#FFFFFF" height="30.3516" style="stroke:#181818;stroke-width:1.0;" width="10" x="340.5" y="130.6641"/><polygon fill="#181818" points="80.5,65.9609,90.5,69.9609,80.5,73.9609,84.5,69.9609" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="26.5" x2="86.5" y1="69.9609" y2="69.9609"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="47" x="33.5" y="65.1045">DoWork</text><polygon fill="#181818" points="233.5,96.3125,243.5,100.3125,233.5,104.3125,237.5,100.3125" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="102.5" x2="239.5" y1="100.3125" y2="100.3125"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="124" x="109.5" y="95.4561">&lt;&lt; createRequest &gt;&gt;</text><polygon fill="#181818" points="328.5,126.6641,338.5,130.6641,328.5,134.6641,332.5,130.6641" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="255.5" x2="334.5" y1="130.6641" y2="130.6641"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="47" x="262.5" y="125.8076">DoWork</text><polygon fill="#181818" points="266.5,157.0156,256.5,161.0156,266.5,165.0156,262.5,161.0156" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;stroke-dasharray:2.0,2.0;" x1="260.5" x2="344.5" y1="161.0156" y2="161.0156"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="61" x="272.5" y="156.1592">WorkDone</text><line style="stroke:#A80036;stroke-width:2.0;" x1="336.5" x2="354.5" y1="152.0156" y2="170.0156"/><line style="stroke:#A80036;stroke-width:2.0;" x1="336.5" x2="354.5" y1="170.0156" y2="152.0156"/><polygon fill="#181818" points="113.5,187.3672,103.5,191.3672,113.5,195.3672,109.5,191.3672" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;stroke-dasharray:2.0,2.0;" x1="107.5" x2="249.5" y1="191.3672" y2="191.3672"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="93" x="119.5" y="186.5107">RequestCreated</text><polygon fill="#181818" points="37.5,217.7188,27.5,221.7188,37.5,225.7188,33.5,221.7188" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="31.5" x2="96.5" y1="221.7188" y2="221.7188"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="30" x="43.5" y="216.8623">Done</text><!--MD5=[5f53e077a3b738dee8ed05af6f972a22]
@startuml
participant User

User -> A: DoWork
activate A

A -> B: << createRequest >>
activate B

B -> C: DoWork
activate C
C - -> B: WorkDone
destroy C

B - -> A: RequestCreated
deactivate B

A -> User: Done
deactivate A

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download sequence diagram](sequence.svg ':ignore')
-
-Multiple markdowns can be ordered using `.1.md, .2.md .. ..md`
-
-You can choose where to place a certain diagram by using `![name](.puml)`
-
-
-![ditaa](data:image/png;base64,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)
-[Download ditaa diagram](ditaa.png ':ignore')
-
-Feel free to add any additional details necesary.
diff --git a/docs/1 Internet Banking System/Single Page Application/Extended Docs/README.md b/docs/1 Internet Banking System/Single Page Application/Extended Docs/README.md
deleted file mode 100644
index b49ae34..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Extended Docs/README.md
+++ /dev/null
@@ -1,35 +0,0 @@
-# Extended Docs
-
-`\1 Internet Banking System\Single Page Application\Extended Docs`
-
-* [PySocial Project](../../../README.md)
- * [1 Internet Banking System](../../../1%20Internet%20Banking%20System/README.md)
- * [API Application](../../../1%20Internet%20Banking%20System/API%20Application/README.md)
- * [Single Page Application](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [Dynamic Diagram](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [**Extended Docs**](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [2 Deployment](../../../2%20Deployment/README.md)
-
----
-
-[Single Page Application (up)](../../../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
-
----
-
-
-![class](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="221px" preserveAspectRatio="none" style="width:395px;height:221px;background:#FFFFFF;" version="1.1" viewBox="0 0 395 221" width="395px" zoomAndPan="magnify"><defs/><g><!--MD5=[728d23d58e22fa55ea5a0544ed140874]
cluster net.dummy--><g id="cluster_net.dummy"><path d="M8.5,6 L85.5,6 A3.75,3.75 0 0 1 88,8.5 L95,29.6094 L117.5,29.6094 A2.5,2.5 0 0 1 120,32.1094 L120,211.5 A2.5,2.5 0 0 1 117.5,214 L8.5,214 A2.5,2.5 0 0 1 6,211.5 L6,8.5 A2.5,2.5 0 0 1 8.5,6 " fill="#DDDDDD" style="stroke:#000000;stroke-width:1.5;"/><line style="stroke:#000000;stroke-width:1.5;" x1="6" x2="95" y1="29.6094" y2="29.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="76" x="10" y="22.5332">net.dummy</text></g><!--MD5=[33e59a955278c32565a5bf6f302dc15e]
cluster net.foo--><g id="cluster_net.foo"><path d="M146.5,114 L197.5,114 A3.75,3.75 0 0 1 200,116.5 L207,137.6094 L251.5,137.6094 A2.5,2.5 0 0 1 254,140.1094 L254,211.5 A2.5,2.5 0 0 1 251.5,214 L146.5,214 A2.5,2.5 0 0 1 144,211.5 L144,116.5 A2.5,2.5 0 0 1 146.5,114 " style="stroke:#000000;stroke-width:1.5;fill:none;"/><line style="stroke:#000000;stroke-width:1.5;fill:none;" x1="144" x2="207" y1="137.6094" y2="137.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="50" x="148" y="130.5332">net.foo</text></g><!--MD5=[a192a6f29c441cea5ef200ac5f138a29]
cluster net.unused--><g id="cluster_net.unused"><path d="M280.5,114 L361.5,114 A3.75,3.75 0 0 1 364,116.5 L371,137.6094 L385.5,137.6094 A2.5,2.5 0 0 1 388,140.1094 L388,211.5 A2.5,2.5 0 0 1 385.5,214 L280.5,214 A2.5,2.5 0 0 1 278,211.5 L278,116.5 A2.5,2.5 0 0 1 280.5,114 " style="stroke:#000000;stroke-width:1.5;fill:none;"/><line style="stroke:#000000;stroke-width:1.5;fill:none;" x1="278" x2="371" y1="137.6094" y2="137.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="80" x="282" y="130.5332">net.unused</text></g><!--MD5=[cb3a15f9f15e1ea33d1c370015e332c8]
class net.dummy.Person--><g id="elem_net.dummy.Person"><rect fill="#F1F1F1" height="48" id="net.dummy.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="26.5" y="150"/><ellipse cx="41.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M44.2656,161.875 Q44.4219,161.6563 44.6094,161.5469 Q44.7969,161.4375 45.0156,161.4375 Q45.3906,161.4375 45.625,161.7031 Q45.8594,161.9531 45.8594,162.5625 L45.8594,164.0156 Q45.8594,164.625 45.625,164.8906 Q45.3906,165.1563 45.0156,165.1563 Q44.6719,165.1563 44.4688,164.9531 Q44.2656,164.7656 44.1563,164.25 Q44.1094,163.8906 43.9219,163.7031 Q43.5938,163.3281 42.9844,163.1094 Q42.375,162.8906 41.75,162.8906 Q40.9844,162.8906 40.3438,163.2188 Q39.7188,163.5469 39.2188,164.2969 Q38.7344,165.0469 38.7344,166.0781 L38.7344,167.1719 Q38.7344,168.4063 39.625,169.2344 Q40.5156,170.0469 42.1094,170.0469 Q43.0469,170.0469 43.7031,169.7969 Q44.0938,169.6406 44.5156,169.2031 Q44.7813,168.9375 44.9219,168.8594 Q45.0781,168.7813 45.2813,168.7813 Q45.6094,168.7813 45.8594,169.0469 Q46.125,169.2969 46.125,169.6406 Q46.125,169.9844 45.7813,170.3906 Q45.2813,170.9688 44.4844,171.2969 Q43.4063,171.75 42.1094,171.75 Q40.5938,171.75 39.3906,171.125 Q38.4063,170.625 37.7188,169.5625 Q37.0313,168.4844 37.0313,167.2031 L37.0313,166.0469 Q37.0313,164.7188 37.6406,163.5781 Q38.2656,162.4219 39.3594,161.8125 Q40.4531,161.1875 41.6875,161.1875 Q42.4219,161.1875 43.0625,161.3594 Q43.7188,161.5156 44.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="55.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="27.5" x2="102.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="27.5" x2="102.5" y1="190" y2="190"/></g><!--MD5=[8ac4e197c3b047d8b0ccbf03414837ae]
class net.dummy.Meeting--><g id="elem_net.dummy.Meeting"><rect fill="#F1F1F1" height="48" id="net.dummy.Meeting" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="82" x="22" y="42"/><ellipse cx="37" cy="58" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M39.7656,53.875 Q39.9219,53.6563 40.1094,53.5469 Q40.2969,53.4375 40.5156,53.4375 Q40.8906,53.4375 41.125,53.7031 Q41.3594,53.9531 41.3594,54.5625 L41.3594,56.0156 Q41.3594,56.625 41.125,56.8906 Q40.8906,57.1563 40.5156,57.1563 Q40.1719,57.1563 39.9688,56.9531 Q39.7656,56.7656 39.6563,56.25 Q39.6094,55.8906 39.4219,55.7031 Q39.0938,55.3281 38.4844,55.1094 Q37.875,54.8906 37.25,54.8906 Q36.4844,54.8906 35.8438,55.2188 Q35.2188,55.5469 34.7188,56.2969 Q34.2344,57.0469 34.2344,58.0781 L34.2344,59.1719 Q34.2344,60.4063 35.125,61.2344 Q36.0156,62.0469 37.6094,62.0469 Q38.5469,62.0469 39.2031,61.7969 Q39.5938,61.6406 40.0156,61.2031 Q40.2813,60.9375 40.4219,60.8594 Q40.5781,60.7813 40.7813,60.7813 Q41.1094,60.7813 41.3594,61.0469 Q41.625,61.2969 41.625,61.6406 Q41.625,61.9844 41.2813,62.3906 Q40.7813,62.9688 39.9844,63.2969 Q38.9063,63.75 37.6094,63.75 Q36.0938,63.75 34.8906,63.125 Q33.9063,62.625 33.2188,61.5625 Q32.5313,60.4844 32.5313,59.2031 L32.5313,58.0469 Q32.5313,56.7188 33.1406,55.5781 Q33.7656,54.4219 34.8594,53.8125 Q35.9531,53.1875 37.1875,53.1875 Q37.9219,53.1875 38.5625,53.3594 Q39.2188,53.5156 39.7656,53.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="51" y="63.7285">Meeting</text><line style="stroke:#181818;stroke-width:0.5;" x1="23" x2="103" y1="74" y2="74"/><line style="stroke:#181818;stroke-width:0.5;" x1="23" x2="103" y1="82" y2="82"/></g><!--MD5=[39b7869a7bbdf1e166c12fc90d8f21cb]
class net.foo.Person--><g id="elem_net.foo.Person"><rect fill="#F1F1F1" height="48" id="net.foo.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="160.5" y="150"/><ellipse cx="175.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M178.2656,161.875 Q178.4219,161.6563 178.6094,161.5469 Q178.7969,161.4375 179.0156,161.4375 Q179.3906,161.4375 179.625,161.7031 Q179.8594,161.9531 179.8594,162.5625 L179.8594,164.0156 Q179.8594,164.625 179.625,164.8906 Q179.3906,165.1563 179.0156,165.1563 Q178.6719,165.1563 178.4688,164.9531 Q178.2656,164.7656 178.1563,164.25 Q178.1094,163.8906 177.9219,163.7031 Q177.5938,163.3281 176.9844,163.1094 Q176.375,162.8906 175.75,162.8906 Q174.9844,162.8906 174.3438,163.2188 Q173.7188,163.5469 173.2188,164.2969 Q172.7344,165.0469 172.7344,166.0781 L172.7344,167.1719 Q172.7344,168.4063 173.625,169.2344 Q174.5156,170.0469 176.1094,170.0469 Q177.0469,170.0469 177.7031,169.7969 Q178.0938,169.6406 178.5156,169.2031 Q178.7813,168.9375 178.9219,168.8594 Q179.0781,168.7813 179.2813,168.7813 Q179.6094,168.7813 179.8594,169.0469 Q180.125,169.2969 180.125,169.6406 Q180.125,169.9844 179.7813,170.3906 Q179.2813,170.9688 178.4844,171.2969 Q177.4063,171.75 176.1094,171.75 Q174.5938,171.75 173.3906,171.125 Q172.4063,170.625 171.7188,169.5625 Q171.0313,168.4844 171.0313,167.2031 L171.0313,166.0469 Q171.0313,164.7188 171.6406,163.5781 Q172.2656,162.4219 173.3594,161.8125 Q174.4531,161.1875 175.6875,161.1875 Q176.4219,161.1875 177.0625,161.3594 Q177.7188,161.5156 178.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="189.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="161.5" x2="236.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="161.5" x2="236.5" y1="190" y2="190"/></g><!--MD5=[5f30d223f747d8ac33b5eb84f5743c2a]
class net.unused.Person--><g id="elem_net.unused.Person"><rect fill="#F1F1F1" height="48" id="net.unused.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="294.5" y="150"/><ellipse cx="309.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M312.2656,161.875 Q312.4219,161.6563 312.6094,161.5469 Q312.7969,161.4375 313.0156,161.4375 Q313.3906,161.4375 313.625,161.7031 Q313.8594,161.9531 313.8594,162.5625 L313.8594,164.0156 Q313.8594,164.625 313.625,164.8906 Q313.3906,165.1563 313.0156,165.1563 Q312.6719,165.1563 312.4688,164.9531 Q312.2656,164.7656 312.1563,164.25 Q312.1094,163.8906 311.9219,163.7031 Q311.5938,163.3281 310.9844,163.1094 Q310.375,162.8906 309.75,162.8906 Q308.9844,162.8906 308.3438,163.2188 Q307.7188,163.5469 307.2188,164.2969 Q306.7344,165.0469 306.7344,166.0781 L306.7344,167.1719 Q306.7344,168.4063 307.625,169.2344 Q308.5156,170.0469 310.1094,170.0469 Q311.0469,170.0469 311.7031,169.7969 Q312.0938,169.6406 312.5156,169.2031 Q312.7813,168.9375 312.9219,168.8594 Q313.0781,168.7813 313.2813,168.7813 Q313.6094,168.7813 313.8594,169.0469 Q314.125,169.2969 314.125,169.6406 Q314.125,169.9844 313.7813,170.3906 Q313.2813,170.9688 312.4844,171.2969 Q311.4063,171.75 310.1094,171.75 Q308.5938,171.75 307.3906,171.125 Q306.4063,170.625 305.7188,169.5625 Q305.0313,168.4844 305.0313,167.2031 L305.0313,166.0469 Q305.0313,164.7188 305.6406,163.5781 Q306.2656,162.4219 307.3594,161.8125 Q308.4531,161.1875 309.6875,161.1875 Q310.4219,161.1875 311.0625,161.3594 Q311.7188,161.5156 312.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="323.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="295.5" x2="370.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="295.5" x2="370.5" y1="190" y2="190"/></g><!--MD5=[8e57f1f895cc705ad5645d1ac73dc0a2]
class BaseClass--><g id="elem_BaseClass"><rect codeLine="7" fill="#F1F1F1" height="48" id="BaseClass" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="99" x="144.5" y="42"/><ellipse cx="159.5" cy="58" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M162.2656,53.875 Q162.4219,53.6563 162.6094,53.5469 Q162.7969,53.4375 163.0156,53.4375 Q163.3906,53.4375 163.625,53.7031 Q163.8594,53.9531 163.8594,54.5625 L163.8594,56.0156 Q163.8594,56.625 163.625,56.8906 Q163.3906,57.1563 163.0156,57.1563 Q162.6719,57.1563 162.4688,56.9531 Q162.2656,56.7656 162.1563,56.25 Q162.1094,55.8906 161.9219,55.7031 Q161.5938,55.3281 160.9844,55.1094 Q160.375,54.8906 159.75,54.8906 Q158.9844,54.8906 158.3438,55.2188 Q157.7188,55.5469 157.2188,56.2969 Q156.7344,57.0469 156.7344,58.0781 L156.7344,59.1719 Q156.7344,60.4063 157.625,61.2344 Q158.5156,62.0469 160.1094,62.0469 Q161.0469,62.0469 161.7031,61.7969 Q162.0938,61.6406 162.5156,61.2031 Q162.7813,60.9375 162.9219,60.8594 Q163.0781,60.7813 163.2813,60.7813 Q163.6094,60.7813 163.8594,61.0469 Q164.125,61.2969 164.125,61.6406 Q164.125,61.9844 163.7813,62.3906 Q163.2813,62.9688 162.4844,63.2969 Q161.4063,63.75 160.1094,63.75 Q158.5938,63.75 157.3906,63.125 Q156.4063,62.625 155.7188,61.5625 Q155.0313,60.4844 155.0313,59.2031 L155.0313,58.0469 Q155.0313,56.7188 155.6406,55.5781 Q156.2656,54.4219 157.3594,53.8125 Q158.4531,53.1875 159.6875,53.1875 Q160.4219,53.1875 161.0625,53.3594 Q161.7188,53.5156 162.2656,53.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="67" x="173.5" y="63.7285">BaseClass</text><line style="stroke:#181818;stroke-width:0.5;" x1="145.5" x2="242.5" y1="74" y2="74"/><line style="stroke:#181818;stroke-width:0.5;" x1="145.5" x2="242.5" y1="82" y2="82"/></g><!--MD5=[38d283ab138c7dee77115f9fbc859330]
reverse link BaseClass to net.dummy.Person--><g id="link_BaseClass_net.dummy.Person"><path codeLine="10" d="M148.27,102.54 C146.83,103.71 145.4,104.86 144,106 C126.42,120.3 107.01,136.75 91.83,149.78 " fill="none" id="BaseClass-backto-net.dummy.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="143.94,97.04,163.97,90.11,152.64,108.01,143.94,97.04" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3aad075c01a5f1f4921d0fd2481fc4e0]
reverse link net.dummy.Meeting to net.dummy.Person--><g id="link_net.dummy.Meeting_net.dummy.Person"><path codeLine="11" d="M63.69,103.34 C63.98,118.68 64.3,136.1 64.56,149.68 " fill="none" id="net.dummy.Meeting-backto-net.dummy.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="63.43,90,59.5428,96.0737,63.6541,101.9979,67.5414,95.9242,63.43,90" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[5b94dd299fdb64f5042d8ccdd246a8aa]
reverse link BaseClass to net.dummy.Meeting--><g id="link_BaseClass_net.dummy.Meeting"><path codeLine="13" d="M123.88,66 C117.32,66 110.75,66 104.19,66 " fill="none" id="BaseClass-backto-net.dummy.Meeting" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="124.19,59,144.19,66,124.19,73,124.19,59" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[b57b6e1cdce0b532ba1371e9c7d07ce1]
reverse link net.dummy.Person to net.foo.Person--><g id="link_net.dummy.Person_net.foo.Person"><path codeLine="18" d="M124.06,174 C136.14,174 148.22,174 160.3,174 " fill="none" id="net.dummy.Person-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="123.73,181,103.73,174,123.73,167,123.73,181" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3949315fc233572465e48cd9e3f6e864]
reverse link BaseClass to net.foo.Person--><g id="link_BaseClass_net.foo.Person"><path codeLine="19" d="M196.03,110.02 C196.67,123.58 197.35,138.04 197.9,149.68 " fill="none" id="BaseClass-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="189.04,110.31,195.08,90,203.02,109.65,189.04,110.31" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[736f19012fcb2f75c0b04526aeb93c2d]
reverse link net.dummy.Meeting to net.foo.Person--><g id="link_net.dummy.Meeting_net.foo.Person"><path codeLine="21" d="M108.83,97.74 C112.65,100.49 116.41,103.26 120,106 C138.3,119.96 158.05,136.71 173.23,149.97 " fill="none" id="net.dummy.Meeting-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="98.07,90.16,100.6619,96.8892,107.8703,97.0849,105.2784,90.3557,98.07,90.16" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[20bb99b6116bfc237a0342da45d84df8]
reverse link BaseClass to net.unused.Person--><g id="link_BaseClass_net.unused.Person"><path codeLine="24" d="M248.15,101.74 C250.14,103.16 252.09,104.58 254,106 C272.47,119.74 292.22,136.49 307.35,149.81 " fill="none" id="BaseClass-backto-net.unused.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="243.86,107.28,231.31,90.2,251.77,95.73,243.86,107.28" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3e360cf55433805d5b9245322ea53bd9]
@startuml
' Split into 4 pages
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

class BaseClass

namespace net.dummy #DDDDDD {
	.BaseClass <|- - Person
	Meeting o- - Person
	
	.BaseClass <|- Meeting

}

namespace net.foo {
  net.dummy.Person  <|- Person
  .BaseClass <|- - Person

  net.dummy.Meeting o- - Person
}

BaseClass <|- - net.unused.Person
@enduml

@startuml
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

class BaseClass

namespace net.dummy #DDDDDD {
	.BaseClass <|- - Person
	Meeting o- - Person
	
	.BaseClass <|- Meeting

}

namespace net.foo {
  net.dummy.Person  <|- Person
  .BaseClass <|- - Person

  net.dummy.Meeting o- - Person
}

BaseClass <|- - net.unused.Person
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download class diagram](class.svg ':ignore')
-
-
-![sequence](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="276px" preserveAspectRatio="none" style="width:363px;height:276px;background:#FFFFFF;" version="1.1" viewBox="0 0 363 276" width="363px" zoomAndPan="magnify"><defs/><g><rect fill="#FFFFFF" height="151.7578" style="stroke:#181818;stroke-width:1.0;" width="10" x="92.5" y="69.9609"/><rect fill="#FFFFFF" height="91.0547" style="stroke:#181818;stroke-width:1.0;" width="10" x="245.5" y="100.3125"/><rect fill="#FFFFFF" height="30.3516" style="stroke:#181818;stroke-width:1.0;" width="10" x="340.5" y="130.6641"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="26" x2="26" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="97" x2="97" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="250" x2="250" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="345.5" x2="345.5" y1="37.6094" y2="239.7188"/><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="43" x="5" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="29" x="12" y="26.5332">User</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="43" x="5" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="29" x="12" y="260.252">User</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="86" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="93" y="26.5332">A</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="86" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="93" y="260.252">A</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="239" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="246" y="26.5332">B</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="239" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="246" y="260.252">B</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="24" x="333.5" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="10" x="340.5" y="26.5332">C</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="24" x="333.5" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="10" x="340.5" y="260.252">C</text><rect fill="#FFFFFF" height="151.7578" style="stroke:#181818;stroke-width:1.0;" width="10" x="92.5" y="69.9609"/><rect fill="#FFFFFF" height="91.0547" style="stroke:#181818;stroke-width:1.0;" width="10" x="245.5" y="100.3125"/><rect fill="#FFFFFF" height="30.3516" style="stroke:#181818;stroke-width:1.0;" width="10" x="340.5" y="130.6641"/><polygon fill="#181818" points="80.5,65.9609,90.5,69.9609,80.5,73.9609,84.5,69.9609" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="26.5" x2="86.5" y1="69.9609" y2="69.9609"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="47" x="33.5" y="65.1045">DoWork</text><polygon fill="#181818" points="233.5,96.3125,243.5,100.3125,233.5,104.3125,237.5,100.3125" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="102.5" x2="239.5" y1="100.3125" y2="100.3125"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="124" x="109.5" y="95.4561">&lt;&lt; createRequest &gt;&gt;</text><polygon fill="#181818" points="328.5,126.6641,338.5,130.6641,328.5,134.6641,332.5,130.6641" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="255.5" x2="334.5" y1="130.6641" y2="130.6641"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="47" x="262.5" y="125.8076">DoWork</text><polygon fill="#181818" points="266.5,157.0156,256.5,161.0156,266.5,165.0156,262.5,161.0156" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;stroke-dasharray:2.0,2.0;" x1="260.5" x2="344.5" y1="161.0156" y2="161.0156"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="61" x="272.5" y="156.1592">WorkDone</text><line style="stroke:#A80036;stroke-width:2.0;" x1="336.5" x2="354.5" y1="152.0156" y2="170.0156"/><line style="stroke:#A80036;stroke-width:2.0;" x1="336.5" x2="354.5" y1="170.0156" y2="152.0156"/><polygon fill="#181818" points="113.5,187.3672,103.5,191.3672,113.5,195.3672,109.5,191.3672" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;stroke-dasharray:2.0,2.0;" x1="107.5" x2="249.5" y1="191.3672" y2="191.3672"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="93" x="119.5" y="186.5107">RequestCreated</text><polygon fill="#181818" points="37.5,217.7188,27.5,221.7188,37.5,225.7188,33.5,221.7188" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="31.5" x2="96.5" y1="221.7188" y2="221.7188"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="30" x="43.5" y="216.8623">Done</text><!--MD5=[5f53e077a3b738dee8ed05af6f972a22]
@startuml
participant User

User -> A: DoWork
activate A

A -> B: << createRequest >>
activate B

B -> C: DoWork
activate C
C - -> B: WorkDone
destroy C

B - -> A: RequestCreated
deactivate B

A -> User: Done
deactivate A

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download sequence diagram](sequence.svg ':ignore')
-
-Multiple markdowns can be ordered using `.1.md, .2.md .. ..md`
-
-You can choose where to place a certain diagram by using `![name](.puml)`
-
-
-![ditaa](data:image/png;base64,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)
-[Download ditaa diagram](ditaa.png ':ignore')
-
-Feel free to add any additional details necesary.
diff --git a/docs/1 Internet Banking System/Single Page Application/Extended Docs/class.svg b/docs/1 Internet Banking System/Single Page Application/Extended Docs/class.svg
deleted file mode 100644
index cb3faab..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Extended Docs/class.svg
+++ /dev/null
@@ -1,77 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/Extended Docs/ditaa.png b/docs/1 Internet Banking System/Single Page Application/Extended Docs/ditaa.png
deleted file mode 100644
index 6a000c9..0000000
Binary files a/docs/1 Internet Banking System/Single Page Application/Extended Docs/ditaa.png and /dev/null differ
diff --git a/docs/1 Internet Banking System/Single Page Application/Extended Docs/sequence.svg b/docs/1 Internet Banking System/Single Page Application/Extended Docs/sequence.svg
deleted file mode 100644
index ec0510d..0000000
--- a/docs/1 Internet Banking System/Single Page Application/Extended Docs/sequence.svg
+++ /dev/null
@@ -1,31 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/HOME.md b/docs/1 Internet Banking System/Single Page Application/HOME.md
deleted file mode 100644
index 64f6fde..0000000
--- a/docs/1 Internet Banking System/Single Page Application/HOME.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# Single Page Application
-
-
-![container](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="631px" preserveAspectRatio="none" style="width:918px;height:631px;background:#FFFFFF;" version="1.1" viewBox="0 0 918 631" width="918px" zoomAndPan="magnify"><defs/><g><!--MD5=[38c27b35aef4eebaf210b1fd39b25fb0]
cluster spa--><g id="cluster_spa"><rect height="421" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="662" x="7" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="247.5" y="25.6094">Single Page Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="306.5" y="41.582">[Container]</text></g><!--MD5=[54409d5519d7646972cabb5538a3d297]
entity routing--><g id="elem_routing"><rect fill="#85BBF0" height="90.4375" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="188" x="438" y="87"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="61" x="501.5" y="113.6094">Routing</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="73" x="495.5" y="129.582">[React router]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="530" y="146.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="164" x="452" y="164.3613">Handler slient side routing</text></g><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><g id="elem_store"><rect fill="#85BBF0" height="108.0469" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="216" x="235" y="296"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="80" x="303" y="322.6094">Data Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="42" x="322" y="338.582">[Redux]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="341" y="355.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="249" y="373.3613">The central object holding the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="103" x="291.5" y="390.9707">application state</text></g><!--MD5=[2c4d6263d6a9c508a624946e4f5b83db]
entity login--><g id="elem_login"><rect fill="#85BBF0" height="90.4375" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="119" x="283.5" y="87"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="83" x="301.5" y="113.6094">Login form</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="307" y="129.582">[React Class]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="341" y="146.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="95" x="297.5" y="164.3613">The login page</text></g><!--MD5=[7acc01a6845e7bd2e8afe94137bb9829]
entity profile--><g id="elem_profile"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="217" x="31.5" y="69"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="92" x="94" y="95.6094">Profile Page</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="104" y="111.582">[React Class]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="138" y="128.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="189" x="45.5" y="146.3613">The page where the logged in</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="44" y="163.9707">user can view and edit his/her</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="105" y="181.5801">information</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="693.5" y="287"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="745" y="313.6094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="121" x="742.5" y="329.582">[java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="801" y="346.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="707.5" y="364.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="717.5" y="381.9707">the internet banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="749" y="399.5801">page application.</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M669.1828,145.4529 C669.2666,145.5804 669.351,145.7087 669.4359,145.8379 C670.1155,146.8714 670.8308,147.9594 671.5802,149.0991 C677.5747,158.2163 685.7406,170.6363 695.0888,184.855 C713.785,213.2925 737.21,248.925 757.45,279.72 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="762.07,286.75,760.178,278.4181,755.166,281.7166,762.07,286.75" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="766.5" y="238.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="741" y="253.5508">[JSON/HTTPS]</text></g><!--MD5=[334ae2b5ea9a67a6cab925c77e9701c3]
link login to store--><g id="link_login_store"><path d="M343,177.23 C343,209 343,252.23 343,287.37 " fill="none" id="login-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="343,295.66,346,287.66,340,287.66,343,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="344" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="373" y="245.957">;</text></g><!--MD5=[236a7b55e2b2bbdd3d38377a1d6ad24a]
link routing to store--><g id="link_routing_store"><path d="M493.3,177.23 C464.92,209.67 426.07,254.06 394.99,289.59 " fill="none" id="routing-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="389.67,295.66,397.189,291.6023,392.6669,287.6588,389.67,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="450" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="479" y="245.957">;</text></g><!--MD5=[4fc1864ed4b873a370455e3590a7eeea]
link profile to store--><g id="link_profile_store"><path d="M198.44,195.19 C226.33,224.86 259.53,260.19 287.09,289.5 " fill="none" id="profile-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="292.87,295.66,289.5819,287.774,285.2074,291.8805,292.87,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="255" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="284" y="245.957">;</text></g><rect height="174.4844" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="144" x="752.5" y="441"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="758.5" y="463.5332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="811.5" y="463.5332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="466.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="762.5" y="481.1426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="484.2188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="762.5" y="498.752">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="501.8281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="762.5" y="516.3613">container</text><rect fill="#85BBF0" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="519.4375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="762.5" y="533.9707">component</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="537.0469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="762.5" y="551.5801">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="554.6563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="762.5" y="569.1895">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="572.2656"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="762.5" y="586.7988">external container</text><rect fill="#CCCCCC" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="589.875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="762.5" y="604.4082">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="449" y2="449"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="466.6094" y2="466.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="484.2188" y2="484.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="501.8281" y2="501.8281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="519.4375" y2="519.4375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="537.0469" y2="537.0469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="554.6563" y2="554.6563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="572.2656" y2="572.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="589.875" y2="589.875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="607.4844" y2="607.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="758.5" y1="449" y2="607.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="890.5" x2="890.5" y1="449" y2="607.4844"/><!--MD5=[a3b0f8e8c01eb79bd93b48d3d6a69cec]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

LAYOUT_WITH_LEGEND()

Container(api, "API Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")

Container_Boundary(spa, "Single Page Application") {
    Component(routing, "Routing", "React router", "Handler slient side routing")
    Component(store, "Data Store", "Redux", "The central object holding the application state")
    Component(login, "Login form", "React Class", "The login page")
    Component(profile, "Profile Page", "React Class", "The page where the logged in user can view and edit his/her information")
}

Rel(spa, api, "Uses", "JSON/HTTPS")

Rel(login, store, "Uses");
Rel(routing, store, "Uses");
Rel(profile, store, "Uses");

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}











hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#85BBF0> component |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
|<#CCCCCC> external component |
endlegend

rectangle "==API Application\n//<size:12>[java and Spring MVC]</size>//\n\n Delivers the static content and the internet banking single page application." <<container>> as api

rectangle "==Single Page Application\n<size:12>[Container]</size>" <<boundary>> as spa {
    rectangle "==Routing\n//<size:12>[React router]</size>//\n\n Handler slient side routing" <<component>> as routing
    rectangle "==Data Store\n//<size:12>[Redux]</size>//\n\n The central object holding the application state" <<component>> as store
    rectangle "==Login form\n//<size:12>[React Class]</size>//\n\n The login page" <<component>> as login
    rectangle "==Profile Page\n//<size:12>[React Class]</size>//\n\n The page where the logged in user can view and edit his/her information" <<component>> as profile
}

spa - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//

login - ->> store : **Uses**;
routing - ->> store : **Uses**;
profile - ->> store : **Uses**;

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download container diagram](container.svg ':ignore')
-
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
-
-> Example of included local image
-
-![](2020-01-10-16-21-41.png)
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/README.md b/docs/1 Internet Banking System/Single Page Application/README.md
deleted file mode 100644
index 8eda68d..0000000
--- a/docs/1 Internet Banking System/Single Page Application/README.md
+++ /dev/null
@@ -1,42 +0,0 @@
-# Single Page Application
-
-`\1 Internet Banking System\Single Page Application`
-
-* [PySocial Project](../../README.md)
- * [1 Internet Banking System](../../1%20Internet%20Banking%20System/README.md)
- * [API Application](../../1%20Internet%20Banking%20System/API%20Application/README.md)
- * [**Single Page Application**](../../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [Dynamic Diagram](../../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [Extended Docs](../../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [2 Deployment](../../2%20Deployment/README.md)
-
----
-
-[1 Internet Banking System (up)](../../1%20Internet%20Banking%20System/README.md)
-
-- [Dynamic Diagram](../../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
-
-- [Extended Docs](../../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
-
----
-
-
-![container](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="631px" preserveAspectRatio="none" style="width:918px;height:631px;background:#FFFFFF;" version="1.1" viewBox="0 0 918 631" width="918px" zoomAndPan="magnify"><defs/><g><!--MD5=[38c27b35aef4eebaf210b1fd39b25fb0]
cluster spa--><g id="cluster_spa"><rect height="421" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="662" x="7" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="247.5" y="25.6094">Single Page Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="306.5" y="41.582">[Container]</text></g><!--MD5=[54409d5519d7646972cabb5538a3d297]
entity routing--><g id="elem_routing"><rect fill="#85BBF0" height="90.4375" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="188" x="438" y="87"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="61" x="501.5" y="113.6094">Routing</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="73" x="495.5" y="129.582">[React router]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="530" y="146.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="164" x="452" y="164.3613">Handler slient side routing</text></g><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><g id="elem_store"><rect fill="#85BBF0" height="108.0469" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="216" x="235" y="296"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="80" x="303" y="322.6094">Data Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="42" x="322" y="338.582">[Redux]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="341" y="355.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="249" y="373.3613">The central object holding the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="103" x="291.5" y="390.9707">application state</text></g><!--MD5=[2c4d6263d6a9c508a624946e4f5b83db]
entity login--><g id="elem_login"><rect fill="#85BBF0" height="90.4375" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="119" x="283.5" y="87"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="83" x="301.5" y="113.6094">Login form</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="307" y="129.582">[React Class]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="341" y="146.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="95" x="297.5" y="164.3613">The login page</text></g><!--MD5=[7acc01a6845e7bd2e8afe94137bb9829]
entity profile--><g id="elem_profile"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="217" x="31.5" y="69"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="92" x="94" y="95.6094">Profile Page</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="104" y="111.582">[React Class]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="138" y="128.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="189" x="45.5" y="146.3613">The page where the logged in</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="44" y="163.9707">user can view and edit his/her</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="105" y="181.5801">information</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="693.5" y="287"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="745" y="313.6094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="121" x="742.5" y="329.582">[java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="801" y="346.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="707.5" y="364.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="717.5" y="381.9707">the internet banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="749" y="399.5801">page application.</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M669.1828,145.4529 C669.2666,145.5804 669.351,145.7087 669.4359,145.8379 C670.1155,146.8714 670.8308,147.9594 671.5802,149.0991 C677.5747,158.2163 685.7406,170.6363 695.0888,184.855 C713.785,213.2925 737.21,248.925 757.45,279.72 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="762.07,286.75,760.178,278.4181,755.166,281.7166,762.07,286.75" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="766.5" y="238.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="741" y="253.5508">[JSON/HTTPS]</text></g><!--MD5=[334ae2b5ea9a67a6cab925c77e9701c3]
link login to store--><g id="link_login_store"><path d="M343,177.23 C343,209 343,252.23 343,287.37 " fill="none" id="login-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="343,295.66,346,287.66,340,287.66,343,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="344" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="373" y="245.957">;</text></g><!--MD5=[236a7b55e2b2bbdd3d38377a1d6ad24a]
link routing to store--><g id="link_routing_store"><path d="M493.3,177.23 C464.92,209.67 426.07,254.06 394.99,289.59 " fill="none" id="routing-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="389.67,295.66,397.189,291.6023,392.6669,287.6588,389.67,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="450" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="479" y="245.957">;</text></g><!--MD5=[4fc1864ed4b873a370455e3590a7eeea]
link profile to store--><g id="link_profile_store"><path d="M198.44,195.19 C226.33,224.86 259.53,260.19 287.09,289.5 " fill="none" id="profile-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="292.87,295.66,289.5819,287.774,285.2074,291.8805,292.87,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="255" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="284" y="245.957">;</text></g><rect height="174.4844" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="144" x="752.5" y="441"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="758.5" y="463.5332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="811.5" y="463.5332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="466.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="762.5" y="481.1426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="484.2188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="762.5" y="498.752">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="501.8281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="762.5" y="516.3613">container</text><rect fill="#85BBF0" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="519.4375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="762.5" y="533.9707">component</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="537.0469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="762.5" y="551.5801">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="554.6563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="762.5" y="569.1895">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="572.2656"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="762.5" y="586.7988">external container</text><rect fill="#CCCCCC" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="589.875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="762.5" y="604.4082">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="449" y2="449"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="466.6094" y2="466.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="484.2188" y2="484.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="501.8281" y2="501.8281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="519.4375" y2="519.4375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="537.0469" y2="537.0469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="554.6563" y2="554.6563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="572.2656" y2="572.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="589.875" y2="589.875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="607.4844" y2="607.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="758.5" y1="449" y2="607.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="890.5" x2="890.5" y1="449" y2="607.4844"/><!--MD5=[a3b0f8e8c01eb79bd93b48d3d6a69cec]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

LAYOUT_WITH_LEGEND()

Container(api, "API Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")

Container_Boundary(spa, "Single Page Application") {
    Component(routing, "Routing", "React router", "Handler slient side routing")
    Component(store, "Data Store", "Redux", "The central object holding the application state")
    Component(login, "Login form", "React Class", "The login page")
    Component(profile, "Profile Page", "React Class", "The page where the logged in user can view and edit his/her information")
}

Rel(spa, api, "Uses", "JSON/HTTPS")

Rel(login, store, "Uses");
Rel(routing, store, "Uses");
Rel(profile, store, "Uses");

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}











hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#85BBF0> component |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
|<#CCCCCC> external component |
endlegend

rectangle "==API Application\n//<size:12>[java and Spring MVC]</size>//\n\n Delivers the static content and the internet banking single page application." <<container>> as api

rectangle "==Single Page Application\n<size:12>[Container]</size>" <<boundary>> as spa {
    rectangle "==Routing\n//<size:12>[React router]</size>//\n\n Handler slient side routing" <<component>> as routing
    rectangle "==Data Store\n//<size:12>[Redux]</size>//\n\n The central object holding the application state" <<component>> as store
    rectangle "==Login form\n//<size:12>[React Class]</size>//\n\n The login page" <<component>> as login
    rectangle "==Profile Page\n//<size:12>[React Class]</size>//\n\n The page where the logged in user can view and edit his/her information" <<component>> as profile
}

spa - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//

login - ->> store : **Uses**;
routing - ->> store : **Uses**;
profile - ->> store : **Uses**;

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download container diagram](container.svg ':ignore')
-
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
-
-> Example of included local image
-
-![](2020-01-10-16-21-41.png)
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/Single Page Application/Single Page Application.pdf b/docs/1 Internet Banking System/Single Page Application/Single Page Application.pdf
deleted file mode 100644
index 5fdc693..0000000
Binary files a/docs/1 Internet Banking System/Single Page Application/Single Page Application.pdf and /dev/null differ
diff --git a/docs/1 Internet Banking System/Single Page Application/container.svg b/docs/1 Internet Banking System/Single Page Application/container.svg
deleted file mode 100644
index 3ca0e6a..0000000
--- a/docs/1 Internet Banking System/Single Page Application/container.svg
+++ /dev/null
@@ -1,347 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/1 Internet Banking System/system.svg b/docs/1 Internet Banking System/system.svg
deleted file mode 100644
index d77cff3..0000000
--- a/docs/1 Internet Banking System/system.svg
+++ /dev/null
@@ -1,312 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/1 PySocial System/1 PySocial System.pdf b/docs/1 PySocial System/1 PySocial System.pdf
new file mode 100644
index 0000000..daeb61e
Binary files /dev/null and b/docs/1 PySocial System/1 PySocial System.pdf differ
diff --git a/docs/1 PySocial System/HOME.md b/docs/1 PySocial System/HOME.md
new file mode 100644
index 0000000..1effb7c
--- /dev/null
+++ b/docs/1 PySocial System/HOME.md
@@ -0,0 +1,30 @@
+# 1 PySocial System
+
+
+![system](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1094px" preserveAspectRatio="none" style="width:1253px;height:1094px;background:#FFFFFF;" version="1.1" viewBox="0 0 1253 1094" width="1253px" zoomAndPan="magnify"><defs/><g><!--MD5=[df801953c3eb52426c535e27a34580d5]
cluster pys--><g id="cluster_pys"><rect height="494" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="222" x="516" y="261"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="128" x="563" y="279.6094">PySocial System</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="51" x="601.5" y="295.582">[System]</text></g><!--MD5=[ef876daef8096df7f4ce46fa39b9e1a2]
entity pyWeb--><g id="elem_pyWeb"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="131" x="561.5" y="315"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="571.5" y="341.6094">PyWebView UI</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="357.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="374.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="96" x="581" y="392.3613">UI da aplicação</text></g><!--MD5=[fd71a720deb277bbd1af72c03fa35a41]
entity py--><g id="elem_py"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="189" x="532.5" y="482"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="145" x="554.5" y="508.6094">Python Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="524.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="541.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="165" x="546.5" y="559.3613">Core domain da aplicação</text></g><!--MD5=[734cf7e73ed9318c8e9ec5225b8633af]
entity pyAcl--><g id="elem_pyAcl"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="135" x="559.5" y="649"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="96" x="579" y="675.6094">API Interface</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="691.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="708.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="111" x="573.5" y="726.3613">ACL da aplicação</text></g><!--MD5=[8fc3522a43f8c7199df5e09e5bb0188e]
entity user--><g id="elem_user"><rect fill="#08427B" height="176.1719" rx="2.5" ry="2.5" style="stroke:#073B6F;stroke-width:0.5;" width="207" x="523.5" y="7"/><image height="48" width="48" x="603" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAIAAADYYG7QAAACD0lEQVR4Xu2YoU4EMRCGT+4j8Ai8AhaH4QHgAUjQuFMECUgMIUgwJAgMhgQsAYUiJCiQIBBY+EITsjfTdme6V24v4c8vyGbb+ZjOtN0bNcvjQXmkH83WvYBWto6PLm6v7p7uH1/w2fXD+PBycX1Pv2l3IdDm/vn7x+dXQiAubRzoURa7gRZWd0iGRIiJbOnhnfYBQZNJjNbuyY2eJG8fkDE3bbG4ep6MHUAsgYxmE3nVs6VsBWJSGccsOlFPmLIViMzLOB7pCVO2AtHJMohH7Fh6zqitQK7m0rJvAVYgGcEpe//PLdDz65sM4pF9N7ICcXDKIB5Nv6j7tD0NoSdM2QrU9Gg0ewE1LqBhHR3BBdvj2vapnidjHxD/q6vd7Pvhr31AwcY8eXMTXAKECZZJFXuEq27aLgQK5uLMohCenGGuGewOxSjBvYBqeG6B+Nqiblggdjnc+ZXDy+FNFpFzw76O3UBAROuXh6FoiAcf5g9eTvUgzy0nWg6I8cXHRUpg5bOVBCo+KDpFajOf23GgPme7RSQ+lacIENUgJ6gg1k6HjgOlqnLqip4tEuhv0hNEMXUD0clyXE3p6pZA0S2nnvTlXwLJEZWlb7cTQH1+USgTN4VhAenm/wea1OCAOmqo6fE1WCb9WSKBah+rbUWPWAmE2Rvk0ApiB45eOyNAzU8xcTvj8KvkKEoOaIYeHNA3ZuygAvFMUO0AAAAASUVORK5CYII=" y="17"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="60" x="597" y="81.6094">Usuário</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="99.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="161" x="546.5" y="117.2676">Um usuário que possue a</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="155" x="547.5" y="134.877">necessidade de enviar o</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="533.5" y="152.4863">mesmo conteúdo para várias</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="87" x="583.5" y="170.0957">redes sociais.</text></g><!--MD5=[585917e793a1fe337a2a50e5f9ed7522]
entity face--><g id="elem_face"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="7" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="64" y="859.6094">Facebook API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="115" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="21" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="47" y="912.877">rede social Facebook.</text></g><!--MD5=[f575475bb9b2a227ddc3b96a8d3fb34d]
entity inst--><g id="elem_inst"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="262" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="319" y="859.6094">Instagram API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="370" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="276" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="302.5" y="912.877">rede social Instagram.</text></g><!--MD5=[fd07f395667725ff60a8c06b2c928ecc]
entity x--><g id="elem_x"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="517" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="574" y="859.6094">X (Twiiter) API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="531" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="85" x="584.5" y="912.877">rede social X.</text></g><!--MD5=[2117018183c09a01edf82456b59260a5]
entity tt--><g id="elem_tt"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="772" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="82" x="841" y="859.6094">TikTok API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="880" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="786" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="120" x="822" y="912.877">rede social TikTok.</text></g><!--MD5=[14a53e5de2f3a515d643c2a1018893cf]
entity yt--><g id="elem_yt"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="1027" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="99" x="1087.5" y="859.6094">YouTube API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1135" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="1041" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="135" x="1069.5" y="912.877">rede social YouTube.</text></g><!--MD5=[473f11c98570ddc1410bd9bc4b66bf6a]
link pyWeb to py--><g id="link_pyWeb_py"><path d="M627,405.22 C627,426.29 627,451.65 627,473.68 " fill="none" id="pyWeb-to-py" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,481.95,630,473.95,624,473.95,627,481.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="628" y="448.457">Uses</text></g><!--MD5=[39d6a6c8b6a6dcd4921e1907d9f2a540]
link py to pyAcl--><g id="link_py_pyAcl"><path d="M627,572.22 C627,593.29 627,618.65 627,640.68 " fill="none" id="py-to-pyAcl" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,648.95,630,640.95,624,640.95,627,648.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="628" y="615.457">Uses</text></g><!--MD5=[fbc8c276177d97d8a94fd81429bfb8de]
link user to pyWeb--><g id="link_user_pyWeb"><path d="M627,183.21 C627,224.05 627,271.33 627,306.57 " fill="none" id="user-to-pyWeb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,314.81,630,306.81,624,306.81,627,314.81" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="75" x="628" y="226.457">Interage com</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="19" x="656" y="241.5508">[UI]</text></g><!--MD5=[483eec5be0afa8f3fa55b9e74604b347]
link pyAcl to face--><g id="link_pyAcl_face"><path d="M559.43,716.11 C512.97,730.87 449.99,751.38 395,771 C342.04,789.9 283.94,812.13 234.62,831.45 " fill="none" id="pyAcl-to-face" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="227.1,834.4,235.6429,834.2625,233.446,828.6791,227.1,834.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="411" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="396" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[7663349bf6f6eaa2d5a6226383662c38]
link pyAcl to inst--><g id="link_pyAcl_inst"><path d="M565.6,739.19 C528.4,765.95 480.83,800.19 442.15,828.02 " fill="none" id="pyAcl-to-inst" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="435.53,832.78,443.7748,830.5387,440.2681,825.6701,435.53,832.78" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="531" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="516" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[577866a7e55ab679ceb599ce297f6ac2]
link pyAcl to x--><g id="link_pyAcl_x"><path d="M627,739.42 C627,765.09 627,797.56 627,824.67 " fill="none" id="pyAcl-to-x" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,832.89,630,824.89,624,824.89,627,832.89" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="643" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="628" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[edbb0970577f5f34a35f665a12ea2d0a]
link pyAcl to tt--><g id="link_pyAcl_tt"><path d="M688.4,739.19 C725.6,765.95 773.17,800.19 811.85,828.02 " fill="none" id="pyAcl-to-tt" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="818.47,832.78,813.7319,825.6701,810.2252,830.5387,818.47,832.78" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="786" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="771" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[75306bdb9a51061fb1c0b9bfc4c17bb5]
link pyAcl to yt--><g id="link_pyAcl_yt"><path d="M694.63,715.98 C741.31,730.72 804.7,751.27 860,771 C912.68,789.8 970.43,811.96 1019.5,831.26 " fill="none" id="pyAcl-to-yt" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1026.99,834.21,1020.644,828.4891,1018.4471,834.0725,1026.99,834.21" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="961" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="946" y="799.5508">[JSON/HTTPS]</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="1098" y="938.9531"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="1104" y="961.4863">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1157" y="961.4863"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="964.5625"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="1108" y="979.0957">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="982.1719"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="1108" y="996.7051">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="999.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="1108" y="1014.3145">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1017.3906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="1108" y="1031.9238">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1035"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="1108" y="1049.5332">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1052.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="1108" y="1067.1426">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="946.9531" y2="946.9531"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="964.5625" y2="964.5625"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="982.1719" y2="982.1719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="999.7813" y2="999.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1017.3906" y2="1017.3906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1035" y2="1035"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1052.6094" y2="1052.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1070.2188" y2="1070.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1104" y1="946.9531" y2="1070.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1225" x2="1225" y1="946.9531" y2="1070.2188"/><!--MD5=[d84a0cd1768b34996afb20f8e6a689be]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml

LAYOUT_WITH_LEGEND()

Person(user, "Usuário", "Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais.")
System_Ext(face, "Facebook API", "Interface de comunicação com rede social Facebook.")
System_Ext(inst, "Instagram API", "Interface de comunicação com rede social Instagram.")
System_Ext(x, "X (Twiiter) API", "Interface de comunicação com rede social X.")
System_Ext(tt, "TikTok API", "Interface de comunicação com rede social TikTok.")
System_Ext(yt, "YouTube API", "Interface de comunicação com rede social YouTube.")

System_Boundary(pys, "PySocial System") {
    Container(pyWeb, "PyWebView UI", "Python3", "UI da aplicação")
    Container(py, "Python Application", "Python3", "Core domain da aplicação")
    Container(pyAcl, "API Interface", "Python3", "ACL da aplicação")

    Rel(pyWeb, py, "Uses")
    Rel(py, pyAcl, "Uses")
}

Rel(user, pyWeb, "Interage com", "UI")
Rel(pyAcl, face, "requisita", "JSON/HTTPS")
Rel(pyAcl, inst, "requisita", "JSON/HTTPS")
Rel(pyAcl, x, "requisita", "JSON/HTTPS")
Rel(pyAcl, tt, "requisita", "JSON/HTTPS")
Rel(pyAcl, yt, "requisita", "JSON/HTTPS")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}













hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "<$person>\n==Usuário\n\n Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais." <<person>> as user
rectangle "==Facebook API\n\n Interface de comunicação com rede social Facebook." <<external_system>> as face
rectangle "==Instagram API\n\n Interface de comunicação com rede social Instagram." <<external_system>> as inst
rectangle "==X (Twiiter) API\n\n Interface de comunicação com rede social X." <<external_system>> as x
rectangle "==TikTok API\n\n Interface de comunicação com rede social TikTok." <<external_system>> as tt
rectangle "==YouTube API\n\n Interface de comunicação com rede social YouTube." <<external_system>> as yt

rectangle "==PySocial System\n<size:12>[System]</size>" <<boundary>> as pys {
    rectangle "==PyWebView UI\n//<size:12>[Python3]</size>//\n\n UI da aplicação" <<container>> as pyWeb
    rectangle "==Python Application\n//<size:12>[Python3]</size>//\n\n Core domain da aplicação" <<container>> as py
    rectangle "==API Interface\n//<size:12>[Python3]</size>//\n\n ACL da aplicação" <<container>> as pyAcl

pyWeb - ->> py : **Uses**
py - ->> pyAcl : **Uses**
}

user - ->> pyWeb : **Interage com**\n//<size:12>[UI]</size>//
pyAcl - ->> face : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> inst : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> x : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> tt : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> yt : **requisita**\n//<size:12>[JSON/HTTPS]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
+[Download system diagram](system.svg ':ignore')
+
+**Level 2: Diagrama de contêiner**
+
+
+**Scope**: Sistema de software PySocial.
+
+**Elementos primários**:
+* PyWebView UI
+* Python Application
+* API Interface
+
+
+
+**Elementos de suporte:**
+* Usuário
+* Facebook API
+* Instagram API
+* X (Twiiter) API
+* TikTok API
+* YouTube API
+
+
+
+
+**Público-alvo**: Técnicos dentro e fora da equipe de desenvolvimento de software; incluindo arquitetos de software, desenvolvedores e equipe de operações/suporte.
\ No newline at end of file
diff --git a/docs/1 PySocial System/README.md b/docs/1 PySocial System/README.md
new file mode 100644
index 0000000..6429250
--- /dev/null
+++ b/docs/1 PySocial System/README.md
@@ -0,0 +1,41 @@
+# 1 PySocial System
+
+`\1 PySocial System`
+
+* [PySocial Project](../README.md)
+ * [**1 PySocial System**](../1%20PySocial%20System/README.md)
+
+---
+
+[PySocial Project (up)](../README.md)
+
+---
+
+
+![system](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1094px" preserveAspectRatio="none" style="width:1253px;height:1094px;background:#FFFFFF;" version="1.1" viewBox="0 0 1253 1094" width="1253px" zoomAndPan="magnify"><defs/><g><!--MD5=[df801953c3eb52426c535e27a34580d5]
cluster pys--><g id="cluster_pys"><rect height="494" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="222" x="516" y="261"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="128" x="563" y="279.6094">PySocial System</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="51" x="601.5" y="295.582">[System]</text></g><!--MD5=[ef876daef8096df7f4ce46fa39b9e1a2]
entity pyWeb--><g id="elem_pyWeb"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="131" x="561.5" y="315"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="571.5" y="341.6094">PyWebView UI</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="357.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="374.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="96" x="581" y="392.3613">UI da aplicação</text></g><!--MD5=[fd71a720deb277bbd1af72c03fa35a41]
entity py--><g id="elem_py"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="189" x="532.5" y="482"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="145" x="554.5" y="508.6094">Python Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="524.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="541.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="165" x="546.5" y="559.3613">Core domain da aplicação</text></g><!--MD5=[734cf7e73ed9318c8e9ec5225b8633af]
entity pyAcl--><g id="elem_pyAcl"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="135" x="559.5" y="649"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="96" x="579" y="675.6094">API Interface</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="691.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="708.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="111" x="573.5" y="726.3613">ACL da aplicação</text></g><!--MD5=[8fc3522a43f8c7199df5e09e5bb0188e]
entity user--><g id="elem_user"><rect fill="#08427B" height="176.1719" rx="2.5" ry="2.5" style="stroke:#073B6F;stroke-width:0.5;" width="207" x="523.5" y="7"/><image height="48" width="48" x="603" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAIAAADYYG7QAAACD0lEQVR4Xu2YoU4EMRCGT+4j8Ai8AhaH4QHgAUjQuFMECUgMIUgwJAgMhgQsAYUiJCiQIBBY+EITsjfTdme6V24v4c8vyGbb+ZjOtN0bNcvjQXmkH83WvYBWto6PLm6v7p7uH1/w2fXD+PBycX1Pv2l3IdDm/vn7x+dXQiAubRzoURa7gRZWd0iGRIiJbOnhnfYBQZNJjNbuyY2eJG8fkDE3bbG4ep6MHUAsgYxmE3nVs6VsBWJSGccsOlFPmLIViMzLOB7pCVO2AtHJMohH7Fh6zqitQK7m0rJvAVYgGcEpe//PLdDz65sM4pF9N7ICcXDKIB5Nv6j7tD0NoSdM2QrU9Gg0ewE1LqBhHR3BBdvj2vapnidjHxD/q6vd7Pvhr31AwcY8eXMTXAKECZZJFXuEq27aLgQK5uLMohCenGGuGewOxSjBvYBqeG6B+Nqiblggdjnc+ZXDy+FNFpFzw76O3UBAROuXh6FoiAcf5g9eTvUgzy0nWg6I8cXHRUpg5bOVBCo+KDpFajOf23GgPme7RSQ+lacIENUgJ6gg1k6HjgOlqnLqip4tEuhv0hNEMXUD0clyXE3p6pZA0S2nnvTlXwLJEZWlb7cTQH1+USgTN4VhAenm/wea1OCAOmqo6fE1WCb9WSKBah+rbUWPWAmE2Rvk0ApiB45eOyNAzU8xcTvj8KvkKEoOaIYeHNA3ZuygAvFMUO0AAAAASUVORK5CYII=" y="17"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="60" x="597" y="81.6094">Usuário</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="99.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="161" x="546.5" y="117.2676">Um usuário que possue a</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="155" x="547.5" y="134.877">necessidade de enviar o</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="533.5" y="152.4863">mesmo conteúdo para várias</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="87" x="583.5" y="170.0957">redes sociais.</text></g><!--MD5=[585917e793a1fe337a2a50e5f9ed7522]
entity face--><g id="elem_face"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="7" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="64" y="859.6094">Facebook API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="115" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="21" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="47" y="912.877">rede social Facebook.</text></g><!--MD5=[f575475bb9b2a227ddc3b96a8d3fb34d]
entity inst--><g id="elem_inst"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="262" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="319" y="859.6094">Instagram API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="370" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="276" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="302.5" y="912.877">rede social Instagram.</text></g><!--MD5=[fd07f395667725ff60a8c06b2c928ecc]
entity x--><g id="elem_x"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="517" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="574" y="859.6094">X (Twiiter) API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="531" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="85" x="584.5" y="912.877">rede social X.</text></g><!--MD5=[2117018183c09a01edf82456b59260a5]
entity tt--><g id="elem_tt"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="772" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="82" x="841" y="859.6094">TikTok API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="880" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="786" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="120" x="822" y="912.877">rede social TikTok.</text></g><!--MD5=[14a53e5de2f3a515d643c2a1018893cf]
entity yt--><g id="elem_yt"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="1027" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="99" x="1087.5" y="859.6094">YouTube API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1135" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="1041" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="135" x="1069.5" y="912.877">rede social YouTube.</text></g><!--MD5=[473f11c98570ddc1410bd9bc4b66bf6a]
link pyWeb to py--><g id="link_pyWeb_py"><path d="M627,405.22 C627,426.29 627,451.65 627,473.68 " fill="none" id="pyWeb-to-py" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,481.95,630,473.95,624,473.95,627,481.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="628" y="448.457">Uses</text></g><!--MD5=[39d6a6c8b6a6dcd4921e1907d9f2a540]
link py to pyAcl--><g id="link_py_pyAcl"><path d="M627,572.22 C627,593.29 627,618.65 627,640.68 " fill="none" id="py-to-pyAcl" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,648.95,630,640.95,624,640.95,627,648.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="628" y="615.457">Uses</text></g><!--MD5=[fbc8c276177d97d8a94fd81429bfb8de]
link user to pyWeb--><g id="link_user_pyWeb"><path d="M627,183.21 C627,224.05 627,271.33 627,306.57 " fill="none" id="user-to-pyWeb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,314.81,630,306.81,624,306.81,627,314.81" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="75" x="628" y="226.457">Interage com</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="19" x="656" y="241.5508">[UI]</text></g><!--MD5=[483eec5be0afa8f3fa55b9e74604b347]
link pyAcl to face--><g id="link_pyAcl_face"><path d="M559.43,716.11 C512.97,730.87 449.99,751.38 395,771 C342.04,789.9 283.94,812.13 234.62,831.45 " fill="none" id="pyAcl-to-face" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="227.1,834.4,235.6429,834.2625,233.446,828.6791,227.1,834.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="411" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="396" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[7663349bf6f6eaa2d5a6226383662c38]
link pyAcl to inst--><g id="link_pyAcl_inst"><path d="M565.6,739.19 C528.4,765.95 480.83,800.19 442.15,828.02 " fill="none" id="pyAcl-to-inst" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="435.53,832.78,443.7748,830.5387,440.2681,825.6701,435.53,832.78" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="531" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="516" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[577866a7e55ab679ceb599ce297f6ac2]
link pyAcl to x--><g id="link_pyAcl_x"><path d="M627,739.42 C627,765.09 627,797.56 627,824.67 " fill="none" id="pyAcl-to-x" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,832.89,630,824.89,624,824.89,627,832.89" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="643" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="628" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[edbb0970577f5f34a35f665a12ea2d0a]
link pyAcl to tt--><g id="link_pyAcl_tt"><path d="M688.4,739.19 C725.6,765.95 773.17,800.19 811.85,828.02 " fill="none" id="pyAcl-to-tt" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="818.47,832.78,813.7319,825.6701,810.2252,830.5387,818.47,832.78" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="786" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="771" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[75306bdb9a51061fb1c0b9bfc4c17bb5]
link pyAcl to yt--><g id="link_pyAcl_yt"><path d="M694.63,715.98 C741.31,730.72 804.7,751.27 860,771 C912.68,789.8 970.43,811.96 1019.5,831.26 " fill="none" id="pyAcl-to-yt" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1026.99,834.21,1020.644,828.4891,1018.4471,834.0725,1026.99,834.21" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="961" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="946" y="799.5508">[JSON/HTTPS]</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="1098" y="938.9531"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="1104" y="961.4863">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1157" y="961.4863"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="964.5625"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="1108" y="979.0957">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="982.1719"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="1108" y="996.7051">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="999.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="1108" y="1014.3145">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1017.3906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="1108" y="1031.9238">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1035"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="1108" y="1049.5332">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1052.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="1108" y="1067.1426">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="946.9531" y2="946.9531"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="964.5625" y2="964.5625"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="982.1719" y2="982.1719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="999.7813" y2="999.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1017.3906" y2="1017.3906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1035" y2="1035"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1052.6094" y2="1052.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1070.2188" y2="1070.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1104" y1="946.9531" y2="1070.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1225" x2="1225" y1="946.9531" y2="1070.2188"/><!--MD5=[d84a0cd1768b34996afb20f8e6a689be]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml

LAYOUT_WITH_LEGEND()

Person(user, "Usuário", "Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais.")
System_Ext(face, "Facebook API", "Interface de comunicação com rede social Facebook.")
System_Ext(inst, "Instagram API", "Interface de comunicação com rede social Instagram.")
System_Ext(x, "X (Twiiter) API", "Interface de comunicação com rede social X.")
System_Ext(tt, "TikTok API", "Interface de comunicação com rede social TikTok.")
System_Ext(yt, "YouTube API", "Interface de comunicação com rede social YouTube.")

System_Boundary(pys, "PySocial System") {
    Container(pyWeb, "PyWebView UI", "Python3", "UI da aplicação")
    Container(py, "Python Application", "Python3", "Core domain da aplicação")
    Container(pyAcl, "API Interface", "Python3", "ACL da aplicação")

    Rel(pyWeb, py, "Uses")
    Rel(py, pyAcl, "Uses")
}

Rel(user, pyWeb, "Interage com", "UI")
Rel(pyAcl, face, "requisita", "JSON/HTTPS")
Rel(pyAcl, inst, "requisita", "JSON/HTTPS")
Rel(pyAcl, x, "requisita", "JSON/HTTPS")
Rel(pyAcl, tt, "requisita", "JSON/HTTPS")
Rel(pyAcl, yt, "requisita", "JSON/HTTPS")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}













hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "<$person>\n==Usuário\n\n Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais." <<person>> as user
rectangle "==Facebook API\n\n Interface de comunicação com rede social Facebook." <<external_system>> as face
rectangle "==Instagram API\n\n Interface de comunicação com rede social Instagram." <<external_system>> as inst
rectangle "==X (Twiiter) API\n\n Interface de comunicação com rede social X." <<external_system>> as x
rectangle "==TikTok API\n\n Interface de comunicação com rede social TikTok." <<external_system>> as tt
rectangle "==YouTube API\n\n Interface de comunicação com rede social YouTube." <<external_system>> as yt

rectangle "==PySocial System\n<size:12>[System]</size>" <<boundary>> as pys {
    rectangle "==PyWebView UI\n//<size:12>[Python3]</size>//\n\n UI da aplicação" <<container>> as pyWeb
    rectangle "==Python Application\n//<size:12>[Python3]</size>//\n\n Core domain da aplicação" <<container>> as py
    rectangle "==API Interface\n//<size:12>[Python3]</size>//\n\n ACL da aplicação" <<container>> as pyAcl

pyWeb - ->> py : **Uses**
py - ->> pyAcl : **Uses**
}

user - ->> pyWeb : **Interage com**\n//<size:12>[UI]</size>//
pyAcl - ->> face : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> inst : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> x : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> tt : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> yt : **requisita**\n//<size:12>[JSON/HTTPS]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
+[Download system diagram](system.svg ':ignore')
+
+**Level 2: Diagrama de contêiner**
+
+
+**Scope**: Sistema de software PySocial.
+
+**Elementos primários**:
+* PyWebView UI
+* Python Application
+* API Interface
+
+
+
+**Elementos de suporte:**
+* Usuário
+* Facebook API
+* Instagram API
+* X (Twiiter) API
+* TikTok API
+* YouTube API
+
+
+
+
+**Público-alvo**: Técnicos dentro e fora da equipe de desenvolvimento de software; incluindo arquitetos de software, desenvolvedores e equipe de operações/suporte.
\ No newline at end of file
diff --git a/docs/1 PySocial System/system.svg b/docs/1 PySocial System/system.svg
new file mode 100644
index 0000000..82788ba
--- /dev/null
+++ b/docs/1 PySocial System/system.svg
@@ -0,0 +1,313 @@
+
\ No newline at end of file
diff --git a/docs/2 Deployment/2 Deployment.pdf b/docs/2 Deployment/2 Deployment.pdf
deleted file mode 100644
index 6261b51..0000000
Binary files a/docs/2 Deployment/2 Deployment.pdf and /dev/null differ
diff --git a/docs/2 Deployment/HOME.md b/docs/2 Deployment/HOME.md
deleted file mode 100644
index 15050ef..0000000
--- a/docs/2 Deployment/HOME.md
+++ /dev/null
@@ -1,15 +0,0 @@
-# 2 Deployment
-
-
-![deployment](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1549px" preserveAspectRatio="none" style="width:989px;height:1549px;background:#FFFFFF;" version="1.1" viewBox="0 0 989 1549" width="989px" zoomAndPan="magnify"><defs/><g><!--MD5=[d4f46b85ec0fd4984e46b6ab68a49907]
cluster plc--><g id="cluster_plc"><rect height="1097" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="670" x="7" y="284"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="97" x="293.5" y="302.6094">Big Bank plc</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="269" y="318.582">[Big Bank plc data center]</text></g><!--MD5=[cb60efe6e32ae9dc1419f0024d193ed3]
cluster dn--><g id="cluster_dn"><rect height="282" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="298" x="31" y="346"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="108" x="107" y="364.6094">bigbank-api***</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="18" x="235" y="364.6094">x8</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="126.5" y="380.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[8f463db2213924b28ab9fa8a8a25c26a]
cluster apache--><g id="cluster_apache"><rect height="196" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="250" x="55" y="408"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="119" x="120.5" y="426.6094">Apache Tomcat</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="121.5" y="442.582">[Apache Tomcat 8.x]</text></g><!--MD5=[7e0f1b407756c52dd30c4ead0f9230ac]
cluster bigbankdb01--><g id="cluster_bigbankdb01"><rect height="308" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="270" x="31" y="692"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="105" x="113.5" y="710.6094">bigbank-db01</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="112.5" y="726.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[d58f35efa7ac429240bfa5a7c4204cd4]
cluster oracle--><g id="cluster_oracle"><rect height="222" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="222" x="55" y="754"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="121" x="105.5" y="772.6094">Oracle - Primary</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="70" x="131" y="788.582">[Oracle 12c]</text></g><!--MD5=[9fa18d40767c7b2b82a18fa9dfe8338d]
cluster bigbankdb02--><g id="cluster_bigbankdb02"><rect height="308" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="270" x="124" y="1049"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="105" x="206.5" y="1067.6094">bigbank-db02</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="205.5" y="1083.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[69ad4c2ae5d24231281b185261861c19]
cluster oracle2--><g id="cluster_oracle2"><rect height="222" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="222" x="148" y="1111"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="145" x="186.5" y="1129.6094">Oracle - Secondary</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="70" x="224" y="1145.582">[Oracle 12c]</text></g><!--MD5=[8732ada0ac3d982aaf760ffd06e5f6c2]
cluster bb2--><g id="cluster_bb2"><rect height="282" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="300" x="353" y="346"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="430" y="364.6094">bigbank-web***</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="18" x="558" y="364.6094">x4</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="449.5" y="380.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[c9f3238ce9b9b9fe2ea53139a741cb96]
cluster apache2--><g id="cluster_apache2"><rect height="196" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="252" x="377" y="408"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="119" x="443.5" y="426.6094">Apache Tomcat</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="444.5" y="442.582">[Apache Tomcat 8.x]</text></g><!--MD5=[543156d0aa455e6607833fc05f747439]
cluster mob--><g id="cluster_mob"><rect height="213" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="238" x="61" y="7"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="197" x="81.5" y="25.6094">Customer's mobile device</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="125" x="117.5" y="41.582">[Apple IOS or Android]</text></g><!--MD5=[8cd91a8026ecd064a658212c3b3f8063]
cluster comp--><g id="cluster_comp"><rect height="299" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="282" x="701" y="696.5"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="165" x="759.5" y="715.1094">Customer's computer</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="212" x="736" y="731.082">[Mircosoft Windows of Apple macOS]</text></g><!--MD5=[2de28e47f9582cb6df153deeec479525]
cluster browser--><g id="cluster_browser"><rect height="213" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="234" x="725" y="758.5"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="103" x="790.5" y="777.1094">Web Browser</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="182" x="751" y="793.082">[Google Chrome, Mozilla Firefox]</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="217" x="71.5" y="462"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="122" y="488.6094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="124" x="118" y="504.582">[Java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="178" y="521.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="99" y="539.3613">Provides Internet Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="197" x="81.5" y="556.9707">functionality via a JSON/HTTPS</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="25" x="167.5" y="574.5801">API.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><path d="M71,818 C71,808 166,808 166,808 C166,808 261,808 261,818 L261,950.2656 C261,960.2656 166,960.2656 166,960.2656 C166,960.2656 71,960.2656 71,950.2656 L71,818 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M71,818 C71,828 166,828 166,828 C166,828 261,828 261,818 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="130" y="848.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="82" y="864.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="164" y="881.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="92" y="899.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="101.5" y="916.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="81" y="934.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="113.5" y="952.1895">access logs, etc.</text></g><!--MD5=[2331507006b4b8bee4c616015350b23c]
entity db2--><g id="elem_db2"><path d="M164,1175 C164,1165 259,1165 259,1165 C259,1165 354,1165 354,1175 L354,1307.2656 C354,1317.2656 259,1317.2656 259,1317.2656 C259,1317.2656 164,1317.2656 164,1307.2656 L164,1175 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M164,1175 C164,1185 259,1185 259,1185 C259,1185 354,1185 354,1175 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="223" y="1205.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="175" y="1221.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="257" y="1238.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="185" y="1256.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="194.5" y="1273.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="174" y="1291.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="206.5" y="1309.1895">access logs, etc.</text></g><!--MD5=[08af8945a84acfe1eabc0963aa87c412]
entity web--><g id="elem_web"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="393.5" y="462"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="124" x="441" y="488.6094">Web Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="124" x="441" y="504.582">[Java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="501" y="521.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="407.5" y="539.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="417" y="556.9707">the Internet Banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="449" y="574.5801">page application.</text></g><!--MD5=[870e13a82a9bc0252b17e3ad6e742bb1]
entity mobile--><g id="elem_mobile"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="77" y="61"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="137.5" y="87.6094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="153.5" y="103.582">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="178" y="120.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="93.5" y="138.3613">Provides a limited subset of</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="127" x="114.5" y="155.9707">the Internet Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="87" y="173.5801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="122" x="119" y="191.1895">their mobile device.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="741.5" y="812.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="751.5" y="839.1094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="133" x="775.5" y="855.082">[JavaScript and Angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="840" y="872.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="165" x="759.5" y="889.8613">Provides all of the Internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="146" x="767" y="907.4707">Banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="766" y="925.0801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="815" y="942.6895">browser.</text></g><!--MD5=[aa67fb756ea91151fa7b0a063a4e1220]
link mobile to api--><g id="link_mobile_api"><path d="M180,204.22 C180,274.86 180,382.84 180,453.44 " fill="none" id="mobile-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="180,461.86,183,453.86,177,453.86,180,461.86" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="104" x="181" y="249.457">Makes API calls to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="71" x="197.5" y="264.5508">[json/HTTPS]</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M741.3,817.26 C675.62,775.96 587.14,723.28 505,684 C450.19,657.79 432.12,661.55 377,636 C348.78,622.92 319.11,607.37 291.61,592.14 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="284.29,588.07,289.8128,594.5891,292.7375,589.3503,284.29,588.07" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="104" x="487" y="657.457">Makes API calls to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="71" x="503.5" y="672.5508">[json/HTTPS]</text></g><!--MD5=[ca038ce5783dc4b0fafb3b6644ac783b]
link web to spa--><g id="link_web_spa"><path d="M592.82,588.02 C615.09,605.07 638.22,624.32 658,644 C707.73,693.46 755.8,756.6 790.32,805.56 " fill="none" id="web-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="795.1,812.37,792.9531,804.1001,788.0447,807.551,795.1,812.37" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="149" x="687" y="657.457">Delivers to the customer's</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="75" x="724" y="672.5508">web browser</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M177.56,588.18 C175.26,646.81 171.8,735.08 169.26,799.75 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="168.94,807.92,172.2517,800.0439,166.2564,799.8084,168.94,807.92" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="143" x="176" y="657.457">Reads from and writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="228.5" y="672.5508">[JDBC]</text></g><!--MD5=[c945a0638e97c8d85bbaa16159667354]
link api to db2--><g id="link_api_db2"><path d="M283.55,588.21 C301.53,604.02 317.73,622.68 328,644 C409.05,812.28 342.71,1037.23 295.68,1156.9 " fill="none" id="api-to-db2" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="292.62,1164.63,298.3556,1158.2973,292.7773,1156.0874,292.62,1164.63" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="143" x="367" y="881.457">Reads from and writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="419.5" y="896.5508">[JDBC]</text></g><!--MD5=[ea1351de5d5b841bf911f898ed156919]
link db to db2--><g id="link_db_db2"><path d="M185.72,960.29 C200.83,1017.94 221.65,1097.42 237.24,1156.93 " fill="none" id="db-to-db2" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="239.31,1164.82,240.1845,1156.3209,234.3804,1157.8415,239.31,1164.82" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="205" y="1029.457">Replicates data to</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="834" y="1394"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="840" y="1416.5332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="893" y="1416.5332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1419.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="844" y="1434.1426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1437.2188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="844" y="1451.752">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1454.8281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="844" y="1469.3613">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1472.4375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="844" y="1486.9707">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1490.0469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="844" y="1504.5801">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1507.6563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="844" y="1522.1895">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1402" y2="1402"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1419.6094" y2="1419.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1437.2188" y2="1437.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1454.8281" y2="1454.8281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1472.4375" y2="1472.4375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1490.0469" y2="1490.0469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1507.6563" y2="1507.6563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1525.2656" y2="1525.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="840" y1="1402" y2="1525.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="961" x2="961" y1="1402" y2="1525.2656"/><!--MD5=[6a999edbe8a16f3529bdcbc0e4af265d]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Deployment.puml

LAYOUT_WITH_LEGEND()

Deployment_Node(plc, "Big Bank plc", "Big Bank plc data center"){
    Deployment_Node(dn, "bigbank-api***\tx8", "Ubuntu 16.04 LTS"){
        Deployment_Node(apache, "Apache Tomcat", "Apache Tomcat 8.x"){
            Container(api, "API Application", "Java and Spring MVC", "Provides Internet Banking functionality via a JSON/HTTPS API.")
        }
    }
    Deployment_Node(bigbankdb01, "bigbank-db01", "Ubuntu 16.04 LTS"){
        Deployment_Node(oracle, "Oracle - Primary", "Oracle 12c"){
            ContainerDb(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
        }
    }
    Deployment_Node(bigbankdb02, "bigbank-db02", "Ubuntu 16.04 LTS"){
        Deployment_Node(oracle2, "Oracle - Secondary", "Oracle 12c"){
            ContainerDb(db2, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
        }
    }
    Deployment_Node(bb2, "bigbank-web***\tx4", "Ubuntu 16.04 LTS"){
        Deployment_Node(apache2, "Apache Tomcat", "Apache Tomcat 8.x"){
            Container(web, "Web Application", "Java and Spring MVC", "Delivers the static content and the Internet Banking single page application.")
        }
    }
}

Deployment_Node(mob, "Customer's mobile device", "Apple IOS or Android"){
    Container(mobile, "Mobile App", "Xamarin", "Provides a limited subset of the Internet Banking functionality to customers via their mobile device.")
}

Deployment_Node(comp, "Customer's computer", "Mircosoft Windows of Apple macOS"){
    Deployment_Node(browser, "Web Browser", "Google Chrome, Mozilla Firefox"){
        Container(spa, "Single Page Application", "JavaScript and Angular", "Provides all of the Internet Banking functionality to customers via their web browser.")
    }
}

Rel(mobile, api, "Makes API calls to", "json/HTTPS")
Rel(spa, api, "Makes API calls to", "json/HTTPS")
Rel(web, spa, "Delivers to the customer's web browser")
Rel(api, db, "Reads from and writes to", "JDBC")
Rel(api, db2, "Reads from and writes to", "JDBC")
Rel(db, db2, "Replicates data to")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}














skinparam rectangle<<node>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #000000
    BorderColor #A2A2A2
    BorderStyle solid
}


hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "==Big Bank plc\n<size:12>[Big Bank plc data center]</size>" <<node>> as plc{
    rectangle "==bigbank-api***\tx8\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as dn{
        rectangle "==Apache Tomcat\n<size:12>[Apache Tomcat 8.x]</size>" <<node>> as apache{
            rectangle "==API Application\n//<size:12>[Java and Spring MVC]</size>//\n\n Provides Internet Banking functionality via a JSON/HTTPS API." <<container>> as api
        }
    }
    rectangle "==bigbank-db01\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bigbankdb01{
        rectangle "==Oracle - Primary\n<size:12>[Oracle 12c]</size>" <<node>> as oracle{
            database "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
        }
    }
    rectangle "==bigbank-db02\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bigbankdb02{
        rectangle "==Oracle - Secondary\n<size:12>[Oracle 12c]</size>" <<node>> as oracle2{
            database "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db2
        }
    }
    rectangle "==bigbank-web***\tx4\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bb2{
        rectangle "==Apache Tomcat\n<size:12>[Apache Tomcat 8.x]</size>" <<node>> as apache2{
            rectangle "==Web Application\n//<size:12>[Java and Spring MVC]</size>//\n\n Delivers the static content and the Internet Banking single page application." <<container>> as web
        }
    }
}

rectangle "==Customer's mobile device\n<size:12>[Apple IOS or Android]</size>" <<node>> as mob{
    rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset of the Internet Banking functionality to customers via their mobile device." <<container>> as mobile
}

rectangle "==Customer's computer\n<size:12>[Mircosoft Windows of Apple macOS]</size>" <<node>> as comp{
    rectangle "==Web Browser\n<size:12>[Google Chrome, Mozilla Firefox]</size>" <<node>> as browser{
        rectangle "==Single Page Application\n//<size:12>[JavaScript and Angular]</size>//\n\n Provides all of the Internet Banking functionality to customers via their web browser." <<container>> as spa
    }
}

mobile - ->> api : **Makes API calls to**\n//<size:12>[json/HTTPS]</size>//
spa - ->> api : **Makes API calls to**\n//<size:12>[json/HTTPS]</size>//
web - ->> spa : **Delivers to the customer's web browser**
api - ->> db : **Reads from and writes to**\n//<size:12>[JDBC]</size>//
api - ->> db2 : **Reads from and writes to**\n//<size:12>[JDBC]</size>//
db - ->> db2 : **Replicates data to**

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download deployment diagram](deployment.svg ':ignore')
-
-**Deployment diagram**
-
-A deployment diagram allows you to illustrate how containers in the static model are mapped to infrastructure. This deployment diagram is based upon a UML deployment diagram, although simplified slightly to show the mapping between containers and deployment nodes. A deployment node is something like physical infrastructure (e.g. a physical server or device), virtualised infrastructure (e.g. IaaS, PaaS, a virtual machine), containerised infrastructure (e.g. a Docker container), an execution environment (e.g. a database server, Java EE web/application server, Microsoft IIS), etc. Deployment nodes can be nested.
-
-**Scope**: A single software system.
-
-**Primary elements**: Deployment nodes and containers within the software system in scope.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
\ No newline at end of file
diff --git a/docs/2 Deployment/README.md b/docs/2 Deployment/README.md
deleted file mode 100644
index 1281367..0000000
--- a/docs/2 Deployment/README.md
+++ /dev/null
@@ -1,31 +0,0 @@
-# 2 Deployment
-
-`\2 Deployment`
-
-* [PySocial Project](../README.md)
- * [1 Internet Banking System](../1%20Internet%20Banking%20System/README.md)
- * [API Application](../1%20Internet%20Banking%20System/API%20Application/README.md)
- * [Single Page Application](../1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [Dynamic Diagram](../1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [Extended Docs](../1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [**2 Deployment**](../2%20Deployment/README.md)
-
----
-
-[PySocial Project (up)](../README.md)
-
----
-
-
-![deployment](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1549px" preserveAspectRatio="none" style="width:989px;height:1549px;background:#FFFFFF;" version="1.1" viewBox="0 0 989 1549" width="989px" zoomAndPan="magnify"><defs/><g><!--MD5=[d4f46b85ec0fd4984e46b6ab68a49907]
cluster plc--><g id="cluster_plc"><rect height="1097" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="670" x="7" y="284"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="97" x="293.5" y="302.6094">Big Bank plc</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="269" y="318.582">[Big Bank plc data center]</text></g><!--MD5=[cb60efe6e32ae9dc1419f0024d193ed3]
cluster dn--><g id="cluster_dn"><rect height="282" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="298" x="31" y="346"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="108" x="107" y="364.6094">bigbank-api***</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="18" x="235" y="364.6094">x8</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="126.5" y="380.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[8f463db2213924b28ab9fa8a8a25c26a]
cluster apache--><g id="cluster_apache"><rect height="196" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="250" x="55" y="408"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="119" x="120.5" y="426.6094">Apache Tomcat</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="121.5" y="442.582">[Apache Tomcat 8.x]</text></g><!--MD5=[7e0f1b407756c52dd30c4ead0f9230ac]
cluster bigbankdb01--><g id="cluster_bigbankdb01"><rect height="308" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="270" x="31" y="692"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="105" x="113.5" y="710.6094">bigbank-db01</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="112.5" y="726.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[d58f35efa7ac429240bfa5a7c4204cd4]
cluster oracle--><g id="cluster_oracle"><rect height="222" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="222" x="55" y="754"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="121" x="105.5" y="772.6094">Oracle - Primary</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="70" x="131" y="788.582">[Oracle 12c]</text></g><!--MD5=[9fa18d40767c7b2b82a18fa9dfe8338d]
cluster bigbankdb02--><g id="cluster_bigbankdb02"><rect height="308" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="270" x="124" y="1049"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="105" x="206.5" y="1067.6094">bigbank-db02</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="205.5" y="1083.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[69ad4c2ae5d24231281b185261861c19]
cluster oracle2--><g id="cluster_oracle2"><rect height="222" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="222" x="148" y="1111"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="145" x="186.5" y="1129.6094">Oracle - Secondary</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="70" x="224" y="1145.582">[Oracle 12c]</text></g><!--MD5=[8732ada0ac3d982aaf760ffd06e5f6c2]
cluster bb2--><g id="cluster_bb2"><rect height="282" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="300" x="353" y="346"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="430" y="364.6094">bigbank-web***</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="18" x="558" y="364.6094">x4</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="449.5" y="380.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[c9f3238ce9b9b9fe2ea53139a741cb96]
cluster apache2--><g id="cluster_apache2"><rect height="196" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="252" x="377" y="408"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="119" x="443.5" y="426.6094">Apache Tomcat</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="444.5" y="442.582">[Apache Tomcat 8.x]</text></g><!--MD5=[543156d0aa455e6607833fc05f747439]
cluster mob--><g id="cluster_mob"><rect height="213" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="238" x="61" y="7"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="197" x="81.5" y="25.6094">Customer's mobile device</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="125" x="117.5" y="41.582">[Apple IOS or Android]</text></g><!--MD5=[8cd91a8026ecd064a658212c3b3f8063]
cluster comp--><g id="cluster_comp"><rect height="299" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="282" x="701" y="696.5"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="165" x="759.5" y="715.1094">Customer's computer</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="212" x="736" y="731.082">[Mircosoft Windows of Apple macOS]</text></g><!--MD5=[2de28e47f9582cb6df153deeec479525]
cluster browser--><g id="cluster_browser"><rect height="213" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="234" x="725" y="758.5"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="103" x="790.5" y="777.1094">Web Browser</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="182" x="751" y="793.082">[Google Chrome, Mozilla Firefox]</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="217" x="71.5" y="462"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="122" y="488.6094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="124" x="118" y="504.582">[Java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="178" y="521.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="99" y="539.3613">Provides Internet Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="197" x="81.5" y="556.9707">functionality via a JSON/HTTPS</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="25" x="167.5" y="574.5801">API.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><path d="M71,818 C71,808 166,808 166,808 C166,808 261,808 261,818 L261,950.2656 C261,960.2656 166,960.2656 166,960.2656 C166,960.2656 71,960.2656 71,950.2656 L71,818 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M71,818 C71,828 166,828 166,828 C166,828 261,828 261,818 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="130" y="848.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="82" y="864.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="164" y="881.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="92" y="899.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="101.5" y="916.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="81" y="934.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="113.5" y="952.1895">access logs, etc.</text></g><!--MD5=[2331507006b4b8bee4c616015350b23c]
entity db2--><g id="elem_db2"><path d="M164,1175 C164,1165 259,1165 259,1165 C259,1165 354,1165 354,1175 L354,1307.2656 C354,1317.2656 259,1317.2656 259,1317.2656 C259,1317.2656 164,1317.2656 164,1307.2656 L164,1175 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M164,1175 C164,1185 259,1185 259,1185 C259,1185 354,1185 354,1175 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="223" y="1205.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="175" y="1221.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="257" y="1238.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="185" y="1256.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="194.5" y="1273.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="174" y="1291.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="206.5" y="1309.1895">access logs, etc.</text></g><!--MD5=[08af8945a84acfe1eabc0963aa87c412]
entity web--><g id="elem_web"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="393.5" y="462"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="124" x="441" y="488.6094">Web Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="124" x="441" y="504.582">[Java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="501" y="521.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="407.5" y="539.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="417" y="556.9707">the Internet Banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="449" y="574.5801">page application.</text></g><!--MD5=[870e13a82a9bc0252b17e3ad6e742bb1]
entity mobile--><g id="elem_mobile"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="77" y="61"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="137.5" y="87.6094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="153.5" y="103.582">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="178" y="120.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="93.5" y="138.3613">Provides a limited subset of</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="127" x="114.5" y="155.9707">the Internet Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="87" y="173.5801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="122" x="119" y="191.1895">their mobile device.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="741.5" y="812.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="751.5" y="839.1094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="133" x="775.5" y="855.082">[JavaScript and Angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="840" y="872.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="165" x="759.5" y="889.8613">Provides all of the Internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="146" x="767" y="907.4707">Banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="766" y="925.0801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="815" y="942.6895">browser.</text></g><!--MD5=[aa67fb756ea91151fa7b0a063a4e1220]
link mobile to api--><g id="link_mobile_api"><path d="M180,204.22 C180,274.86 180,382.84 180,453.44 " fill="none" id="mobile-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="180,461.86,183,453.86,177,453.86,180,461.86" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="104" x="181" y="249.457">Makes API calls to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="71" x="197.5" y="264.5508">[json/HTTPS]</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M741.3,817.26 C675.62,775.96 587.14,723.28 505,684 C450.19,657.79 432.12,661.55 377,636 C348.78,622.92 319.11,607.37 291.61,592.14 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="284.29,588.07,289.8128,594.5891,292.7375,589.3503,284.29,588.07" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="104" x="487" y="657.457">Makes API calls to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="71" x="503.5" y="672.5508">[json/HTTPS]</text></g><!--MD5=[ca038ce5783dc4b0fafb3b6644ac783b]
link web to spa--><g id="link_web_spa"><path d="M592.82,588.02 C615.09,605.07 638.22,624.32 658,644 C707.73,693.46 755.8,756.6 790.32,805.56 " fill="none" id="web-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="795.1,812.37,792.9531,804.1001,788.0447,807.551,795.1,812.37" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="149" x="687" y="657.457">Delivers to the customer's</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="75" x="724" y="672.5508">web browser</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M177.56,588.18 C175.26,646.81 171.8,735.08 169.26,799.75 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="168.94,807.92,172.2517,800.0439,166.2564,799.8084,168.94,807.92" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="143" x="176" y="657.457">Reads from and writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="228.5" y="672.5508">[JDBC]</text></g><!--MD5=[c945a0638e97c8d85bbaa16159667354]
link api to db2--><g id="link_api_db2"><path d="M283.55,588.21 C301.53,604.02 317.73,622.68 328,644 C409.05,812.28 342.71,1037.23 295.68,1156.9 " fill="none" id="api-to-db2" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="292.62,1164.63,298.3556,1158.2973,292.7773,1156.0874,292.62,1164.63" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="143" x="367" y="881.457">Reads from and writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="419.5" y="896.5508">[JDBC]</text></g><!--MD5=[ea1351de5d5b841bf911f898ed156919]
link db to db2--><g id="link_db_db2"><path d="M185.72,960.29 C200.83,1017.94 221.65,1097.42 237.24,1156.93 " fill="none" id="db-to-db2" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="239.31,1164.82,240.1845,1156.3209,234.3804,1157.8415,239.31,1164.82" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="205" y="1029.457">Replicates data to</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="834" y="1394"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="840" y="1416.5332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="893" y="1416.5332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1419.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="844" y="1434.1426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1437.2188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="844" y="1451.752">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1454.8281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="844" y="1469.3613">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1472.4375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="844" y="1486.9707">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1490.0469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="844" y="1504.5801">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1507.6563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="844" y="1522.1895">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1402" y2="1402"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1419.6094" y2="1419.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1437.2188" y2="1437.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1454.8281" y2="1454.8281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1472.4375" y2="1472.4375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1490.0469" y2="1490.0469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1507.6563" y2="1507.6563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1525.2656" y2="1525.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="840" y1="1402" y2="1525.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="961" x2="961" y1="1402" y2="1525.2656"/><!--MD5=[6a999edbe8a16f3529bdcbc0e4af265d]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Deployment.puml

LAYOUT_WITH_LEGEND()

Deployment_Node(plc, "Big Bank plc", "Big Bank plc data center"){
    Deployment_Node(dn, "bigbank-api***\tx8", "Ubuntu 16.04 LTS"){
        Deployment_Node(apache, "Apache Tomcat", "Apache Tomcat 8.x"){
            Container(api, "API Application", "Java and Spring MVC", "Provides Internet Banking functionality via a JSON/HTTPS API.")
        }
    }
    Deployment_Node(bigbankdb01, "bigbank-db01", "Ubuntu 16.04 LTS"){
        Deployment_Node(oracle, "Oracle - Primary", "Oracle 12c"){
            ContainerDb(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
        }
    }
    Deployment_Node(bigbankdb02, "bigbank-db02", "Ubuntu 16.04 LTS"){
        Deployment_Node(oracle2, "Oracle - Secondary", "Oracle 12c"){
            ContainerDb(db2, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
        }
    }
    Deployment_Node(bb2, "bigbank-web***\tx4", "Ubuntu 16.04 LTS"){
        Deployment_Node(apache2, "Apache Tomcat", "Apache Tomcat 8.x"){
            Container(web, "Web Application", "Java and Spring MVC", "Delivers the static content and the Internet Banking single page application.")
        }
    }
}

Deployment_Node(mob, "Customer's mobile device", "Apple IOS or Android"){
    Container(mobile, "Mobile App", "Xamarin", "Provides a limited subset of the Internet Banking functionality to customers via their mobile device.")
}

Deployment_Node(comp, "Customer's computer", "Mircosoft Windows of Apple macOS"){
    Deployment_Node(browser, "Web Browser", "Google Chrome, Mozilla Firefox"){
        Container(spa, "Single Page Application", "JavaScript and Angular", "Provides all of the Internet Banking functionality to customers via their web browser.")
    }
}

Rel(mobile, api, "Makes API calls to", "json/HTTPS")
Rel(spa, api, "Makes API calls to", "json/HTTPS")
Rel(web, spa, "Delivers to the customer's web browser")
Rel(api, db, "Reads from and writes to", "JDBC")
Rel(api, db2, "Reads from and writes to", "JDBC")
Rel(db, db2, "Replicates data to")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}














skinparam rectangle<<node>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #000000
    BorderColor #A2A2A2
    BorderStyle solid
}


hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "==Big Bank plc\n<size:12>[Big Bank plc data center]</size>" <<node>> as plc{
    rectangle "==bigbank-api***\tx8\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as dn{
        rectangle "==Apache Tomcat\n<size:12>[Apache Tomcat 8.x]</size>" <<node>> as apache{
            rectangle "==API Application\n//<size:12>[Java and Spring MVC]</size>//\n\n Provides Internet Banking functionality via a JSON/HTTPS API." <<container>> as api
        }
    }
    rectangle "==bigbank-db01\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bigbankdb01{
        rectangle "==Oracle - Primary\n<size:12>[Oracle 12c]</size>" <<node>> as oracle{
            database "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
        }
    }
    rectangle "==bigbank-db02\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bigbankdb02{
        rectangle "==Oracle - Secondary\n<size:12>[Oracle 12c]</size>" <<node>> as oracle2{
            database "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db2
        }
    }
    rectangle "==bigbank-web***\tx4\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bb2{
        rectangle "==Apache Tomcat\n<size:12>[Apache Tomcat 8.x]</size>" <<node>> as apache2{
            rectangle "==Web Application\n//<size:12>[Java and Spring MVC]</size>//\n\n Delivers the static content and the Internet Banking single page application." <<container>> as web
        }
    }
}

rectangle "==Customer's mobile device\n<size:12>[Apple IOS or Android]</size>" <<node>> as mob{
    rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset of the Internet Banking functionality to customers via their mobile device." <<container>> as mobile
}

rectangle "==Customer's computer\n<size:12>[Mircosoft Windows of Apple macOS]</size>" <<node>> as comp{
    rectangle "==Web Browser\n<size:12>[Google Chrome, Mozilla Firefox]</size>" <<node>> as browser{
        rectangle "==Single Page Application\n//<size:12>[JavaScript and Angular]</size>//\n\n Provides all of the Internet Banking functionality to customers via their web browser." <<container>> as spa
    }
}

mobile - ->> api : **Makes API calls to**\n//<size:12>[json/HTTPS]</size>//
spa - ->> api : **Makes API calls to**\n//<size:12>[json/HTTPS]</size>//
web - ->> spa : **Delivers to the customer's web browser**
api - ->> db : **Reads from and writes to**\n//<size:12>[JDBC]</size>//
api - ->> db2 : **Reads from and writes to**\n//<size:12>[JDBC]</size>//
db - ->> db2 : **Replicates data to**

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download deployment diagram](deployment.svg ':ignore')
-
-**Deployment diagram**
-
-A deployment diagram allows you to illustrate how containers in the static model are mapped to infrastructure. This deployment diagram is based upon a UML deployment diagram, although simplified slightly to show the mapping between containers and deployment nodes. A deployment node is something like physical infrastructure (e.g. a physical server or device), virtualised infrastructure (e.g. IaaS, PaaS, a virtual machine), containerised infrastructure (e.g. a Docker container), an execution environment (e.g. a database server, Java EE web/application server, Microsoft IIS), etc. Deployment nodes can be nested.
-
-**Scope**: A single software system.
-
-**Primary elements**: Deployment nodes and containers within the software system in scope.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
\ No newline at end of file
diff --git a/docs/2 Deployment/deployment.svg b/docs/2 Deployment/deployment.svg
deleted file mode 100644
index 7207ec3..0000000
--- a/docs/2 Deployment/deployment.svg
+++ /dev/null
@@ -1,363 +0,0 @@
-
\ No newline at end of file
diff --git a/docs/2020-01-10-16-21-41.png b/docs/2020-01-10-16-21-41.png
deleted file mode 100644
index ea176bb..0000000
Binary files a/docs/2020-01-10-16-21-41.png and /dev/null differ
diff --git a/docs/PySocial Project.pdf b/docs/PySocial Project.pdf
index d53d030..9a40266 100644
Binary files a/docs/PySocial Project.pdf and b/docs/PySocial Project.pdf differ
diff --git a/docs/PySocial.md b/docs/PySocial.md
index 8b6e292..70348d6 100644
--- a/docs/PySocial.md
+++ b/docs/PySocial.md
@@ -1,12 +1,7 @@
# PySocial
* [PySocial Project](#PySocial-Project)
- * [1 Internet Banking System](#1-Internet-Banking-System)
- * [API Application](#API-Application)
- * [Single Page Application](#Single-Page-Application)
- * [Dynamic Diagram](#Dynamic-Diagram)
- * [Extended Docs](#Extended-Docs)
- * [2 Deployment](#2-Deployment)
+ * [1 PySocial System](#1-PySocial-System)
---
@@ -37,150 +32,38 @@
**Público-alvo**: Todos, técnicos e não técnicos, dentro e fora da equipe de desenvolvimento de software.
-## 1 Internet Banking System
+## 1 PySocial System
-`\1 Internet Banking System`
+`\1 PySocial System`
[PySocial Project](#PySocial)
-![system](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1232px" preserveAspectRatio="none" style="width:939px;height:1232px;background:#FFFFFF;" version="1.1" viewBox="0 0 939 1232" width="939px" zoomAndPan="magnify"><defs/><g><!--MD5=[ba4347344a0e48752a561a8e7e2333c9]
cluster ibs--><g id="cluster_ibs"><rect height="901.5" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="475" x="229" y="163"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="126" x="403.5" y="181.6094">Internet Banking</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="51" x="441" y="197.582">[System]</text></g><!--MD5=[fe2e87a9fbde6b36e5fa52b641d8fb64]
entity wa--><g id="elem_wa"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="416.5" y="217"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="124" x="464" y="243.6094">Web Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="121" x="465.5" y="259.582">[java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="524" y="276.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="430.5" y="294.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="440.5" y="311.9707">the internet banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="472" y="329.5801">page application.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="486.5" y="452.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="496.5" y="479.1094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="127" x="523.5" y="495.082">[javascript and angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="585" y="512.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="512.5" y="529.8613">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="512.5" y="547.4707">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="511" y="565.0801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="560" y="582.6895">browser.</text></g><!--MD5=[99c5416311fbf9d118be657efd773f39]
entity ma--><g id="elem_ma"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="245" y="452.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="305.5" y="479.1094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="321.5" y="495.082">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="346" y="512.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="261.5" y="529.8613">Provides a limited subset ot</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="283" y="547.4707">the internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="255" y="565.0801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="264.5" y="582.6895">their mobile mobile device.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="190" x="487" y="905.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="546" y="932.1094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="498" y="948.082">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="580" y="965.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="508" y="982.8613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="517.5" y="1000.4707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="497" y="1018.0801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="529.5" y="1035.6895">access logs, etc.</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="212" x="476" y="687.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="524" y="714.1094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="117" x="523.5" y="730.082">[java and String MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="580" y="747.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="161" x="501.5" y="764.8613">Provides internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="486" y="782.4707">functionality via a JSON/HTTP</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="25" x="569.5" y="800.0801">API.</text></g><!--MD5=[055880c5ddffda0f84a4901cdc35d67e]
entity pbc--><g id="elem_pbc"><rect fill="#08427B" height="161.0781" rx="2.5" ry="2.5" style="stroke:#073B6F;stroke-width:0.5;" width="206" x="7" y="199.5"/><image height="48" width="48" x="86" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAIAAADYYG7QAAACD0lEQVR4Xu2YoU4EMRCGT+4j8Ai8AhaH4QHgAUjQuFMECUgMIUgwJAgMhgQsAYUiJCiQIBBY+EITsjfTdme6V24v4c8vyGbb+ZjOtN0bNcvjQXmkH83WvYBWto6PLm6v7p7uH1/w2fXD+PBycX1Pv2l3IdDm/vn7x+dXQiAubRzoURa7gRZWd0iGRIiJbOnhnfYBQZNJjNbuyY2eJG8fkDE3bbG4ep6MHUAsgYxmE3nVs6VsBWJSGccsOlFPmLIViMzLOB7pCVO2AtHJMohH7Fh6zqitQK7m0rJvAVYgGcEpe//PLdDz65sM4pF9N7ICcXDKIB5Nv6j7tD0NoSdM2QrU9Gg0ewE1LqBhHR3BBdvj2vapnidjHxD/q6vd7Pvhr31AwcY8eXMTXAKECZZJFXuEq27aLgQK5uLMohCenGGuGewOxSjBvYBqeG6B+Nqiblggdjnc+ZXDy+FNFpFzw76O3UBAROuXh6FoiAcf5g9eTvUgzy0nWg6I8cXHRUpg5bOVBCo+KDpFajOf23GgPme7RSQ+lacIENUgJ6gg1k6HjgOlqnLqip4tEuhv0hNEMXUD0clyXE3p6pZA0S2nnvTlXwLJEZWlb7cTQH1+USgTN4VhAenm/wea1OCAOmqo6fE1WCb9WSKBah+rbUWPWAmE2Rvk0ApiB45eOyNAzU8xcTvj8KvkKEoOaIYeHNA3ZuygAvFMUO0AAAAASUVORK5CYII=" y="209.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="136" x="40" y="274.1094">Personal Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="75" x="72.5" y="294.2344">Customer</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="108" y="312.2832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="21" y="329.8926">A customer of the bank, with</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="155" x="32.5" y="347.502">personal bank accounts.</text></g><!--MD5=[ded6a69210fbbc7961dee7b773232267]
entity es--><g id="elem_es"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="176" x="338" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="373" y="33.6094">E-mail system</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="424" y="51.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="137" x="357.5" y="69.2676">The internal Microsoft</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="156" x="348" y="86.877">Exchange e-mail system.</text></g><!--MD5=[caf83f36d3620b5db28366bd7d249751]
entity mbs--><g id="elem_mbs"><rect fill="#999999" height="130.6875" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="213" x="720.5" y="911.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="751.5" y="938.1094">Mainframe Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="57" x="798.5" y="958.2344">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="825" y="976.2832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="185" x="734.5" y="993.8926">Stores all of the core banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="733.5" y="1011.502">information about customers,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="740.5" y="1029.1113">accounts, transactions, etc.</text></g><!--MD5=[e9c20127f585181a79dab89266001537]
link api to es--><g id="link_api_es"><path d="M652.28,687.36 C675.2,661.74 696.86,629.97 705,595.5 C750.29,403.64 774.42,310.31 653,155 C620.81,113.83 568.19,89.11 521.72,74.5 " fill="none" id="api-to-es" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="514.02,72.15,520.7895,77.3629,522.5479,71.6264,514.02,72.15" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="81" x="742" y="403.957">Sends e-mails</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="763.5" y="419.0508">[SMTP]</text></g><!--MD5=[058ef8e85ab64ed7b349259f69e8bfb6]
link api to mbs--><g id="link_api_mbs"><path d="M658.88,813.73 C670.46,823.53 682.15,833.67 693,843.5 C714.72,863.17 737.65,885.3 758.28,905.76 " fill="none" id="api-to-mbs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="764.03,911.48,760.4651,903.7153,756.2385,907.9739,764.03,911.48" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="749.5" y="856.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="728" y="872.0508">[XML/HTTPS]</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M582,813.74 C582,839.6 582,869.92 582,897.31 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="582,905.32,585,897.32,579,897.32,582,905.32" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="101" x="583" y="856.957">Reads &amp; writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="614.5" y="872.0508">[JDBC]</text></g><!--MD5=[61eecc891977d187ae935fece35ea030]
link wa to spa--><g id="link_wa_spa"><path d="M541.63,343.01 C549.41,373.86 558.89,411.5 567.18,444.36 " fill="none" id="wa-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="569.14,452.16,570.0918,443.6692,564.2741,445.137,569.14,452.16" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="46" x="561" y="411.457">Delivers</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M585.42,595.73 C584.83,622.4 584.16,652.71 583.56,679.33 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="583.38,687.47,586.5507,679.5361,580.5521,679.4076,583.38,687.47" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="610.5" y="638.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="585" y="654.0508">[JSON/HTTPS]</text></g><!--MD5=[efcb8ef56d3c96dbd54ad0916bef4ec1]
link ma to api--><g id="link_ma_api"><path d="M421.72,595.73 C450.36,623.2 483.03,654.55 511.37,681.73 " fill="none" id="ma-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="517.35,687.47,513.6581,679.7648,509.502,684.0923,517.35,687.47" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="511.5" y="638.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="486" y="654.0508">[JSON/HTTPS]</text></g><!--MD5=[7acc9246d326cc0ca04f231532551af9]
link pbc to wa--><g id="link_pbc_wa"><path d="M213.1,280 C272.28,280 346.81,280 408.28,280 " fill="none" id="pbc-to-wa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="416.48,280,408.48,277,408.48,283,416.48,280" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="300.25" y="258.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="45" x="292.25" y="273.5508">[HTTPS]</text></g><!--MD5=[b09e1e3c9017f3791a48d778fd7ab8a5]
link pbc to spa--><g id="link_pbc_spa"><path d="M213.01,351.78 C218.36,354.83 223.7,357.76 229,360.5 C330.46,413 366.25,402.57 469,452.5 C472.29,454.1 475.61,455.76 478.94,457.46 " fill="none" id="pbc-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="486.25,461.27,480.542,454.9125,477.7691,460.2333,486.25,461.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="396" y="411.457">Uses</text></g><!--MD5=[2d531d403c1ff55482e84426773c64ad]
link pbc to ma--><g id="link_pbc_ma"><path d="M188.26,360.58 C215.45,388.23 245.88,419.16 272.82,446.55 " fill="none" id="pbc-to-ma" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="278.51,452.34,275.0434,444.5308,270.7634,448.7358,278.51,452.34" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="244" y="411.457">Uses</text></g><!--MD5=[8b7693a20d41c2a1fa27d9f6a96ec3b6]
link es to pbc--><g id="link_es_pbc"><path d="M337.98,91.64 C302.55,108.52 262.29,130.27 229,155 C213.7,166.36 198.63,179.78 184.62,193.51 " fill="none" id="es-to-pbc" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="178.68,199.41,186.4671,195.8941,182.2352,191.6408,178.68,199.41" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="95" x="265" y="143.457">Sends e-mails to</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="784.5" y="1077.5"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="790.5" y="1100.0332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="843.5" y="1100.0332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1103.1094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="794.5" y="1117.6426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1120.7188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="794.5" y="1135.252">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1138.3281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="794.5" y="1152.8613">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1155.9375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="794.5" y="1170.4707">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1173.5469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="794.5" y="1188.0801">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="790.5" y="1191.1563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="794.5" y="1205.6895">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1085.5" y2="1085.5"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1103.1094" y2="1103.1094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1120.7188" y2="1120.7188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1138.3281" y2="1138.3281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1155.9375" y2="1155.9375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1173.5469" y2="1173.5469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1191.1563" y2="1191.1563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="911.5" y1="1208.7656" y2="1208.7656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="790.5" x2="790.5" y1="1085.5" y2="1208.7656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="911.5" x2="911.5" y1="1085.5" y2="1208.7656"/><!--MD5=[b6997e2e3bb5d4f6be4be230d598b248]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml

LAYOUT_WITH_LEGEND()

Person(pbc, "Personal Banking Customer", "A customer of the bank, with personal bank accounts.")
System_Ext(es, "E-mail system", "The internal Microsoft Exchange e-mail system.")
System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")
System_Boundary(ibs, "Internet Banking") {
    Container(wa, "Web Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")
    Container(spa, "Single Page Application", "javascript and angular", "Provides all the internet banking functionality to customers via their web browser.")
    Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
    Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
    Container(api, "API Application", "java and String MVC", "Provides internet banking functionality via a JSON/HTTP API.")

    Rel(api, es, "Sends e-mails", "SMTP")
    Rel(api, mbs, "Uses", "XML/HTTPS")
    Rel(api, db, "Reads & writes to", "JDBC")
    Rel(wa, spa, "Delivers")
    Rel(spa, api, "Uses", "JSON/HTTPS")
    Rel(ma, api, "Uses", "JSON/HTTPS")
}

Rel(pbc, wa, "Uses", "HTTPS")
Rel(pbc, spa, "Uses")
Rel(pbc, ma, "Uses")
Rel(es, pbc, "Sends e-mails to")
@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}













hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "<$person>\n==Personal Banking Customer\n\n A customer of the bank, with personal bank accounts." <<person>> as pbc
rectangle "==E-mail system\n\n The internal Microsoft Exchange e-mail system." <<external_system>> as es
rectangle "==Mainframe Banking System\n\n Stores all of the core banking information about customers, accounts, transactions, etc." <<external_system>> as mbs
rectangle "==Internet Banking\n<size:12>[System]</size>" <<boundary>> as ibs {
    rectangle "==Web Application\n//<size:12>[java and Spring MVC]</size>//\n\n Delivers the static content and the internet banking single page application." <<container>> as wa
    rectangle "==Single Page Application\n//<size:12>[javascript and angular]</size>//\n\n Provides all the internet banking functionality to customers via their web browser." <<container>> as spa
    rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device." <<container>> as ma
    rectangle "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
    rectangle "==API Application\n//<size:12>[java and String MVC]</size>//\n\n Provides internet banking functionality via a JSON/HTTP API." <<container>> as api

api - ->> es : **Sends e-mails**\n//<size:12>[SMTP]</size>//
api - ->> mbs : **Uses**\n//<size:12>[XML/HTTPS]</size>//
api - ->> db : **Reads & writes to**\n//<size:12>[JDBC]</size>//
wa - ->> spa : **Delivers**
spa - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
ma - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
}

pbc - ->> wa : **Uses**\n//<size:12>[HTTPS]</size>//
pbc - ->> spa : **Uses**
pbc - ->> ma : **Uses**
es - ->> pbc : **Sends e-mails to**
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
+![system](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1094px" preserveAspectRatio="none" style="width:1253px;height:1094px;background:#FFFFFF;" version="1.1" viewBox="0 0 1253 1094" width="1253px" zoomAndPan="magnify"><defs/><g><!--MD5=[df801953c3eb52426c535e27a34580d5]
cluster pys--><g id="cluster_pys"><rect height="494" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="222" x="516" y="261"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="128" x="563" y="279.6094">PySocial System</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="51" x="601.5" y="295.582">[System]</text></g><!--MD5=[ef876daef8096df7f4ce46fa39b9e1a2]
entity pyWeb--><g id="elem_pyWeb"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="131" x="561.5" y="315"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="571.5" y="341.6094">PyWebView UI</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="357.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="374.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="96" x="581" y="392.3613">UI da aplicação</text></g><!--MD5=[fd71a720deb277bbd1af72c03fa35a41]
entity py--><g id="elem_py"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="189" x="532.5" y="482"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="145" x="554.5" y="508.6094">Python Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="524.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="541.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="165" x="546.5" y="559.3613">Core domain da aplicação</text></g><!--MD5=[734cf7e73ed9318c8e9ec5225b8633af]
entity pyAcl--><g id="elem_pyAcl"><rect fill="#438DD5" height="90.4375" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="135" x="559.5" y="649"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="96" x="579" y="675.6094">API Interface</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="51" x="601.5" y="691.582">[Python3]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="708.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="111" x="573.5" y="726.3613">ACL da aplicação</text></g><!--MD5=[8fc3522a43f8c7199df5e09e5bb0188e]
entity user--><g id="elem_user"><rect fill="#08427B" height="176.1719" rx="2.5" ry="2.5" style="stroke:#073B6F;stroke-width:0.5;" width="207" x="523.5" y="7"/><image height="48" width="48" x="603" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAIAAADYYG7QAAACD0lEQVR4Xu2YoU4EMRCGT+4j8Ai8AhaH4QHgAUjQuFMECUgMIUgwJAgMhgQsAYUiJCiQIBBY+EITsjfTdme6V24v4c8vyGbb+ZjOtN0bNcvjQXmkH83WvYBWto6PLm6v7p7uH1/w2fXD+PBycX1Pv2l3IdDm/vn7x+dXQiAubRzoURa7gRZWd0iGRIiJbOnhnfYBQZNJjNbuyY2eJG8fkDE3bbG4ep6MHUAsgYxmE3nVs6VsBWJSGccsOlFPmLIViMzLOB7pCVO2AtHJMohH7Fh6zqitQK7m0rJvAVYgGcEpe//PLdDz65sM4pF9N7ICcXDKIB5Nv6j7tD0NoSdM2QrU9Gg0ewE1LqBhHR3BBdvj2vapnidjHxD/q6vd7Pvhr31AwcY8eXMTXAKECZZJFXuEq27aLgQK5uLMohCenGGuGewOxSjBvYBqeG6B+Nqiblggdjnc+ZXDy+FNFpFzw76O3UBAROuXh6FoiAcf5g9eTvUgzy0nWg6I8cXHRUpg5bOVBCo+KDpFajOf23GgPme7RSQ+lacIENUgJ6gg1k6HjgOlqnLqip4tEuhv0hNEMXUD0clyXE3p6pZA0S2nnvTlXwLJEZWlb7cTQH1+USgTN4VhAenm/wea1OCAOmqo6fE1WCb9WSKBah+rbUWPWAmE2Rvk0ApiB45eOyNAzU8xcTvj8KvkKEoOaIYeHNA3ZuygAvFMUO0AAAAASUVORK5CYII=" y="17"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="60" x="597" y="81.6094">Usuário</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="99.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="161" x="546.5" y="117.2676">Um usuário que possue a</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="155" x="547.5" y="134.877">necessidade de enviar o</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="533.5" y="152.4863">mesmo conteúdo para várias</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="87" x="583.5" y="170.0957">redes sociais.</text></g><!--MD5=[585917e793a1fe337a2a50e5f9ed7522]
entity face--><g id="elem_face"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="7" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="64" y="859.6094">Facebook API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="115" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="21" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="47" y="912.877">rede social Facebook.</text></g><!--MD5=[f575475bb9b2a227ddc3b96a8d3fb34d]
entity inst--><g id="elem_inst"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="262" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="319" y="859.6094">Instagram API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="370" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="276" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="302.5" y="912.877">rede social Instagram.</text></g><!--MD5=[fd07f395667725ff60a8c06b2c928ecc]
entity x--><g id="elem_x"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="517" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="106" x="574" y="859.6094">X (Twiiter) API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="625" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="531" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="85" x="584.5" y="912.877">rede social X.</text></g><!--MD5=[2117018183c09a01edf82456b59260a5]
entity tt--><g id="elem_tt"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="772" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="82" x="841" y="859.6094">TikTok API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="880" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="786" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="120" x="822" y="912.877">rede social TikTok.</text></g><!--MD5=[14a53e5de2f3a515d643c2a1018893cf]
entity yt--><g id="elem_yt"><rect fill="#999999" height="92.9531" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="220" x="1027" y="833"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="99" x="1087.5" y="859.6094">YouTube API</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1135" y="877.6582"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="192" x="1041" y="895.2676">Interface de comunicação com</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="135" x="1069.5" y="912.877">rede social YouTube.</text></g><!--MD5=[473f11c98570ddc1410bd9bc4b66bf6a]
link pyWeb to py--><g id="link_pyWeb_py"><path d="M627,405.22 C627,426.29 627,451.65 627,473.68 " fill="none" id="pyWeb-to-py" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,481.95,630,473.95,624,473.95,627,481.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="628" y="448.457">Uses</text></g><!--MD5=[39d6a6c8b6a6dcd4921e1907d9f2a540]
link py to pyAcl--><g id="link_py_pyAcl"><path d="M627,572.22 C627,593.29 627,618.65 627,640.68 " fill="none" id="py-to-pyAcl" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,648.95,630,640.95,624,640.95,627,648.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="628" y="615.457">Uses</text></g><!--MD5=[fbc8c276177d97d8a94fd81429bfb8de]
link user to pyWeb--><g id="link_user_pyWeb"><path d="M627,183.21 C627,224.05 627,271.33 627,306.57 " fill="none" id="user-to-pyWeb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,314.81,630,306.81,624,306.81,627,314.81" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="75" x="628" y="226.457">Interage com</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="19" x="656" y="241.5508">[UI]</text></g><!--MD5=[483eec5be0afa8f3fa55b9e74604b347]
link pyAcl to face--><g id="link_pyAcl_face"><path d="M559.43,716.11 C512.97,730.87 449.99,751.38 395,771 C342.04,789.9 283.94,812.13 234.62,831.45 " fill="none" id="pyAcl-to-face" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="227.1,834.4,235.6429,834.2625,233.446,828.6791,227.1,834.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="411" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="396" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[7663349bf6f6eaa2d5a6226383662c38]
link pyAcl to inst--><g id="link_pyAcl_inst"><path d="M565.6,739.19 C528.4,765.95 480.83,800.19 442.15,828.02 " fill="none" id="pyAcl-to-inst" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="435.53,832.78,443.7748,830.5387,440.2681,825.6701,435.53,832.78" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="531" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="516" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[577866a7e55ab679ceb599ce297f6ac2]
link pyAcl to x--><g id="link_pyAcl_x"><path d="M627,739.42 C627,765.09 627,797.56 627,824.67 " fill="none" id="pyAcl-to-x" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="627,832.89,630,824.89,624,824.89,627,832.89" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="643" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="628" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[edbb0970577f5f34a35f665a12ea2d0a]
link pyAcl to tt--><g id="link_pyAcl_tt"><path d="M688.4,739.19 C725.6,765.95 773.17,800.19 811.85,828.02 " fill="none" id="pyAcl-to-tt" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="818.47,832.78,813.7319,825.6701,810.2252,830.5387,818.47,832.78" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="786" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="771" y="799.5508">[JSON/HTTPS]</text></g><!--MD5=[75306bdb9a51061fb1c0b9bfc4c17bb5]
link pyAcl to yt--><g id="link_pyAcl_yt"><path d="M694.63,715.98 C741.31,730.72 804.7,751.27 860,771 C912.68,789.8 970.43,811.96 1019.5,831.26 " fill="none" id="pyAcl-to-yt" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1026.99,834.21,1020.644,828.4891,1018.4471,834.0725,1026.99,834.21" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="50" x="961" y="784.457">requisita</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="946" y="799.5508">[JSON/HTTPS]</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="1098" y="938.9531"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="1104" y="961.4863">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1157" y="961.4863"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="964.5625"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="1108" y="979.0957">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="982.1719"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="1108" y="996.7051">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="999.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="1108" y="1014.3145">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1017.3906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="1108" y="1031.9238">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1035"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="1108" y="1049.5332">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="1104" y="1052.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="1108" y="1067.1426">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="946.9531" y2="946.9531"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="964.5625" y2="964.5625"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="982.1719" y2="982.1719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="999.7813" y2="999.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1017.3906" y2="1017.3906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1035" y2="1035"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1052.6094" y2="1052.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1225" y1="1070.2188" y2="1070.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1104" x2="1104" y1="946.9531" y2="1070.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1225" x2="1225" y1="946.9531" y2="1070.2188"/><!--MD5=[d84a0cd1768b34996afb20f8e6a689be]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml

LAYOUT_WITH_LEGEND()

Person(user, "Usuário", "Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais.")
System_Ext(face, "Facebook API", "Interface de comunicação com rede social Facebook.")
System_Ext(inst, "Instagram API", "Interface de comunicação com rede social Instagram.")
System_Ext(x, "X (Twiiter) API", "Interface de comunicação com rede social X.")
System_Ext(tt, "TikTok API", "Interface de comunicação com rede social TikTok.")
System_Ext(yt, "YouTube API", "Interface de comunicação com rede social YouTube.")

System_Boundary(pys, "PySocial System") {
    Container(pyWeb, "PyWebView UI", "Python3", "UI da aplicação")
    Container(py, "Python Application", "Python3", "Core domain da aplicação")
    Container(pyAcl, "API Interface", "Python3", "ACL da aplicação")

    Rel(pyWeb, py, "Uses")
    Rel(py, pyAcl, "Uses")
}

Rel(user, pyWeb, "Interage com", "UI")
Rel(pyAcl, face, "requisita", "JSON/HTTPS")
Rel(pyAcl, inst, "requisita", "JSON/HTTPS")
Rel(pyAcl, x, "requisita", "JSON/HTTPS")
Rel(pyAcl, tt, "requisita", "JSON/HTTPS")
Rel(pyAcl, yt, "requisita", "JSON/HTTPS")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}













hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "<$person>\n==Usuário\n\n Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais." <<person>> as user
rectangle "==Facebook API\n\n Interface de comunicação com rede social Facebook." <<external_system>> as face
rectangle "==Instagram API\n\n Interface de comunicação com rede social Instagram." <<external_system>> as inst
rectangle "==X (Twiiter) API\n\n Interface de comunicação com rede social X." <<external_system>> as x
rectangle "==TikTok API\n\n Interface de comunicação com rede social TikTok." <<external_system>> as tt
rectangle "==YouTube API\n\n Interface de comunicação com rede social YouTube." <<external_system>> as yt

rectangle "==PySocial System\n<size:12>[System]</size>" <<boundary>> as pys {
    rectangle "==PyWebView UI\n//<size:12>[Python3]</size>//\n\n UI da aplicação" <<container>> as pyWeb
    rectangle "==Python Application\n//<size:12>[Python3]</size>//\n\n Core domain da aplicação" <<container>> as py
    rectangle "==API Interface\n//<size:12>[Python3]</size>//\n\n ACL da aplicação" <<container>> as pyAcl

pyWeb - ->> py : **Uses**
py - ->> pyAcl : **Uses**
}

user - ->> pyWeb : **Interage com**\n//<size:12>[UI]</size>//
pyAcl - ->> face : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> inst : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> x : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> tt : **requisita**\n//<size:12>[JSON/HTTPS]</size>//
pyAcl - ->> yt : **requisita**\n//<size:12>[JSON/HTTPS]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-[Download system diagram](/1%20Internet%20Banking%20System/system.svg ':ignore')
+[Download system diagram](/1%20PySocial%20System/system.svg ':ignore')
-**Level 2: Container diagram**
+**Level 2: Diagrama de contêiner**
-Once you understand how your system fits in to the overall IT environment, a really useful next step is to zoom-in to the system boundary with a Container diagram. A "container" is something like a server-side web application, single-page application, desktop application, mobile app, database schema, file system, etc. Essentially, a container is a separately runnable/deployable unit (e.g. a separate process space) that executes code or stores data.
-The Container diagram shows the high-level shape of the software architecture and how responsibilities are distributed across it. It also shows the major technology choices and how the containers communicate with one another. It's a simple, high-level technology focussed diagram that is useful for software developers and support/operations staff alike.
+**Scope**: Sistema de software PySocial.
-**Scope**: A single software system.
+**Elementos primários**:
+* PyWebView UI
+* Python Application
+* API Interface
-**Primary elements**: Containers within the software system in scope.
-Supporting elements: People and software systems directly connected to the containers.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
-
-**Notes**: This diagram says nothing about deployment scenarios, clustering, replication, failover, etc.
-
-## API Application
-
-`\1 Internet Banking System\API Application`
-
-[PySocial Project](#PySocial)
-
-
-![container](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1073px" preserveAspectRatio="none" style="width:500px;height:1073px;background:#FFFFFF;" version="1.1" viewBox="0 0 500 1073" width="500px" zoomAndPan="magnify"><defs/><g><!--MD5=[7442f3b126ee602ae02566c1a49e158a]
cluster api--><g id="cluster_api"><rect height="421" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="487" x="7" y="228"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="192.5" y="246.6094">API Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="219" y="262.582">[Container]</text></g><!--MD5=[30860e21ba0e39165c540f9e23fe2d63]
entity sign--><g id="elem_sign"><rect fill="#85BBF0" height="108.0469" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="207" x="24.5" y="301"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="133" x="61.5" y="327.6094">Sign In Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="113" x="71.5" y="343.582">[MVC Rest Controlle]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="360.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="38.5" y="378.3613">Allows users to sign in to the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="150" x="53" y="395.9707">internet banking system</text></g><!--MD5=[4d2c1095686cc4272d4556037dedae14]
entity accounts--><g id="elem_accounts"><rect fill="#85BBF0" height="145.7813" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="192" x="277" y="282"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="150" x="296" y="308.6094">Accounts Summary</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="76" x="335" y="328.7344">Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="113" x="316.5" y="344.707">[MVC Rest Controlle]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="361.877"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="164" x="291" y="379.4863">Provides customers with a</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="301" y="397.0957">summory of their bank</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="57" x="344.5" y="414.7051">accounts</text></g><!--MD5=[6f1da96282e479ff2a49312c7753703d]
entity security--><g id="elem_security"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="23" y="506"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="49.5" y="532.6094">Security Component</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="91" y="548.582">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="565.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="37" y="583.3613">Provides functionality related</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="142" x="55" y="600.9707">to singing in, changing</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="79" y="618.5801">passwords, etc.</text></g><!--MD5=[8f94240328f985b36a3be06efd5d45ef]
entity mbsfacade--><g id="elem_mbsfacade"><rect fill="#85BBF0" height="128.1719" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="268" y="505"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="297.5" y="531.6094">Mainframe Banking</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="314.5" y="551.7344">System Facade</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="336" y="567.707">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="584.877"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="282" y="602.4863">A facade onto the mainframe</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="102" x="322" y="620.0957">banking system.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="29.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="39.5" y="33.6094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="112" x="74" y="49.582">[javascript and react]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="128" y="66.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="55.5" y="84.3613">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="55.5" y="101.9707">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="119.5801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="103" y="137.1895">browser.</text></g><!--MD5=[99c5416311fbf9d118be657efd773f39]
entity ma--><g id="elem_ma"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="268" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="328.5" y="33.6094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="344.5" y="49.582">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="369" y="66.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="284.5" y="84.3613">Provides a limited subset ot</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="306" y="101.9707">the internet banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="278" y="119.5801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="287.5" y="137.1895">their mobile mobile device.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="190" x="33" y="727"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="92" y="753.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="44" y="769.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="786.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="804.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="63.5" y="821.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="43" y="839.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="75.5" y="857.1895">access logs, etc.</text></g><!--MD5=[caf83f36d3620b5db28366bd7d249751]
entity mbs--><g id="elem_mbs"><rect fill="#999999" height="130.6875" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="213" x="266.5" y="733"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="147" x="297.5" y="759.6094">Mainframe Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="57" x="344.5" y="779.7344">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="371" y="797.7832"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="185" x="280.5" y="815.3926">Stores all of the core banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="183" x="279.5" y="833.002">information about customers,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="286.5" y="850.6113">accounts, transactions, etc.</text></g><!--MD5=[95dadc5fd8c5c901d6969e2e98c70c21]
link sign to security--><g id="link_sign_security"><path d="M128,409.22 C128,436.02 128,468.85 128,497.7 " fill="none" id="sign-to-security" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,505.72,131,497.72,125,497.72,128,505.72" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="129" y="471.457">Uses</text></g><!--MD5=[42d8fcfb42dec18b2b51d602409b2c47]
link accounts to mbsfacade--><g id="link_accounts_mbsfacade"><path d="M373,428.07 C373,450.31 373,474.77 373,496.94 " fill="none" id="accounts-to-mbsfacade" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="373,504.99,376,496.99,370,496.99,373,504.99" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="374" y="471.457">Uses</text></g><!--MD5=[2f3b256d614db35f96be6b3c1201bf4f]
link security to db--><g id="link_security_db"><path d="M128,632.17 C128,658.87 128,690.38 128,718.69 " fill="none" id="security-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,726.98,131,718.98,125,718.98,128,726.98" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="87" x="129" y="678.457">Read &amp; write to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="153.5" y="693.5508">[JDBC]</text></g><!--MD5=[db502886685a38a9fde1816e185dd0e0]
link mbsfacade to mbs--><g id="link_mbsfacade_mbs"><path d="M373,633.07 C373,661.44 373,695.09 373,724.54 " fill="none" id="mbsfacade-to-mbs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="373,732.72,376,724.72,370,724.72,373,732.72" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="395.5" y="678.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="374" y="693.5508">[XML/HTTPS]</text></g><!--MD5=[c99bcb02a7404ff7207e229366f7705a]
link spa to sign--><g id="link_spa_sign"><path d="M77.48,150.07 C72.39,159.73 68,169.84 65,180 C53.71,218.24 68.18,260.3 86.08,293.49 " fill="none" id="spa-to-sign" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="90.19,300.86,88.9097,292.4125,83.6709,295.3372,90.19,300.86" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="91.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="66" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[cadaf8a8a3c36cf6631f6dffced8899b]
link spa to accounts--><g id="link_spa_accounts"><path d="M145.43,150.34 C153.94,173.4 167.01,196.92 187,212 C209.18,228.74 224.31,207.26 249,220 C274.88,233.35 298.15,254.37 317.36,275.84 " fill="none" id="spa-to-accounts" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="322.66,281.9,319.643,273.9064,315.1308,277.8612,322.66,281.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="213.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="188" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[f21b9bec839c07106b83575f200b93d2]
link ma to sign--><g id="link_ma_sign"><path d="M327.09,150.06 C311.66,171.52 293.1,194.13 273,212 C267.64,216.76 264.67,215.62 259,220 C230.4,242.1 201.95,270.26 178.91,295.05 " fill="none" id="ma-to-sign" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="173.48,300.94,181.1091,297.0933,176.6986,293.0254,173.48,300.94" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="328.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="303" y="208.5508">[JSON/HTTPS]</text></g><!--MD5=[334addda0037abd6e432739e1785e7cb]
link ma to accounts--><g id="link_ma_accounts"><path d="M390.08,150.23 C392.11,160.16 393.86,170.29 395,180 C398.6,210.54 395.93,244.07 391.38,273.47 " fill="none" id="ma-to-accounts" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="390.05,281.65,394.2831,274.2283,388.3593,273.275,390.05,281.65" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="422.5" y="193.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="397" y="208.5508">[JSON/HTTPS]</text></g><rect height="174.4844" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="144" x="334" y="883.2656"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="340" y="905.7988">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="393" y="905.7988"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="908.875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="344" y="923.4082">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="926.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="344" y="941.0176">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="944.0938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="344" y="958.627">container</text><rect fill="#85BBF0" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="961.7031"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="344" y="976.2363">component</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="979.3125"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="344" y="993.8457">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="996.9219"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="344" y="1011.4551">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="1014.5313"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="344" y="1029.0645">external container</text><rect fill="#CCCCCC" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="340" y="1032.1406"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="344" y="1046.6738">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="891.2656" y2="891.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="908.875" y2="908.875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="926.4844" y2="926.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="944.0938" y2="944.0938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="961.7031" y2="961.7031"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="979.3125" y2="979.3125"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="996.9219" y2="996.9219"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1014.5313" y2="1014.5313"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1032.1406" y2="1032.1406"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="472" y1="1049.75" y2="1049.75"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="340" x2="340" y1="891.2656" y2="1049.75"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="472" x2="472" y1="891.2656" y2="1049.75"/><!--MD5=[97230ba690e1599ca29f1f3298fa8193]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

LAYOUT_WITH_LEGEND()

Container(spa, "Single Page Application", "javascript and react", "Provides all the internet banking functionality to customers via their web browser.")
Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")

Container_Boundary(api, "API Application") {
    Component(sign, "Sign In Controller", "MVC Rest Controlle", "Allows users to sign in to the internet banking system")
    Component(accounts, "Accounts Summary Controller", "MVC Rest Controlle", "Provides customers with a summory of their bank accounts")
    Component(security, "Security Component", "Spring Bean", "Provides functionality related to singing in, changing passwords, etc.")
    Component(mbsfacade, "Mainframe Banking System Facade", "Spring Bean", "A facade onto the mainframe banking system.")

    Rel(sign, security, "Uses")
    Rel(accounts, mbsfacade, "Uses")
    Rel(security, db, "Read & write to", "JDBC")
    Rel(mbsfacade, mbs, "Uses", "XML/HTTPS")
}

Rel(spa, sign, "Uses", "JSON/HTTPS")
Rel(spa, accounts, "Uses", "JSON/HTTPS")

Rel(ma, sign, "Uses", "JSON/HTTPS")
Rel(ma, accounts, "Uses", "JSON/HTTPS")
@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}











hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#85BBF0> component |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
|<#CCCCCC> external component |
endlegend

rectangle "==Single Page Application\n//<size:12>[javascript and react]</size>//\n\n Provides all the internet banking functionality to customers via their web browser." <<container>> as spa
rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device." <<container>> as ma
rectangle "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
rectangle "==Mainframe Banking System\n\n Stores all of the core banking information about customers, accounts, transactions, etc." <<external_system>> as mbs

rectangle "==API Application\n<size:12>[Container]</size>" <<boundary>> as api {
    rectangle "==Sign In Controller\n//<size:12>[MVC Rest Controlle]</size>//\n\n Allows users to sign in to the internet banking system" <<component>> as sign
    rectangle "==Accounts Summary Controller\n//<size:12>[MVC Rest Controlle]</size>//\n\n Provides customers with a summory of their bank accounts" <<component>> as accounts
    rectangle "==Security Component\n//<size:12>[Spring Bean]</size>//\n\n Provides functionality related to singing in, changing passwords, etc." <<component>> as security
    rectangle "==Mainframe Banking System Facade\n//<size:12>[Spring Bean]</size>//\n\n A facade onto the mainframe banking system." <<component>> as mbsfacade

sign - ->> security : **Uses**
accounts - ->> mbsfacade : **Uses**
security - ->> db : **Read & write to**\n//<size:12>[JDBC]</size>//
mbsfacade - ->> mbs : **Uses**\n//<size:12>[XML/HTTPS]</size>//
}

spa - ->> sign : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
spa - ->> accounts : **Uses**\n//<size:12>[JSON/HTTPS]</size>//

ma - ->> sign : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
ma - ->> accounts : **Uses**\n//<size:12>[JSON/HTTPS]</size>//
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-
-[Download container diagram](/1%20Internet%20Banking%20System/API%20Application/container.svg ':ignore')
-
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
-
-## Single Page Application
-
-`\1 Internet Banking System\Single Page Application`
-
-[PySocial Project](#PySocial)
-
-
-![container](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="631px" preserveAspectRatio="none" style="width:918px;height:631px;background:#FFFFFF;" version="1.1" viewBox="0 0 918 631" width="918px" zoomAndPan="magnify"><defs/><g><!--MD5=[38c27b35aef4eebaf210b1fd39b25fb0]
cluster spa--><g id="cluster_spa"><rect height="421" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="662" x="7" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="247.5" y="25.6094">Single Page Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="306.5" y="41.582">[Container]</text></g><!--MD5=[54409d5519d7646972cabb5538a3d297]
entity routing--><g id="elem_routing"><rect fill="#85BBF0" height="90.4375" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="188" x="438" y="87"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="61" x="501.5" y="113.6094">Routing</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="73" x="495.5" y="129.582">[React router]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="530" y="146.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="164" x="452" y="164.3613">Handler slient side routing</text></g><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><g id="elem_store"><rect fill="#85BBF0" height="108.0469" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="216" x="235" y="296"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="80" x="303" y="322.6094">Data Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="42" x="322" y="338.582">[Redux]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="341" y="355.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="249" y="373.3613">The central object holding the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="103" x="291.5" y="390.9707">application state</text></g><!--MD5=[2c4d6263d6a9c508a624946e4f5b83db]
entity login--><g id="elem_login"><rect fill="#85BBF0" height="90.4375" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="119" x="283.5" y="87"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="83" x="301.5" y="113.6094">Login form</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="307" y="129.582">[React Class]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="341" y="146.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="95" x="297.5" y="164.3613">The login page</text></g><!--MD5=[7acc01a6845e7bd2e8afe94137bb9829]
entity profile--><g id="elem_profile"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="217" x="31.5" y="69"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="92" x="94" y="95.6094">Profile Page</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="72" x="104" y="111.582">[React Class]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="138" y="128.752"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="189" x="45.5" y="146.3613">The page where the logged in</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="188" x="44" y="163.9707">user can view and edit his/her</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="105" y="181.5801">information</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="693.5" y="287"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="745" y="313.6094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="121" x="742.5" y="329.582">[java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="801" y="346.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="707.5" y="364.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="717.5" y="381.9707">the internet banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="749" y="399.5801">page application.</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M669.1828,145.4529 C669.2666,145.5804 669.351,145.7087 669.4359,145.8379 C670.1155,146.8714 670.8308,147.9594 671.5802,149.0991 C677.5747,158.2163 685.7406,170.6363 695.0888,184.855 C713.785,213.2925 737.21,248.925 757.45,279.72 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="762.07,286.75,760.178,278.4181,755.166,281.7166,762.07,286.75" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="766.5" y="238.457">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="741" y="253.5508">[JSON/HTTPS]</text></g><!--MD5=[334ae2b5ea9a67a6cab925c77e9701c3]
link login to store--><g id="link_login_store"><path d="M343,177.23 C343,209 343,252.23 343,287.37 " fill="none" id="login-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="343,295.66,346,287.66,340,287.66,343,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="344" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="373" y="245.957">;</text></g><!--MD5=[236a7b55e2b2bbdd3d38377a1d6ad24a]
link routing to store--><g id="link_routing_store"><path d="M493.3,177.23 C464.92,209.67 426.07,254.06 394.99,289.59 " fill="none" id="routing-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="389.67,295.66,397.189,291.6023,392.6669,287.6588,389.67,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="450" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="479" y="245.957">;</text></g><!--MD5=[4fc1864ed4b873a370455e3590a7eeea]
link profile to store--><g id="link_profile_store"><path d="M198.44,195.19 C226.33,224.86 259.53,260.19 287.09,289.5 " fill="none" id="profile-to-store" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="292.87,295.66,289.5819,287.774,285.2074,291.8805,292.87,295.66" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="29" x="255" y="245.957">Uses</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="3" x="284" y="245.957">;</text></g><rect height="174.4844" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="144" x="752.5" y="441"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="758.5" y="463.5332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="811.5" y="463.5332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="466.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="762.5" y="481.1426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="484.2188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="762.5" y="498.752">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="501.8281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="762.5" y="516.3613">container</text><rect fill="#85BBF0" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="519.4375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="70" x="762.5" y="533.9707">component</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="537.0469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="762.5" y="551.5801">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="554.6563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="762.5" y="569.1895">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="572.2656"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="762.5" y="586.7988">external container</text><rect fill="#CCCCCC" height="17.6094" style="stroke:none;stroke-width:1.0;" width="132" x="758.5" y="589.875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="762.5" y="604.4082">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="449" y2="449"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="466.6094" y2="466.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="484.2188" y2="484.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="501.8281" y2="501.8281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="519.4375" y2="519.4375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="537.0469" y2="537.0469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="554.6563" y2="554.6563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="572.2656" y2="572.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="589.875" y2="589.875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="890.5" y1="607.4844" y2="607.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="758.5" x2="758.5" y1="449" y2="607.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="890.5" x2="890.5" y1="449" y2="607.4844"/><!--MD5=[a3b0f8e8c01eb79bd93b48d3d6a69cec]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

LAYOUT_WITH_LEGEND()

Container(api, "API Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")

Container_Boundary(spa, "Single Page Application") {
    Component(routing, "Routing", "React router", "Handler slient side routing")
    Component(store, "Data Store", "Redux", "The central object holding the application state")
    Component(login, "Login form", "React Class", "The login page")
    Component(profile, "Profile Page", "React Class", "The page where the logged in user can view and edit his/her information")
}

Rel(spa, api, "Uses", "JSON/HTTPS")

Rel(login, store, "Uses");
Rel(routing, store, "Uses");
Rel(profile, store, "Uses");

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}











hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#85BBF0> component |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
|<#CCCCCC> external component |
endlegend

rectangle "==API Application\n//<size:12>[java and Spring MVC]</size>//\n\n Delivers the static content and the internet banking single page application." <<container>> as api

rectangle "==Single Page Application\n<size:12>[Container]</size>" <<boundary>> as spa {
    rectangle "==Routing\n//<size:12>[React router]</size>//\n\n Handler slient side routing" <<component>> as routing
    rectangle "==Data Store\n//<size:12>[Redux]</size>//\n\n The central object holding the application state" <<component>> as store
    rectangle "==Login form\n//<size:12>[React Class]</size>//\n\n The login page" <<component>> as login
    rectangle "==Profile Page\n//<size:12>[React Class]</size>//\n\n The page where the logged in user can view and edit his/her information" <<component>> as profile
}

spa - ->> api : **Uses**\n//<size:12>[JSON/HTTPS]</size>//

login - ->> store : **Uses**;
routing - ->> store : **Uses**;
profile - ->> store : **Uses**;

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-
-[Download container diagram](/1%20Internet%20Banking%20System/Single%20Page%20Application/container.svg ':ignore')
-
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
-
-> Example of included local image
-
-![](2020-01-10-16-21-41.png)
-
-## Dynamic Diagram
-
-`\1 Internet Banking System\Single Page Application\Dynamic Diagram`
-
-[PySocial Project](#PySocial)
-
-
-![dynamic](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="973px" preserveAspectRatio="none" style="width:280px;height:973px;background:#FFFFFF;" version="1.1" viewBox="0 0 280 973" width="280px" zoomAndPan="magnify"><defs/><g><!--MD5=[9327bfcb173f1b9645ad568e29f29f90]
cluster bc--><g id="cluster_bc"><rect height="448" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="242" x="7" y="246"/><text fill="#444444" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="76" x="90" y="262.5332">«boundary»</text><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="70" y="282.2188">API Application</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="63" x="96.5" y="298.1914">[Container]</text></g><!--MD5=[7d31e0ad99682b9efa7ed3dbba05f561]
entity signin--><g id="elem_signin"><rect fill="#85BBF0" height="125.6563" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="207" x="23.5" y="317"/><text fill="#000000" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="86" x="84" y="341.5332">«component»</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="133" x="60.5" y="361.2188">Sign In Controller</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="156" x="49" y="377.1914">[Spring MVC Rest Controller]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="125" y="394.3613"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="37.5" y="411.9707">Allows users to sign in to the</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="153" x="50.5" y="429.5801">internet Banking System</text></g><!--MD5=[6f1da96282e479ff2a49312c7753703d]
entity security--><g id="elem_security"><rect fill="#85BBF0" height="143.2656" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="210" x="23" y="535"/><text fill="#000000" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="86" x="85" y="559.5332">«component»</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="49.5" y="579.2188">Security Component</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="74" x="91" y="595.1914">[Spring Bean]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="612.3613"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="37" y="629.9707">Provides functionality related</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="142" x="55" y="647.5801">to signing in, changing</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="79" y="665.1895">passwords, etc.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="160.875" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="26.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="75" x="89.5" y="31.5332">«container»</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="36.5" y="51.2188">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="128" x="63" y="67.1914">[javascript and Angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="125" y="84.3613"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="52.5" y="101.9707">Provides all the internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="52.5" y="119.5801">banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="51" y="137.1895">customers via thier web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="100" y="154.7988">browser.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><path d="M33,797 C33,787 128,787 128,787 C128,787 223,787 223,797 L223,946.875 C223,956.875 128,956.875 128,956.875 C128,956.875 33,956.875 33,946.875 L33,797 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M33,797 C33,807 128,807 128,807 C128,807 223,807 223,797 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" font-style="italic" lengthAdjust="spacing" textLength="75" x="90.5" y="825.5332">«container»</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="92" y="845.2188">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="148" x="54" y="861.1914">[Oracle Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="126" y="878.3613"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="54" y="895.9707">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="121" x="65.5" y="913.5801">information hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="43" y="931.1895">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="75.5" y="948.7988">access logs, etc.</text></g><!--MD5=[a3715e1b0eb5ea6f4ea74782513c7fba]
link spa to signin--><g id="link_spa_signin"><path d="M127,168.26 C127,212.29 127,266.47 127,308.86 " fill="none" id="spa-to-signin" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="127,316.91,130,308.91,124,308.91,127,316.91" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="141" x="128" y="211.457">1: Submits credentials to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="80" x="158.5" y="226.5508">[JSON/HTTPS]</text></g><!--MD5=[34ef625f00519263ae52d116cb2c43c2]
link signin to security--><g id="link_signin_security"><path d="M127.28,443.24 C127.39,469.1 127.53,499.42 127.65,526.81 " fill="none" id="signin-to-security" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="127.69,534.82,130.6471,526.804,124.6472,526.8362,127.69,534.82" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="141" x="128" y="486.457">2: Calls isAuthenticated()</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="14" x="193" y="501.5508">on</text></g><!--MD5=[2f3b256d614db35f96be6b3c1201bf4f]
link security to db--><g id="link_security_db"><path d="M128,678.11 C128,708.89 128,745.39 128,778.31 " fill="none" id="security-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="128,786.59,131,778.59,125,778.59,128,786.59" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="122" x="129" y="723.457">3: select * from users</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="133" y="738.5508">where username = ?</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="172.5" y="753.6445">[JDBC]</text></g><!--MD5=[84dcae9ff33dd327841b0a8f7a5f76d5]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Dynamic.puml

Container(spa, "Single Page Application", "javascript and Angular", "Provides all the internet banking functionality to customers via thier web browser.")
ContainerDb(db, "Database", "Oracle Database Schema", "Stores user registration information hashed authentication credentials, access logs, etc.")
Container_Boundary(bc, "API Application"){
    Component(signin, "Sign In Controller", "Spring MVC Rest Controller", "Allows users to sign in to the internet Banking System")
    Component(security, "Security Component", "Spring Bean", "Provides functionality related to signing in, changing passwords, etc.")
}

Rel(spa, signin, "Submits credentials to", "JSON/HTTPS")
Rel(signin, security, "Calls isAuthenticated() on")
Rel(security, db, "select * from users where username = ?", "JDBC")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

















skinparam rectangle<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam database<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam queue<<component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #85BBF0
    BorderColor #78A8D8
}

skinparam rectangle<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam database<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}

skinparam queue<<external_component>> {
    StereotypeFontColor #000000
    FontColor #000000
    BackgroundColor #CCCCCC
    BorderColor #BFBFBF
}






























rectangle "==Single Page Application\n//<size:12>[javascript and Angular]</size>//\n\n Provides all the internet banking functionality to customers via thier web browser." <<container>> as spa
database "==Database\n//<size:12>[Oracle Database Schema]</size>//\n\n Stores user registration information hashed authentication credentials, access logs, etc." <<container>> as db
rectangle "==API Application\n<size:12>[Container]</size>" <<boundary>> as bc{
    rectangle "==Sign In Controller\n//<size:12>[Spring MVC Rest Controller]</size>//\n\n Allows users to sign in to the internet Banking System" <<component>> as signin
    rectangle "==Security Component\n//<size:12>[Spring Bean]</size>//\n\n Provides functionality related to signing in, changing passwords, etc." <<component>> as security
}

spa - ->> signin : **1: Submits credentials to**\n//<size:12>[JSON/HTTPS]</size>//
signin - ->> security : **2: Calls isAuthenticated() on**
security - ->> db : **3: select * from users where username = ?**\n//<size:12>[JDBC]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-
-[Download dynamic diagram](/1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/dynamic.svg ':ignore')
-
-**Dynamic diagram**
-
-A simple dynamic diagram can be useful when you want to show how elements in a static model collaborate at runtime to implement a user story, use case, feature, etc. This dynamic diagram is based upon a UML communication diagram (previously known as a "UML collaboration diagram"). It is similar to a UML sequence diagram although it allows a free-form arrangement of diagram elements with numbered interactions to indicate ordering.
-
-**Scope**: An enterprise, software system or container.
-
-**Primary and supporting elements**: Depends on the diagram scope; enterprise (see System Landscape diagram), software system (see System Context or Container diagrams), container (see Component diagram).
-
-**Intended audience**: Technical and non-technical people, inside and outside of the software development team.
-
-## Extended Docs
-
-`\1 Internet Banking System\Single Page Application\Extended Docs`
-
-[PySocial Project](#PySocial)
-
-
-![class](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="221px" preserveAspectRatio="none" style="width:395px;height:221px;background:#FFFFFF;" version="1.1" viewBox="0 0 395 221" width="395px" zoomAndPan="magnify"><defs/><g><!--MD5=[728d23d58e22fa55ea5a0544ed140874]
cluster net.dummy--><g id="cluster_net.dummy"><path d="M8.5,6 L85.5,6 A3.75,3.75 0 0 1 88,8.5 L95,29.6094 L117.5,29.6094 A2.5,2.5 0 0 1 120,32.1094 L120,211.5 A2.5,2.5 0 0 1 117.5,214 L8.5,214 A2.5,2.5 0 0 1 6,211.5 L6,8.5 A2.5,2.5 0 0 1 8.5,6 " fill="#DDDDDD" style="stroke:#000000;stroke-width:1.5;"/><line style="stroke:#000000;stroke-width:1.5;" x1="6" x2="95" y1="29.6094" y2="29.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="76" x="10" y="22.5332">net.dummy</text></g><!--MD5=[33e59a955278c32565a5bf6f302dc15e]
cluster net.foo--><g id="cluster_net.foo"><path d="M146.5,114 L197.5,114 A3.75,3.75 0 0 1 200,116.5 L207,137.6094 L251.5,137.6094 A2.5,2.5 0 0 1 254,140.1094 L254,211.5 A2.5,2.5 0 0 1 251.5,214 L146.5,214 A2.5,2.5 0 0 1 144,211.5 L144,116.5 A2.5,2.5 0 0 1 146.5,114 " style="stroke:#000000;stroke-width:1.5;fill:none;"/><line style="stroke:#000000;stroke-width:1.5;fill:none;" x1="144" x2="207" y1="137.6094" y2="137.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="50" x="148" y="130.5332">net.foo</text></g><!--MD5=[a192a6f29c441cea5ef200ac5f138a29]
cluster net.unused--><g id="cluster_net.unused"><path d="M280.5,114 L361.5,114 A3.75,3.75 0 0 1 364,116.5 L371,137.6094 L385.5,137.6094 A2.5,2.5 0 0 1 388,140.1094 L388,211.5 A2.5,2.5 0 0 1 385.5,214 L280.5,214 A2.5,2.5 0 0 1 278,211.5 L278,116.5 A2.5,2.5 0 0 1 280.5,114 " style="stroke:#000000;stroke-width:1.5;fill:none;"/><line style="stroke:#000000;stroke-width:1.5;fill:none;" x1="278" x2="371" y1="137.6094" y2="137.6094"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="80" x="282" y="130.5332">net.unused</text></g><!--MD5=[cb3a15f9f15e1ea33d1c370015e332c8]
class net.dummy.Person--><g id="elem_net.dummy.Person"><rect fill="#F1F1F1" height="48" id="net.dummy.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="26.5" y="150"/><ellipse cx="41.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M44.2656,161.875 Q44.4219,161.6563 44.6094,161.5469 Q44.7969,161.4375 45.0156,161.4375 Q45.3906,161.4375 45.625,161.7031 Q45.8594,161.9531 45.8594,162.5625 L45.8594,164.0156 Q45.8594,164.625 45.625,164.8906 Q45.3906,165.1563 45.0156,165.1563 Q44.6719,165.1563 44.4688,164.9531 Q44.2656,164.7656 44.1563,164.25 Q44.1094,163.8906 43.9219,163.7031 Q43.5938,163.3281 42.9844,163.1094 Q42.375,162.8906 41.75,162.8906 Q40.9844,162.8906 40.3438,163.2188 Q39.7188,163.5469 39.2188,164.2969 Q38.7344,165.0469 38.7344,166.0781 L38.7344,167.1719 Q38.7344,168.4063 39.625,169.2344 Q40.5156,170.0469 42.1094,170.0469 Q43.0469,170.0469 43.7031,169.7969 Q44.0938,169.6406 44.5156,169.2031 Q44.7813,168.9375 44.9219,168.8594 Q45.0781,168.7813 45.2813,168.7813 Q45.6094,168.7813 45.8594,169.0469 Q46.125,169.2969 46.125,169.6406 Q46.125,169.9844 45.7813,170.3906 Q45.2813,170.9688 44.4844,171.2969 Q43.4063,171.75 42.1094,171.75 Q40.5938,171.75 39.3906,171.125 Q38.4063,170.625 37.7188,169.5625 Q37.0313,168.4844 37.0313,167.2031 L37.0313,166.0469 Q37.0313,164.7188 37.6406,163.5781 Q38.2656,162.4219 39.3594,161.8125 Q40.4531,161.1875 41.6875,161.1875 Q42.4219,161.1875 43.0625,161.3594 Q43.7188,161.5156 44.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="55.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="27.5" x2="102.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="27.5" x2="102.5" y1="190" y2="190"/></g><!--MD5=[8ac4e197c3b047d8b0ccbf03414837ae]
class net.dummy.Meeting--><g id="elem_net.dummy.Meeting"><rect fill="#F1F1F1" height="48" id="net.dummy.Meeting" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="82" x="22" y="42"/><ellipse cx="37" cy="58" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M39.7656,53.875 Q39.9219,53.6563 40.1094,53.5469 Q40.2969,53.4375 40.5156,53.4375 Q40.8906,53.4375 41.125,53.7031 Q41.3594,53.9531 41.3594,54.5625 L41.3594,56.0156 Q41.3594,56.625 41.125,56.8906 Q40.8906,57.1563 40.5156,57.1563 Q40.1719,57.1563 39.9688,56.9531 Q39.7656,56.7656 39.6563,56.25 Q39.6094,55.8906 39.4219,55.7031 Q39.0938,55.3281 38.4844,55.1094 Q37.875,54.8906 37.25,54.8906 Q36.4844,54.8906 35.8438,55.2188 Q35.2188,55.5469 34.7188,56.2969 Q34.2344,57.0469 34.2344,58.0781 L34.2344,59.1719 Q34.2344,60.4063 35.125,61.2344 Q36.0156,62.0469 37.6094,62.0469 Q38.5469,62.0469 39.2031,61.7969 Q39.5938,61.6406 40.0156,61.2031 Q40.2813,60.9375 40.4219,60.8594 Q40.5781,60.7813 40.7813,60.7813 Q41.1094,60.7813 41.3594,61.0469 Q41.625,61.2969 41.625,61.6406 Q41.625,61.9844 41.2813,62.3906 Q40.7813,62.9688 39.9844,63.2969 Q38.9063,63.75 37.6094,63.75 Q36.0938,63.75 34.8906,63.125 Q33.9063,62.625 33.2188,61.5625 Q32.5313,60.4844 32.5313,59.2031 L32.5313,58.0469 Q32.5313,56.7188 33.1406,55.5781 Q33.7656,54.4219 34.8594,53.8125 Q35.9531,53.1875 37.1875,53.1875 Q37.9219,53.1875 38.5625,53.3594 Q39.2188,53.5156 39.7656,53.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="51" y="63.7285">Meeting</text><line style="stroke:#181818;stroke-width:0.5;" x1="23" x2="103" y1="74" y2="74"/><line style="stroke:#181818;stroke-width:0.5;" x1="23" x2="103" y1="82" y2="82"/></g><!--MD5=[39b7869a7bbdf1e166c12fc90d8f21cb]
class net.foo.Person--><g id="elem_net.foo.Person"><rect fill="#F1F1F1" height="48" id="net.foo.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="160.5" y="150"/><ellipse cx="175.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M178.2656,161.875 Q178.4219,161.6563 178.6094,161.5469 Q178.7969,161.4375 179.0156,161.4375 Q179.3906,161.4375 179.625,161.7031 Q179.8594,161.9531 179.8594,162.5625 L179.8594,164.0156 Q179.8594,164.625 179.625,164.8906 Q179.3906,165.1563 179.0156,165.1563 Q178.6719,165.1563 178.4688,164.9531 Q178.2656,164.7656 178.1563,164.25 Q178.1094,163.8906 177.9219,163.7031 Q177.5938,163.3281 176.9844,163.1094 Q176.375,162.8906 175.75,162.8906 Q174.9844,162.8906 174.3438,163.2188 Q173.7188,163.5469 173.2188,164.2969 Q172.7344,165.0469 172.7344,166.0781 L172.7344,167.1719 Q172.7344,168.4063 173.625,169.2344 Q174.5156,170.0469 176.1094,170.0469 Q177.0469,170.0469 177.7031,169.7969 Q178.0938,169.6406 178.5156,169.2031 Q178.7813,168.9375 178.9219,168.8594 Q179.0781,168.7813 179.2813,168.7813 Q179.6094,168.7813 179.8594,169.0469 Q180.125,169.2969 180.125,169.6406 Q180.125,169.9844 179.7813,170.3906 Q179.2813,170.9688 178.4844,171.2969 Q177.4063,171.75 176.1094,171.75 Q174.5938,171.75 173.3906,171.125 Q172.4063,170.625 171.7188,169.5625 Q171.0313,168.4844 171.0313,167.2031 L171.0313,166.0469 Q171.0313,164.7188 171.6406,163.5781 Q172.2656,162.4219 173.3594,161.8125 Q174.4531,161.1875 175.6875,161.1875 Q176.4219,161.1875 177.0625,161.3594 Q177.7188,161.5156 178.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="189.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="161.5" x2="236.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="161.5" x2="236.5" y1="190" y2="190"/></g><!--MD5=[5f30d223f747d8ac33b5eb84f5743c2a]
class net.unused.Person--><g id="elem_net.unused.Person"><rect fill="#F1F1F1" height="48" id="net.unused.Person" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="77" x="294.5" y="150"/><ellipse cx="309.5" cy="166" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M312.2656,161.875 Q312.4219,161.6563 312.6094,161.5469 Q312.7969,161.4375 313.0156,161.4375 Q313.3906,161.4375 313.625,161.7031 Q313.8594,161.9531 313.8594,162.5625 L313.8594,164.0156 Q313.8594,164.625 313.625,164.8906 Q313.3906,165.1563 313.0156,165.1563 Q312.6719,165.1563 312.4688,164.9531 Q312.2656,164.7656 312.1563,164.25 Q312.1094,163.8906 311.9219,163.7031 Q311.5938,163.3281 310.9844,163.1094 Q310.375,162.8906 309.75,162.8906 Q308.9844,162.8906 308.3438,163.2188 Q307.7188,163.5469 307.2188,164.2969 Q306.7344,165.0469 306.7344,166.0781 L306.7344,167.1719 Q306.7344,168.4063 307.625,169.2344 Q308.5156,170.0469 310.1094,170.0469 Q311.0469,170.0469 311.7031,169.7969 Q312.0938,169.6406 312.5156,169.2031 Q312.7813,168.9375 312.9219,168.8594 Q313.0781,168.7813 313.2813,168.7813 Q313.6094,168.7813 313.8594,169.0469 Q314.125,169.2969 314.125,169.6406 Q314.125,169.9844 313.7813,170.3906 Q313.2813,170.9688 312.4844,171.2969 Q311.4063,171.75 310.1094,171.75 Q308.5938,171.75 307.3906,171.125 Q306.4063,170.625 305.7188,169.5625 Q305.0313,168.4844 305.0313,167.2031 L305.0313,166.0469 Q305.0313,164.7188 305.6406,163.5781 Q306.2656,162.4219 307.3594,161.8125 Q308.4531,161.1875 309.6875,161.1875 Q310.4219,161.1875 311.0625,161.3594 Q311.7188,161.5156 312.2656,161.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="323.5" y="171.7285">Person</text><line style="stroke:#181818;stroke-width:0.5;" x1="295.5" x2="370.5" y1="182" y2="182"/><line style="stroke:#181818;stroke-width:0.5;" x1="295.5" x2="370.5" y1="190" y2="190"/></g><!--MD5=[8e57f1f895cc705ad5645d1ac73dc0a2]
class BaseClass--><g id="elem_BaseClass"><rect codeLine="7" fill="#F1F1F1" height="48" id="BaseClass" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="99" x="144.5" y="42"/><ellipse cx="159.5" cy="58" fill="#ADD1B2" rx="11" ry="11" style="stroke:#181818;stroke-width:1.0;"/><path d="M162.2656,53.875 Q162.4219,53.6563 162.6094,53.5469 Q162.7969,53.4375 163.0156,53.4375 Q163.3906,53.4375 163.625,53.7031 Q163.8594,53.9531 163.8594,54.5625 L163.8594,56.0156 Q163.8594,56.625 163.625,56.8906 Q163.3906,57.1563 163.0156,57.1563 Q162.6719,57.1563 162.4688,56.9531 Q162.2656,56.7656 162.1563,56.25 Q162.1094,55.8906 161.9219,55.7031 Q161.5938,55.3281 160.9844,55.1094 Q160.375,54.8906 159.75,54.8906 Q158.9844,54.8906 158.3438,55.2188 Q157.7188,55.5469 157.2188,56.2969 Q156.7344,57.0469 156.7344,58.0781 L156.7344,59.1719 Q156.7344,60.4063 157.625,61.2344 Q158.5156,62.0469 160.1094,62.0469 Q161.0469,62.0469 161.7031,61.7969 Q162.0938,61.6406 162.5156,61.2031 Q162.7813,60.9375 162.9219,60.8594 Q163.0781,60.7813 163.2813,60.7813 Q163.6094,60.7813 163.8594,61.0469 Q164.125,61.2969 164.125,61.6406 Q164.125,61.9844 163.7813,62.3906 Q163.2813,62.9688 162.4844,63.2969 Q161.4063,63.75 160.1094,63.75 Q158.5938,63.75 157.3906,63.125 Q156.4063,62.625 155.7188,61.5625 Q155.0313,60.4844 155.0313,59.2031 L155.0313,58.0469 Q155.0313,56.7188 155.6406,55.5781 Q156.2656,54.4219 157.3594,53.8125 Q158.4531,53.1875 159.6875,53.1875 Q160.4219,53.1875 161.0625,53.3594 Q161.7188,53.5156 162.2656,53.875 Z " fill="#000000"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="67" x="173.5" y="63.7285">BaseClass</text><line style="stroke:#181818;stroke-width:0.5;" x1="145.5" x2="242.5" y1="74" y2="74"/><line style="stroke:#181818;stroke-width:0.5;" x1="145.5" x2="242.5" y1="82" y2="82"/></g><!--MD5=[38d283ab138c7dee77115f9fbc859330]
reverse link BaseClass to net.dummy.Person--><g id="link_BaseClass_net.dummy.Person"><path codeLine="10" d="M148.27,102.54 C146.83,103.71 145.4,104.86 144,106 C126.42,120.3 107.01,136.75 91.83,149.78 " fill="none" id="BaseClass-backto-net.dummy.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="143.94,97.04,163.97,90.11,152.64,108.01,143.94,97.04" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3aad075c01a5f1f4921d0fd2481fc4e0]
reverse link net.dummy.Meeting to net.dummy.Person--><g id="link_net.dummy.Meeting_net.dummy.Person"><path codeLine="11" d="M63.69,103.34 C63.98,118.68 64.3,136.1 64.56,149.68 " fill="none" id="net.dummy.Meeting-backto-net.dummy.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="63.43,90,59.5428,96.0737,63.6541,101.9979,67.5414,95.9242,63.43,90" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[5b94dd299fdb64f5042d8ccdd246a8aa]
reverse link BaseClass to net.dummy.Meeting--><g id="link_BaseClass_net.dummy.Meeting"><path codeLine="13" d="M123.88,66 C117.32,66 110.75,66 104.19,66 " fill="none" id="BaseClass-backto-net.dummy.Meeting" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="124.19,59,144.19,66,124.19,73,124.19,59" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[b57b6e1cdce0b532ba1371e9c7d07ce1]
reverse link net.dummy.Person to net.foo.Person--><g id="link_net.dummy.Person_net.foo.Person"><path codeLine="18" d="M124.06,174 C136.14,174 148.22,174 160.3,174 " fill="none" id="net.dummy.Person-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="123.73,181,103.73,174,123.73,167,123.73,181" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3949315fc233572465e48cd9e3f6e864]
reverse link BaseClass to net.foo.Person--><g id="link_BaseClass_net.foo.Person"><path codeLine="19" d="M196.03,110.02 C196.67,123.58 197.35,138.04 197.9,149.68 " fill="none" id="BaseClass-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="189.04,110.31,195.08,90,203.02,109.65,189.04,110.31" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[736f19012fcb2f75c0b04526aeb93c2d]
reverse link net.dummy.Meeting to net.foo.Person--><g id="link_net.dummy.Meeting_net.foo.Person"><path codeLine="21" d="M108.83,97.74 C112.65,100.49 116.41,103.26 120,106 C138.3,119.96 158.05,136.71 173.23,149.97 " fill="none" id="net.dummy.Meeting-backto-net.foo.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="98.07,90.16,100.6619,96.8892,107.8703,97.0849,105.2784,90.3557,98.07,90.16" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[20bb99b6116bfc237a0342da45d84df8]
reverse link BaseClass to net.unused.Person--><g id="link_BaseClass_net.unused.Person"><path codeLine="24" d="M248.15,101.74 C250.14,103.16 252.09,104.58 254,106 C272.47,119.74 292.22,136.49 307.35,149.81 " fill="none" id="BaseClass-backto-net.unused.Person" style="stroke:#181818;stroke-width:1.0;"/><polygon fill="none" points="243.86,107.28,231.31,90.2,251.77,95.73,243.86,107.28" style="stroke:#181818;stroke-width:1.0;"/></g><!--MD5=[3e360cf55433805d5b9245322ea53bd9]
@startuml
' Split into 4 pages
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

class BaseClass

namespace net.dummy #DDDDDD {
	.BaseClass <|- - Person
	Meeting o- - Person
	
	.BaseClass <|- Meeting

}

namespace net.foo {
  net.dummy.Person  <|- Person
  .BaseClass <|- - Person

  net.dummy.Meeting o- - Person
}

BaseClass <|- - net.unused.Person
@enduml

@startuml
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

class BaseClass

namespace net.dummy #DDDDDD {
	.BaseClass <|- - Person
	Meeting o- - Person
	
	.BaseClass <|- Meeting

}

namespace net.foo {
  net.dummy.Person  <|- Person
  .BaseClass <|- - Person

  net.dummy.Meeting o- - Person
}

BaseClass <|- - net.unused.Person
@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-
-[Download class diagram](/1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/class.svg ':ignore')
-
-
-![sequence](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="276px" preserveAspectRatio="none" style="width:363px;height:276px;background:#FFFFFF;" version="1.1" viewBox="0 0 363 276" width="363px" zoomAndPan="magnify"><defs/><g><rect fill="#FFFFFF" height="151.7578" style="stroke:#181818;stroke-width:1.0;" width="10" x="92.5" y="69.9609"/><rect fill="#FFFFFF" height="91.0547" style="stroke:#181818;stroke-width:1.0;" width="10" x="245.5" y="100.3125"/><rect fill="#FFFFFF" height="30.3516" style="stroke:#181818;stroke-width:1.0;" width="10" x="340.5" y="130.6641"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="26" x2="26" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="97" x2="97" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="250" x2="250" y1="37.6094" y2="239.7188"/><line style="stroke:#181818;stroke-width:0.5;stroke-dasharray:5.0,5.0;" x1="345.5" x2="345.5" y1="37.6094" y2="239.7188"/><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="43" x="5" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="29" x="12" y="26.5332">User</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="43" x="5" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="29" x="12" y="260.252">User</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="86" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="93" y="26.5332">A</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="86" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="93" y="260.252">A</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="239" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="246" y="26.5332">B</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="23" x="239" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="9" x="246" y="260.252">B</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="24" x="333.5" y="5"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="10" x="340.5" y="26.5332">C</text><rect fill="#E2E2F0" height="31.6094" rx="2.5" ry="2.5" style="stroke:#181818;stroke-width:0.5;" width="24" x="333.5" y="238.7188"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="10" x="340.5" y="260.252">C</text><rect fill="#FFFFFF" height="151.7578" style="stroke:#181818;stroke-width:1.0;" width="10" x="92.5" y="69.9609"/><rect fill="#FFFFFF" height="91.0547" style="stroke:#181818;stroke-width:1.0;" width="10" x="245.5" y="100.3125"/><rect fill="#FFFFFF" height="30.3516" style="stroke:#181818;stroke-width:1.0;" width="10" x="340.5" y="130.6641"/><polygon fill="#181818" points="80.5,65.9609,90.5,69.9609,80.5,73.9609,84.5,69.9609" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="26.5" x2="86.5" y1="69.9609" y2="69.9609"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="47" x="33.5" y="65.1045">DoWork</text><polygon fill="#181818" points="233.5,96.3125,243.5,100.3125,233.5,104.3125,237.5,100.3125" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="102.5" x2="239.5" y1="100.3125" y2="100.3125"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="124" x="109.5" y="95.4561">&lt;&lt; createRequest &gt;&gt;</text><polygon fill="#181818" points="328.5,126.6641,338.5,130.6641,328.5,134.6641,332.5,130.6641" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="255.5" x2="334.5" y1="130.6641" y2="130.6641"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="47" x="262.5" y="125.8076">DoWork</text><polygon fill="#181818" points="266.5,157.0156,256.5,161.0156,266.5,165.0156,262.5,161.0156" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;stroke-dasharray:2.0,2.0;" x1="260.5" x2="344.5" y1="161.0156" y2="161.0156"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="61" x="272.5" y="156.1592">WorkDone</text><line style="stroke:#A80036;stroke-width:2.0;" x1="336.5" x2="354.5" y1="152.0156" y2="170.0156"/><line style="stroke:#A80036;stroke-width:2.0;" x1="336.5" x2="354.5" y1="170.0156" y2="152.0156"/><polygon fill="#181818" points="113.5,187.3672,103.5,191.3672,113.5,195.3672,109.5,191.3672" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;stroke-dasharray:2.0,2.0;" x1="107.5" x2="249.5" y1="191.3672" y2="191.3672"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="93" x="119.5" y="186.5107">RequestCreated</text><polygon fill="#181818" points="37.5,217.7188,27.5,221.7188,37.5,225.7188,33.5,221.7188" style="stroke:#181818;stroke-width:1.0;"/><line style="stroke:#181818;stroke-width:1.0;" x1="31.5" x2="96.5" y1="221.7188" y2="221.7188"/><text fill="#000000" font-family="sans-serif" font-size="13" lengthAdjust="spacing" textLength="30" x="43.5" y="216.8623">Done</text><!--MD5=[5f53e077a3b738dee8ed05af6f972a22]
@startuml
participant User

User -> A: DoWork
activate A

A -> B: << createRequest >>
activate B

B -> C: DoWork
activate C
C - -> B: WorkDone
destroy C

B - -> A: RequestCreated
deactivate B

A -> User: Done
deactivate A

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-
-[Download sequence diagram](/1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/sequence.svg ':ignore')
-
-Multiple markdowns can be ordered using `.1.md, .2.md .. ..md`
-
-You can choose where to place a certain diagram by using `![name](.puml)`
-
-
-![ditaa](data:image/png;base64,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)
-
-[Download ditaa diagram](/1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/ditaa.png ':ignore')
-
-Feel free to add any additional details necesary.
-
-
-## 2 Deployment
-
-`\2 Deployment`
-
-[PySocial Project](#PySocial)
-
-
-![deployment](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="1549px" preserveAspectRatio="none" style="width:989px;height:1549px;background:#FFFFFF;" version="1.1" viewBox="0 0 989 1549" width="989px" zoomAndPan="magnify"><defs/><g><!--MD5=[d4f46b85ec0fd4984e46b6ab68a49907]
cluster plc--><g id="cluster_plc"><rect height="1097" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="670" x="7" y="284"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="97" x="293.5" y="302.6094">Big Bank plc</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="269" y="318.582">[Big Bank plc data center]</text></g><!--MD5=[cb60efe6e32ae9dc1419f0024d193ed3]
cluster dn--><g id="cluster_dn"><rect height="282" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="298" x="31" y="346"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="108" x="107" y="364.6094">bigbank-api***</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="18" x="235" y="364.6094">x8</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="126.5" y="380.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[8f463db2213924b28ab9fa8a8a25c26a]
cluster apache--><g id="cluster_apache"><rect height="196" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="250" x="55" y="408"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="119" x="120.5" y="426.6094">Apache Tomcat</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="121.5" y="442.582">[Apache Tomcat 8.x]</text></g><!--MD5=[7e0f1b407756c52dd30c4ead0f9230ac]
cluster bigbankdb01--><g id="cluster_bigbankdb01"><rect height="308" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="270" x="31" y="692"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="105" x="113.5" y="710.6094">bigbank-db01</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="112.5" y="726.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[d58f35efa7ac429240bfa5a7c4204cd4]
cluster oracle--><g id="cluster_oracle"><rect height="222" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="222" x="55" y="754"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="121" x="105.5" y="772.6094">Oracle - Primary</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="70" x="131" y="788.582">[Oracle 12c]</text></g><!--MD5=[9fa18d40767c7b2b82a18fa9dfe8338d]
cluster bigbankdb02--><g id="cluster_bigbankdb02"><rect height="308" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="270" x="124" y="1049"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="105" x="206.5" y="1067.6094">bigbank-db02</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="205.5" y="1083.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[69ad4c2ae5d24231281b185261861c19]
cluster oracle2--><g id="cluster_oracle2"><rect height="222" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="222" x="148" y="1111"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="145" x="186.5" y="1129.6094">Oracle - Secondary</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="70" x="224" y="1145.582">[Oracle 12c]</text></g><!--MD5=[8732ada0ac3d982aaf760ffd06e5f6c2]
cluster bb2--><g id="cluster_bb2"><rect height="282" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="300" x="353" y="346"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="430" y="364.6094">bigbank-web***</text><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="18" x="558" y="364.6094">x4</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="449.5" y="380.582">[Ubuntu 16.04 LTS]</text></g><!--MD5=[c9f3238ce9b9b9fe2ea53139a741cb96]
cluster apache2--><g id="cluster_apache2"><rect height="196" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="252" x="377" y="408"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="119" x="443.5" y="426.6094">Apache Tomcat</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="117" x="444.5" y="442.582">[Apache Tomcat 8.x]</text></g><!--MD5=[543156d0aa455e6607833fc05f747439]
cluster mob--><g id="cluster_mob"><rect height="213" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="238" x="61" y="7"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="197" x="81.5" y="25.6094">Customer's mobile device</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="125" x="117.5" y="41.582">[Apple IOS or Android]</text></g><!--MD5=[8cd91a8026ecd064a658212c3b3f8063]
cluster comp--><g id="cluster_comp"><rect height="299" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="282" x="701" y="696.5"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="165" x="759.5" y="715.1094">Customer's computer</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="212" x="736" y="731.082">[Mircosoft Windows of Apple macOS]</text></g><!--MD5=[2de28e47f9582cb6df153deeec479525]
cluster browser--><g id="cluster_browser"><rect height="213" rx="2.5" ry="2.5" style="stroke:#A2A2A2;stroke-width:1.0;fill:none;" width="234" x="725" y="758.5"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="103" x="790.5" y="777.1094">Web Browser</text><text fill="#000000" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="182" x="751" y="793.082">[Google Chrome, Mozilla Firefox]</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="217" x="71.5" y="462"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="116" x="122" y="488.6094">API Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="124" x="118" y="504.582">[Java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="178" y="521.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="99" y="539.3613">Provides Internet Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="197" x="81.5" y="556.9707">functionality via a JSON/HTTPS</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="25" x="167.5" y="574.5801">API.</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><path d="M71,818 C71,808 166,808 166,808 C166,808 261,808 261,818 L261,950.2656 C261,960.2656 166,960.2656 166,960.2656 C166,960.2656 71,960.2656 71,950.2656 L71,818 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M71,818 C71,828 166,828 166,828 C166,828 261,828 261,818 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="130" y="848.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="82" y="864.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="164" y="881.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="92" y="899.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="101.5" y="916.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="81" y="934.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="113.5" y="952.1895">access logs, etc.</text></g><!--MD5=[2331507006b4b8bee4c616015350b23c]
entity db2--><g id="elem_db2"><path d="M164,1175 C164,1165 259,1165 259,1165 C259,1165 354,1165 354,1175 L354,1307.2656 C354,1317.2656 259,1317.2656 259,1317.2656 C259,1317.2656 164,1317.2656 164,1307.2656 L164,1175 " fill="#438DD5" style="stroke:#3C7FC0;stroke-width:0.5;"/><path d="M164,1175 C164,1185 259,1185 259,1185 C259,1185 354,1185 354,1175 " fill="none" style="stroke:#3C7FC0;stroke-width:0.5;"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="72" x="223" y="1205.6094">Database</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="168" x="175" y="1221.582">[Relational Database Schema]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="257" y="1238.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="185" y="1256.3613">Stores user registration</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="125" x="194.5" y="1273.9707">information, hashed</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="166" x="174" y="1291.5801">authentication credentials,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="105" x="206.5" y="1309.1895">access logs, etc.</text></g><!--MD5=[08af8945a84acfe1eabc0963aa87c412]
entity web--><g id="elem_web"><rect fill="#438DD5" height="125.6563" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="219" x="393.5" y="462"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="124" x="441" y="488.6094">Web Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="124" x="441" y="504.582">[Java and Spring MVC]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="501" y="521.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="407.5" y="539.3613">Delivers the static content and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="417" y="556.9707">the Internet Banking single</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="449" y="574.5801">page application.</text></g><!--MD5=[870e13a82a9bc0252b17e3ad6e742bb1]
entity mobile--><g id="elem_mobile"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="77" y="61"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="137.5" y="87.6094">Mobile App</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="53" x="153.5" y="103.582">[Xamarin]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="178" y="120.752"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="173" x="93.5" y="138.3613">Provides a limited subset of</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="127" x="114.5" y="155.9707">the Internet Banking</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="87" y="173.5801">functionality to customers via</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="122" x="119" y="191.1895">their mobile device.</text></g><!--MD5=[33573e971ff506c0f246109ca3fd77bd]
entity spa--><g id="elem_spa"><rect fill="#438DD5" height="143.2656" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="201" x="741.5" y="812.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="181" x="751.5" y="839.1094">Single Page Application</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="133" x="775.5" y="855.082">[JavaScript and Angular]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="840" y="872.252"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="165" x="759.5" y="889.8613">Provides all of the Internet</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="146" x="767" y="907.4707">Banking functionality to</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="766" y="925.0801">customers via their web</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="54" x="815" y="942.6895">browser.</text></g><!--MD5=[aa67fb756ea91151fa7b0a063a4e1220]
link mobile to api--><g id="link_mobile_api"><path d="M180,204.22 C180,274.86 180,382.84 180,453.44 " fill="none" id="mobile-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="180,461.86,183,453.86,177,453.86,180,461.86" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="104" x="181" y="249.457">Makes API calls to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="71" x="197.5" y="264.5508">[json/HTTPS]</text></g><!--MD5=[b20751f21bc3c5e56073fe913b5ac5ab]
link spa to api--><g id="link_spa_api"><path d="M741.3,817.26 C675.62,775.96 587.14,723.28 505,684 C450.19,657.79 432.12,661.55 377,636 C348.78,622.92 319.11,607.37 291.61,592.14 " fill="none" id="spa-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="284.29,588.07,289.8128,594.5891,292.7375,589.3503,284.29,588.07" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="104" x="487" y="657.457">Makes API calls to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="71" x="503.5" y="672.5508">[json/HTTPS]</text></g><!--MD5=[ca038ce5783dc4b0fafb3b6644ac783b]
link web to spa--><g id="link_web_spa"><path d="M592.82,588.02 C615.09,605.07 638.22,624.32 658,644 C707.73,693.46 755.8,756.6 790.32,805.56 " fill="none" id="web-to-spa" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="795.1,812.37,792.9531,804.1001,788.0447,807.551,795.1,812.37" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="149" x="687" y="657.457">Delivers to the customer's</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="75" x="724" y="672.5508">web browser</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M177.56,588.18 C175.26,646.81 171.8,735.08 169.26,799.75 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="168.94,807.92,172.2517,800.0439,166.2564,799.8084,168.94,807.92" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="143" x="176" y="657.457">Reads from and writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="228.5" y="672.5508">[JDBC]</text></g><!--MD5=[c945a0638e97c8d85bbaa16159667354]
link api to db2--><g id="link_api_db2"><path d="M283.55,588.21 C301.53,604.02 317.73,622.68 328,644 C409.05,812.28 342.71,1037.23 295.68,1156.9 " fill="none" id="api-to-db2" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="292.62,1164.63,298.3556,1158.2973,292.7773,1156.0874,292.62,1164.63" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="143" x="367" y="881.457">Reads from and writes to</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="38" x="419.5" y="896.5508">[JDBC]</text></g><!--MD5=[ea1351de5d5b841bf911f898ed156919]
link db to db2--><g id="link_db_db2"><path d="M185.72,960.29 C200.83,1017.94 221.65,1097.42 237.24,1156.93 " fill="none" id="db-to-db2" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="239.31,1164.82,240.1845,1156.3209,234.3804,1157.8415,239.31,1164.82" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="205" y="1029.457">Replicates data to</text></g><rect height="139.2656" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="133" x="834" y="1394"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="53" x="840" y="1416.5332">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="893" y="1416.5332"> </text><rect fill="#08427B" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1419.6094"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="844" y="1434.1426">person</text><rect fill="#1168BD" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1437.2188"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="44" x="844" y="1451.752">system</text><rect fill="#438DD5" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1454.8281"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="59" x="844" y="1469.3613">container</text><rect fill="#686868" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1472.4375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="844" y="1486.9707">external person</text><rect fill="#999999" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1490.0469"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="98" x="844" y="1504.5801">external system</text><rect fill="#B3B3B3" height="17.6094" style="stroke:none;stroke-width:1.0;" width="121" x="840" y="1507.6563"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="113" x="844" y="1522.1895">external container</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1402" y2="1402"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1419.6094" y2="1419.6094"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1437.2188" y2="1437.2188"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1454.8281" y2="1454.8281"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1472.4375" y2="1472.4375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1490.0469" y2="1490.0469"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1507.6563" y2="1507.6563"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="961" y1="1525.2656" y2="1525.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="840" x2="840" y1="1402" y2="1525.2656"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="961" x2="961" y1="1402" y2="1525.2656"/><!--MD5=[6a999edbe8a16f3529bdcbc0e4af265d]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Deployment.puml

LAYOUT_WITH_LEGEND()

Deployment_Node(plc, "Big Bank plc", "Big Bank plc data center"){
    Deployment_Node(dn, "bigbank-api***\tx8", "Ubuntu 16.04 LTS"){
        Deployment_Node(apache, "Apache Tomcat", "Apache Tomcat 8.x"){
            Container(api, "API Application", "Java and Spring MVC", "Provides Internet Banking functionality via a JSON/HTTPS API.")
        }
    }
    Deployment_Node(bigbankdb01, "bigbank-db01", "Ubuntu 16.04 LTS"){
        Deployment_Node(oracle, "Oracle - Primary", "Oracle 12c"){
            ContainerDb(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
        }
    }
    Deployment_Node(bigbankdb02, "bigbank-db02", "Ubuntu 16.04 LTS"){
        Deployment_Node(oracle2, "Oracle - Secondary", "Oracle 12c"){
            ContainerDb(db2, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
        }
    }
    Deployment_Node(bb2, "bigbank-web***\tx4", "Ubuntu 16.04 LTS"){
        Deployment_Node(apache2, "Apache Tomcat", "Apache Tomcat 8.x"){
            Container(web, "Web Application", "Java and Spring MVC", "Delivers the static content and the Internet Banking single page application.")
        }
    }
}

Deployment_Node(mob, "Customer's mobile device", "Apple IOS or Android"){
    Container(mobile, "Mobile App", "Xamarin", "Provides a limited subset of the Internet Banking functionality to customers via their mobile device.")
}

Deployment_Node(comp, "Customer's computer", "Mircosoft Windows of Apple macOS"){
    Deployment_Node(browser, "Web Browser", "Google Chrome, Mozilla Firefox"){
        Container(spa, "Single Page Application", "JavaScript and Angular", "Provides all of the Internet Banking functionality to customers via their web browser.")
    }
}

Rel(mobile, api, "Makes API calls to", "json/HTTPS")
Rel(spa, api, "Makes API calls to", "json/HTTPS")
Rel(web, spa, "Delivers to the customer's web browser")
Rel(api, db, "Reads from and writes to", "JDBC")
Rel(api, db2, "Reads from and writes to", "JDBC")
Rel(db, db2, "Replicates data to")

@enduml

@startuml





skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam LegendBorderColor transparent
skinparam LegendBackgroundColor transparent
skinparam LegendFontColor #FFFFFF

skinparam rectangle {
    StereotypeFontSize 12
    shadowing false
}

skinparam database {
    StereotypeFontSize 12
    shadowing false
}

skinparam queue {
    StereotypeFontSize 12
    shadowing false
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}

skinparam rectangle<<boundary>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #444444
    BorderColor #444444
    BorderStyle dashed
}





























skinparam rectangle<<person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #08427B
    BorderColor #073B6F
}

skinparam rectangle<<external_person>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #686868
    BorderColor #8A8A8A
}

skinparam rectangle<<system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #1168BD
    BorderColor #3C7FC0
}

skinparam rectangle<<external_system>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #999999
    BorderColor #8A8A8A
}

sprite $person [48x48/16] {
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
0000000000000000000049BCCA7200000000000000000000
0000000000000000006EFFFFFFFFB3000000000000000000
00000000000000001CFFFFFFFFFFFF700000000000000000
0000000000000001EFFFFFFFFFFFFFF80000000000000000
000000000000000CFFFFFFFFFFFFFFFF6000000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
00000000000001FFFFFFFFFFFFFFFFFFF900000000000000
00000000000006FFFFFFFFFFFFFFFFFFFF00000000000000
0000000000000BFFFFFFFFFFFFFFFFFFFF40000000000000
0000000000000EFFFFFFFFFFFFFFFFFFFF70000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000FFFFFFFFFFFFFFFFFFFFF80000000000000
0000000000000DFFFFFFFFFFFFFFFFFFFF60000000000000
0000000000000AFFFFFFFFFFFFFFFFFFFF40000000000000
00000000000006FFFFFFFFFFFFFFFFFFFE00000000000000
00000000000000EFFFFFFFFFFFFFFFFFF800000000000000
000000000000007FFFFFFFFFFFFFFFFFF100000000000000
000000000000000BFFFFFFFFFFFFFFFF5000000000000000
0000000000000001DFFFFFFFFFFFFFF70000000000000000
00000000000000000BFFFFFFFFFFFF500000000000000000
0000000000000000005DFFFFFFFFA1000000000000000000
0000000000000000000037ABB96100000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000025788300000000005886410000000000000
000000000007DFFFFFFD9643347BFFFFFFFB400000000000
0000000004EFFFFFFFFFFFFFFFFFFFFFFFFFFB1000000000
000000007FFFFFFFFFFFFFFFFFFFFFFFFFFFFFD200000000
00000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE10000000
0000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB0000000
000000BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5000000
000003FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD000000
000009FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF200000
00000DFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF600000
00000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF800000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFB00000
00001FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA00000
00000EFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF700000
000006FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFE100000
0000008FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD3000000
000000014555555555555555555555555555555300000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000
}
















skinparam rectangle<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam database<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam queue<<container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #438DD5
    BorderColor #3C7FC0
}

skinparam rectangle<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam database<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}

skinparam queue<<external_container>> {
    StereotypeFontColor #FFFFFF
    FontColor #FFFFFF
    BackgroundColor #B3B3B3
    BorderColor #A6A6A6
}














skinparam rectangle<<node>> {
    Shadowing false
    StereotypeFontSize 0
    FontColor #000000
    BorderColor #A2A2A2
    BorderStyle solid
}


hide stereotype
legend right
|<color:#000000>**Legend**</color> |
|<#08427B> person |
|<#1168BD> system |
|<#438DD5> container |
|<#686868> external person |
|<#999999> external system |
|<#B3B3B3> external container |
endlegend

rectangle "==Big Bank plc\n<size:12>[Big Bank plc data center]</size>" <<node>> as plc{
    rectangle "==bigbank-api***\tx8\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as dn{
        rectangle "==Apache Tomcat\n<size:12>[Apache Tomcat 8.x]</size>" <<node>> as apache{
            rectangle "==API Application\n//<size:12>[Java and Spring MVC]</size>//\n\n Provides Internet Banking functionality via a JSON/HTTPS API." <<container>> as api
        }
    }
    rectangle "==bigbank-db01\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bigbankdb01{
        rectangle "==Oracle - Primary\n<size:12>[Oracle 12c]</size>" <<node>> as oracle{
            database "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db
        }
    }
    rectangle "==bigbank-db02\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bigbankdb02{
        rectangle "==Oracle - Secondary\n<size:12>[Oracle 12c]</size>" <<node>> as oracle2{
            database "==Database\n//<size:12>[Relational Database Schema]</size>//\n\n Stores user registration information, hashed authentication credentials, access logs, etc." <<container>> as db2
        }
    }
    rectangle "==bigbank-web***\tx4\n<size:12>[Ubuntu 16.04 LTS]</size>" <<node>> as bb2{
        rectangle "==Apache Tomcat\n<size:12>[Apache Tomcat 8.x]</size>" <<node>> as apache2{
            rectangle "==Web Application\n//<size:12>[Java and Spring MVC]</size>//\n\n Delivers the static content and the Internet Banking single page application." <<container>> as web
        }
    }
}

rectangle "==Customer's mobile device\n<size:12>[Apple IOS or Android]</size>" <<node>> as mob{
    rectangle "==Mobile App\n//<size:12>[Xamarin]</size>//\n\n Provides a limited subset of the Internet Banking functionality to customers via their mobile device." <<container>> as mobile
}

rectangle "==Customer's computer\n<size:12>[Mircosoft Windows of Apple macOS]</size>" <<node>> as comp{
    rectangle "==Web Browser\n<size:12>[Google Chrome, Mozilla Firefox]</size>" <<node>> as browser{
        rectangle "==Single Page Application\n//<size:12>[JavaScript and Angular]</size>//\n\n Provides all of the Internet Banking functionality to customers via their web browser." <<container>> as spa
    }
}

mobile - ->> api : **Makes API calls to**\n//<size:12>[json/HTTPS]</size>//
spa - ->> api : **Makes API calls to**\n//<size:12>[json/HTTPS]</size>//
web - ->> spa : **Delivers to the customer's web browser**
api - ->> db : **Reads from and writes to**\n//<size:12>[JDBC]</size>//
api - ->> db2 : **Reads from and writes to**\n//<size:12>[JDBC]</size>//
db - ->> db2 : **Replicates data to**

@enduml

PlantUML version 1.2022.3(Tue Mar 29 13:10:57 BRT 2022)
(GPL source distribution)
Java Runtime: Java(TM) SE Runtime Environment
JVM: Java HotSpot(TM) 64-Bit Server VM
Default Encoding: UTF-8
Language: pt
Country: BR
--></g></svg>)
-
-[Download deployment diagram](/2%20Deployment/deployment.svg ':ignore')
-
-**Deployment diagram**
+
-A deployment diagram allows you to illustrate how containers in the static model are mapped to infrastructure. This deployment diagram is based upon a UML deployment diagram, although simplified slightly to show the mapping between containers and deployment nodes. A deployment node is something like physical infrastructure (e.g. a physical server or device), virtualised infrastructure (e.g. IaaS, PaaS, a virtual machine), containerised infrastructure (e.g. a Docker container), an execution environment (e.g. a database server, Java EE web/application server, Microsoft IIS), etc. Deployment nodes can be nested.
+**Elementos de suporte:**
+* Usuário
+* Facebook API
+* Instagram API
+* X (Twiiter) API
+* TikTok API
+* YouTube API
-**Scope**: A single software system.
-**Primary elements**: Deployment nodes and containers within the software system in scope.
+
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
\ No newline at end of file
+**Público-alvo**: Técnicos dentro e fora da equipe de desenvolvimento de software; incluindo arquitetos de software, desenvolvedores e equipe de operações/suporte.
\ No newline at end of file
diff --git a/docs/PySocial.pdf b/docs/PySocial.pdf
index 9e257e8..b326059 100644
Binary files a/docs/PySocial.pdf and b/docs/PySocial.pdf differ
diff --git a/docs/README.md b/docs/README.md
index acbc64a..c3de3d0 100644
--- a/docs/README.md
+++ b/docs/README.md
@@ -1,18 +1,11 @@
# PySocial Project
* [**PySocial Project**](README.md)
- * [1 Internet Banking System](1%20Internet%20Banking%20System/README.md)
- * [API Application](1%20Internet%20Banking%20System/API%20Application/README.md)
- * [Single Page Application](1%20Internet%20Banking%20System/Single%20Page%20Application/README.md)
- * [Dynamic Diagram](1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/README.md)
- * [Extended Docs](1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/README.md)
- * [2 Deployment](2%20Deployment/README.md)
+ * [1 PySocial System](1%20PySocial%20System/README.md)
---
-- [1 Internet Banking System](1%20Internet%20Banking%20System/README.md)
-
-- [2 Deployment](2%20Deployment/README.md)
+- [1 PySocial System](1%20PySocial%20System/README.md)
---
diff --git a/docs/_sidebar.md b/docs/_sidebar.md
index b6fdb5b..5e38867 100644
--- a/docs/_sidebar.md
+++ b/docs/_sidebar.md
@@ -1,7 +1,2 @@
* [PySocial Project](HOME)
- * [1 Internet Banking System](1%20Internet%20Banking%20System/HOME)
- * [API Application](1%20Internet%20Banking%20System/API%20Application/HOME)
- * [Single Page Application](1%20Internet%20Banking%20System/Single%20Page%20Application/HOME)
- * [Dynamic Diagram](1%20Internet%20Banking%20System/Single%20Page%20Application/Dynamic%20Diagram/HOME)
- * [Extended Docs](1%20Internet%20Banking%20System/Single%20Page%20Application/Extended%20Docs/HOME)
- * [2 Deployment](2%20Deployment/HOME)
+ * [1 PySocial System](1%20PySocial%20System/HOME)
diff --git a/src/1 Internet Banking System/API Application/container.md b/src/1 Internet Banking System/API Application/container.md
deleted file mode 100644
index e784698..0000000
--- a/src/1 Internet Banking System/API Application/container.md
+++ /dev/null
@@ -1,12 +0,0 @@
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
\ No newline at end of file
diff --git a/src/1 Internet Banking System/API Application/container.puml b/src/1 Internet Banking System/API Application/container.puml
deleted file mode 100644
index 26ed266..0000000
--- a/src/1 Internet Banking System/API Application/container.puml
+++ /dev/null
@@ -1,28 +0,0 @@
-@startuml
-!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml
-
-LAYOUT_WITH_LEGEND()
-
-Container(spa, "Single Page Application", "javascript and react", "Provides all the internet banking functionality to customers via their web browser.")
-Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
-Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
-System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")
-
-Container_Boundary(api, "API Application") {
- Component(sign, "Sign In Controller", "MVC Rest Controlle", "Allows users to sign in to the internet banking system")
- Component(accounts, "Accounts Summary Controller", "MVC Rest Controlle", "Provides customers with a summory of their bank accounts")
- Component(security, "Security Component", "Spring Bean", "Provides functionality related to singing in, changing passwords, etc.")
- Component(mbsfacade, "Mainframe Banking System Facade", "Spring Bean", "A facade onto the mainframe banking system.")
-
- Rel(sign, security, "Uses")
- Rel(accounts, mbsfacade, "Uses")
- Rel(security, db, "Read & write to", "JDBC")
- Rel(mbsfacade, mbs, "Uses", "XML/HTTPS")
-}
-
-Rel(spa, sign, "Uses", "JSON/HTTPS")
-Rel(spa, accounts, "Uses", "JSON/HTTPS")
-
-Rel(ma, sign, "Uses", "JSON/HTTPS")
-Rel(ma, accounts, "Uses", "JSON/HTTPS")
-@enduml
diff --git a/src/1 Internet Banking System/Single Page Application/2020-01-10-16-21-41.png b/src/1 Internet Banking System/Single Page Application/2020-01-10-16-21-41.png
deleted file mode 100644
index ea176bb..0000000
Binary files a/src/1 Internet Banking System/Single Page Application/2020-01-10-16-21-41.png and /dev/null differ
diff --git a/src/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.md b/src/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.md
deleted file mode 100644
index c01ca1b..0000000
--- a/src/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.md
+++ /dev/null
@@ -1,9 +0,0 @@
-**Dynamic diagram**
-
-A simple dynamic diagram can be useful when you want to show how elements in a static model collaborate at runtime to implement a user story, use case, feature, etc. This dynamic diagram is based upon a UML communication diagram (previously known as a "UML collaboration diagram"). It is similar to a UML sequence diagram although it allows a free-form arrangement of diagram elements with numbered interactions to indicate ordering.
-
-**Scope**: An enterprise, software system or container.
-
-**Primary and supporting elements**: Depends on the diagram scope; enterprise (see System Landscape diagram), software system (see System Context or Container diagrams), container (see Component diagram).
-
-**Intended audience**: Technical and non-technical people, inside and outside of the software development team.
\ No newline at end of file
diff --git a/src/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.puml b/src/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.puml
deleted file mode 100644
index 7709819..0000000
--- a/src/1 Internet Banking System/Single Page Application/Dynamic Diagram/dynamic.puml
+++ /dev/null
@@ -1,15 +0,0 @@
-@startuml
-!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Dynamic.puml
-
-Container(spa, "Single Page Application", "javascript and Angular", "Provides all the internet banking functionality to customers via thier web browser.")
-ContainerDb(db, "Database", "Oracle Database Schema", "Stores user registration information hashed authentication credentials, access logs, etc.")
-Container_Boundary(bc, "API Application"){
- Component(signin, "Sign In Controller", "Spring MVC Rest Controller", "Allows users to sign in to the internet Banking System")
- Component(security, "Security Component", "Spring Bean", "Provides functionality related to signing in, changing passwords, etc.")
-}
-
-Rel(spa, signin, "Submits credentials to", "JSON/HTTPS")
-Rel(signin, security, "Calls isAuthenticated() on")
-Rel(security, db, "select * from users where username = ?", "JDBC")
-
-@enduml
diff --git a/src/1 Internet Banking System/Single Page Application/Extended Docs/class.puml b/src/1 Internet Banking System/Single Page Application/Extended Docs/class.puml
deleted file mode 100644
index cd726b2..0000000
--- a/src/1 Internet Banking System/Single Page Application/Extended Docs/class.puml
+++ /dev/null
@@ -1,26 +0,0 @@
-@startuml
-' Split into 4 pages
-page 2x2
-skinparam pageMargin 10
-skinparam pageExternalColor gray
-skinparam pageBorderColor black
-
-class BaseClass
-
-namespace net.dummy #DDDDDD {
- .BaseClass <|-- Person
- Meeting o-- Person
-
- .BaseClass <|- Meeting
-
-}
-
-namespace net.foo {
- net.dummy.Person <|- Person
- .BaseClass <|-- Person
-
- net.dummy.Meeting o-- Person
-}
-
-BaseClass <|-- net.unused.Person
-@enduml
\ No newline at end of file
diff --git a/src/1 Internet Banking System/Single Page Application/Extended Docs/details.1.md b/src/1 Internet Banking System/Single Page Application/Extended Docs/details.1.md
deleted file mode 100644
index 214c72e..0000000
--- a/src/1 Internet Banking System/Single Page Application/Extended Docs/details.1.md
+++ /dev/null
@@ -1 +0,0 @@
-Multiple markdowns can be ordered using `.1.md, .2.md .. ..md`
\ No newline at end of file
diff --git a/src/1 Internet Banking System/Single Page Application/Extended Docs/details.md b/src/1 Internet Banking System/Single Page Application/Extended Docs/details.md
deleted file mode 100644
index 82e37ec..0000000
--- a/src/1 Internet Banking System/Single Page Application/Extended Docs/details.md
+++ /dev/null
@@ -1,5 +0,0 @@
-You can choose where to place a certain diagram by using `![name](.puml)`
-
-![ditaa](ditaa.puml)
-
-Feel free to add any additional details necesary.
diff --git a/src/1 Internet Banking System/Single Page Application/Extended Docs/ditaa.puml b/src/1 Internet Banking System/Single Page Application/Extended Docs/ditaa.puml
deleted file mode 100644
index 62aac64..0000000
--- a/src/1 Internet Banking System/Single Page Application/Extended Docs/ditaa.puml
+++ /dev/null
@@ -1,9 +0,0 @@
-@startditaa -E
-+---------+ /--------\ +-------+
-| cBLU +--+cAAA +---+Version|
-| | | Data | | V3 |
-| +----+ | Base | |cRED{d}|
-| |cPNK| | {s}| +-------+
-| | | \---+----/
-+----+----+
-@endditaa
\ No newline at end of file
diff --git a/src/1 Internet Banking System/Single Page Application/Extended Docs/sequence.puml b/src/1 Internet Banking System/Single Page Application/Extended Docs/sequence.puml
deleted file mode 100644
index 5f13ffa..0000000
--- a/src/1 Internet Banking System/Single Page Application/Extended Docs/sequence.puml
+++ /dev/null
@@ -1,21 +0,0 @@
-@startuml
-participant User
-
-User -> A: DoWork
-activate A
-
-A -> B: << createRequest >>
-activate B
-
-B -> C: DoWork
-activate C
-C --> B: WorkDone
-destroy C
-
-B --> A: RequestCreated
-deactivate B
-
-A -> User: Done
-deactivate A
-
-@enduml
\ No newline at end of file
diff --git a/src/1 Internet Banking System/Single Page Application/container.md b/src/1 Internet Banking System/Single Page Application/container.md
deleted file mode 100644
index 282e9b8..0000000
--- a/src/1 Internet Banking System/Single Page Application/container.md
+++ /dev/null
@@ -1,16 +0,0 @@
-**Level 3: Component diagram**
-
-Next you can zoom in and decompose each container further to identify the major structural building blocks and their interactions.
-
-The Component diagram shows how a container is made up of a number of "components", what each of those components are, their responsibilities and the technology/implementation details.
-
-**Scope**: A single container.
-
-**Primary elements**: Components within the container in scope.
-Supporting elements: Containers (within the software system in scope) plus people and software systems directly connected to the components.
-
-**Intended audience**: Software architects and developers.
-
-> Example of included local image
-
-![](2020-01-10-16-21-41.png)
\ No newline at end of file
diff --git a/src/1 Internet Banking System/Single Page Application/container.puml b/src/1 Internet Banking System/Single Page Application/container.puml
deleted file mode 100644
index 8124325..0000000
--- a/src/1 Internet Banking System/Single Page Application/container.puml
+++ /dev/null
@@ -1,21 +0,0 @@
-@startuml
-!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml
-
-LAYOUT_WITH_LEGEND()
-
-Container(api, "API Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")
-
-Container_Boundary(spa, "Single Page Application") {
- Component(routing, "Routing", "React router", "Handler slient side routing")
- Component(store, "Data Store", "Redux", "The central object holding the application state")
- Component(login, "Login form", "React Class", "The login page")
- Component(profile, "Profile Page", "React Class", "The page where the logged in user can view and edit his/her information")
-}
-
-Rel(spa, api, "Uses", "JSON/HTTPS")
-
-Rel(login, store, "Uses");
-Rel(routing, store, "Uses");
-Rel(profile, store, "Uses");
-
-@enduml
diff --git a/src/1 Internet Banking System/system.md b/src/1 Internet Banking System/system.md
deleted file mode 100644
index 13cedbc..0000000
--- a/src/1 Internet Banking System/system.md
+++ /dev/null
@@ -1,14 +0,0 @@
-**Level 2: Container diagram**
-
-Once you understand how your system fits in to the overall IT environment, a really useful next step is to zoom-in to the system boundary with a Container diagram. A "container" is something like a server-side web application, single-page application, desktop application, mobile app, database schema, file system, etc. Essentially, a container is a separately runnable/deployable unit (e.g. a separate process space) that executes code or stores data.
-
-The Container diagram shows the high-level shape of the software architecture and how responsibilities are distributed across it. It also shows the major technology choices and how the containers communicate with one another. It's a simple, high-level technology focussed diagram that is useful for software developers and support/operations staff alike.
-
-**Scope**: A single software system.
-
-**Primary elements**: Containers within the software system in scope.
-Supporting elements: People and software systems directly connected to the containers.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
-
-**Notes**: This diagram says nothing about deployment scenarios, clustering, replication, failover, etc.
\ No newline at end of file
diff --git a/src/1 Internet Banking System/system.puml b/src/1 Internet Banking System/system.puml
deleted file mode 100644
index 2c73f08..0000000
--- a/src/1 Internet Banking System/system.puml
+++ /dev/null
@@ -1,28 +0,0 @@
-@startuml
-!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml
-
-LAYOUT_WITH_LEGEND()
-
-Person(pbc, "Personal Banking Customer", "A customer of the bank, with personal bank accounts.")
-System_Ext(es, "E-mail system", "The internal Microsoft Exchange e-mail system.")
-System_Ext(mbs, "Mainframe Banking System", "Stores all of the core banking information about customers, accounts, transactions, etc.")
-System_Boundary(ibs, "Internet Banking") {
- Container(wa, "Web Application", "java and Spring MVC", "Delivers the static content and the internet banking single page application.")
- Container(spa, "Single Page Application", "javascript and angular", "Provides all the internet banking functionality to customers via their web browser.")
- Container(ma, "Mobile App", "Xamarin", "Provides a limited subset ot the internet banking functionality to customers via their mobile mobile device.")
- Container(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
- Container(api, "API Application", "java and String MVC", "Provides internet banking functionality via a JSON/HTTP API.")
-
- Rel(api, es, "Sends e-mails", "SMTP")
- Rel(api, mbs, "Uses", "XML/HTTPS")
- Rel(api, db, "Reads & writes to", "JDBC")
- Rel(wa, spa, "Delivers")
- Rel(spa, api, "Uses", "JSON/HTTPS")
- Rel(ma, api, "Uses", "JSON/HTTPS")
-}
-
-Rel(pbc, wa, "Uses", "HTTPS")
-Rel(pbc, spa, "Uses")
-Rel(pbc, ma, "Uses")
-Rel(es, pbc, "Sends e-mails to")
-@enduml
diff --git a/src/1 PySocial System/system.md b/src/1 PySocial System/system.md
new file mode 100644
index 0000000..a360663
--- /dev/null
+++ b/src/1 PySocial System/system.md
@@ -0,0 +1,24 @@
+**Level 2: Diagrama de contêiner**
+
+
+**Scope**: Sistema de software PySocial.
+
+**Elementos primários**:
+* PyWebView UI
+* Python Application
+* API Interface
+
+
+
+**Elementos de suporte:**
+* Usuário
+* Facebook API
+* Instagram API
+* X (Twiiter) API
+* TikTok API
+* YouTube API
+
+
+
+
+**Público-alvo**: Técnicos dentro e fora da equipe de desenvolvimento de software; incluindo arquitetos de software, desenvolvedores e equipe de operações/suporte.
\ No newline at end of file
diff --git a/src/1 PySocial System/system.puml b/src/1 PySocial System/system.puml
new file mode 100644
index 0000000..e8cf566
--- /dev/null
+++ b/src/1 PySocial System/system.puml
@@ -0,0 +1,29 @@
+@startuml
+!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Container.puml
+
+LAYOUT_WITH_LEGEND()
+
+Person(user, "Usuário", "Um usuário que possue a necessidade de enviar o mesmo conteúdo para várias redes sociais.")
+System_Ext(face, "Facebook API", "Interface de comunicação com rede social Facebook.")
+System_Ext(inst, "Instagram API", "Interface de comunicação com rede social Instagram.")
+System_Ext(x, "X (Twiiter) API", "Interface de comunicação com rede social X.")
+System_Ext(tt, "TikTok API", "Interface de comunicação com rede social TikTok.")
+System_Ext(yt, "YouTube API", "Interface de comunicação com rede social YouTube.")
+
+System_Boundary(pys, "PySocial System") {
+ Container(pyWeb, "PyWebView UI", "Python3", "UI da aplicação")
+ Container(py, "Python Application", "Python3", "Core domain da aplicação")
+ Container(pyAcl, "API Interface", "Python3", "ACL da aplicação")
+
+ Rel(pyWeb, py, "Uses")
+ Rel(py, pyAcl, "Uses")
+}
+
+Rel(user, pyWeb, "Interage com", "UI")
+Rel(pyAcl, face, "requisita", "JSON/HTTPS")
+Rel(pyAcl, inst, "requisita", "JSON/HTTPS")
+Rel(pyAcl, x, "requisita", "JSON/HTTPS")
+Rel(pyAcl, tt, "requisita", "JSON/HTTPS")
+Rel(pyAcl, yt, "requisita", "JSON/HTTPS")
+
+@enduml
diff --git a/src/2 Deployment/deployment.md b/src/2 Deployment/deployment.md
deleted file mode 100644
index 99e9ccd..0000000
--- a/src/2 Deployment/deployment.md
+++ /dev/null
@@ -1,9 +0,0 @@
-**Deployment diagram**
-
-A deployment diagram allows you to illustrate how containers in the static model are mapped to infrastructure. This deployment diagram is based upon a UML deployment diagram, although simplified slightly to show the mapping between containers and deployment nodes. A deployment node is something like physical infrastructure (e.g. a physical server or device), virtualised infrastructure (e.g. IaaS, PaaS, a virtual machine), containerised infrastructure (e.g. a Docker container), an execution environment (e.g. a database server, Java EE web/application server, Microsoft IIS), etc. Deployment nodes can be nested.
-
-**Scope**: A single software system.
-
-**Primary elements**: Deployment nodes and containers within the software system in scope.
-
-**Intended audience**: Technical people inside and outside of the software development team; including software architects, developers and operations/support staff.
\ No newline at end of file
diff --git a/src/2 Deployment/deployment.puml b/src/2 Deployment/deployment.puml
deleted file mode 100644
index a812d6a..0000000
--- a/src/2 Deployment/deployment.puml
+++ /dev/null
@@ -1,46 +0,0 @@
-@startuml
-!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Deployment.puml
-
-LAYOUT_WITH_LEGEND()
-
-Deployment_Node(plc, "Big Bank plc", "Big Bank plc data center"){
- Deployment_Node(dn, "bigbank-api***\tx8", "Ubuntu 16.04 LTS"){
- Deployment_Node(apache, "Apache Tomcat", "Apache Tomcat 8.x"){
- Container(api, "API Application", "Java and Spring MVC", "Provides Internet Banking functionality via a JSON/HTTPS API.")
- }
- }
- Deployment_Node(bigbankdb01, "bigbank-db01", "Ubuntu 16.04 LTS"){
- Deployment_Node(oracle, "Oracle - Primary", "Oracle 12c"){
- ContainerDb(db, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
- }
- }
- Deployment_Node(bigbankdb02, "bigbank-db02", "Ubuntu 16.04 LTS"){
- Deployment_Node(oracle2, "Oracle - Secondary", "Oracle 12c"){
- ContainerDb(db2, "Database", "Relational Database Schema", "Stores user registration information, hashed authentication credentials, access logs, etc.")
- }
- }
- Deployment_Node(bb2, "bigbank-web***\tx4", "Ubuntu 16.04 LTS"){
- Deployment_Node(apache2, "Apache Tomcat", "Apache Tomcat 8.x"){
- Container(web, "Web Application", "Java and Spring MVC", "Delivers the static content and the Internet Banking single page application.")
- }
- }
-}
-
-Deployment_Node(mob, "Customer's mobile device", "Apple IOS or Android"){
- Container(mobile, "Mobile App", "Xamarin", "Provides a limited subset of the Internet Banking functionality to customers via their mobile device.")
-}
-
-Deployment_Node(comp, "Customer's computer", "Mircosoft Windows of Apple macOS"){
- Deployment_Node(browser, "Web Browser", "Google Chrome, Mozilla Firefox"){
- Container(spa, "Single Page Application", "JavaScript and Angular", "Provides all of the Internet Banking functionality to customers via their web browser.")
- }
-}
-
-Rel(mobile, api, "Makes API calls to", "json/HTTPS")
-Rel(spa, api, "Makes API calls to", "json/HTTPS")
-Rel(web, spa, "Delivers to the customer's web browser")
-Rel(api, db, "Reads from and writes to", "JDBC")
-Rel(api, db2, "Reads from and writes to", "JDBC")
-Rel(db, db2, "Replicates data to")
-
-@enduml
\ No newline at end of file