diff --git a/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/HOME.md b/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/HOME.md index 6807b03..cf5a671 100644 --- a/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/HOME.md +++ b/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/HOME.md @@ -1,7 +1,7 @@ # Algorithm Catalog -![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" contentScriptType="application/ecmascript" contentStyleType="text/css" height="915px" preserveAspectRatio="none" style="width:853px;height:915px;background:#FFFFFF;" version="1.1" viewBox="0 0 853 915" width="853px" zoomAndPan="magnify"><defs/><g><!--MD5=[d3c7e7666fa3f68c4fc45bba2365bdb0]
cluster ads--><rect fill="#FFFFFF" height="719" style="stroke:#444444;stroke-width:1.0;stroke-dasharray:7.0,7.0;" width="577" x="221" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="208" x="405.5" y="23.8516">Algorithm Development</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="478.5" y="38.7637">[System]</text><!--MD5=[69da06a6e8584e6c7f392b42750a07eb]
cluster ac--><rect fill="#FFFFFF" height="452" style="stroke:#444444;stroke-width:1.0;stroke-dasharray:7.0,7.0;" width="513" x="253" y="242"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="431" y="258.8516">Algorithm Catalog</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="80" x="469.5" y="273.7637">[Container]</text><!--MD5=[f92115063e8dc9f632cc320845e472c3]
entity bs--><rect fill="#438DD5" height="101.4844" style="stroke:#3C7FC0;stroke-width:1.5;" width="212" x="525" y="58"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="114" x="574" y="82.8516">Build System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="54" x="604" y="97.7637">[Jenkins]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="633" y="113.5889"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="539" y="129.8857">Builds algorithms into OGC</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="561" y="146.1826">Algorithm Packages.</text><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><rect fill="#85BBF0" height="101.4844" style="stroke:#78A8D8;stroke-width:1.5;" width="208" x="515" y="333"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="91" x="573.5" y="357.8516">search api</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="39" x="599.5" y="372.7637">[cmr?]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="621" y="388.5889"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="180" x="529" y="404.8857">API for listing, viewing, and</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="527" y="421.1826">posting package metadata</text><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><rect fill="#85BBF0" height="165.4844" style="stroke:#78A8D8;stroke-width:1.5;" width="203" x="276.5" y="301"/><image height="64" width="64" x="346" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAIAAAAlC+aJAAAEAUlEQVR42u1aPY4WMQz1qWgpKWgooUOIjgYk2pVotqGiokbiANDTcASOwBE4Ak+y5PXGjn+SmeVbtJKFlm9mEj/HPy9O6PrHn3st9ADgRq6+/Ya8//qL5c3nn/I3P7ogANAG+r24+vLs3acnrz88fv720dOXFcGbeB9f4VuMsI+qAQCGxKyYvqhrXTDmq4/fMf4pADAuDFYxKpRggWm18I+V5cIjvNNCEgHAlHYynoO13HEA7YQuEkyxDgAfu6t8UiDyOmP8wT8BAyB7AKCiHoUtcZ7e7soMK48lagCQL+uLeJJoL4BNSwAAPf3gLgWrIQadWZOs+fHvRdXa2KZkX73HACR847i5SxdKVboFQKfkfxvEnIt0SsV/G0GsBajSZHyg3pjLZSszHcjNXFDa1mCMexQDc0uyW/UFzIxf0FAONdyZMTSnwMRMKzRttiIEm6kRk8KAFOEp6yBOMbMaDcawDocfMWXM5w4RtsjgKjJvtRLHIa8ZWH0PEJg55YVpafKpRL0Si4cIbdbkmR1Mc2x2s24RCNL6CECc/kLqQJxDHQASNJcAQJJKUJFoxgHXNnjHClwuLgIOgMo3FctJLO0UDbFmMAgtrJrOSEHk7VPDNIf6W8o0bnS+svlBTJCygFQ4o8QmoJlmcSbVrGmIFkkdbmVtSUUTWsA92Ni+OSvbXYa7sieueJ7UimC/x10GLlsWDxYwDe5KEfABxPxJ0hTU0t4SK2T5PY8QJGuZSOaqApAv3dHF6jyiZuDFzDiQqFnnxvam3CiiVv0TK+pHolC99rlEfaCiMpcGbFWiuvMJsCFqZ78vd10xLx5pVqZXY8BA9fCXEe1Sih5r22jbVLQpbmYmKrJwHVKYzEoxmtP2vbvN4L2lPMoB2ExaPxaIF4HTK+8TZjHDSIJtUA7AZlKsAAyQSsDehraxmNaFIQ7DWzY+WOC/e+31o0i1JUha7CxxKs8BHEKq3erBxYt3oToFDeuWNiMSAJJJD2nOiTaWFMweVYh0csR0YJM07iy4TytEOgEQUFluS83E8pa4vewau94coe5mwqX7lhRsAqivP3W3c7oiWnEn7rpQKwKpu6GON80ugG4Qt3IgdVsaCwC6abRVhajbVFoD0CpkreYadXd0awD4wyKVaLU3qbunXgZQJ3OtBjN1C9AmgKOaESUAbiYVAHx7YpB9AMVmRPW2ik0RC4Xs8I50FcAsnaVnMzsUsE6kcwCBMeQynJXNM0zx2+I4VImnukdunseI9vUGBxUX9NRDb4w59FfqO8HSnbnDD73ltNMtba0xab91o+/9sejDSX3dr3i4feK90TMOvbnXsBz6tBNzfDZcv/uqL2gedeeCzkgmVh4uf/+/AP4CFS/8F8+bwkcAAAAASUVORK5CYII=" y="311"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="140" x="308" y="389.8516">Algorithm Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="24" x="366" y="404.7637">[s3]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="380" y="420.5889"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="175" x="290.5" y="436.8857">where docker images are</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="355.5" y="453.1826">stored</text><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><rect fill="#85BBF0" height="101.4844" style="stroke:#78A8D8;stroke-width:1.5;" width="206" x="485" y="569"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="81" x="547.5" y="593.8516">database</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="96" x="540" y="608.7637">[elastic search]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="590" y="624.5889"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="499" y="640.8857">Where metadata is stored</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="89" x="543.5" y="657.1826">for packages</text><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><rect fill="#999999" height="57.25" style="stroke:#8A8A8A;stroke-width:1.5;" width="198" x="7" y="80"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="17" y="104.8516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="73" y="123.4766">System</text><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><path d="M612.43,434.13 C607.51,471.2 600.79,521.96 595.64,560.84 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="594.56,568.95,598.5776,561.4095,592.6289,560.6271,594.56,568.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="90" x="623.5" y="508.1387">reads/writes</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="604" y="522.1074">package metadata</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="630" y="536.0762">[JSON/HTTPS]</text><!--MD5=[e873ce36164171149c4fcf5e5d6e05ab]
link sps to api--><path d="M91.2,137.01 C80.22,161.62 70.36,196.95 91,218 C106.79,234.11 476.83,215.9 497,226 C539.02,247.04 570.9,290.09 591.51,325.72 " fill="none" id="sps-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="595.48,332.74,594.1455,324.3009,588.9255,327.2592,595.48,332.74" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="128" x="92" y="201.1387">Gets Package Info</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="115.5" y="215.1074">[JSON/HTTPS]</text><!--MD5=[005a73589667ace0b52bf2a9f6cca4a1]
link bs to ac--><path d="M649.22,159.17 C659.49,180.46 674.46,203.68 695,218 C711.3,229.37 725.37,211.54 739,226 C762.655,251.095 767.6275,289.4 766.5775,321.8313 C766.5119,323.8582 766.4227,325.8622 766.3131,327.8386 C766.2583,328.8268 766.1984,329.8081 766.1338,330.7819 C766.1015,331.2688 766.068,331.7539 766.0334,332.237 " fill="none" id="bs-to-ac" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="766.0334,332.237,769.5976,324.4719,763.613,324.043,766.0334,332.237" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="145" x="696" y="208.1387">Writes OGC Package</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="4" x="841" y="208.1387">;</text><rect fill="#FFFFFF" height="160.6719" rx="5" ry="5" style="stroke:#FFFFFF;stroke-width:1.0;" width="159" x="672" y="739"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="678" y="758.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="741" y="758.9951"/><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="762.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="682" y="775.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="778.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="682" y="791.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="794.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="682" y="807.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="811.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="682" y="824.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="827.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="682" y="840.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="843.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="682" y="856.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="860.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="682" y="873.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="876.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="682" y="889.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="746" y2="746"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="762.2969" y2="762.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="778.5938" y2="778.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="794.8906" y2="794.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="811.1875" y2="811.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="827.4844" y2="827.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="843.7813" y2="843.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="860.0781" y2="860.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="876.375" y2="876.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="892.6719" y2="892.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="678" y1="746" y2="892.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="825" x2="825" y1="746" y2="892.6719"/><!--MD5=[2312f962569101386433a2f81776f7f6]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

!define AWSPuml https://raw.githubusercontent.com/awslabs/aws-icons-for-plantuml/main/dist

!includeurl AWSPuml/AWSCommon.puml
' !includeurl AWSPuml/BusinessApplications/all.puml
!include AWSPuml/Storage/SimpleStorageServiceBucketWithObjects.puml

LAYOUT_WITH_LEGEND()

System_Ext(sps, "Science Processing System", "")
System_Boundary(ads,"Algorithm Development"){
  Container(bs, "Build System", "Jenkins", "Builds algorithms into OGC Algorithm Packages.")
  Container_Boundary(ac, "Algorithm Catalog") {
      Component(api, "search api", "cmr?", "API for listing, viewing, and posting package metadata")
      Component(store, "Algorithm Store", "s3", "where docker images are stored", $sprite="SimpleStorageServiceBucketWithObjects")
      Component(db, "database", "elastic search", "Where metadata is stored for packages" )

      Rel(api, db, "reads/writes package metadata", "JSON/HTTPS")

}

}
Rel(sps, api, "Gets Package Info", "JSON/HTTPS")

Rel(bs, ac, "Writes OGC Package");

@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
}
















skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam rectangle {
    StereotypeFontSize 12
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}









sprite $SimpleStorageServiceBucketWithObjects [64x64/16z] {
pPQ9mfmW38JDGOxtV-6MDOgCvNUtzzV-jmaXaq6s_nKYPXPc9lemK9fvv9LmQ_9E6cwUQrpvos2xBgYgqb6zbXEsIj6Y7b2XnQugXMvtj0g4K83LNna4a_ih
BstFqAjEsoO2gaBkjVgqTVZv2OfCdPQFxJFc1VCNunqQyWH1W86gJmfq3TlSlux9E-Qe0PTP48liEDW4OeyPzKpU1jpJYOyPRohCL32BQ1iMSEa5qpNnlXrI
omV2f1e6SjYeiRQ2-CLOE32HZcUFw7UQjPUD6Pg2UZlKim3sEsYVnNEcegFuWtWf-V4N24Sw_TZ0z4L196URxiu2-Ogf8L7TvMDG4P-oee0jgnjqpjlzwNL6
7bLRmecBykEEQXREuucLQK_I2EN70Q1J2kk54_WzZIzgfH4AM7-E7gfGeKPU3dYzz1K5RFitWGDLxZRPd-dv52QwyiJnTV5sRDpTef2W2lQZBkj_HjGFGN25
ShHqkNUgXG2tg0mUcJS1FQ_e2DEcVAR8mcy2Ibnm6iTz9_ZijQcvwPiEvZnWqFhPmJKHnlHgFurI0O9-Jpjhunjmxz8JgCpu3jsBdcn-O3HUjMDXS2ywc79W
jtYe50UW9dUddeFwiLDu9fQJQXti7og50c8ywhUUb8h3U9mVVDUWWp6-mzFyEiJ3040y-0Vbmpd1-8T10m4htlK5F0ZxBD31E3_FxrvqSC010g1xxudvW1RR
hDyZurAuXcnzrvN7EwJOFaKB6EwGS7UiAOA_uG5VX9jPs-zWFjqTl-3X3cbAspkGg7da8Ehk-26qi_tNV0C
}

skinparam rectangle<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}
skinparam participant<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}

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 "==Science Processing System" <<external_system>> as sps
rectangle "==Algorithm Development\n<size:12>[System]</size>" <<boundary>> as ads{
  rectangle "==Build System\n//<size:12>[Jenkins]</size>//\n\n Builds algorithms into OGC Algorithm Packages." <<container>> as bs
  rectangle "==Algorithm Catalog\n<size:12>[Container]</size>" <<boundary>> as ac {
      rectangle "==search api\n//<size:12>[cmr?]</size>//\n\n API for listing, viewing, and posting package metadata" <<component>> as api
      rectangle "<$SimpleStorageServiceBucketWithObjects>\n==Algorithm Store\n//<size:12>[s3]</size>//\n\n where docker images are stored" <<component>> as store
      rectangle "==database\n//<size:12>[elastic search]</size>//\n\n Where metadata is stored for packages" <<component>> as db

api - ->> db : **reads/writes package metadata**\n//<size:12>[JSON/HTTPS]</size>//

}

}
sps - ->> api : **Gets Package Info**\n//<size:12>[JSON/HTTPS]</size>//

bs - ->> ac : **Writes OGC Package**;

@enduml

PlantUML version 1.2021.12(Tue Oct 05 16:01:58 GMT 2021)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>) +![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="917px" preserveAspectRatio="none" style="width:853px;height:917px;background:#FFFFFF;" version="1.1" viewBox="0 0 853 917" width="853px" zoomAndPan="magnify"><defs/><g><!--MD5=[d3c7e7666fa3f68c4fc45bba2365bdb0]
cluster ads--><g id="cluster_ads"><rect height="719" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="577" x="221" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="208" x="405.5" y="23.8516">Algorithm Development</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="478.5" y="38.7637">[System]</text></g><!--MD5=[69da06a6e8584e6c7f392b42750a07eb]
cluster ac--><g id="cluster_ac"><rect height="452" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="513" x="253" y="242"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="431" y="258.8516">Algorithm Catalog</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="80" x="469.5" y="273.7637">[Container]</text></g><!--MD5=[f92115063e8dc9f632cc320845e472c3]
entity bs--><g id="elem_bs"><rect fill="#438DD5" height="101.4844" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="212" x="525" y="58"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="114" x="574" y="82.8516">Build System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="54" x="604" y="97.7637">[Jenkins]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="629" y="113.5889"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="539" y="129.8857">Builds algorithms into OGC</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="561" y="146.1826">Algorithm Packages.</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#85BBF0" height="101.4844" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="208" x="515" y="333"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="91" x="573.5" y="357.8516">search api</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="39" x="599.5" y="372.7637">[cmr?]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="617" y="388.5889"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="180" x="529" y="404.8857">API for listing, viewing, and</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="527" y="421.1826">posting package metadata</text></g><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><g id="elem_store"><rect fill="#85BBF0" height="165.4844" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="203" x="276.5" y="301"/><image height="64" width="64" x="346" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAIAAAAlC+aJAAAEAUlEQVR42u1aPY4WMQz1qWgpKWgooUOIjgYk2pVotqGiokbiANDTcASOwBE4Ak+y5PXGjn+SmeVbtJKFlm9mEj/HPy9O6PrHn3st9ADgRq6+/Ya8//qL5c3nn/I3P7ogANAG+r24+vLs3acnrz88fv720dOXFcGbeB9f4VuMsI+qAQCGxKyYvqhrXTDmq4/fMf4pADAuDFYxKpRggWm18I+V5cIjvNNCEgHAlHYynoO13HEA7YQuEkyxDgAfu6t8UiDyOmP8wT8BAyB7AKCiHoUtcZ7e7soMK48lagCQL+uLeJJoL4BNSwAAPf3gLgWrIQadWZOs+fHvRdXa2KZkX73HACR847i5SxdKVboFQKfkfxvEnIt0SsV/G0GsBajSZHyg3pjLZSszHcjNXFDa1mCMexQDc0uyW/UFzIxf0FAONdyZMTSnwMRMKzRttiIEm6kRk8KAFOEp6yBOMbMaDcawDocfMWXM5w4RtsjgKjJvtRLHIa8ZWH0PEJg55YVpafKpRL0Si4cIbdbkmR1Mc2x2s24RCNL6CECc/kLqQJxDHQASNJcAQJJKUJFoxgHXNnjHClwuLgIOgMo3FctJLO0UDbFmMAgtrJrOSEHk7VPDNIf6W8o0bnS+svlBTJCygFQ4o8QmoJlmcSbVrGmIFkkdbmVtSUUTWsA92Ni+OSvbXYa7sieueJ7UimC/x10GLlsWDxYwDe5KEfABxPxJ0hTU0t4SK2T5PY8QJGuZSOaqApAv3dHF6jyiZuDFzDiQqFnnxvam3CiiVv0TK+pHolC99rlEfaCiMpcGbFWiuvMJsCFqZ78vd10xLx5pVqZXY8BA9fCXEe1Sih5r22jbVLQpbmYmKrJwHVKYzEoxmtP2vbvN4L2lPMoB2ExaPxaIF4HTK+8TZjHDSIJtUA7AZlKsAAyQSsDehraxmNaFIQ7DWzY+WOC/e+31o0i1JUha7CxxKs8BHEKq3erBxYt3oToFDeuWNiMSAJJJD2nOiTaWFMweVYh0csR0YJM07iy4TytEOgEQUFluS83E8pa4vewau94coe5mwqX7lhRsAqivP3W3c7oiWnEn7rpQKwKpu6GON80ugG4Qt3IgdVsaCwC6abRVhajbVFoD0CpkreYadXd0awD4wyKVaLU3qbunXgZQJ3OtBjN1C9AmgKOaESUAbiYVAHx7YpB9AMVmRPW2ik0RC4Xs8I50FcAsnaVnMzsUsE6kcwCBMeQynJXNM0zx2+I4VImnukdunseI9vUGBxUX9NRDb4w59FfqO8HSnbnDD73ltNMtba0xab91o+/9sejDSX3dr3i4feK90TMOvbnXsBz6tBNzfDZcv/uqL2gedeeCzkgmVh4uf/+/AP4CFS/8F8+bwkcAAAAASUVORK5CYII=" y="311"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="140" x="308" y="389.8516">Algorithm Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="24" x="366" y="404.7637">[s3]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="376" y="420.5889"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="175" x="290.5" y="436.8857">where docker images are</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="355.5" y="453.1826">stored</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#85BBF0" height="101.4844" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="206" x="485" y="569"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="81" x="547.5" y="593.8516">database</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="96" x="540" y="608.7637">[elastic search]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="586" y="624.5889"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="499" y="640.8857">Where metadata is stored</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="89" x="543.5" y="657.1826">for packages</text></g><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><g id="elem_sps"><rect fill="#999999" height="57.25" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="198" x="7" y="80"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="17" y="104.8516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="73" y="123.4766">System</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M612.43,434.13 C607.51,471.2 600.79,521.96 595.64,560.84 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="594.56,568.95,598.5776,561.4095,592.6289,560.6271,594.56,568.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="90" x="623.5" y="508.1387">reads/writes</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="604" y="522.1074">package metadata</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="630" y="536.0762">[JSON/HTTPS]</text></g><!--MD5=[e873ce36164171149c4fcf5e5d6e05ab]
link sps to api--><g id="link_sps_api"><path d="M91.2,137.01 C80.22,161.62 70.36,196.95 91,218 C106.79,234.11 476.83,215.9 497,226 C539.02,247.04 570.9,290.09 591.51,325.72 " fill="none" id="sps-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="595.48,332.74,594.1455,324.3009,588.9255,327.2592,595.48,332.74" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="128" x="92" y="201.1387">Gets Package Info</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="115.5" y="215.1074">[JSON/HTTPS]</text></g><!--MD5=[005a73589667ace0b52bf2a9f6cca4a1]
link bs to ac--><g id="link_bs_ac"><path d="M649.22,159.17 C659.49,180.46 674.46,203.68 695,218 C711.3,229.37 725.37,211.54 739,226 C762.655,251.095 767.6275,289.4 766.5775,321.8313 C766.5119,323.8582 766.4227,325.8622 766.3131,327.8386 C766.2583,328.8268 766.1984,329.8081 766.1338,330.7819 C766.1015,331.2688 766.068,331.7539 766.0334,332.237 " fill="none" id="bs-to-ac" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="766.0334,332.237,769.5976,324.4719,763.613,324.043,766.0334,332.237" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="145" x="696" y="208.1387">Writes OGC Package</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="4" x="841" y="208.1387">;</text></g><rect height="162.6719" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="159" x="672" y="739"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="678" y="759.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="737" y="759.9951"> </text><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="763.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="682" y="776.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="779.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="682" y="792.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="795.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="682" y="808.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="812.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="682" y="825.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="828.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="682" y="841.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="844.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="682" y="857.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="861.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="682" y="874.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="877.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="682" y="890.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="747" y2="747"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="763.2969" y2="763.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="779.5938" y2="779.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="795.8906" y2="795.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="812.1875" y2="812.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="828.4844" y2="828.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="844.7813" y2="844.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="861.0781" y2="861.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="877.375" y2="877.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="893.6719" y2="893.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="678" y1="747" y2="893.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="825" x2="825" y1="747" y2="893.6719"/><!--MD5=[f09f524e827a94d12dc345cbb8ea26be]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

!define AWSPuml https://raw.githubusercontent.com/awslabs/aws-icons-for-plantuml/main/dist

!includeurl AWSPuml/AWSCommon.puml
' !includeurl AWSPuml/BusinessApplications/all.puml
!include AWSPuml/Storage/SimpleStorageServiceBucketWithObjects.puml

LAYOUT_WITH_LEGEND()

System_Ext(sps, "Science Processing System", "")
System_Boundary(ads,"Algorithm Development"){
  Container(bs, "Build System", "Jenkins", "Builds algorithms into OGC Algorithm Packages.")
  Container_Boundary(ac, "Algorithm Catalog") {
      Component(api, "search api", "cmr?", "API for listing, viewing, and posting package metadata")
      Component(store, "Algorithm Store", "s3", "where docker images are stored", $sprite="SimpleStorageServiceBucketWithObjects")
      Component(db, "database", "elastic search", "Where metadata is stored for packages" )

      Rel(api, db, "reads/writes package metadata", "JSON/HTTPS")

}

}
Rel(sps, api, "Gets Package Info", "JSON/HTTPS")

Rel(bs, ac, "Writes OGC Package");

@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
}
















skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam rectangle {
    StereotypeFontSize 12
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}









sprite $SimpleStorageServiceBucketWithObjects [64x64/16z] {
pPQ9mfmW38JDGOxtV-6MDOgCvNUtzzV-jmaXaq6s_nKYPXPc9lemK9fvv9LmQ_9E6cwUQrpvos2xBgYgqb6zbXEsIj6Y7b2XnQugXMvtj0g4K83LNna4a_ih
BstFqAjEsoO2gaBkjVgqTVZv2OfCdPQFxJFc1VCNunqQyWH1W86gJmfq3TlSlux9E-Qe0PTP48liEDW4OeyPzKpU1jpJYOyPRohCL32BQ1iMSEa5qpNnlXrI
omV2f1e6SjYeiRQ2-CLOE32HZcUFw7UQjPUD6Pg2UZlKim3sEsYVnNEcegFuWtWf-V4N24Sw_TZ0z4L196URxiu2-Ogf8L7TvMDG4P-oee0jgnjqpjlzwNL6
7bLRmecBykEEQXREuucLQK_I2EN70Q1J2kk54_WzZIzgfH4AM7-E7gfGeKPU3dYzz1K5RFitWGDLxZRPd-dv52QwyiJnTV5sRDpTef2W2lQZBkj_HjGFGN25
ShHqkNUgXG2tg0mUcJS1FQ_e2DEcVAR8mcy2Ibnm6iTz9_ZijQcvwPiEvZnWqFhPmJKHnlHgFurI0O9-Jpjhunjmxz8JgCpu3jsBdcn-O3HUjMDXS2ywc79W
jtYe50UW9dUddeFwiLDu9fQJQXti7og50c8ywhUUb8h3U9mVVDUWWp6-mzFyEiJ3040y-0Vbmpd1-8T10m4htlK5F0ZxBD31E3_FxrvqSC010g1xxudvW1RR
hDyZurAuXcnzrvN7EwJOFaKB6EwGS7UiAOA_uG5VX9jPs-zWFjqTl-3X3cbAspkGg7da8Ehk-26qi_tNV0C
}

skinparam rectangle<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}
skinparam participant<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}

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 "==Science Processing System" <<external_system>> as sps
rectangle "==Algorithm Development\n<size:12>[System]</size>" <<boundary>> as ads{
  rectangle "==Build System\n//<size:12>[Jenkins]</size>//\n\n Builds algorithms into OGC Algorithm Packages." <<container>> as bs
  rectangle "==Algorithm Catalog\n<size:12>[Container]</size>" <<boundary>> as ac {
      rectangle "==search api\n//<size:12>[cmr?]</size>//\n\n API for listing, viewing, and posting package metadata" <<component>> as api
      rectangle "<$SimpleStorageServiceBucketWithObjects>\n==Algorithm Store\n//<size:12>[s3]</size>//\n\n where docker images are stored" <<component>> as store
      rectangle "==database\n//<size:12>[elastic search]</size>//\n\n Where metadata is stored for packages" <<component>> as db

api - ->> db : **reads/writes package metadata**\n//<size:12>[JSON/HTTPS]</size>//

}

}
sps - ->> api : **Gets Package Info**\n//<size:12>[JSON/HTTPS]</size>//

bs - ->> ac : **Writes OGC Package**;

@enduml

PlantUML version 1.2022.3(Tue Mar 29 16:10:57 GMT 2022)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>) [Download container diagram](container.svg ':ignore') **Level 3: Component diagram** diff --git a/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/README.md b/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/README.md index a70c3ad..88691ba 100644 --- a/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/README.md +++ b/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/README.md @@ -25,7 +25,7 @@ --- -![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" contentScriptType="application/ecmascript" contentStyleType="text/css" height="915px" preserveAspectRatio="none" style="width:853px;height:915px;background:#FFFFFF;" version="1.1" viewBox="0 0 853 915" width="853px" zoomAndPan="magnify"><defs/><g><!--MD5=[d3c7e7666fa3f68c4fc45bba2365bdb0]
cluster ads--><rect fill="#FFFFFF" height="719" style="stroke:#444444;stroke-width:1.0;stroke-dasharray:7.0,7.0;" width="577" x="221" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="208" x="405.5" y="23.8516">Algorithm Development</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="478.5" y="38.7637">[System]</text><!--MD5=[69da06a6e8584e6c7f392b42750a07eb]
cluster ac--><rect fill="#FFFFFF" height="452" style="stroke:#444444;stroke-width:1.0;stroke-dasharray:7.0,7.0;" width="513" x="253" y="242"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="431" y="258.8516">Algorithm Catalog</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="80" x="469.5" y="273.7637">[Container]</text><!--MD5=[f92115063e8dc9f632cc320845e472c3]
entity bs--><rect fill="#438DD5" height="101.4844" style="stroke:#3C7FC0;stroke-width:1.5;" width="212" x="525" y="58"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="114" x="574" y="82.8516">Build System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="54" x="604" y="97.7637">[Jenkins]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="633" y="113.5889"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="539" y="129.8857">Builds algorithms into OGC</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="561" y="146.1826">Algorithm Packages.</text><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><rect fill="#85BBF0" height="101.4844" style="stroke:#78A8D8;stroke-width:1.5;" width="208" x="515" y="333"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="91" x="573.5" y="357.8516">search api</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="39" x="599.5" y="372.7637">[cmr?]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="621" y="388.5889"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="180" x="529" y="404.8857">API for listing, viewing, and</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="527" y="421.1826">posting package metadata</text><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><rect fill="#85BBF0" height="165.4844" style="stroke:#78A8D8;stroke-width:1.5;" width="203" x="276.5" y="301"/><image height="64" width="64" x="346" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAIAAAAlC+aJAAAEAUlEQVR42u1aPY4WMQz1qWgpKWgooUOIjgYk2pVotqGiokbiANDTcASOwBE4Ak+y5PXGjn+SmeVbtJKFlm9mEj/HPy9O6PrHn3st9ADgRq6+/Ya8//qL5c3nn/I3P7ogANAG+r24+vLs3acnrz88fv720dOXFcGbeB9f4VuMsI+qAQCGxKyYvqhrXTDmq4/fMf4pADAuDFYxKpRggWm18I+V5cIjvNNCEgHAlHYynoO13HEA7YQuEkyxDgAfu6t8UiDyOmP8wT8BAyB7AKCiHoUtcZ7e7soMK48lagCQL+uLeJJoL4BNSwAAPf3gLgWrIQadWZOs+fHvRdXa2KZkX73HACR847i5SxdKVboFQKfkfxvEnIt0SsV/G0GsBajSZHyg3pjLZSszHcjNXFDa1mCMexQDc0uyW/UFzIxf0FAONdyZMTSnwMRMKzRttiIEm6kRk8KAFOEp6yBOMbMaDcawDocfMWXM5w4RtsjgKjJvtRLHIa8ZWH0PEJg55YVpafKpRL0Si4cIbdbkmR1Mc2x2s24RCNL6CECc/kLqQJxDHQASNJcAQJJKUJFoxgHXNnjHClwuLgIOgMo3FctJLO0UDbFmMAgtrJrOSEHk7VPDNIf6W8o0bnS+svlBTJCygFQ4o8QmoJlmcSbVrGmIFkkdbmVtSUUTWsA92Ni+OSvbXYa7sieueJ7UimC/x10GLlsWDxYwDe5KEfABxPxJ0hTU0t4SK2T5PY8QJGuZSOaqApAv3dHF6jyiZuDFzDiQqFnnxvam3CiiVv0TK+pHolC99rlEfaCiMpcGbFWiuvMJsCFqZ78vd10xLx5pVqZXY8BA9fCXEe1Sih5r22jbVLQpbmYmKrJwHVKYzEoxmtP2vbvN4L2lPMoB2ExaPxaIF4HTK+8TZjHDSIJtUA7AZlKsAAyQSsDehraxmNaFIQ7DWzY+WOC/e+31o0i1JUha7CxxKs8BHEKq3erBxYt3oToFDeuWNiMSAJJJD2nOiTaWFMweVYh0csR0YJM07iy4TytEOgEQUFluS83E8pa4vewau94coe5mwqX7lhRsAqivP3W3c7oiWnEn7rpQKwKpu6GON80ugG4Qt3IgdVsaCwC6abRVhajbVFoD0CpkreYadXd0awD4wyKVaLU3qbunXgZQJ3OtBjN1C9AmgKOaESUAbiYVAHx7YpB9AMVmRPW2ik0RC4Xs8I50FcAsnaVnMzsUsE6kcwCBMeQynJXNM0zx2+I4VImnukdunseI9vUGBxUX9NRDb4w59FfqO8HSnbnDD73ltNMtba0xab91o+/9sejDSX3dr3i4feK90TMOvbnXsBz6tBNzfDZcv/uqL2gedeeCzkgmVh4uf/+/AP4CFS/8F8+bwkcAAAAASUVORK5CYII=" y="311"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="140" x="308" y="389.8516">Algorithm Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="24" x="366" y="404.7637">[s3]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="380" y="420.5889"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="175" x="290.5" y="436.8857">where docker images are</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="355.5" y="453.1826">stored</text><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><rect fill="#85BBF0" height="101.4844" style="stroke:#78A8D8;stroke-width:1.5;" width="206" x="485" y="569"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="81" x="547.5" y="593.8516">database</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="96" x="540" y="608.7637">[elastic search]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="590" y="624.5889"/><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="499" y="640.8857">Where metadata is stored</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="89" x="543.5" y="657.1826">for packages</text><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><rect fill="#999999" height="57.25" style="stroke:#8A8A8A;stroke-width:1.5;" width="198" x="7" y="80"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="17" y="104.8516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="73" y="123.4766">System</text><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><path d="M612.43,434.13 C607.51,471.2 600.79,521.96 595.64,560.84 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="594.56,568.95,598.5776,561.4095,592.6289,560.6271,594.56,568.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="90" x="623.5" y="508.1387">reads/writes</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="604" y="522.1074">package metadata</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="630" y="536.0762">[JSON/HTTPS]</text><!--MD5=[e873ce36164171149c4fcf5e5d6e05ab]
link sps to api--><path d="M91.2,137.01 C80.22,161.62 70.36,196.95 91,218 C106.79,234.11 476.83,215.9 497,226 C539.02,247.04 570.9,290.09 591.51,325.72 " fill="none" id="sps-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="595.48,332.74,594.1455,324.3009,588.9255,327.2592,595.48,332.74" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="128" x="92" y="201.1387">Gets Package Info</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="115.5" y="215.1074">[JSON/HTTPS]</text><!--MD5=[005a73589667ace0b52bf2a9f6cca4a1]
link bs to ac--><path d="M649.22,159.17 C659.49,180.46 674.46,203.68 695,218 C711.3,229.37 725.37,211.54 739,226 C762.655,251.095 767.6275,289.4 766.5775,321.8313 C766.5119,323.8582 766.4227,325.8622 766.3131,327.8386 C766.2583,328.8268 766.1984,329.8081 766.1338,330.7819 C766.1015,331.2688 766.068,331.7539 766.0334,332.237 " fill="none" id="bs-to-ac" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="766.0334,332.237,769.5976,324.4719,763.613,324.043,766.0334,332.237" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="145" x="696" y="208.1387">Writes OGC Package</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="4" x="841" y="208.1387">;</text><rect fill="#FFFFFF" height="160.6719" rx="5" ry="5" style="stroke:#FFFFFF;stroke-width:1.0;" width="159" x="672" y="739"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="678" y="758.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="741" y="758.9951"/><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="762.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="682" y="775.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="778.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="682" y="791.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="794.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="682" y="807.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="811.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="682" y="824.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="827.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="682" y="840.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="843.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="682" y="856.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="860.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="682" y="873.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="876.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="682" y="889.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="746" y2="746"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="762.2969" y2="762.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="778.5938" y2="778.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="794.8906" y2="794.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="811.1875" y2="811.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="827.4844" y2="827.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="843.7813" y2="843.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="860.0781" y2="860.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="876.375" y2="876.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="892.6719" y2="892.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="678" y1="746" y2="892.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="825" x2="825" y1="746" y2="892.6719"/><!--MD5=[2312f962569101386433a2f81776f7f6]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

!define AWSPuml https://raw.githubusercontent.com/awslabs/aws-icons-for-plantuml/main/dist

!includeurl AWSPuml/AWSCommon.puml
' !includeurl AWSPuml/BusinessApplications/all.puml
!include AWSPuml/Storage/SimpleStorageServiceBucketWithObjects.puml

LAYOUT_WITH_LEGEND()

System_Ext(sps, "Science Processing System", "")
System_Boundary(ads,"Algorithm Development"){
  Container(bs, "Build System", "Jenkins", "Builds algorithms into OGC Algorithm Packages.")
  Container_Boundary(ac, "Algorithm Catalog") {
      Component(api, "search api", "cmr?", "API for listing, viewing, and posting package metadata")
      Component(store, "Algorithm Store", "s3", "where docker images are stored", $sprite="SimpleStorageServiceBucketWithObjects")
      Component(db, "database", "elastic search", "Where metadata is stored for packages" )

      Rel(api, db, "reads/writes package metadata", "JSON/HTTPS")

}

}
Rel(sps, api, "Gets Package Info", "JSON/HTTPS")

Rel(bs, ac, "Writes OGC Package");

@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
}
















skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam rectangle {
    StereotypeFontSize 12
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}









sprite $SimpleStorageServiceBucketWithObjects [64x64/16z] {
pPQ9mfmW38JDGOxtV-6MDOgCvNUtzzV-jmaXaq6s_nKYPXPc9lemK9fvv9LmQ_9E6cwUQrpvos2xBgYgqb6zbXEsIj6Y7b2XnQugXMvtj0g4K83LNna4a_ih
BstFqAjEsoO2gaBkjVgqTVZv2OfCdPQFxJFc1VCNunqQyWH1W86gJmfq3TlSlux9E-Qe0PTP48liEDW4OeyPzKpU1jpJYOyPRohCL32BQ1iMSEa5qpNnlXrI
omV2f1e6SjYeiRQ2-CLOE32HZcUFw7UQjPUD6Pg2UZlKim3sEsYVnNEcegFuWtWf-V4N24Sw_TZ0z4L196URxiu2-Ogf8L7TvMDG4P-oee0jgnjqpjlzwNL6
7bLRmecBykEEQXREuucLQK_I2EN70Q1J2kk54_WzZIzgfH4AM7-E7gfGeKPU3dYzz1K5RFitWGDLxZRPd-dv52QwyiJnTV5sRDpTef2W2lQZBkj_HjGFGN25
ShHqkNUgXG2tg0mUcJS1FQ_e2DEcVAR8mcy2Ibnm6iTz9_ZijQcvwPiEvZnWqFhPmJKHnlHgFurI0O9-Jpjhunjmxz8JgCpu3jsBdcn-O3HUjMDXS2ywc79W
jtYe50UW9dUddeFwiLDu9fQJQXti7og50c8ywhUUb8h3U9mVVDUWWp6-mzFyEiJ3040y-0Vbmpd1-8T10m4htlK5F0ZxBD31E3_FxrvqSC010g1xxudvW1RR
hDyZurAuXcnzrvN7EwJOFaKB6EwGS7UiAOA_uG5VX9jPs-zWFjqTl-3X3cbAspkGg7da8Ehk-26qi_tNV0C
}

skinparam rectangle<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}
skinparam participant<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}

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 "==Science Processing System" <<external_system>> as sps
rectangle "==Algorithm Development\n<size:12>[System]</size>" <<boundary>> as ads{
  rectangle "==Build System\n//<size:12>[Jenkins]</size>//\n\n Builds algorithms into OGC Algorithm Packages." <<container>> as bs
  rectangle "==Algorithm Catalog\n<size:12>[Container]</size>" <<boundary>> as ac {
      rectangle "==search api\n//<size:12>[cmr?]</size>//\n\n API for listing, viewing, and posting package metadata" <<component>> as api
      rectangle "<$SimpleStorageServiceBucketWithObjects>\n==Algorithm Store\n//<size:12>[s3]</size>//\n\n where docker images are stored" <<component>> as store
      rectangle "==database\n//<size:12>[elastic search]</size>//\n\n Where metadata is stored for packages" <<component>> as db

api - ->> db : **reads/writes package metadata**\n//<size:12>[JSON/HTTPS]</size>//

}

}
sps - ->> api : **Gets Package Info**\n//<size:12>[JSON/HTTPS]</size>//

bs - ->> ac : **Writes OGC Package**;

@enduml

PlantUML version 1.2021.12(Tue Oct 05 16:01:58 GMT 2021)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>) +![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="917px" preserveAspectRatio="none" style="width:853px;height:917px;background:#FFFFFF;" version="1.1" viewBox="0 0 853 917" width="853px" zoomAndPan="magnify"><defs/><g><!--MD5=[d3c7e7666fa3f68c4fc45bba2365bdb0]
cluster ads--><g id="cluster_ads"><rect height="719" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="577" x="221" y="7"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="208" x="405.5" y="23.8516">Algorithm Development</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="478.5" y="38.7637">[System]</text></g><!--MD5=[69da06a6e8584e6c7f392b42750a07eb]
cluster ac--><g id="cluster_ac"><rect height="452" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="513" x="253" y="242"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="157" x="431" y="258.8516">Algorithm Catalog</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="80" x="469.5" y="273.7637">[Container]</text></g><!--MD5=[f92115063e8dc9f632cc320845e472c3]
entity bs--><g id="elem_bs"><rect fill="#438DD5" height="101.4844" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="212" x="525" y="58"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="114" x="574" y="82.8516">Build System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="54" x="604" y="97.7637">[Jenkins]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="629" y="113.5889"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="539" y="129.8857">Builds algorithms into OGC</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="140" x="561" y="146.1826">Algorithm Packages.</text></g><!--MD5=[e2307af040e3f87d22824e7603ca28ec]
entity api--><g id="elem_api"><rect fill="#85BBF0" height="101.4844" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="208" x="515" y="333"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="91" x="573.5" y="357.8516">search api</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="39" x="599.5" y="372.7637">[cmr?]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="617" y="388.5889"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="180" x="529" y="404.8857">API for listing, viewing, and</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="527" y="421.1826">posting package metadata</text></g><!--MD5=[0686720d71d32ea68f81164171d509ce]
entity store--><g id="elem_store"><rect fill="#85BBF0" height="165.4844" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="203" x="276.5" y="301"/><image height="64" width="64" x="346" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAIAAAAlC+aJAAAEAUlEQVR42u1aPY4WMQz1qWgpKWgooUOIjgYk2pVotqGiokbiANDTcASOwBE4Ak+y5PXGjn+SmeVbtJKFlm9mEj/HPy9O6PrHn3st9ADgRq6+/Ya8//qL5c3nn/I3P7ogANAG+r24+vLs3acnrz88fv720dOXFcGbeB9f4VuMsI+qAQCGxKyYvqhrXTDmq4/fMf4pADAuDFYxKpRggWm18I+V5cIjvNNCEgHAlHYynoO13HEA7YQuEkyxDgAfu6t8UiDyOmP8wT8BAyB7AKCiHoUtcZ7e7soMK48lagCQL+uLeJJoL4BNSwAAPf3gLgWrIQadWZOs+fHvRdXa2KZkX73HACR847i5SxdKVboFQKfkfxvEnIt0SsV/G0GsBajSZHyg3pjLZSszHcjNXFDa1mCMexQDc0uyW/UFzIxf0FAONdyZMTSnwMRMKzRttiIEm6kRk8KAFOEp6yBOMbMaDcawDocfMWXM5w4RtsjgKjJvtRLHIa8ZWH0PEJg55YVpafKpRL0Si4cIbdbkmR1Mc2x2s24RCNL6CECc/kLqQJxDHQASNJcAQJJKUJFoxgHXNnjHClwuLgIOgMo3FctJLO0UDbFmMAgtrJrOSEHk7VPDNIf6W8o0bnS+svlBTJCygFQ4o8QmoJlmcSbVrGmIFkkdbmVtSUUTWsA92Ni+OSvbXYa7sieueJ7UimC/x10GLlsWDxYwDe5KEfABxPxJ0hTU0t4SK2T5PY8QJGuZSOaqApAv3dHF6jyiZuDFzDiQqFnnxvam3CiiVv0TK+pHolC99rlEfaCiMpcGbFWiuvMJsCFqZ78vd10xLx5pVqZXY8BA9fCXEe1Sih5r22jbVLQpbmYmKrJwHVKYzEoxmtP2vbvN4L2lPMoB2ExaPxaIF4HTK+8TZjHDSIJtUA7AZlKsAAyQSsDehraxmNaFIQ7DWzY+WOC/e+31o0i1JUha7CxxKs8BHEKq3erBxYt3oToFDeuWNiMSAJJJD2nOiTaWFMweVYh0csR0YJM07iy4TytEOgEQUFluS83E8pa4vewau94coe5mwqX7lhRsAqivP3W3c7oiWnEn7rpQKwKpu6GON80ugG4Qt3IgdVsaCwC6abRVhajbVFoD0CpkreYadXd0awD4wyKVaLU3qbunXgZQJ3OtBjN1C9AmgKOaESUAbiYVAHx7YpB9AMVmRPW2ik0RC4Xs8I50FcAsnaVnMzsUsE6kcwCBMeQynJXNM0zx2+I4VImnukdunseI9vUGBxUX9NRDb4w59FfqO8HSnbnDD73ltNMtba0xab91o+/9sejDSX3dr3i4feK90TMOvbnXsBz6tBNzfDZcv/uqL2gedeeCzkgmVh4uf/+/AP4CFS/8F8+bwkcAAAAASUVORK5CYII=" y="311"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="140" x="308" y="389.8516">Algorithm Store</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="24" x="366" y="404.7637">[s3]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="376" y="420.5889"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="175" x="290.5" y="436.8857">where docker images are</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="45" x="355.5" y="453.1826">stored</text></g><!--MD5=[7468467f3b6b392f1d176d828c753b77]
entity db--><g id="elem_db"><rect fill="#85BBF0" height="101.4844" rx="2.5" ry="2.5" style="stroke:#78A8D8;stroke-width:0.5;" width="206" x="485" y="569"/><text fill="#000000" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="81" x="547.5" y="593.8516">database</text><text fill="#000000" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="96" x="540" y="608.7637">[elastic search]</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="586" y="624.5889"> </text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="499" y="640.8857">Where metadata is stored</text><text fill="#000000" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="89" x="543.5" y="657.1826">for packages</text></g><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><g id="elem_sps"><rect fill="#999999" height="57.25" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="198" x="7" y="80"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="17" y="104.8516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="73" y="123.4766">System</text></g><!--MD5=[1b9dbcfdb69d97b7ce5f2d963fc4ed75]
link api to db--><g id="link_api_db"><path d="M612.43,434.13 C607.51,471.2 600.79,521.96 595.64,560.84 " fill="none" id="api-to-db" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="594.56,568.95,598.5776,561.4095,592.6289,560.6271,594.56,568.95" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="90" x="623.5" y="508.1387">reads/writes</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="604" y="522.1074">package metadata</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="630" y="536.0762">[JSON/HTTPS]</text></g><!--MD5=[e873ce36164171149c4fcf5e5d6e05ab]
link sps to api--><g id="link_sps_api"><path d="M91.2,137.01 C80.22,161.62 70.36,196.95 91,218 C106.79,234.11 476.83,215.9 497,226 C539.02,247.04 570.9,290.09 591.51,325.72 " fill="none" id="sps-to-api" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="595.48,332.74,594.1455,324.3009,588.9255,327.2592,595.48,332.74" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="128" x="92" y="201.1387">Gets Package Info</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="81" x="115.5" y="215.1074">[JSON/HTTPS]</text></g><!--MD5=[005a73589667ace0b52bf2a9f6cca4a1]
link bs to ac--><g id="link_bs_ac"><path d="M649.22,159.17 C659.49,180.46 674.46,203.68 695,218 C711.3,229.37 725.37,211.54 739,226 C762.655,251.095 767.6275,289.4 766.5775,321.8313 C766.5119,323.8582 766.4227,325.8622 766.3131,327.8386 C766.2583,328.8268 766.1984,329.8081 766.1338,330.7819 C766.1015,331.2688 766.068,331.7539 766.0334,332.237 " fill="none" id="bs-to-ac" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="766.0334,332.237,769.5976,324.4719,763.613,324.043,766.0334,332.237" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="145" x="696" y="208.1387">Writes OGC Package</text><text fill="#666666" font-family="sans-serif" font-size="12" lengthAdjust="spacing" textLength="4" x="841" y="208.1387">;</text></g><rect height="162.6719" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="159" x="672" y="739"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="678" y="759.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="737" y="759.9951"> </text><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="763.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="682" y="776.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="779.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="682" y="792.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="795.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="682" y="808.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="812.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="682" y="825.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="828.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="682" y="841.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="844.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="682" y="857.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="861.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="682" y="874.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="678" y="877.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="682" y="890.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="747" y2="747"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="763.2969" y2="763.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="779.5938" y2="779.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="795.8906" y2="795.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="812.1875" y2="812.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="828.4844" y2="828.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="844.7813" y2="844.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="861.0781" y2="861.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="877.375" y2="877.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="825" y1="893.6719" y2="893.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="678" x2="678" y1="747" y2="893.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="825" x2="825" y1="747" y2="893.6719"/><!--MD5=[f09f524e827a94d12dc345cbb8ea26be]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

!define AWSPuml https://raw.githubusercontent.com/awslabs/aws-icons-for-plantuml/main/dist

!includeurl AWSPuml/AWSCommon.puml
' !includeurl AWSPuml/BusinessApplications/all.puml
!include AWSPuml/Storage/SimpleStorageServiceBucketWithObjects.puml

LAYOUT_WITH_LEGEND()

System_Ext(sps, "Science Processing System", "")
System_Boundary(ads,"Algorithm Development"){
  Container(bs, "Build System", "Jenkins", "Builds algorithms into OGC Algorithm Packages.")
  Container_Boundary(ac, "Algorithm Catalog") {
      Component(api, "search api", "cmr?", "API for listing, viewing, and posting package metadata")
      Component(store, "Algorithm Store", "s3", "where docker images are stored", $sprite="SimpleStorageServiceBucketWithObjects")
      Component(db, "database", "elastic search", "Where metadata is stored for packages" )

      Rel(api, db, "reads/writes package metadata", "JSON/HTTPS")

}

}
Rel(sps, api, "Gets Package Info", "JSON/HTTPS")

Rel(bs, ac, "Writes OGC Package");

@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
}
















skinparam defaultTextAlignment center

skinparam wrapWidth 200
skinparam maxMessageSize 150

skinparam rectangle {
    StereotypeFontSize 12
}

skinparam Arrow {
    Color #666666
    FontColor #666666
    FontSize 12
}









sprite $SimpleStorageServiceBucketWithObjects [64x64/16z] {
pPQ9mfmW38JDGOxtV-6MDOgCvNUtzzV-jmaXaq6s_nKYPXPc9lemK9fvv9LmQ_9E6cwUQrpvos2xBgYgqb6zbXEsIj6Y7b2XnQugXMvtj0g4K83LNna4a_ih
BstFqAjEsoO2gaBkjVgqTVZv2OfCdPQFxJFc1VCNunqQyWH1W86gJmfq3TlSlux9E-Qe0PTP48liEDW4OeyPzKpU1jpJYOyPRohCL32BQ1iMSEa5qpNnlXrI
omV2f1e6SjYeiRQ2-CLOE32HZcUFw7UQjPUD6Pg2UZlKim3sEsYVnNEcegFuWtWf-V4N24Sw_TZ0z4L196URxiu2-Ogf8L7TvMDG4P-oee0jgnjqpjlzwNL6
7bLRmecBykEEQXREuucLQK_I2EN70Q1J2kk54_WzZIzgfH4AM7-E7gfGeKPU3dYzz1K5RFitWGDLxZRPd-dv52QwyiJnTV5sRDpTef2W2lQZBkj_HjGFGN25
ShHqkNUgXG2tg0mUcJS1FQ_e2DEcVAR8mcy2Ibnm6iTz9_ZijQcvwPiEvZnWqFhPmJKHnlHgFurI0O9-Jpjhunjmxz8JgCpu3jsBdcn-O3HUjMDXS2ywc79W
jtYe50UW9dUddeFwiLDu9fQJQXti7og50c8ywhUUb8h3U9mVVDUWWp6-mzFyEiJ3040y-0Vbmpd1-8T10m4htlK5F0ZxBD31E3_FxrvqSC010g1xxudvW1RR
hDyZurAuXcnzrvN7EwJOFaKB6EwGS7UiAOA_uG5VX9jPs-zWFjqTl-3X3cbAspkGg7da8Ehk-26qi_tNV0C
}

skinparam rectangle<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}
skinparam participant<<SimpleStorageServiceBucketWithObjects>> {
    BackgroundColor #FFFFFF
    BorderColor #FF9900
}

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 "==Science Processing System" <<external_system>> as sps
rectangle "==Algorithm Development\n<size:12>[System]</size>" <<boundary>> as ads{
  rectangle "==Build System\n//<size:12>[Jenkins]</size>//\n\n Builds algorithms into OGC Algorithm Packages." <<container>> as bs
  rectangle "==Algorithm Catalog\n<size:12>[Container]</size>" <<boundary>> as ac {
      rectangle "==search api\n//<size:12>[cmr?]</size>//\n\n API for listing, viewing, and posting package metadata" <<component>> as api
      rectangle "<$SimpleStorageServiceBucketWithObjects>\n==Algorithm Store\n//<size:12>[s3]</size>//\n\n where docker images are stored" <<component>> as store
      rectangle "==database\n//<size:12>[elastic search]</size>//\n\n Where metadata is stored for packages" <<component>> as db

api - ->> db : **reads/writes package metadata**\n//<size:12>[JSON/HTTPS]</size>//

}

}
sps - ->> api : **Gets Package Info**\n//<size:12>[JSON/HTTPS]</size>//

bs - ->> ac : **Writes OGC Package**;

@enduml

PlantUML version 1.2022.3(Tue Mar 29 16:10:57 GMT 2022)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>) [Download container diagram](container.svg ':ignore') **Level 3: Component diagram** diff --git a/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/container.svg b/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/container.svg index a7bfff1..84284b5 100644 --- a/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/container.svg +++ b/docs/1. Unity Architecture/Algorithm Development/Algorithm Catalog/container.svg @@ -1,14 +1,14 @@ -Algorithm Development[System]Algorithm Catalog[Container]Build System[Jenkins]Builds algorithms into OGCAlgorithm Packages.search api[cmr?]API for listing, viewing, andposting package metadataAlgorithm Store[s3]where docker images arestoreddatabase[elastic search]Where metadata is storedfor packagesScience ProcessingSystemreads/writespackage metadata[JSON/HTTPS]Gets Package Info[JSON/HTTPS]Writes OGC Package;Legendpersonsystemcontainercomponentexternal personexternal systemexternal containerexternal componentAlgorithm Development[System]Algorithm Catalog[Container]Build System[Jenkins] Builds algorithms into OGCAlgorithm Packages.search api[cmr?] API for listing, viewing, andposting package metadataAlgorithm Store[s3] where docker images arestoreddatabase[elastic search] Where metadata is storedfor packagesScience ProcessingSystemreads/writespackage metadata[JSON/HTTPS]Gets Package Info[JSON/HTTPS]Writes OGC Package;Legend personsystemcontainercomponentexternal personexternal systemexternal containerexternal componentAlgorithm Development[System]Algorithm Catalog[Cmr & ECR]Stores Algorithm Package(docker) and Descriptor forUnity usage.Eclipse Che[eclipse che]IDE for algorithmdevelopment.Jupyter Notebooks[jupyter]IDE for algorithmdevelopment.Build System[jenkins]Builds, tests and packagesalgorithms.Source Control[git]Code repository for storingalgorithm codeScience ProcessingSubsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataData ServicesSubsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.Analysis ServicesHigher level data functionsto access and transformdata.Common ServicesPlatform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystemspushes topushes tobuilds algorithmpackagepublishes toaccess Data[HTTP]uses[JSON/HTTPS]Legendpersonsystemcontainercomponentexternal personexternal systemexternal containerexternal componentAlgorithm Development[System]Algorithm Catalog[Cmr & ECR] Stores Algorithm Package(docker) and Descriptor forUnity usage.Eclipse Che[eclipse che] IDE for algorithmdevelopment.Jupyter Notebooks[jupyter] IDE for algorithmdevelopment.Build System[jenkins] Builds, tests and packagesalgorithms.Source Control[git] Code repository for storingalgorithm codeScience Processing Subsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataData Services Subsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.Analysis Services Higher level data functionsto access and transformdata.Common Services Platform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystemspushes topushes tobuilds algorithmpackagepublishes toaccess Data[HTTP]uses[JSON/HTTPS]Legend personsystemcontainercomponentexternal personexternal systemexternal containerexternal componentanalysis Services[System]TransformationService[WCS, WCPS]Transforms data productsAnalysis OptimizedData Stores (AODS)[]Storage of non-optimizeddata in analysis optimizedformatsScience ProcessingSubsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataData ServicesSubsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.Common ServicesPlatform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystemsAlgorithmDevelopmentSubsystem for developingand assembling sciencealgorithms into an algorithmcatalogRetrieves Data Fromoptimizes andstoress data fromRetrieves Data FromRequests large scaleprocessing fromRequeststransformed datafromLegendpersonsystemcontainercomponentexternal personexternal systemexternal containerexternal componentanalysis Services[System]TransformationService[WCS, WCPS] Transforms data productsAnalysis OptimizedData Stores (AODS)[] Storage of non-optimizeddata in analysis optimizedformatsScience Processing Subsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataData Services Subsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.Common Services Platform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystemsAlgorithmDevelopment Subsystem for developingand assembling sciencealgorithms into an algorithmcatalogRetrieves Data Fromoptimizes andstoress data fromRetrieves Data FromRequests large scaleprocessing fromRequeststransformed datafromLegend personsystemcontainercomponentexternal personexternal systemexternal containerexternal componentServices Areas[System]Common Services[System]Science ProcessingSubsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataData ServicesSubsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.Analysis ServicesHigher level data functionsto access and transformdata.AlgorithmDevelopmentSubsystem for developingand assembling sciencealgorithms into an algorithmcatalogAuthenticationService[Cognito, SSO]Authenticate and authorizeusers at point of requestLogging Services[TBD]Provides a systematic wayfor other service areas topublish logsMetrics Services[TBD]Provides a systematic wayfor other service areas topublish metricsNotification Services[TBD]Provides a systematic wayfor other service areas toprovide machine-to-machineand machine-to-usernotificationsDeployment Services[TBD]Provides registries, artifactcontrol, and deploymentsupport for other serviceareas.SupportsDeployment ofAuthenticates usersPublishes Logs[http]Publishes Metrics[http]Notifies[email/http]Legendpersonsystemcontainercomponentexternal personexternal systemexternal containerexternal component \ No newline at end of file +Services Areas[System]Common Services[System]Science Processing Subsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataData Services Subsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.Analysis Services Higher level data functionsto access and transformdata.AlgorithmDevelopment Subsystem for developingand assembling sciencealgorithms into an algorithmcatalogAuthenticationService[Cognito, SSO] Authenticate and authorizeusers at point of requestLogging Services[TBD] Provides a systematic wayfor other service areas topublish logsMetrics Services[TBD] Provides a systematic wayfor other service areas topublish metricsNotification Services[TBD] Provides a systematic wayfor other service areas toprovide machine-to-machineand machine-to-usernotificationsDeployment Services[TBD] Provides registries, artifactcontrol, and deploymentsupport for other serviceareas.SupportsDeployment ofAuthenticates usersPublishes Logs[http]Publishes Metrics[http]Notifies[email/http] \ No newline at end of file diff --git a/docs/1. Unity Architecture/Data Services/HOME.md b/docs/1. Unity Architecture/Data Services/HOME.md index acb74d0..457dfb1 100644 --- a/docs/1. Unity Architecture/Data Services/HOME.md +++ b/docs/1. Unity Architecture/Data Services/HOME.md @@ -1,7 +1,7 @@ # Data Services -![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" contentScriptType="application/ecmascript" contentStyleType="text/css" height="899px" preserveAspectRatio="none" style="width:1270px;height:899px;background:#FFFFFF;" version="1.1" viewBox="0 0 1270 899" width="1270px" zoomAndPan="magnify"><defs/><g><!--MD5=[26883a742dd7c94a71fa058fc72d7bad]
cluster UDS--><rect fill="#FFFFFF" height="465.5" style="stroke:#444444;stroke-width:1.0;stroke-dasharray:7.0,7.0;" width="515" x="7" y="243"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="122" x="203.5" y="259.8516">Data Services</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="233.5" y="274.7637">[System]</text><!--MD5=[727c1040af9be188ab17d19c49f9ac10]
entity ds--><rect fill="#438DD5" height="136.4063" style="stroke:#3C7FC0;stroke-width:1.5;" width="203" x="275.5" y="302"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="167" x="290.5" y="326.8516">Ingest and Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="344" y="345.4766">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="62" x="346" y="360.3887">[Cumulus]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="379" y="376.2139"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="171" x="291.5" y="392.5107">Ingest, basic catalog and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="285.5" y="408.8076">persistent Storage of data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="346" y="425.1045">products</text><!--MD5=[5d03f27da8fde5c71e244cdb7d4def2c]
entity cmr--><rect fill="#438DD5" height="117.7813" style="stroke:#3C7FC0;stroke-width:1.5;" width="217" x="272.5" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="151" x="305.5" y="591.3516">Metadata Search</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="36" x="363" y="606.2637">[CMR]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="383" y="622.0889"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="286.5" y="638.3857">Provides users and services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="295" y="654.6826">spatio/tempral searchfor</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="134" x="314" y="670.9795">Unity data products</text><!--MD5=[90ffe57d7e472346980a4e6a48d8acfa]
entity fb--><rect fill="#438DD5" height="117.7813" style="stroke:#3C7FC0;stroke-width:1.5;" width="206" x="31" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="78.5" y="591.3516">Fast Browse</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="47" x="110.5" y="606.2637">[WMTS]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="136" y="622.0889"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="45" y="638.3857">Allows the retrieval of tiled</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="143" x="60.5" y="654.6826">images for fast visual</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="55" x="106.5" y="670.9795">browse.</text><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><rect fill="#999999" height="136.4063" style="stroke:#8A8A8A;stroke-width:1.5;" width="208" x="155" y="8.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="173" y="33.3516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="261" y="50.1201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="196" y="66.417">Subsystem for the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="165" y="82.7139">generation of science data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="183" y="99.0107">products through the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="167.5" y="115.3076">combination of Algorithms</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="228" y="131.6045">and Data</text><!--MD5=[a9d198bd5c1c9d64f3f6943bebfbf470]
entity as--><rect fill="#999999" height="103.8125" style="stroke:#8A8A8A;stroke-width:1.5;" width="210" x="546" y="573.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="152" x="575" y="598.3516">Analysis Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="653" y="615.1201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="560" y="631.417">Higher level data functions</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="565.5" y="647.7139">to access and transform</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="34" x="634" y="664.0107">data.</text><!--MD5=[d5096230de5c7e9b5a3d1997ba7f37f3]
entity cs--><rect fill="#999999" height="169" style="stroke:#8A8A8A;stroke-width:1.5;" width="219" x="791.5" y="541"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="158" x="822" y="565.8516">Common Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="903" y="582.6201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="825" y="598.917">Platform wide tool and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="186" x="806" y="615.2139">functional implementations</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="195" x="801.5" y="631.5107">including authentication and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="647.8076">authorization, metrics</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="199" x="801.5" y="664.1045">publication, logging services,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="680.4014">deployment and build</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="58" x="872" y="696.6982">systems</text><!--MD5=[d4c4ca0c6539aad8b80246bd3465f857]
entity ads--><rect fill="#999999" height="138.7344" style="stroke:#8A8A8A;stroke-width:1.5;" width="215" x="458.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="520.5" y="31.8516">Algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="507.5" y="50.4766">Development</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="568" y="67.2451"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="476.5" y="83.542">Subsystem for developing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="480.5" y="99.8389">and assembling science</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="468.5" y="116.1357">algorithms into an algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="541" y="132.4326">catalog</text><!--MD5=[a8305b23d211bc1ccd9424c697ead2f2]
entity archive--><rect fill="#999999" height="136.4063" style="stroke:#8A8A8A;stroke-width:1.5;" width="218" x="1046" y="557.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="1122" y="582.3516">Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="1157" y="599.1201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="1082.5" y="615.417">Long term archive for</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="194" x="1056" y="631.7139">distribution of data products</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="1072" y="648.0107">to end users. Examples</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="1056.5" y="664.3076">include PDS, DAAC, or other</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="1079" y="680.6045">NASA approved entity.</text><!--MD5=[1752fd400c1e59390568b5c63c91457d]
link ds to cmr--><path d="M378.06,438.27 C378.65,475.36 379.37,521.24 379.95,558.18 " fill="none" id="ds-to-cmr" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="380.08,566.4,382.9511,558.3528,376.9518,558.4492,380.08,566.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="98" x="380" y="487.1387">catalogs umm</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="86" x="388" y="501.1074">metadata in</text><!--MD5=[4f0dd796c22f3c3a8520ce288b6be380]
link ds to fb--><path d="M280.95,438.12 C269.4,447.65 258.13,457.72 248,468 C220.92,495.49 195.21,529.8 175.07,559.28 " fill="none" id="ds-to-fb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="170.34,566.27,177.3131,561.3329,172.3474,557.9652,170.34,566.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="120" x="249" y="494.1387">Registers tiles in</text><!--MD5=[ffe3e732a9639be178da20d3a5a1095a]
link ds to sps--><path d="M275.12,310.32 C243.43,286.4 212.29,255.66 195,219 C184.77,197.31 189.37,173.61 199.74,151.92 " fill="none" id="ds-to-sps" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="203.46,144.64,197.1482,150.3986,202.491,153.1289,203.46,144.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="196" y="188.1387">SPS accesses data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="213.5" y="202.1074">for processing</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="251.5" y="216.0762">[S3]</text><!--MD5=[12853f797ecbccb97d7945848cad75a9]
link sps to ds--><path d="M319.57,144.67 C326.57,154.7 332.98,165.28 338,176 C355.17,212.7 364.81,256.79 370.2,293.56 " fill="none" id="sps-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="371.35,301.77,373.2074,293.4303,367.2658,294.2654,371.35,301.77" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="147" x="354" y="188.1387">Registers generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="34" x="410.5" y="202.1074">Data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="409" y="216.0762">[CNM]</text><!--MD5=[4bb0246b24efa3458e4019418427926f]
link ds to as--><path d="M457.34,438.14 C468.75,448.03 480.25,458.19 491,468 C526.12,500.04 564.21,537.2 594.42,567.27 " fill="none" id="ds-to-as" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="600.35,573.19,596.7948,565.4208,592.5629,569.6741,600.35,573.19" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="148" x="536" y="480.1387">AS accesses data for</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="556.5" y="494.1074">transformation</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="597" y="508.0762">[S3]</text><!--MD5=[c623f8eb9b9b99b5edfde57cdad58ab8]
link ads to ds--><path d="M552.37,146.11 C544.06,172.07 530.86,199.92 510,219 C500.77,227.45 493.27,219.84 483,227 C457.74,244.61 436.03,270.16 418.95,294.74 " fill="none" id="ads-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="414.26,301.64,421.2404,296.7132,416.2797,293.3381,414.26,301.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="539" y="188.1387">Retrieves generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="69" x="579.5" y="202.1074">data from</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="60" x="584" y="216.0762">[HTTP/S3]</text><!--MD5=[4327822f3cd29a5a620f738e948d832f]
link ds to cs--><path d="M478.71,436.36 C480.14,436.93 481.57,437.47 483,438 C571.47,470.58 605.92,431.85 693,468 C732.42,484.36 771.07,509.96 804.15,535.74 " fill="none" id="ds-to-cs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="810.69,540.9,806.2742,533.5856,802.5535,538.2927,810.69,540.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="105" x="768" y="480.1387">Registers data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="100" x="772.5" y="494.1074">provenance in</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="40" x="802.5" y="508.0762">[HTTP]</text><!--MD5=[e3f069aa297629b3d102948ea47a4205]
link UDS to archive--><path d="M522.101,372.4291 C522.4514,372.492 522.8125,372.5569 523.1843,372.6239 C523.9279,372.7579 524.7139,372.9 525.5416,373.0503 C532.1625,374.2529 541.4425,375.9776 552.8875,378.2039 C575.7775,382.6566 607.3275,389.1156 643.585,397.4163 C716.1,414.0175 807.445,437.985 886,468 C952.29,493.33 966.71,505.23 1028,541 C1034.67,544.89 1041.47,548.98 1048.28,553.18 " fill="none" id="UDS-to-archive" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1055.1,557.4,1049.8804,550.6357,1046.7197,555.7357,1055.1,557.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="96" x="976" y="487.1387">Archives data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="1005.5" y="501.1074">[CNM]</text><rect fill="#FFFFFF" height="160.6719" rx="5" ry="5" style="stroke:#FFFFFF;stroke-width:1.0;" width="159" x="1089" y="723"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="1095" y="742.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="1158" y="742.9951"/><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="746.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="1099" y="759.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="762.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="1099" y="775.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="778.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="1099" y="791.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="795.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="1099" y="808.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="811.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="1099" y="824.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="827.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="1099" y="840.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="844.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="1099" y="857.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="860.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="1099" y="873.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="730" y2="730"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="746.2969" y2="746.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="762.5938" y2="762.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="778.8906" y2="778.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="795.1875" y2="795.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="811.4844" y2="811.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="827.7813" y2="827.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="844.0781" y2="844.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="860.375" y2="860.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="876.6719" y2="876.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1095" y1="730" y2="876.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1242" x2="1242" y1="730" y2="876.6719"/><!--MD5=[9a011527f276984aeaf8df33eb96cd1f]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

'Global vars repeated for referencing other common systems
!global $USC_DESC = "Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems"
!global $AS_DESC = "Higher level data functions to access and transform data."
!global $ADS_DESC = "Subsystem for developing and assembling science algorithms into an algorithm catalog"
!global $SPS_DESC = "Subsystem for the generation of science data products through the combination of Algorithms and Data"
!global $DS_DESC = "Subsystem for ingestion, storage, and access to data products for use in the Unity System."

LAYOUT_WITH_LEGEND()

'Global 'external systems' definitions
System_Ext(sps, "Science Processing", $SPS_DESC)
'System_Ext(ds, "Data Services", $DS_DESC)
System_Ext(as, "Analysis Services", $AS_DESC)
System_Ext(cs, "Common Services", $USC_DESC)
System_Ext(ads, "Algorithm Development", $ADS_DESC)

System_Ext(archive, "Archive", "Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity.")


System_Boundary(UDS, "Data Services") {

    Container(ds, "Ingest and Archive System", "Cumulus", "Ingest, basic catalog and persistent Storage of data products")
    Container(cmr, "Metadata Search", "CMR", "Provides users and services spatio/tempral searchfor Unity data products")
    Container(fb, "Fast Browse", "WMTS", "Allows the retrieval of tiled images for fast visual browse.")

    Rel(ds, cmr, "catalogs umm metadata in")
    Rel(ds, fb, "Registers tiles in")
}

Rel(ds, sps, "SPS accesses data for processing", "S3")
Rel(ds, as, "AS accesses data for transformation", "S3")

Rel(sps, ds, "Registers generated Data", "CNM")
Rel(ads, ds, "Retrieves generated data from", "HTTP/S3")
Rel(ds, cs, "Registers data provenance in", "HTTP")
Rel(UDS, archive, "Archives data", "CNM")

@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 "==Science Processing\n\n Subsystem for the generation of science data products through the combination of Algorithms and Data" <<external_system>> as sps
rectangle "==Analysis Services\n\n Higher level data functions to access and transform data." <<external_system>> as as
rectangle "==Common Services\n\n Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems" <<external_system>> as cs
rectangle "==Algorithm Development\n\n Subsystem for developing and assembling science algorithms into an algorithm catalog" <<external_system>> as ads

rectangle "==Archive\n\n Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity." <<external_system>> as archive


rectangle "==Data Services\n<size:12>[System]</size>" <<boundary>> as UDS {

    rectangle "==Ingest and Archive System\n//<size:12>[Cumulus]</size>//\n\n Ingest, basic catalog and persistent Storage of data products" <<container>> as ds
    rectangle "==Metadata Search\n//<size:12>[CMR]</size>//\n\n Provides users and services spatio/tempral searchfor Unity data products" <<container>> as cmr
    rectangle "==Fast Browse\n//<size:12>[WMTS]</size>//\n\n Allows the retrieval of tiled images for fast visual browse." <<container>> as fb

ds - ->> cmr : **catalogs umm metadata in**
ds - ->> fb : **Registers tiles in**
}

ds - ->> sps : **SPS accesses data for processing**\n//<size:12>[S3]</size>//
ds - ->> as : **AS accesses data for transformation**\n//<size:12>[S3]</size>//

sps - ->> ds : **Registers generated Data**\n//<size:12>[CNM]</size>//
ads - ->> ds : **Retrieves generated data from**\n//<size:12>[HTTP/S3]</size>//
ds - ->> cs : **Registers data provenance in**\n//<size:12>[HTTP]</size>//
UDS - ->> archive : **Archives data**\n//<size:12>[CNM]</size>//

@enduml

PlantUML version 1.2021.12(Tue Oct 05 16:01:58 GMT 2021)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></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="901px" preserveAspectRatio="none" style="width:1270px;height:901px;background:#FFFFFF;" version="1.1" viewBox="0 0 1270 901" width="1270px" zoomAndPan="magnify"><defs/><g><!--MD5=[26883a742dd7c94a71fa058fc72d7bad]
cluster UDS--><g id="cluster_UDS"><rect height="465.5" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="515" x="7" y="243"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="122" x="203.5" y="259.8516">Data Services</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="233.5" y="274.7637">[System]</text></g><!--MD5=[727c1040af9be188ab17d19c49f9ac10]
entity ds--><g id="elem_ds"><rect fill="#438DD5" height="136.4063" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="203" x="275.5" y="302"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="167" x="290.5" y="326.8516">Ingest and Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="344" y="345.4766">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="62" x="346" y="360.3887">[Cumulus]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="375" y="376.2139"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="171" x="291.5" y="392.5107">Ingest, basic catalog and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="285.5" y="408.8076">persistent Storage of data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="346" y="425.1045">products</text></g><!--MD5=[5d03f27da8fde5c71e244cdb7d4def2c]
entity cmr--><g id="elem_cmr"><rect fill="#438DD5" height="117.7813" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="217" x="272.5" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="151" x="305.5" y="591.3516">Metadata Search</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="36" x="363" y="606.2637">[CMR]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="379" y="622.0889"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="286.5" y="638.3857">Provides users and services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="295" y="654.6826">spatio/tempral searchfor</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="134" x="314" y="670.9795">Unity data products</text></g><!--MD5=[90ffe57d7e472346980a4e6a48d8acfa]
entity fb--><g id="elem_fb"><rect fill="#438DD5" height="117.7813" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="31" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="78.5" y="591.3516">Fast Browse</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="47" x="110.5" y="606.2637">[WMTS]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="132" y="622.0889"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="45" y="638.3857">Allows the retrieval of tiled</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="143" x="60.5" y="654.6826">images for fast visual</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="55" x="106.5" y="670.9795">browse.</text></g><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><g id="elem_sps"><rect fill="#999999" height="136.4063" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="208" x="155" y="8.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="173" y="33.3516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="257" y="50.1201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="196" y="66.417">Subsystem for the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="165" y="82.7139">generation of science data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="183" y="99.0107">products through the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="167.5" y="115.3076">combination of Algorithms</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="228" y="131.6045">and Data</text></g><!--MD5=[a9d198bd5c1c9d64f3f6943bebfbf470]
entity as--><g id="elem_as"><rect fill="#999999" height="103.8125" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="210" x="546" y="573.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="152" x="575" y="598.3516">Analysis Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="649" y="615.1201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="560" y="631.417">Higher level data functions</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="565.5" y="647.7139">to access and transform</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="34" x="634" y="664.0107">data.</text></g><!--MD5=[d5096230de5c7e9b5a3d1997ba7f37f3]
entity cs--><g id="elem_cs"><rect fill="#999999" height="169" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="219" x="791.5" y="541"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="158" x="822" y="565.8516">Common Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="899" y="582.6201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="825" y="598.917">Platform wide tool and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="186" x="806" y="615.2139">functional implementations</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="195" x="801.5" y="631.5107">including authentication and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="647.8076">authorization, metrics</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="199" x="801.5" y="664.1045">publication, logging services,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="680.4014">deployment and build</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="58" x="872" y="696.6982">systems</text></g><!--MD5=[d4c4ca0c6539aad8b80246bd3465f857]
entity ads--><g id="elem_ads"><rect fill="#999999" height="138.7344" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="215" x="458.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="520.5" y="31.8516">Algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="507.5" y="50.4766">Development</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="564" y="67.2451"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="476.5" y="83.542">Subsystem for developing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="480.5" y="99.8389">and assembling science</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="468.5" y="116.1357">algorithms into an algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="541" y="132.4326">catalog</text></g><!--MD5=[a8305b23d211bc1ccd9424c697ead2f2]
entity archive--><g id="elem_archive"><rect fill="#999999" height="136.4063" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="218" x="1046" y="557.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="1122" y="582.3516">Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1153" y="599.1201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="1082.5" y="615.417">Long term archive for</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="194" x="1056" y="631.7139">distribution of data products</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="1072" y="648.0107">to end users. Examples</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="1056.5" y="664.3076">include PDS, DAAC, or other</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="1079" y="680.6045">NASA approved entity.</text></g><!--MD5=[1752fd400c1e59390568b5c63c91457d]
link ds to cmr--><g id="link_ds_cmr"><path d="M378.06,438.27 C378.65,475.36 379.37,521.24 379.95,558.18 " fill="none" id="ds-to-cmr" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="380.08,566.4,382.9511,558.3528,376.9518,558.4492,380.08,566.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="98" x="380" y="487.1387">catalogs umm</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="86" x="388" y="501.1074">metadata in</text></g><!--MD5=[4f0dd796c22f3c3a8520ce288b6be380]
link ds to fb--><g id="link_ds_fb"><path d="M280.95,438.12 C269.4,447.65 258.13,457.72 248,468 C220.92,495.49 195.21,529.8 175.07,559.28 " fill="none" id="ds-to-fb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="170.34,566.27,177.3131,561.3329,172.3474,557.9652,170.34,566.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="120" x="249" y="494.1387">Registers tiles in</text></g><!--MD5=[ffe3e732a9639be178da20d3a5a1095a]
link ds to sps--><g id="link_ds_sps"><path d="M275.12,310.32 C243.43,286.4 212.29,255.66 195,219 C184.77,197.31 189.37,173.61 199.74,151.92 " fill="none" id="ds-to-sps" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="203.46,144.64,197.1482,150.3986,202.491,153.1289,203.46,144.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="196" y="188.1387">SPS accesses data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="213.5" y="202.1074">for processing</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="251.5" y="216.0762">[S3]</text></g><!--MD5=[12853f797ecbccb97d7945848cad75a9]
link sps to ds--><g id="link_sps_ds"><path d="M319.57,144.67 C326.57,154.7 332.98,165.28 338,176 C355.17,212.7 364.81,256.79 370.2,293.56 " fill="none" id="sps-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="371.35,301.77,373.2074,293.4303,367.2658,294.2654,371.35,301.77" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="147" x="354" y="188.1387">Registers generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="34" x="410.5" y="202.1074">Data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="409" y="216.0762">[CNM]</text></g><!--MD5=[4bb0246b24efa3458e4019418427926f]
link ds to as--><g id="link_ds_as"><path d="M457.34,438.14 C468.75,448.03 480.25,458.19 491,468 C526.12,500.04 564.21,537.2 594.42,567.27 " fill="none" id="ds-to-as" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="600.35,573.19,596.7948,565.4208,592.5629,569.6741,600.35,573.19" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="148" x="536" y="480.1387">AS accesses data for</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="556.5" y="494.1074">transformation</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="597" y="508.0762">[S3]</text></g><!--MD5=[c623f8eb9b9b99b5edfde57cdad58ab8]
link ads to ds--><g id="link_ads_ds"><path d="M552.37,146.11 C544.06,172.07 530.86,199.92 510,219 C500.77,227.45 493.27,219.84 483,227 C457.74,244.61 436.03,270.16 418.95,294.74 " fill="none" id="ads-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="414.26,301.64,421.2404,296.7132,416.2797,293.3381,414.26,301.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="539" y="188.1387">Retrieves generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="69" x="579.5" y="202.1074">data from</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="60" x="584" y="216.0762">[HTTP/S3]</text></g><!--MD5=[4327822f3cd29a5a620f738e948d832f]
link ds to cs--><g id="link_ds_cs"><path d="M478.71,436.36 C480.14,436.93 481.57,437.47 483,438 C571.47,470.58 605.92,431.85 693,468 C732.42,484.36 771.07,509.96 804.15,535.74 " fill="none" id="ds-to-cs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="810.69,540.9,806.2742,533.5856,802.5535,538.2927,810.69,540.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="105" x="768" y="480.1387">Registers data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="100" x="772.5" y="494.1074">provenance in</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="40" x="802.5" y="508.0762">[HTTP]</text></g><!--MD5=[e3f069aa297629b3d102948ea47a4205]
link UDS to archive--><g id="link_UDS_archive"><path d="M522.101,372.4291 C522.4514,372.492 522.8125,372.5569 523.1843,372.6239 C523.9279,372.7579 524.7139,372.9 525.5416,373.0503 C532.1625,374.2529 541.4425,375.9776 552.8875,378.2039 C575.7775,382.6566 607.3275,389.1156 643.585,397.4163 C716.1,414.0175 807.445,437.985 886,468 C952.29,493.33 966.71,505.23 1028,541 C1034.67,544.89 1041.47,548.98 1048.28,553.18 " fill="none" id="UDS-to-archive" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1055.1,557.4,1049.8804,550.6357,1046.7197,555.7357,1055.1,557.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="96" x="976" y="487.1387">Archives data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="1005.5" y="501.1074">[CNM]</text></g><rect height="162.6719" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="159" x="1089" y="723"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="1095" y="743.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1154" y="743.9951"> </text><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="747.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="1099" y="760.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="763.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="1099" y="776.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="779.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="1099" y="792.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="796.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="1099" y="809.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="812.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="1099" y="825.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="828.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="1099" y="841.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="845.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="1099" y="858.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="861.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="1099" y="874.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="731" y2="731"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="747.2969" y2="747.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="763.5938" y2="763.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="779.8906" y2="779.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="796.1875" y2="796.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="812.4844" y2="812.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="828.7813" y2="828.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="845.0781" y2="845.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="861.375" y2="861.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="877.6719" y2="877.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1095" y1="731" y2="877.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1242" x2="1242" y1="731" y2="877.6719"/><!--MD5=[5560287dd068573d7bfa1c1f9d3154c6]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

'Global vars repeated for referencing other common systems
!global $USC_DESC = "Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems"
!global $AS_DESC = "Higher level data functions to access and transform data."
!global $ADS_DESC = "Subsystem for developing and assembling science algorithms into an algorithm catalog"
!global $SPS_DESC = "Subsystem for the generation of science data products through the combination of Algorithms and Data"
!global $DS_DESC = "Subsystem for ingestion, storage, and access to data products for use in the Unity System."

LAYOUT_WITH_LEGEND()

'Global 'external systems' definitions
System_Ext(sps, "Science Processing", $SPS_DESC)
'System_Ext(ds, "Data Services", $DS_DESC)
System_Ext(as, "Analysis Services", $AS_DESC)
System_Ext(cs, "Common Services", $USC_DESC)
System_Ext(ads, "Algorithm Development", $ADS_DESC)

System_Ext(archive, "Archive", "Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity.")


System_Boundary(UDS, "Data Services") {

    Container(ds, "Ingest and Archive System", "Cumulus", "Ingest, basic catalog and persistent Storage of data products")
    Container(cmr, "Metadata Search", "CMR", "Provides users and services spatio/tempral searchfor Unity data products")
    Container(fb, "Fast Browse", "WMTS", "Allows the retrieval of tiled images for fast visual browse.")

    Rel(ds, cmr, "catalogs umm metadata in")
    Rel(ds, fb, "Registers tiles in")
}

Rel(ds, sps, "SPS accesses data for processing", "S3")
Rel(ds, as, "AS accesses data for transformation", "S3")

Rel(sps, ds, "Registers generated Data", "CNM")
Rel(ads, ds, "Retrieves generated data from", "HTTP/S3")
Rel(ds, cs, "Registers data provenance in", "HTTP")
Rel(UDS, archive, "Archives data", "CNM")

@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 "==Science Processing\n\n Subsystem for the generation of science data products through the combination of Algorithms and Data" <<external_system>> as sps
rectangle "==Analysis Services\n\n Higher level data functions to access and transform data." <<external_system>> as as
rectangle "==Common Services\n\n Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems" <<external_system>> as cs
rectangle "==Algorithm Development\n\n Subsystem for developing and assembling science algorithms into an algorithm catalog" <<external_system>> as ads

rectangle "==Archive\n\n Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity." <<external_system>> as archive


rectangle "==Data Services\n<size:12>[System]</size>" <<boundary>> as UDS {

    rectangle "==Ingest and Archive System\n//<size:12>[Cumulus]</size>//\n\n Ingest, basic catalog and persistent Storage of data products" <<container>> as ds
    rectangle "==Metadata Search\n//<size:12>[CMR]</size>//\n\n Provides users and services spatio/tempral searchfor Unity data products" <<container>> as cmr
    rectangle "==Fast Browse\n//<size:12>[WMTS]</size>//\n\n Allows the retrieval of tiled images for fast visual browse." <<container>> as fb

ds - ->> cmr : **catalogs umm metadata in**
ds - ->> fb : **Registers tiles in**
}

ds - ->> sps : **SPS accesses data for processing**\n//<size:12>[S3]</size>//
ds - ->> as : **AS accesses data for transformation**\n//<size:12>[S3]</size>//

sps - ->> ds : **Registers generated Data**\n//<size:12>[CNM]</size>//
ads - ->> ds : **Retrieves generated data from**\n//<size:12>[HTTP/S3]</size>//
ds - ->> cs : **Registers data provenance in**\n//<size:12>[HTTP]</size>//
UDS - ->> archive : **Archives data**\n//<size:12>[CNM]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 16:10:57 GMT 2022)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>) [Download system diagram](system.svg ':ignore') # Data Services diff --git a/docs/1. Unity Architecture/Data Services/README.md b/docs/1. Unity Architecture/Data Services/README.md index 2ebfb02..5f07dec 100644 --- a/docs/1. Unity Architecture/Data Services/README.md +++ b/docs/1. Unity Architecture/Data Services/README.md @@ -25,7 +25,7 @@ --- -![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" contentScriptType="application/ecmascript" contentStyleType="text/css" height="899px" preserveAspectRatio="none" style="width:1270px;height:899px;background:#FFFFFF;" version="1.1" viewBox="0 0 1270 899" width="1270px" zoomAndPan="magnify"><defs/><g><!--MD5=[26883a742dd7c94a71fa058fc72d7bad]
cluster UDS--><rect fill="#FFFFFF" height="465.5" style="stroke:#444444;stroke-width:1.0;stroke-dasharray:7.0,7.0;" width="515" x="7" y="243"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="122" x="203.5" y="259.8516">Data Services</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="233.5" y="274.7637">[System]</text><!--MD5=[727c1040af9be188ab17d19c49f9ac10]
entity ds--><rect fill="#438DD5" height="136.4063" style="stroke:#3C7FC0;stroke-width:1.5;" width="203" x="275.5" y="302"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="167" x="290.5" y="326.8516">Ingest and Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="344" y="345.4766">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="62" x="346" y="360.3887">[Cumulus]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="379" y="376.2139"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="171" x="291.5" y="392.5107">Ingest, basic catalog and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="285.5" y="408.8076">persistent Storage of data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="346" y="425.1045">products</text><!--MD5=[5d03f27da8fde5c71e244cdb7d4def2c]
entity cmr--><rect fill="#438DD5" height="117.7813" style="stroke:#3C7FC0;stroke-width:1.5;" width="217" x="272.5" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="151" x="305.5" y="591.3516">Metadata Search</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="36" x="363" y="606.2637">[CMR]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="383" y="622.0889"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="286.5" y="638.3857">Provides users and services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="295" y="654.6826">spatio/tempral searchfor</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="134" x="314" y="670.9795">Unity data products</text><!--MD5=[90ffe57d7e472346980a4e6a48d8acfa]
entity fb--><rect fill="#438DD5" height="117.7813" style="stroke:#3C7FC0;stroke-width:1.5;" width="206" x="31" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="78.5" y="591.3516">Fast Browse</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="47" x="110.5" y="606.2637">[WMTS]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="136" y="622.0889"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="45" y="638.3857">Allows the retrieval of tiled</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="143" x="60.5" y="654.6826">images for fast visual</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="55" x="106.5" y="670.9795">browse.</text><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><rect fill="#999999" height="136.4063" style="stroke:#8A8A8A;stroke-width:1.5;" width="208" x="155" y="8.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="173" y="33.3516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="261" y="50.1201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="196" y="66.417">Subsystem for the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="165" y="82.7139">generation of science data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="183" y="99.0107">products through the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="167.5" y="115.3076">combination of Algorithms</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="228" y="131.6045">and Data</text><!--MD5=[a9d198bd5c1c9d64f3f6943bebfbf470]
entity as--><rect fill="#999999" height="103.8125" style="stroke:#8A8A8A;stroke-width:1.5;" width="210" x="546" y="573.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="152" x="575" y="598.3516">Analysis Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="653" y="615.1201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="560" y="631.417">Higher level data functions</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="565.5" y="647.7139">to access and transform</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="34" x="634" y="664.0107">data.</text><!--MD5=[d5096230de5c7e9b5a3d1997ba7f37f3]
entity cs--><rect fill="#999999" height="169" style="stroke:#8A8A8A;stroke-width:1.5;" width="219" x="791.5" y="541"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="158" x="822" y="565.8516">Common Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="903" y="582.6201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="825" y="598.917">Platform wide tool and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="186" x="806" y="615.2139">functional implementations</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="195" x="801.5" y="631.5107">including authentication and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="647.8076">authorization, metrics</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="199" x="801.5" y="664.1045">publication, logging services,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="680.4014">deployment and build</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="58" x="872" y="696.6982">systems</text><!--MD5=[d4c4ca0c6539aad8b80246bd3465f857]
entity ads--><rect fill="#999999" height="138.7344" style="stroke:#8A8A8A;stroke-width:1.5;" width="215" x="458.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="520.5" y="31.8516">Algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="507.5" y="50.4766">Development</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="568" y="67.2451"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="476.5" y="83.542">Subsystem for developing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="480.5" y="99.8389">and assembling science</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="468.5" y="116.1357">algorithms into an algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="541" y="132.4326">catalog</text><!--MD5=[a8305b23d211bc1ccd9424c697ead2f2]
entity archive--><rect fill="#999999" height="136.4063" style="stroke:#8A8A8A;stroke-width:1.5;" width="218" x="1046" y="557.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="1122" y="582.3516">Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="1157" y="599.1201"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="1082.5" y="615.417">Long term archive for</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="194" x="1056" y="631.7139">distribution of data products</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="1072" y="648.0107">to end users. Examples</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="1056.5" y="664.3076">include PDS, DAAC, or other</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="1079" y="680.6045">NASA approved entity.</text><!--MD5=[1752fd400c1e59390568b5c63c91457d]
link ds to cmr--><path d="M378.06,438.27 C378.65,475.36 379.37,521.24 379.95,558.18 " fill="none" id="ds-to-cmr" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="380.08,566.4,382.9511,558.3528,376.9518,558.4492,380.08,566.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="98" x="380" y="487.1387">catalogs umm</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="86" x="388" y="501.1074">metadata in</text><!--MD5=[4f0dd796c22f3c3a8520ce288b6be380]
link ds to fb--><path d="M280.95,438.12 C269.4,447.65 258.13,457.72 248,468 C220.92,495.49 195.21,529.8 175.07,559.28 " fill="none" id="ds-to-fb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="170.34,566.27,177.3131,561.3329,172.3474,557.9652,170.34,566.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="120" x="249" y="494.1387">Registers tiles in</text><!--MD5=[ffe3e732a9639be178da20d3a5a1095a]
link ds to sps--><path d="M275.12,310.32 C243.43,286.4 212.29,255.66 195,219 C184.77,197.31 189.37,173.61 199.74,151.92 " fill="none" id="ds-to-sps" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="203.46,144.64,197.1482,150.3986,202.491,153.1289,203.46,144.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="196" y="188.1387">SPS accesses data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="213.5" y="202.1074">for processing</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="251.5" y="216.0762">[S3]</text><!--MD5=[12853f797ecbccb97d7945848cad75a9]
link sps to ds--><path d="M319.57,144.67 C326.57,154.7 332.98,165.28 338,176 C355.17,212.7 364.81,256.79 370.2,293.56 " fill="none" id="sps-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="371.35,301.77,373.2074,293.4303,367.2658,294.2654,371.35,301.77" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="147" x="354" y="188.1387">Registers generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="34" x="410.5" y="202.1074">Data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="409" y="216.0762">[CNM]</text><!--MD5=[4bb0246b24efa3458e4019418427926f]
link ds to as--><path d="M457.34,438.14 C468.75,448.03 480.25,458.19 491,468 C526.12,500.04 564.21,537.2 594.42,567.27 " fill="none" id="ds-to-as" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="600.35,573.19,596.7948,565.4208,592.5629,569.6741,600.35,573.19" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="148" x="536" y="480.1387">AS accesses data for</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="556.5" y="494.1074">transformation</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="597" y="508.0762">[S3]</text><!--MD5=[c623f8eb9b9b99b5edfde57cdad58ab8]
link ads to ds--><path d="M552.37,146.11 C544.06,172.07 530.86,199.92 510,219 C500.77,227.45 493.27,219.84 483,227 C457.74,244.61 436.03,270.16 418.95,294.74 " fill="none" id="ads-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="414.26,301.64,421.2404,296.7132,416.2797,293.3381,414.26,301.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="539" y="188.1387">Retrieves generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="69" x="579.5" y="202.1074">data from</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="60" x="584" y="216.0762">[HTTP/S3]</text><!--MD5=[4327822f3cd29a5a620f738e948d832f]
link ds to cs--><path d="M478.71,436.36 C480.14,436.93 481.57,437.47 483,438 C571.47,470.58 605.92,431.85 693,468 C732.42,484.36 771.07,509.96 804.15,535.74 " fill="none" id="ds-to-cs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="810.69,540.9,806.2742,533.5856,802.5535,538.2927,810.69,540.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="105" x="768" y="480.1387">Registers data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="100" x="772.5" y="494.1074">provenance in</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="40" x="802.5" y="508.0762">[HTTP]</text><!--MD5=[e3f069aa297629b3d102948ea47a4205]
link UDS to archive--><path d="M522.101,372.4291 C522.4514,372.492 522.8125,372.5569 523.1843,372.6239 C523.9279,372.7579 524.7139,372.9 525.5416,373.0503 C532.1625,374.2529 541.4425,375.9776 552.8875,378.2039 C575.7775,382.6566 607.3275,389.1156 643.585,397.4163 C716.1,414.0175 807.445,437.985 886,468 C952.29,493.33 966.71,505.23 1028,541 C1034.67,544.89 1041.47,548.98 1048.28,553.18 " fill="none" id="UDS-to-archive" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1055.1,557.4,1049.8804,550.6357,1046.7197,555.7357,1055.1,557.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="96" x="976" y="487.1387">Archives data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="1005.5" y="501.1074">[CNM]</text><rect fill="#FFFFFF" height="160.6719" rx="5" ry="5" style="stroke:#FFFFFF;stroke-width:1.0;" width="159" x="1089" y="723"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="1095" y="742.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="0" x="1158" y="742.9951"/><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="746.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="1099" y="759.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="762.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="1099" y="775.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="778.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="1099" y="791.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="795.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="1099" y="808.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="811.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="1099" y="824.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="827.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="1099" y="840.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="844.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="1099" y="857.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="860.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="1099" y="873.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="730" y2="730"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="746.2969" y2="746.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="762.5938" y2="762.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="778.8906" y2="778.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="795.1875" y2="795.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="811.4844" y2="811.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="827.7813" y2="827.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="844.0781" y2="844.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="860.375" y2="860.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="876.6719" y2="876.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1095" y1="730" y2="876.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1242" x2="1242" y1="730" y2="876.6719"/><!--MD5=[9a011527f276984aeaf8df33eb96cd1f]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

'Global vars repeated for referencing other common systems
!global $USC_DESC = "Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems"
!global $AS_DESC = "Higher level data functions to access and transform data."
!global $ADS_DESC = "Subsystem for developing and assembling science algorithms into an algorithm catalog"
!global $SPS_DESC = "Subsystem for the generation of science data products through the combination of Algorithms and Data"
!global $DS_DESC = "Subsystem for ingestion, storage, and access to data products for use in the Unity System."

LAYOUT_WITH_LEGEND()

'Global 'external systems' definitions
System_Ext(sps, "Science Processing", $SPS_DESC)
'System_Ext(ds, "Data Services", $DS_DESC)
System_Ext(as, "Analysis Services", $AS_DESC)
System_Ext(cs, "Common Services", $USC_DESC)
System_Ext(ads, "Algorithm Development", $ADS_DESC)

System_Ext(archive, "Archive", "Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity.")


System_Boundary(UDS, "Data Services") {

    Container(ds, "Ingest and Archive System", "Cumulus", "Ingest, basic catalog and persistent Storage of data products")
    Container(cmr, "Metadata Search", "CMR", "Provides users and services spatio/tempral searchfor Unity data products")
    Container(fb, "Fast Browse", "WMTS", "Allows the retrieval of tiled images for fast visual browse.")

    Rel(ds, cmr, "catalogs umm metadata in")
    Rel(ds, fb, "Registers tiles in")
}

Rel(ds, sps, "SPS accesses data for processing", "S3")
Rel(ds, as, "AS accesses data for transformation", "S3")

Rel(sps, ds, "Registers generated Data", "CNM")
Rel(ads, ds, "Retrieves generated data from", "HTTP/S3")
Rel(ds, cs, "Registers data provenance in", "HTTP")
Rel(UDS, archive, "Archives data", "CNM")

@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 "==Science Processing\n\n Subsystem for the generation of science data products through the combination of Algorithms and Data" <<external_system>> as sps
rectangle "==Analysis Services\n\n Higher level data functions to access and transform data." <<external_system>> as as
rectangle "==Common Services\n\n Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems" <<external_system>> as cs
rectangle "==Algorithm Development\n\n Subsystem for developing and assembling science algorithms into an algorithm catalog" <<external_system>> as ads

rectangle "==Archive\n\n Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity." <<external_system>> as archive


rectangle "==Data Services\n<size:12>[System]</size>" <<boundary>> as UDS {

    rectangle "==Ingest and Archive System\n//<size:12>[Cumulus]</size>//\n\n Ingest, basic catalog and persistent Storage of data products" <<container>> as ds
    rectangle "==Metadata Search\n//<size:12>[CMR]</size>//\n\n Provides users and services spatio/tempral searchfor Unity data products" <<container>> as cmr
    rectangle "==Fast Browse\n//<size:12>[WMTS]</size>//\n\n Allows the retrieval of tiled images for fast visual browse." <<container>> as fb

ds - ->> cmr : **catalogs umm metadata in**
ds - ->> fb : **Registers tiles in**
}

ds - ->> sps : **SPS accesses data for processing**\n//<size:12>[S3]</size>//
ds - ->> as : **AS accesses data for transformation**\n//<size:12>[S3]</size>//

sps - ->> ds : **Registers generated Data**\n//<size:12>[CNM]</size>//
ads - ->> ds : **Retrieves generated data from**\n//<size:12>[HTTP/S3]</size>//
ds - ->> cs : **Registers data provenance in**\n//<size:12>[HTTP]</size>//
UDS - ->> archive : **Archives data**\n//<size:12>[CNM]</size>//

@enduml

PlantUML version 1.2021.12(Tue Oct 05 16:01:58 GMT 2021)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></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="901px" preserveAspectRatio="none" style="width:1270px;height:901px;background:#FFFFFF;" version="1.1" viewBox="0 0 1270 901" width="1270px" zoomAndPan="magnify"><defs/><g><!--MD5=[26883a742dd7c94a71fa058fc72d7bad]
cluster UDS--><g id="cluster_UDS"><rect height="465.5" rx="2.5" ry="2.5" style="stroke:#444444;stroke-width:1.0;fill:none;stroke-dasharray:7.0,7.0;" width="515" x="7" y="243"/><text fill="#444444" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="122" x="203.5" y="259.8516">Data Services</text><text fill="#444444" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="62" x="233.5" y="274.7637">[System]</text></g><!--MD5=[727c1040af9be188ab17d19c49f9ac10]
entity ds--><g id="elem_ds"><rect fill="#438DD5" height="136.4063" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="203" x="275.5" y="302"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="167" x="290.5" y="326.8516">Ingest and Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="344" y="345.4766">System</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="62" x="346" y="360.3887">[Cumulus]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="375" y="376.2139"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="171" x="291.5" y="392.5107">Ingest, basic catalog and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="285.5" y="408.8076">persistent Storage of data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="346" y="425.1045">products</text></g><!--MD5=[5d03f27da8fde5c71e244cdb7d4def2c]
entity cmr--><g id="elem_cmr"><rect fill="#438DD5" height="117.7813" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="217" x="272.5" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="151" x="305.5" y="591.3516">Metadata Search</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="36" x="363" y="606.2637">[CMR]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="379" y="622.0889"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="286.5" y="638.3857">Provides users and services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="168" x="295" y="654.6826">spatio/tempral searchfor</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="134" x="314" y="670.9795">Unity data products</text></g><!--MD5=[90ffe57d7e472346980a4e6a48d8acfa]
entity fb--><g id="elem_fb"><rect fill="#438DD5" height="117.7813" rx="2.5" ry="2.5" style="stroke:#3C7FC0;stroke-width:0.5;" width="206" x="31" y="566.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="111" x="78.5" y="591.3516">Fast Browse</text><text fill="#FFFFFF" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="47" x="110.5" y="606.2637">[WMTS]</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="132" y="622.0889"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="178" x="45" y="638.3857">Allows the retrieval of tiled</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="143" x="60.5" y="654.6826">images for fast visual</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="55" x="106.5" y="670.9795">browse.</text></g><!--MD5=[3fffc34736d2f7e76958dc3c596e3531]
entity sps--><g id="elem_sps"><rect fill="#999999" height="136.4063" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="208" x="155" y="8.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="172" x="173" y="33.3516">Science Processing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="257" y="50.1201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="126" x="196" y="66.417">Subsystem for the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="184" x="165" y="82.7139">generation of science data</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="148" x="183" y="99.0107">products through the</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="167.5" y="115.3076">combination of Algorithms</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="62" x="228" y="131.6045">and Data</text></g><!--MD5=[a9d198bd5c1c9d64f3f6943bebfbf470]
entity as--><g id="elem_as"><rect fill="#999999" height="103.8125" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="210" x="546" y="573.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="152" x="575" y="598.3516">Analysis Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="649" y="615.1201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="182" x="560" y="631.417">Higher level data functions</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="565.5" y="647.7139">to access and transform</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="34" x="634" y="664.0107">data.</text></g><!--MD5=[d5096230de5c7e9b5a3d1997ba7f37f3]
entity cs--><g id="elem_cs"><rect fill="#999999" height="169" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="219" x="791.5" y="541"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="158" x="822" y="565.8516">Common Services</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="899" y="582.6201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="825" y="598.917">Platform wide tool and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="186" x="806" y="615.2139">functional implementations</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="195" x="801.5" y="631.5107">including authentication and</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="647.8076">authorization, metrics</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="199" x="801.5" y="664.1045">publication, logging services,</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="149" x="824.5" y="680.4014">deployment and build</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="58" x="872" y="696.6982">systems</text></g><!--MD5=[d4c4ca0c6539aad8b80246bd3465f857]
entity ads--><g id="elem_ads"><rect fill="#999999" height="138.7344" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="215" x="458.5" y="7"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="85" x="520.5" y="31.8516">Algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="117" x="507.5" y="50.4766">Development</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="564" y="67.2451"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="179" x="476.5" y="83.542">Subsystem for developing</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="167" x="480.5" y="99.8389">and assembling science</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="191" x="468.5" y="116.1357">algorithms into an algorithm</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="541" y="132.4326">catalog</text></g><!--MD5=[a8305b23d211bc1ccd9424c697ead2f2]
entity archive--><g id="elem_archive"><rect fill="#999999" height="136.4063" rx="2.5" ry="2.5" style="stroke:#8A8A8A;stroke-width:0.5;" width="218" x="1046" y="557.5"/><text fill="#FFFFFF" font-family="sans-serif" font-size="16" font-weight="bold" lengthAdjust="spacing" textLength="66" x="1122" y="582.3516">Archive</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1153" y="599.1201"> </text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="145" x="1082.5" y="615.417">Long term archive for</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="194" x="1056" y="631.7139">distribution of data products</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="162" x="1072" y="648.0107">to end users. Examples</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="193" x="1056.5" y="664.3076">include PDS, DAAC, or other</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="152" x="1079" y="680.6045">NASA approved entity.</text></g><!--MD5=[1752fd400c1e59390568b5c63c91457d]
link ds to cmr--><g id="link_ds_cmr"><path d="M378.06,438.27 C378.65,475.36 379.37,521.24 379.95,558.18 " fill="none" id="ds-to-cmr" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="380.08,566.4,382.9511,558.3528,376.9518,558.4492,380.08,566.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="98" x="380" y="487.1387">catalogs umm</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="86" x="388" y="501.1074">metadata in</text></g><!--MD5=[4f0dd796c22f3c3a8520ce288b6be380]
link ds to fb--><g id="link_ds_fb"><path d="M280.95,438.12 C269.4,447.65 258.13,457.72 248,468 C220.92,495.49 195.21,529.8 175.07,559.28 " fill="none" id="ds-to-fb" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="170.34,566.27,177.3131,561.3329,172.3474,557.9652,170.34,566.27" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="120" x="249" y="494.1387">Registers tiles in</text></g><!--MD5=[ffe3e732a9639be178da20d3a5a1095a]
link ds to sps--><g id="link_ds_sps"><path d="M275.12,310.32 C243.43,286.4 212.29,255.66 195,219 C184.77,197.31 189.37,173.61 199.74,151.92 " fill="none" id="ds-to-sps" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="203.46,144.64,197.1482,150.3986,202.491,153.1289,203.46,144.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="133" x="196" y="188.1387">SPS accesses data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="102" x="213.5" y="202.1074">for processing</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="251.5" y="216.0762">[S3]</text></g><!--MD5=[12853f797ecbccb97d7945848cad75a9]
link sps to ds--><g id="link_sps_ds"><path d="M319.57,144.67 C326.57,154.7 332.98,165.28 338,176 C355.17,212.7 364.81,256.79 370.2,293.56 " fill="none" id="sps-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="371.35,301.77,373.2074,293.4303,367.2658,294.2654,371.35,301.77" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="147" x="354" y="188.1387">Registers generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="34" x="410.5" y="202.1074">Data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="409" y="216.0762">[CNM]</text></g><!--MD5=[4bb0246b24efa3458e4019418427926f]
link ds to as--><g id="link_ds_as"><path d="M457.34,438.14 C468.75,448.03 480.25,458.19 491,468 C526.12,500.04 564.21,537.2 594.42,567.27 " fill="none" id="ds-to-as" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="600.35,573.19,596.7948,565.4208,592.5629,569.6741,600.35,573.19" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="148" x="536" y="480.1387">AS accesses data for</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="107" x="556.5" y="494.1074">transformation</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="26" x="597" y="508.0762">[S3]</text></g><!--MD5=[c623f8eb9b9b99b5edfde57cdad58ab8]
link ads to ds--><g id="link_ads_ds"><path d="M552.37,146.11 C544.06,172.07 530.86,199.92 510,219 C500.77,227.45 493.27,219.84 483,227 C457.74,244.61 436.03,270.16 418.95,294.74 " fill="none" id="ads-to-ds" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="414.26,301.64,421.2404,296.7132,416.2797,293.3381,414.26,301.64" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="146" x="539" y="188.1387">Retrieves generated</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="69" x="579.5" y="202.1074">data from</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="60" x="584" y="216.0762">[HTTP/S3]</text></g><!--MD5=[4327822f3cd29a5a620f738e948d832f]
link ds to cs--><g id="link_ds_cs"><path d="M478.71,436.36 C480.14,436.93 481.57,437.47 483,438 C571.47,470.58 605.92,431.85 693,468 C732.42,484.36 771.07,509.96 804.15,535.74 " fill="none" id="ds-to-cs" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="810.69,540.9,806.2742,533.5856,802.5535,538.2927,810.69,540.9" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="105" x="768" y="480.1387">Registers data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="100" x="772.5" y="494.1074">provenance in</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="40" x="802.5" y="508.0762">[HTTP]</text></g><!--MD5=[e3f069aa297629b3d102948ea47a4205]
link UDS to archive--><g id="link_UDS_archive"><path d="M522.101,372.4291 C522.4514,372.492 522.8125,372.5569 523.1843,372.6239 C523.9279,372.7579 524.7139,372.9 525.5416,373.0503 C532.1625,374.2529 541.4425,375.9776 552.8875,378.2039 C575.7775,382.6566 607.3275,389.1156 643.585,397.4163 C716.1,414.0175 807.445,437.985 886,468 C952.29,493.33 966.71,505.23 1028,541 C1034.67,544.89 1041.47,548.98 1048.28,553.18 " fill="none" id="UDS-to-archive" style="stroke:#666666;stroke-width:1.0;"/><polygon fill="#666666" points="1055.1,557.4,1049.8804,550.6357,1046.7197,555.7357,1055.1,557.4" style="stroke:#666666;stroke-width:1.0;"/><text fill="#666666" font-family="sans-serif" font-size="12" font-weight="bold" lengthAdjust="spacing" textLength="96" x="976" y="487.1387">Archives data</text><text fill="#666666" font-family="sans-serif" font-size="12" font-style="italic" lengthAdjust="spacing" textLength="37" x="1005.5" y="501.1074">[CNM]</text></g><rect height="162.6719" rx="7.5" ry="7.5" style="stroke:#00000000;stroke-width:1.0;fill:none;" width="159" x="1089" y="723"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="59" x="1095" y="743.9951">Legend</text><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="4" x="1154" y="743.9951"> </text><rect fill="#08427B" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="747.2969"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="49" x="1099" y="760.292">person</text><rect fill="#1168BD" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="763.5938"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="50" x="1099" y="776.5889">system</text><rect fill="#438DD5" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="779.8906"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="65" x="1099" y="792.8857">container</text><rect fill="#85BBF0" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="796.1875"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="80" x="1099" y="809.1826">component</text><rect fill="#686868" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="812.4844"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="108" x="1099" y="825.4795">external person</text><rect fill="#999999" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="828.7813"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="109" x="1099" y="841.7764">external system</text><rect fill="#B3B3B3" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="845.0781"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="124" x="1099" y="858.0732">external container</text><rect fill="#CCCCCC" height="16.2969" style="stroke:none;stroke-width:1.0;" width="147" x="1095" y="861.375"/><text fill="#FFFFFF" font-family="sans-serif" font-size="14" lengthAdjust="spacing" textLength="139" x="1099" y="874.3701">external component</text><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="731" y2="731"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="747.2969" y2="747.2969"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="763.5938" y2="763.5938"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="779.8906" y2="779.8906"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="796.1875" y2="796.1875"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="812.4844" y2="812.4844"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="828.7813" y2="828.7813"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="845.0781" y2="845.0781"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="861.375" y2="861.375"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1242" y1="877.6719" y2="877.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1095" x2="1095" y1="731" y2="877.6719"/><line style="stroke:#FFFFFF;stroke-width:1.0;" x1="1242" x2="1242" y1="731" y2="877.6719"/><!--MD5=[5560287dd068573d7bfa1c1f9d3154c6]
@startuml
!include https://raw.githubusercontent.com/adrianvlupu/C4-PlantUML/latest/C4_Component.puml

'Global vars repeated for referencing other common systems
!global $USC_DESC = "Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems"
!global $AS_DESC = "Higher level data functions to access and transform data."
!global $ADS_DESC = "Subsystem for developing and assembling science algorithms into an algorithm catalog"
!global $SPS_DESC = "Subsystem for the generation of science data products through the combination of Algorithms and Data"
!global $DS_DESC = "Subsystem for ingestion, storage, and access to data products for use in the Unity System."

LAYOUT_WITH_LEGEND()

'Global 'external systems' definitions
System_Ext(sps, "Science Processing", $SPS_DESC)
'System_Ext(ds, "Data Services", $DS_DESC)
System_Ext(as, "Analysis Services", $AS_DESC)
System_Ext(cs, "Common Services", $USC_DESC)
System_Ext(ads, "Algorithm Development", $ADS_DESC)

System_Ext(archive, "Archive", "Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity.")


System_Boundary(UDS, "Data Services") {

    Container(ds, "Ingest and Archive System", "Cumulus", "Ingest, basic catalog and persistent Storage of data products")
    Container(cmr, "Metadata Search", "CMR", "Provides users and services spatio/tempral searchfor Unity data products")
    Container(fb, "Fast Browse", "WMTS", "Allows the retrieval of tiled images for fast visual browse.")

    Rel(ds, cmr, "catalogs umm metadata in")
    Rel(ds, fb, "Registers tiles in")
}

Rel(ds, sps, "SPS accesses data for processing", "S3")
Rel(ds, as, "AS accesses data for transformation", "S3")

Rel(sps, ds, "Registers generated Data", "CNM")
Rel(ads, ds, "Retrieves generated data from", "HTTP/S3")
Rel(ds, cs, "Registers data provenance in", "HTTP")
Rel(UDS, archive, "Archives data", "CNM")

@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 "==Science Processing\n\n Subsystem for the generation of science data products through the combination of Algorithms and Data" <<external_system>> as sps
rectangle "==Analysis Services\n\n Higher level data functions to access and transform data." <<external_system>> as as
rectangle "==Common Services\n\n Platform wide tool and functional implementations including authentication and authorization, metrics publication, logging services, deployment and build systems" <<external_system>> as cs
rectangle "==Algorithm Development\n\n Subsystem for developing and assembling science algorithms into an algorithm catalog" <<external_system>> as ads

rectangle "==Archive\n\n Long term archive for distribution of data products to end users. Examples include PDS, DAAC, or other NASA approved entity." <<external_system>> as archive


rectangle "==Data Services\n<size:12>[System]</size>" <<boundary>> as UDS {

    rectangle "==Ingest and Archive System\n//<size:12>[Cumulus]</size>//\n\n Ingest, basic catalog and persistent Storage of data products" <<container>> as ds
    rectangle "==Metadata Search\n//<size:12>[CMR]</size>//\n\n Provides users and services spatio/tempral searchfor Unity data products" <<container>> as cmr
    rectangle "==Fast Browse\n//<size:12>[WMTS]</size>//\n\n Allows the retrieval of tiled images for fast visual browse." <<container>> as fb

ds - ->> cmr : **catalogs umm metadata in**
ds - ->> fb : **Registers tiles in**
}

ds - ->> sps : **SPS accesses data for processing**\n//<size:12>[S3]</size>//
ds - ->> as : **AS accesses data for transformation**\n//<size:12>[S3]</size>//

sps - ->> ds : **Registers generated Data**\n//<size:12>[CNM]</size>//
ads - ->> ds : **Retrieves generated data from**\n//<size:12>[HTTP/S3]</size>//
ds - ->> cs : **Registers data provenance in**\n//<size:12>[HTTP]</size>//
UDS - ->> archive : **Archives data**\n//<size:12>[CNM]</size>//

@enduml

PlantUML version 1.2022.3(Tue Mar 29 16:10:57 GMT 2022)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>) [Download system diagram](system.svg ':ignore') # Data Services diff --git a/docs/1. Unity Architecture/Data Services/system.svg b/docs/1. Unity Architecture/Data Services/system.svg index 59e4bd4..18250f1 100644 --- a/docs/1. Unity Architecture/Data Services/system.svg +++ b/docs/1. Unity Architecture/Data Services/system.svg @@ -1,21 +1,21 @@ -Data Services[System]Ingest and ArchiveSystem[Cumulus]Ingest, basic catalog andpersistent Storage of dataproductsMetadata Search[CMR]Provides users and servicesspatio/tempral searchforUnity data productsFast Browse[WMTS]Allows the retrieval of tiledimages for fast visualbrowse.Science ProcessingSubsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataAnalysis ServicesHigher level data functionsto access and transformdata.Common ServicesPlatform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystemsAlgorithmDevelopmentSubsystem for developingand assembling sciencealgorithms into an algorithmcatalogArchiveLong term archive fordistribution of data productsto end users. Examplesinclude PDS, DAAC, or otherNASA approved entity.catalogs ummmetadata inRegisters tiles inSPS accesses datafor processing[S3]Registers generatedData[CNM]AS accesses data fortransformation[S3]Retrieves generateddata from[HTTP/S3]Registers dataprovenance in[HTTP]Archives data[CNM]Legendpersonsystemcontainercomponentexternal personexternal systemexternal containerexternal componentData Services[System]Ingest and ArchiveSystem[Cumulus] Ingest, basic catalog andpersistent Storage of dataproductsMetadata Search[CMR] Provides users and servicesspatio/tempral searchforUnity data productsFast Browse[WMTS] Allows the retrieval of tiledimages for fast visualbrowse.Science Processing Subsystem for thegeneration of science dataproducts through thecombination of Algorithmsand DataAnalysis Services Higher level data functionsto access and transformdata.Common Services Platform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystemsAlgorithmDevelopment Subsystem for developingand assembling sciencealgorithms into an algorithmcatalogArchive Long term archive fordistribution of data productsto end users. Examplesinclude PDS, DAAC, or otherNASA approved entity.catalogs ummmetadata inRegisters tiles inSPS accesses datafor processing[S3]Registers generatedData[CNM]AS accesses data fortransformation[S3]Retrieves generateddata from[HTTP/S3]Registers dataprovenance in[HTTP]Archives data[CNM]Legend personsystemcontainercomponentexternal personexternal systemexternal containerexternal component«boundary»Science Processing[System]«container»Workflow Catalog[TBD]Workflow catalog for build,registering, and deployingworkflows«container»Workflow Builder[TBD]Workflow catalog for build,registering, and deployingworkflows«component»ExecutionManagement Service[WPS-T]Allows request of workflowdeployment and productprocessing«component»Algorithm Deploymentand Execution System[WPS-T: HySDS, Others]Execute the algorithms togenerate products«external_system»Data ServicesSubsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.«external_system»Analysis ServicesHigher level data functionsto access and transformdata.«external_system»Common ServicesPlatform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystems«external_system»AlgorithmDevelopmentSubsystem for developingand assembling sciencealgorithms into an algorithmcatalog«person»OperatorTeams responsible for theoperational production andmonitoring of products.«person»Algorithm IntegratorTeams responsible forchaining and optimizingworkflows for productgenerationdeploys andexecutes algorithmsonRegisters workflowsondeploys requestworkflow fromcatalogRequests andmonitors executionsBuilds and validatesworkflowsrequests execution[OGC WPS-T]requests execution[OGC WPS-T]Stages dataproducts[S3]Catalogs data[CNM]«boundary»Science Processing[System]«container»Workflow Catalog[TBD] Workflow catalog for build,registering, and deployingworkflows«container»Workflow Builder[TBD] Workflow catalog for build,registering, and deployingworkflows«component»ExecutionManagement Service[WPS-T] Allows request of workflowdeployment and productprocessing«component»Algorithm Deploymentand Execution System[WPS-T: HySDS, Others] Execute the algorithms togenerate products«external_system»Data Services Subsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.«external_system»Analysis Services Higher level data functionsto access and transformdata.«external_system»Common Services Platform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and buildsystems«external_system»AlgorithmDevelopment Subsystem for developingand assembling sciencealgorithms into an algorithmcatalog«person»Operator Teams responsible for theoperational production andmonitoring of products.«person»Algorithm Integrator Teams responsible forchaining and optimizingworkflows for productgenerationdeploys andexecutes algorithmsonRegisters workflowsondeploys requestworkflow fromcatalogRequests andmonitors executionsBuilds and validatesworkflowsrequests execution[OGC WPS-T]requests execution[OGC WPS-T]Stages dataproducts[S3]Catalogs data[CNM]Unity[System]AlgorithmDevelopment[Subsystem for developing andassembling science algorithmsinto an algorithm catalog]Science Processing[Subsystem for the generationof science data productsthrough the combination ofAlgorithms and Data]Data Services[Subsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.]Analysis Services[Higher level data functions toaccess and transform data.]Common Services[Platform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and build systems]Algorithm DeveloperTeams responsible for thedevelopment of sciencealgorithmsOperatorTeams responsible for theoperational production andmonitoring of products.Cal/ValTeams responsible for thecalibration & validation ofdata products.Other UserUsers interested inexamining data products,algorithm prototypes, or'open science' styleinvestigations of productgeneration (reproduce,re-run, examine).Data InputsOriginating point of data forthe project/science teams toprocess into higher levelproducts.ArchiveLong term archive fordistribution of data productsto end users. Examplesinclude PDS, DAAC, or otherNASA approved entity.Algorithm Catalog[API]Deliver or stage dataproducts forprocessingSends data toarchiveLogin to developalgorithms, testalgorithms,operationalizeworkflows, executeand monitoroperationalworkflows, validateproducts[UI]ensure ongoingproduct generation,monitor processing,triage issues,ensure archivedeliveryCalibrate algorithmsand validategenerated datausing existing dataproductsUsers interested inexamining dataproducts, algorithmprototypes, or 'openscience' styleinvestigations ofproduct generation(reproduce, re-run,examine)Legendpersonsystemcontainerexternal personexternal systemexternal containerUnity[System]AlgorithmDevelopment[Subsystem for developing andassembling science algorithmsinto an algorithm catalog]Science Processing[Subsystem for the generationof science data productsthrough the combination ofAlgorithms and Data]Data Services[Subsystem for ingestion,storage, and access to dataproducts for use in the UnitySystem.]Analysis Services[Higher level data functions toaccess and transform data.]Common Services[Platform wide tool andfunctional implementationsincluding authentication andauthorization, metricspublication, logging services,deployment and build systems]Algorithm Developer Teams responsible for thedevelopment of sciencealgorithmsOperator Teams responsible for theoperational production andmonitoring of products.Cal/Val Teams responsible for thecalibration & validation ofdata products.Other User Users interested inexamining data products,algorithm prototypes, or'open science' styleinvestigations of productgeneration (reproduce,re-run, examine).Data Inputs Originating point of data forthe project/science teams toprocess into higher levelproducts.Archive Long term archive fordistribution of data productsto end users. Examplesinclude PDS, DAAC, or otherNASA approved entity.Algorithm Catalog[API]Deliver or stage dataproducts forprocessingSends data toarchiveLogin to developalgorithms, testalgorithms,operationalizeworkflows, executeand monitoroperationalworkflows, validateproducts[UI]ensure ongoingproduct generation,monitor processing,triage issues,ensure archivedeliveryCalibrate algorithmsand validategenerated datausing existing dataproductsUsers interested inexamining dataproducts, algorithmprototypes, or 'openscience' styleinvestigations ofproduct generation(reproduce, re-run,examine)Legend personsystemcontainerexternal personexternal systemexternal containerAlgorithm DeveloperTeams responsible for thedevelopment of sciencealgorithmsOperatorTeams responsible for theoperational production andmonitoring of products.Cal/ValTeams responsible for thecalibration & validation ofdata products.Other UserUsers interested inexamining data products,algorithm prototypes, or'open science' styleinvestigations of productgeneration (reproduce,re-run, examine).UnityAllows users to develop,operationalize, and generatescience products, theiralgorithms, and theirworkflows through standardinterfaces. Allows analysis ofthe resulting data productsfor validation as well as datause. Includes provenanceinformation for differentcomponents of the system.Data InputsOriginating point of data forthe project/science teams toprocess into higher levelproducts.ArchiveLong term archive fordistribution of data productsto end users. Examplesinclude PDS, DAAC, or otherNASA approved entity.Deliver or stage dataproducts forprocessingSends data toarchiveLogin to developalgorithms, testalgorithms,operationalizeworkflows, executeand monitoroperationalworkflows, validateproducts[UI]ensure ongoingproduct generation,monitor processing,triage issues,ensure archivedeliveryCalibrate algorithmsand validategenerated datausing existing dataproductsUsers interested inexamining dataproducts, algorithmprototypes, or 'openscience' styleinvestigations ofproduct generation(reproduce, re-run,examine)Legendpersonsystemexternal personexternal systemAlgorithm Developer Teams responsible for thedevelopment of sciencealgorithmsOperator Teams responsible for theoperational production andmonitoring of products.Cal/Val Teams responsible for thecalibration & validation ofdata products.Other User Users interested inexamining data products,algorithm prototypes, or'open science' styleinvestigations of productgeneration (reproduce,re-run, examine).Unity Allows users to develop,operationalize, and generatescience products, theiralgorithms, and theirworkflows through standardinterfaces. Allows analysis ofthe resulting data productsfor validation as well as datause. Includes provenanceinformation for differentcomponents of the system.Data Inputs Originating point of data forthe project/science teams toprocess into higher levelproducts.Archive Long term archive fordistribution of data productsto end users. Examplesinclude PDS, DAAC, or otherNASA approved entity.Deliver or stage dataproducts forprocessingSends data toarchiveLogin to developalgorithms, testalgorithms,operationalizeworkflows, executeand monitoroperationalworkflows, validateproducts[UI]ensure ongoingproduct generation,monitor processing,triage issues,ensure archivedeliveryCalibrate algorithmsand validategenerated datausing existing dataproductsUsers interested inexamining dataproducts, algorithmprototypes, or 'openscience' styleinvestigations ofproduct generation(reproduce, re-run,examine)Legend personsystemexternal personexternal system