diff --git a/.docs/api/storage-service.md b/.docs/api/storage-service.md index e962c70966a3438d1379c5809e701510168d8785..5994929a5deb8e8f87fe33265823043a3387c72e 100644 --- a/.docs/api/storage-service.md +++ b/.docs/api/storage-service.md @@ -11,6 +11,7 @@ author: Martin Weise * Ports: 8888/tcp, 9000/tcp * Prometheus: `http://<hostname>:9091/metrics` * Filer UI: `http://<hostname>:8888` + * Cluster UI: `http://<hostname>:9333` To directly access in Kubernetes (for e.g. debugging), forward the svc port to your local machine: diff --git a/.docs/concepts/index.md b/.docs/concepts/index.md index c43e820a4a021725e313e6ee3c1a249b7da391fc..168758f9958f2e0c98ea8fb7ea34e63963e2e0f3 100644 --- a/.docs/concepts/index.md +++ b/.docs/concepts/index.md @@ -22,6 +22,6 @@ technologies. The conceptualized microservices (c.f. [Fig. 1](#fig1)) operate th *findability*, *accessability*, *interoperability* and *reuseability* (FAIR). <figure id="fig1" markdown> - -<figcaption>Fig. 1: Architecture of the services deployed via Docker Compose</figcaption> + +<figcaption>Fig. 1: Architecture of the services</figcaption> </figure> \ No newline at end of file diff --git a/.docs/images/architecture-docker-compose.svg b/.docs/images/architecture-docker-compose.svg deleted file mode 100644 index 96d6fc1256d69597f18ecb86bce81ea26b88fbc7..0000000000000000000000000000000000000000 --- a/.docs/images/architecture-docker-compose.svg +++ /dev/null @@ -1,3 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg xmlns="http://www.w3.org/2000/svg" style="background: transparent; background-color: transparent; color-scheme: light;" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="611px" height="614px" viewBox="-0.5 -0.5 611 614"><defs/><g><g data-cell-id="0"><g data-cell-id="1"><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-26"><g><rect x="420" y="505.61" width="150" height="105" rx="6.3" ry="6.3" fill="none" stroke="#000000" stroke-dasharray="3 3" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-97"><g><path d="M 495 428.63 L 495 411 L 380 411 L 380 171 L 337.5 171 L 337.5 153.37" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 495 433.88 L 491.5 426.88 L 495 428.63 L 498.5 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 337.5 148.12 L 341 155.12 L 337.5 153.37 L 334 155.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-98"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 173px; margin-left: 362px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="347.5" y="167" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-143"><g><path d="M 115 428.63 L 115 411 L 220 411 L 220 171 L 272.5 171 L 272.5 153.37" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 433.88 L 111.5 426.88 L 115 428.63 L 118.5 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 272.5 148.12 L 276 155.12 L 272.5 153.37 L 269 155.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-144"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 172px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="226.5" y="166" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-77"><g><path d="M 376.37 137 L 388 137 L 388 331 L 495 331 L 495 346.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 137 L 378.12 133.5 L 376.37 137 L 378.12 140.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 495 351.88 L 491.5 344.88 L 495 346.63 L 498.5 344.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-78"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 296px; margin-left: 451px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="436.5" y="290" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-79"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 332px; margin-left: 451px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="436.5" y="326" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-81"><g><path d="M 305 399.37 L 305 428.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 305 394.12 L 308.5 401.12 L 305 399.37 L 301.5 401.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 433.88 L 301.5 426.88 L 305 428.63 L 308.5 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 409px; margin-left: 305px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">LDAP</div></div></div></foreignObject><image x="290.5" y="403" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-82"><g><rect x="72.5" y="589" width="85" height="20" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 599px; margin-left: 71px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">data-db</div></div></div></foreignObject><image x="71" y="592.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-83"><g><path d="M 82.5 428.63 L 82.5 393" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 82.5 433.88 L 79 426.88 L 82.5 428.63 L 86 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-84"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 412px; margin-left: 83px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">AMQP</div></div></div></foreignObject><image x="67" y="406" width="32" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-85"><g><rect x="50" y="435" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 455px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Data Service</div></div></div></foreignObject><image x="51" y="448.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-86"><g><path d="M 115 481.37 L 115 500 L 114.63 518.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 476.12 L 118.5 483.12 L 115 481.37 L 111.5 483.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 114.52 523.88 L 111.16 516.81 L 114.63 518.63 L 118.16 516.95 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-87"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 498px; margin-left: 115px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">JDBC</div></div></div></foreignObject><image x="100.5" y="492" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-88"><g><path d="M 186.37 373 L 233.63 373" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 181.12 373 L 188.12 369.5 L 186.37 373 L 188.12 376.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 238.88 373 L 231.88 376.5 L 233.63 373 L 231.88 369.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-89"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 374px; margin-left: 211px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">LDAP</div></div></div></foreignObject><image x="196.5" y="368" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-90"><g><path d="M 115 346.63 L 115 331 L 210 331 L 210 137 L 233.63 137" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 351.88 L 111.5 344.88 L 115 346.63 L 118.5 344.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 238.88 137 L 231.88 140.5 L 233.63 137 L 231.88 133.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-91"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 332px; margin-left: 191px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; "><div>AMQP,<br />MQTT</div></div></div></div></foreignObject><image x="174" y="319.5" width="34" height="28.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-92"><g><rect x="50" y="353" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 373px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Broker Service</b><div><i>rabbitmq</i></div></div></div></div></foreignObject><image x="51" y="359" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-96"><g><rect x="240" y="353" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 373px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Identity Service</b><div><i>openldap</i></div></div></div></div></foreignObject><image x="241" y="359" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-99"><g><path d="M 462.5 435 L 462.5 421 L 308 421 C 308 417.1 302 417.1 302 421 L 302 421 L 147.5 421 L 147.5 428.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 147.5 433.88 L 144 426.88 L 147.5 428.63 L 151 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-100"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 422px; margin-left: 246px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="231.5" y="416" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-101"><g><rect x="430" y="435" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 455px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Metadata Service</div></div></div></foreignObject><image x="431" y="448.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-102"><g><path d="M 376.37 465 L 423.63 465" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 465 L 378.12 461.5 L 376.37 465 L 378.12 468.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 428.88 465 L 421.88 468.5 L 423.63 465 L 421.88 461.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-103"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 466px; margin-left: 401px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="386.5" y="460" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-106"><g><path d="M 470 195.6 C 470 190.85 481.19 187 495 187 C 501.63 187 507.99 187.91 512.68 189.52 C 517.37 191.13 520 193.32 520 195.6 L 520 242.4 C 520 247.15 508.81 251 495 251 C 481.19 251 470 247.15 470 242.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 520 195.6 C 520 200.35 508.81 204.2 495 204.2 C 481.19 204.2 470 200.35 470 195.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-107"><g><rect x="452.5" y="251.5" width="85" height="17" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 260px; margin-left: 451px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">search-db</div></div></div></foreignObject><image x="451" y="253.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-111"><g><path d="M 280 523.6 C 280 518.85 291.19 515 305 515 C 311.63 515 317.99 515.91 322.68 517.52 C 327.37 519.13 330 521.32 330 523.6 L 330 570.4 C 330 575.15 318.81 579 305 579 C 291.19 579 280 575.15 280 570.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 330 523.6 C 330 528.35 318.81 532.2 305 532.2 C 291.19 532.2 280 528.35 280 523.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-112"><g><rect x="262.5" y="579" width="85" height="20" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 589px; margin-left: 261px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">auth-db</div></div></div></foreignObject><image x="261" y="582.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-115"><g><path d="M 376.37 117 L 423.63 117" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 117 L 378.12 113.5 L 376.37 117 L 378.12 120.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 428.88 117 L 421.88 120.5 L 423.63 117 L 421.88 113.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 117px; margin-left: 400px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="385.5" y="111" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-117"><g><path d="M 233.63 127 L 200 127 L 200 291 L 186.37 291" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 238.88 127 L 231.88 130.5 L 233.63 127 L 231.88 123.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 181.12 291 L 188.12 287.5 L 186.37 291 L 188.12 294.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-118"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 242px; margin-left: 191px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="176.5" y="236" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-13"><g><path d="M 305 147 L 305 182.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 305 187.88 L 301.5 180.88 L 305 182.63 L 308.5 180.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-119"><g><rect x="240" y="107" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 127px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Gateway Service</b><div><i>nginx</i></div></div></div></div></foreignObject><image x="241" y="113" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-121"><g><path d="M 115 264.63 L 115 250 L 114.65 235.37" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 269.88 L 111.5 262.88 L 115 264.63 L 118.5 262.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 114.53 230.12 L 118.19 237.03 L 114.65 235.37 L 111.19 237.2 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-122"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 251px; margin-left: 115px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">S3</div></div></div></foreignObject><image x="108.5" y="245" width="13" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-123"><g><rect x="50" y="271" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 291px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Analyse Service</div></div></div></foreignObject><image x="51" y="284.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-125"><g><path d="M 495 153.37 L 495 180.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 495 148.12 L 498.5 155.12 L 495 153.37 L 491.5 155.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 495 185.88 L 491.5 178.88 L 495 180.63 L 498.5 178.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-126"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 167px; margin-left: 497px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="482.5" y="161" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-127"><g><path d="M 276.37 41 L 305 41 L 305 100.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 271.12 41 L 278.12 37.5 L 276.37 41 L 278.12 44.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 105.88 L 301.5 98.88 L 305 100.63 L 308.5 98.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-128"><g><ellipse cx="255" cy="7.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 255 15 L 255 40 M 255 20 L 240 20 M 255 20 L 270 20 M 255 40 L 240 60 M 255 40 L 270 60" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 67px; margin-left: 255px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">Researcher</div></div></div></foreignObject><image x="224" y="67.5" width="62" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-129"><g><ellipse cx="225" cy="524.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 225 532 L 225 557 M 225 537 L 210 537 M 225 537 L 240 537 M 225 557 L 210 577 M 225 557 L 240 577" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 584px; margin-left: 225px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">Database<div>Engineer</div></div></div></div></foreignObject><image x="199.5" y="584.5" width="51" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-133"><g><path d="M 305 481.37 L 305 508.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 305 476.12 L 308.5 483.12 L 305 481.37 L 301.5 483.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 513.88 L 301.5 506.88 L 305 508.63 L 308.5 506.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 495px; margin-left: 305px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">JDBC</div></div></div></foreignObject><image x="290.5" y="489" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-134"><g><ellipse cx="385" cy="524.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 385 532 L 385 557 M 385 537 L 370 537 M 385 537 L 400 537 M 385 557 L 370 577 M 385 557 L 400 577" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 584px; margin-left: 385px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">System<div>Engineer</div></div></div></div></foreignObject><image x="361" y="584.5" width="48" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-135"><g><path d="M 59.5 523.6 C 59.5 518.85 70.69 515 84.5 515 C 91.13 515 97.49 515.91 102.18 517.52 C 106.87 519.13 109.5 521.32 109.5 523.6 L 109.5 570.4 C 109.5 575.15 98.31 579 84.5 579 C 70.69 579 59.5 575.15 59.5 570.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 109.5 523.6 C 109.5 528.35 98.31 532.2 84.5 532.2 C 70.69 532.2 59.5 528.35 59.5 523.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-136"><g><path d="M 119.5 523.6 C 119.5 518.85 130.69 515 144.5 515 C 151.13 515 157.49 515.91 162.18 517.52 C 166.87 519.13 169.5 521.32 169.5 523.6 L 169.5 570.4 C 169.5 575.15 158.31 579 144.5 579 C 130.69 579 119.5 575.15 119.5 570.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 169.5 523.6 C 169.5 528.35 158.31 532.2 144.5 532.2 C 130.69 532.2 119.5 528.35 119.5 523.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-137"><g><path d="M 89.5 533.6 C 89.5 528.85 100.69 525 114.5 525 C 121.13 525 127.49 525.91 132.18 527.52 C 136.87 529.13 139.5 531.32 139.5 533.6 L 139.5 580.4 C 139.5 585.15 128.31 589 114.5 589 C 100.69 589 89.5 585.15 89.5 580.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 139.5 533.6 C 139.5 538.35 128.31 542.2 114.5 542.2 C 100.69 542.2 89.5 538.35 89.5 533.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-138"><g><rect x="40" y="506" width="150" height="105" rx="6.3" ry="6.3" fill="none" stroke="#000000" stroke-dasharray="3 3" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-139"><g><path d="M 210 547 L 196.37 547" fill="none" stroke="#000000" stroke-miterlimit="10" stroke-dasharray="3 3" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 191.12 547 L 198.12 543.5 L 196.37 547 L 198.12 550.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-140"><g><rect x="430" y="271" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 291px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">User Interface</div></div></div></foreignObject><image x="431" y="284.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-141"><g><path d="M 333.63 41 L 305 41 L 305 100.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 338.88 41 L 331.88 44.5 L 333.63 41 L 331.88 37.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 105.88 L 301.5 98.88 L 305 100.63 L 308.5 98.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-142"><g><ellipse cx="355" cy="7.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 355 15 L 355 40 M 355 20 L 340 20 M 355 20 L 370 20 M 355 40 L 340 60 M 355 40 L 370 60" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 67px; margin-left: 355px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">Machine</div></div></div></foreignObject><image x="332.5" y="67.5" width="45" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-147"><g><path d="M 376.37 127 L 403 127 L 403 291 L 423.63 291" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 127 L 378.12 123.5 L 376.37 127 L 378.12 130.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 428.88 291 L 421.88 294.5 L 423.63 291 L 421.88 287.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-148"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 217px; margin-left: 404px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="389.5" y="211" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-149"><g><path d="M 423.63 137 L 417 137 L 417 288 C 420.9 288 420.9 294 417 294 L 417 294 L 417 328 C 420.9 328 420.9 334 417 334 L 417 334 L 417 408 C 420.9 408 420.9 414 417 414 L 417 414 L 417 418 C 420.9 418 420.9 424 417 424 L 417 424 L 417 445 L 430 445" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 428.88 137 L 421.88 140.5 L 423.63 137 L 421.88 133.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-150"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 238px; margin-left: 421px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="406.5" y="232" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="a_cl7nsyDpLQFaXOHeFD-3"><g><path d="M 279.5 257.6 C 279.5 252.85 290.69 249 304.5 249 C 311.13 249 317.49 249.91 322.18 251.52 C 326.87 253.13 329.5 255.32 329.5 257.6 L 329.5 304.4 C 329.5 309.15 318.31 313 304.5 313 C 290.69 313 279.5 309.15 279.5 304.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 329.5 257.6 C 329.5 262.35 318.31 266.2 304.5 266.2 C 290.69 266.2 279.5 262.35 279.5 257.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="a_cl7nsyDpLQFaXOHeFD-4"><g><rect x="262" y="313" width="85" height="17" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 322px; margin-left: 260px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">metric-db</div></div></div></foreignObject><image x="260" y="315.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-6"><g><path d="M 570 127 L 550 127 L 580 127 L 564.87 127" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 561.12 127 L 566.12 124.5 L 564.87 127 L 566.12 129.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-5"><g><rect x="570" y="120" width="40" height="14" rx="2.1" ry="2.1" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 127px; margin-left: 571px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="571" y="120.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-9"><g><path d="M 570 373 L 550 373 L 580 373 L 564.87 373" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 561.12 373 L 566.12 370.5 L 564.87 373 L 566.12 375.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-8"><g><rect x="570" y="366.5" width="40" height="13" rx="1.95" ry="1.95" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 373px; margin-left: 571px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="571" y="366.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-11"><g><path d="M 40 209 L 60 209 L 29.5 209 L 44.63 209" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 48.38 209 L 43.38 211.5 L 44.63 209 L 43.38 206.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-10"><g><rect x="0" y="203" width="40" height="12" rx="1.8" ry="1.8" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 209px; margin-left: 1px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="1" y="202.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-12"><g><rect x="240" y="189" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 209px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Dashboard UI</b><div><i>grafana</i></div></div></div></div></foreignObject><image x="241" y="195" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-17"><g><path d="M 230 455 L 250 455 L 220 455 L 235.13 455" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 238.88 455 L 233.88 457.5 L 235.13 455 L 233.88 452.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-18"><g><path d="M 230 455 L 250 455 L 220 455 L 238.13 455" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 238.88 455 L 237.88 455.5 L 238.13 455 L 237.88 454.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-14"><g><rect x="190" y="448.5" width="40" height="13" rx="1.95" ry="1.95" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 455px; margin-left: 191px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="191" y="448.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-104"><g><rect x="240" y="435" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 455px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Auth Service</b><br /><i>keycloak</i></div></div></div></foreignObject><image x="241" y="441" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-120"><g><rect x="49.5" y="189" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 209px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Storage Service</b><div><i>seaweedfs</i></div></div></div></div></foreignObject><image x="51" y="195" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-105"><g><rect x="430" y="107" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 127px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Search Service</div></div></div></foreignObject><image x="431" y="120.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-108"><g><rect x="430" y="353" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 373px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Dashboard Service</b></div></div></div></foreignObject><image x="431" y="366.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-21"><g><rect x="452.5" y="588.61" width="85" height="20" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 599px; margin-left: 451px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">data-db</div></div></div></foreignObject><image x="451" y="592.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-23"><g><path d="M 439.5 523.21 C 439.5 518.46 450.69 514.61 464.5 514.61 C 471.13 514.61 477.49 515.52 482.18 517.13 C 486.87 518.74 489.5 520.93 489.5 523.21 L 489.5 570.01 C 489.5 574.76 478.31 578.61 464.5 578.61 C 450.69 578.61 439.5 574.76 439.5 570.01 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 489.5 523.21 C 489.5 527.96 478.31 531.81 464.5 531.81 C 450.69 531.81 439.5 527.96 439.5 523.21" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-24"><g><path d="M 499.5 523.21 C 499.5 518.46 510.69 514.61 524.5 514.61 C 531.13 514.61 537.49 515.52 542.18 517.13 C 546.87 518.74 549.5 520.93 549.5 523.21 L 549.5 570.01 C 549.5 574.76 538.31 578.61 524.5 578.61 C 510.69 578.61 499.5 574.76 499.5 570.01 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 549.5 523.21 C 549.5 527.96 538.31 531.81 524.5 531.81 C 510.69 531.81 499.5 527.96 499.5 523.21" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-25"><g><path d="M 470.5 533.21 C 470.5 528.46 481.69 524.61 495.5 524.61 C 502.13 524.61 508.49 525.52 513.18 527.13 C 517.87 528.74 520.5 530.93 520.5 533.21 L 520.5 580.01 C 520.5 584.76 509.31 588.61 495.5 588.61 C 481.69 588.61 470.5 584.76 470.5 580.01 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 520.5 533.21 C 520.5 537.96 509.31 541.81 495.5 541.81 C 481.69 541.81 470.5 537.96 470.5 533.21" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-29"><g><path d="M 494.86 481.37 L 494.86 518.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 494.86 476.12 L 498.36 483.12 L 494.86 481.37 L 491.36 483.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 494.86 523.88 L 491.36 516.88 L 494.86 518.63 L 498.36 516.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-30"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 498px; margin-left: 496px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">JDBC</div></div></div></foreignObject><image x="481.5" y="492" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g></g></g></g></svg> \ No newline at end of file diff --git a/.docs/images/architecture.drawio b/.docs/images/architecture.drawio index 4343db2e4a0483a162a38cd87ac13b3674f79761..2559a653790f7a5de96948d00394017982d8073a 100644 --- a/.docs/images/architecture.drawio +++ b/.docs/images/architecture.drawio @@ -1,10 +1,10 @@ <mxfile host="Electron" agent="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/26.2.2 Chrome/134.0.6998.178 Electron/35.1.2 Safari/537.36" version="26.2.2" pages="9"> <diagram id="mvBsv1rP8O80Qe3yGnn_" name="docker-compose"> - <mxGraphModel dx="819" dy="330" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="1169" pageHeight="827" math="0" shadow="0"> + <mxGraphModel dx="985" dy="565" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="1169" pageHeight="827" math="0" shadow="0"> <root> <mxCell id="0" /> <mxCell id="1" parent="0" /> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-26" value="" style="rounded=1;whiteSpace=wrap;html=1;fillColor=none;dashed=1;arcSize=6;" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-26" value="" style="rounded=1;whiteSpace=wrap;html=1;fillColor=none;dashed=1;arcSize=6;" parent="1" vertex="1"> <mxGeometry x="700" y="574.61" width="150" height="105" as="geometry" /> </mxCell> <mxCell id="FWEJ_FGA9GBXbfwohBE8-97" value="" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;exitX=0.5;exitY=0;exitDx=0;exitDy=0;entryX=0.75;entryY=1;entryDx=0;entryDy=0;jumpStyle=arc;startArrow=classic;startFill=1;" parent="1" source="FWEJ_FGA9GBXbfwohBE8-101" target="FWEJ_FGA9GBXbfwohBE8-119" edge="1"> @@ -165,7 +165,7 @@ <mxPoint x="-9" y="-20" as="offset" /> </mxGeometry> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-13" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;exitX=0.5;exitY=1;exitDx=0;exitDy=0;entryX=0.5;entryY=0;entryDx=0;entryDy=0;" edge="1" parent="1" source="FWEJ_FGA9GBXbfwohBE8-119" target="uDJ2bVtIrgoZBCZFZmDG-12"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-13" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;exitX=0.5;exitY=1;exitDx=0;exitDy=0;entryX=0.5;entryY=0;entryDx=0;entryDy=0;" parent="1" source="FWEJ_FGA9GBXbfwohBE8-119" target="uDJ2bVtIrgoZBCZFZmDG-12" edge="1"> <mxGeometry relative="1" as="geometry" /> </mxCell> <mxCell id="FWEJ_FGA9GBXbfwohBE8-119" value="<b>Gateway Service</b><div><i>nginx</i></div>" style="rounded=1;whiteSpace=wrap;html=1;fillColor=#E6E6E6;fontColor=#000000;strokeColor=#000000;" parent="1" vertex="1"> @@ -271,34 +271,34 @@ <mxCell id="a_cl7nsyDpLQFaXOHeFD-4" value="metric-db" style="text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;spacing=-1;" parent="1" vertex="1"> <mxGeometry x="542" y="382" width="85" height="17" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-6" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=1;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" edge="1" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-5" target="FWEJ_FGA9GBXbfwohBE8-105"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-6" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=1;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-5" target="FWEJ_FGA9GBXbfwohBE8-105" edge="1"> <mxGeometry relative="1" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-5" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-5" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" parent="1" vertex="1"> <mxGeometry x="850" y="189" width="40" height="14" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-9" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=1;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" edge="1" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-8" target="FWEJ_FGA9GBXbfwohBE8-108"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-9" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=1;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-8" target="FWEJ_FGA9GBXbfwohBE8-108" edge="1"> <mxGeometry relative="1" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-8" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-8" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" parent="1" vertex="1"> <mxGeometry x="850" y="435.5" width="40" height="13" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-11" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" edge="1" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-10" target="FWEJ_FGA9GBXbfwohBE8-120"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-11" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-10" target="FWEJ_FGA9GBXbfwohBE8-120" edge="1"> <mxGeometry relative="1" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-10" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-10" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" parent="1" vertex="1"> <mxGeometry x="280" y="272" width="40" height="12" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-12" value="<b>Dashboard UI</b><div><i>grafana</i></div>" style="rounded=1;whiteSpace=wrap;html=1;fillColor=#E6E6E6;fontColor=#000000;strokeColor=#000000;" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-12" value="<b>Dashboard UI</b><div><i>grafana</i></div>" style="rounded=1;whiteSpace=wrap;html=1;" parent="1" vertex="1"> <mxGeometry x="520" y="258" width="130" height="40" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-17" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" edge="1" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-14" target="FWEJ_FGA9GBXbfwohBE8-104"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-17" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0;entryY=0.5;entryDx=0;entryDy=0;endSize=4;" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-14" target="FWEJ_FGA9GBXbfwohBE8-104" edge="1"> <mxGeometry relative="1" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-18" value="" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;endSize=0;startSize=0;jumpSize=3;" edge="1" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-14" target="FWEJ_FGA9GBXbfwohBE8-104"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-18" value="" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;endSize=0;startSize=0;jumpSize=3;" parent="1" source="uDJ2bVtIrgoZBCZFZmDG-14" target="FWEJ_FGA9GBXbfwohBE8-104" edge="1"> <mxGeometry relative="1" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-14" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-14" value="init" style="rounded=1;whiteSpace=wrap;html=1;fontStyle=1" parent="1" vertex="1"> <mxGeometry x="470" y="517.5" width="40" height="13" as="geometry" /> </mxCell> <mxCell id="FWEJ_FGA9GBXbfwohBE8-104" value="<b>Auth Service</b><br><i>keycloak</i>" style="rounded=1;whiteSpace=wrap;html=1;fillColor=#E6E6E6;fontColor=#000000;strokeColor=#000000;" parent="1" vertex="1"> @@ -313,25 +313,25 @@ <mxCell id="FWEJ_FGA9GBXbfwohBE8-108" value="<b>Dashboard Service</b>" style="rounded=1;whiteSpace=wrap;html=1;" parent="1" vertex="1"> <mxGeometry x="710" y="422" width="130" height="40" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-21" value="data-db" style="text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;spacing=-1;" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-21" value="data-db" style="text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;rounded=0;spacing=-1;" parent="1" vertex="1"> <mxGeometry x="732.5" y="657.61" width="85" height="20" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-23" value="" style="shape=cylinder3;whiteSpace=wrap;html=1;boundedLbl=1;backgroundOutline=1;size=8.600000000000023;fillColor=#E6E6E6;strokeColor=#000000;" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-23" value="" style="shape=cylinder3;whiteSpace=wrap;html=1;boundedLbl=1;backgroundOutline=1;size=8.600000000000023;fillColor=#E6E6E6;strokeColor=#000000;" parent="1" vertex="1"> <mxGeometry x="719.5" y="583.61" width="50" height="64" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-24" value="" style="shape=cylinder3;whiteSpace=wrap;html=1;boundedLbl=1;backgroundOutline=1;size=8.600000000000023;fillColor=#E6E6E6;strokeColor=#000000;" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-24" value="" style="shape=cylinder3;whiteSpace=wrap;html=1;boundedLbl=1;backgroundOutline=1;size=8.600000000000023;fillColor=#E6E6E6;strokeColor=#000000;" parent="1" vertex="1"> <mxGeometry x="779.5" y="583.61" width="50" height="64" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-25" value="" style="shape=cylinder3;whiteSpace=wrap;html=1;boundedLbl=1;backgroundOutline=1;size=8.600000000000023;fillColor=#E6E6E6;strokeColor=#000000;" vertex="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-25" value="" style="shape=cylinder3;whiteSpace=wrap;html=1;boundedLbl=1;backgroundOutline=1;size=8.600000000000023;fillColor=#E6E6E6;strokeColor=#000000;" parent="1" vertex="1"> <mxGeometry x="750.5" y="593.61" width="50" height="64" as="geometry" /> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-29" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0.5;entryY=0;entryDx=0;entryDy=0;entryPerimeter=0;startArrow=classic;startFill=1;" edge="1" parent="1"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-29" style="edgeStyle=orthogonalEdgeStyle;rounded=0;orthogonalLoop=1;jettySize=auto;html=1;entryX=0.5;entryY=0;entryDx=0;entryDy=0;entryPerimeter=0;startArrow=classic;startFill=1;" parent="1" edge="1"> <mxGeometry relative="1" as="geometry"> <mxPoint x="774.86" y="544" as="sourcePoint" /> <mxPoint x="774.86" y="594" as="targetPoint" /> </mxGeometry> </mxCell> - <mxCell id="uDJ2bVtIrgoZBCZFZmDG-30" value="JDBC" style="edgeLabel;html=1;align=center;verticalAlign=middle;resizable=0;points=[];" vertex="1" connectable="0" parent="uDJ2bVtIrgoZBCZFZmDG-29"> + <mxCell id="uDJ2bVtIrgoZBCZFZmDG-30" value="JDBC" style="edgeLabel;html=1;align=center;verticalAlign=middle;resizable=0;points=[];" parent="uDJ2bVtIrgoZBCZFZmDG-29" vertex="1" connectable="0"> <mxGeometry x="0.3566" relative="1" as="geometry"> <mxPoint x="1" y="-12" as="offset" /> </mxGeometry> diff --git a/.docs/images/architecture.svg b/.docs/images/architecture.svg new file mode 100644 index 0000000000000000000000000000000000000000..369974785eeda30172c581771c30a8b0ec270a69 --- /dev/null +++ b/.docs/images/architecture.svg @@ -0,0 +1,3 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg xmlns="http://www.w3.org/2000/svg" style="background: #ffffff; background-color: #ffffff; color-scheme: light;" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="611px" height="614px" viewBox="-0.5 -0.5 611 614"><defs/><rect fill="#ffffff" width="100%" height="100%" x="0" y="0" style="fill: rgb(255, 255, 255);"/><g><g data-cell-id="0"><g data-cell-id="1"><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-26"><g><rect x="420" y="505.61" width="150" height="105" rx="6.3" ry="6.3" fill="none" stroke="#000000" stroke-dasharray="3 3" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-97"><g><path d="M 495.01 428.63 L 495.03 411 L 380 411 L 380 171 L 337.49 171 L 337.5 153.37" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 495 433.88 L 491.51 426.88 L 495.01 428.63 L 498.51 426.89 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 337.5 148.12 L 341 155.12 L 337.5 153.37 L 334 155.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-98"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 172px; margin-left: 361px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="346.5" y="166" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-143"><g><path d="M 115.01 428.63 L 115.03 411 L 220 411 L 220 171 L 272.51 171 L 272.5 153.37" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 433.88 L 111.51 426.88 L 115.01 428.63 L 118.51 426.89 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 272.5 148.12 L 276 155.12 L 272.5 153.37 L 269 155.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-144"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 171px; margin-left: 240px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="225.5" y="165" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-77"><g><path d="M 376.37 137 L 388 137 L 388 331 L 495.03 331 L 495.01 346.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 137 L 378.12 133.5 L 376.37 137 L 378.12 140.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 495 351.88 L 491.51 344.88 L 495.01 346.63 L 498.51 344.89 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-78"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 295px; margin-left: 450px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="435.5" y="289" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-79"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 331px; margin-left: 450px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="435.5" y="325" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-81"><g><path d="M 305 399.37 L 305 428.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 305 394.12 L 308.5 401.12 L 305 399.37 L 301.5 401.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 433.88 L 301.5 426.88 L 305 428.63 L 308.5 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 409px; margin-left: 305px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">LDAP</div></div></div></foreignObject><image x="290.5" y="403" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-82"><g><rect x="72.5" y="589" width="85" height="20" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 599px; margin-left: 71px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">data-db</div></div></div></foreignObject><image x="71" y="592.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-83"><g><path d="M 82.5 428.63 L 82.5 393" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 82.5 433.88 L 79 426.88 L 82.5 428.63 L 86 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-84"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 411px; margin-left: 83px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">AMQP</div></div></div></foreignObject><image x="67" y="405" width="32" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-85"><g><rect x="50" y="435" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 455px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Data Service</div></div></div></foreignObject><image x="51" y="448.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-86"><g><path d="M 115.03 481.37 L 115.03 500.03 L 114.63 518.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115.03 476.12 L 118.53 483.12 L 115.03 481.37 L 111.53 483.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 114.52 523.88 L 111.17 516.81 L 114.63 518.63 L 118.17 516.96 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-87"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 498px; margin-left: 115px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">JDBC</div></div></div></foreignObject><image x="100.5" y="492" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-88"><g><path d="M 186.37 373 L 233.63 373" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 181.12 373 L 188.12 369.5 L 186.37 373 L 188.12 376.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 238.88 373 L 231.88 376.5 L 233.63 373 L 231.88 369.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-89"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 373px; margin-left: 210px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">LDAP</div></div></div></foreignObject><image x="195.5" y="367" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-90"><g><path d="M 115.01 346.63 L 115.03 331 L 210 331 L 210 137 L 233.63 137" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 351.88 L 111.51 344.88 L 115.01 346.63 L 118.51 344.89 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 238.88 137 L 231.88 140.5 L 233.63 137 L 231.88 133.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-91"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 331px; margin-left: 190px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; "><div>AMQP,<br />MQTT</div></div></div></div></foreignObject><image x="173" y="318.5" width="34" height="28.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-92"><g><rect x="50" y="353" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 373px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Broker Service</b><div><i>rabbitmq</i></div></div></div></div></foreignObject><image x="51" y="359" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-96"><g><rect x="240" y="353" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 373px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Identity Service</b><div><i>openldap</i></div></div></div></div></foreignObject><image x="241" y="359" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-99"><g><path d="M 462.5 435 L 462.51 421 L 308 421 C 308 417.1 302 417.1 302 421 L 302 421 L 147.49 421 L 147.49 428.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 147.5 433.88 L 143.99 426.89 L 147.49 428.63 L 150.99 426.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-100"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 421px; margin-left: 245px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="230.5" y="415" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-101"><g><rect x="430" y="435" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 455px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Metadata Service</div></div></div></foreignObject><image x="431" y="448.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-102"><g><path d="M 376.37 465 L 423.63 465" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 465 L 378.12 461.5 L 376.37 465 L 378.12 468.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 428.88 465 L 421.88 468.5 L 423.63 465 L 421.88 461.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-103"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 465px; margin-left: 400px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="385.5" y="459" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-106"><g><path d="M 470 195.6 C 470 190.85 481.19 187 495 187 C 501.63 187 507.99 187.91 512.68 189.52 C 517.37 191.13 520 193.32 520 195.6 L 520 242.4 C 520 247.15 508.81 251 495 251 C 481.19 251 470 247.15 470 242.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 520 195.6 C 520 200.35 508.81 204.2 495 204.2 C 481.19 204.2 470 200.35 470 195.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-107"><g><rect x="452.5" y="251.5" width="85" height="17" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 260px; margin-left: 451px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">search-db</div></div></div></foreignObject><image x="451" y="253.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-111"><g><path d="M 280 523.6 C 280 518.85 291.19 515 305 515 C 311.63 515 317.99 515.91 322.68 517.52 C 327.37 519.13 330 521.32 330 523.6 L 330 570.4 C 330 575.15 318.81 579 305 579 C 291.19 579 280 575.15 280 570.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 330 523.6 C 330 528.35 318.81 532.2 305 532.2 C 291.19 532.2 280 528.35 280 523.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-112"><g><rect x="262.5" y="579" width="85" height="20" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 589px; margin-left: 261px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">auth-db</div></div></div></foreignObject><image x="261" y="582.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-115"><g><path d="M 376.37 117 L 423.63 117" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 117 L 378.12 113.5 L 376.37 117 L 378.12 120.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 428.88 117 L 421.88 120.5 L 423.63 117 L 421.88 113.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 117px; margin-left: 400px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="385.5" y="111" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-117"><g><path d="M 233.63 127 L 200 127 L 200 291 L 186.37 291" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 238.88 127 L 231.88 130.5 L 233.63 127 L 231.88 123.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 181.12 291 L 188.12 287.5 L 186.37 291 L 188.12 294.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-118"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 242px; margin-left: 190px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="175.5" y="236" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-13"><g><path d="M 305 147 L 305 182.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 305 187.88 L 301.5 180.88 L 305 182.63 L 308.5 180.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-119"><g><rect x="240" y="107" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 127px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Gateway Service</b><div><i>nginx</i></div></div></div></div></foreignObject><image x="241" y="113" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-121"><g><path d="M 115.01 264.63 L 115.03 250.03 L 114.66 235.37" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 115 269.88 L 111.51 262.88 L 115.01 264.63 L 118.51 262.89 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 114.53 230.12 L 118.2 237.03 L 114.66 235.37 L 111.21 237.2 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-122"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 251px; margin-left: 115px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">S3</div></div></div></foreignObject><image x="108.5" y="245" width="13" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-123"><g><rect x="50" y="271" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 291px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Analyse Service</div></div></div></foreignObject><image x="51" y="284.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-125"><g><path d="M 495 153.37 L 495 180.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 495 148.12 L 498.5 155.12 L 495 153.37 L 491.5 155.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 495 185.88 L 491.5 178.88 L 495 180.63 L 498.5 178.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-126"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 167px; margin-left: 496px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="481.5" y="161" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-127"><g><path d="M 276.37 41 L 305.03 41 L 305.03 100.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 271.12 41 L 278.12 37.5 L 276.37 41 L 278.12 44.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305.03 105.88 L 301.53 98.88 L 305.03 100.63 L 308.53 98.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-128"><g><ellipse cx="255" cy="7.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 255 15 L 255 40 M 255 20 L 240 20 M 255 20 L 270 20 M 255 40 L 240 60 M 255 40 L 270 60" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 67px; margin-left: 255px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">Researcher</div></div></div></foreignObject><image x="224" y="67.5" width="62" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-129"><g><ellipse cx="225" cy="524.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 225 532 L 225 557 M 225 537 L 210 537 M 225 537 L 240 537 M 225 557 L 210 577 M 225 557 L 240 577" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 584px; margin-left: 225px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">Database<div>Engineer</div></div></div></div></foreignObject><image x="199.5" y="584.5" width="51" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-133"><g><path d="M 305 481.37 L 305 508.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 305 476.12 L 308.5 483.12 L 305 481.37 L 301.5 483.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 513.88 L 301.5 506.88 L 305 508.63 L 308.5 506.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 495px; margin-left: 305px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">JDBC</div></div></div></foreignObject><image x="290.5" y="489" width="29" height="15.75" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-134"><g><ellipse cx="385" cy="524.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 385 532 L 385 557 M 385 537 L 370 537 M 385 537 L 400 537 M 385 557 L 370 577 M 385 557 L 400 577" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 584px; margin-left: 385px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">System<div>Engineer</div></div></div></div></foreignObject><image x="361" y="584.5" width="48" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-135"><g><path d="M 59.5 523.6 C 59.5 518.85 70.69 515 84.5 515 C 91.13 515 97.49 515.91 102.18 517.52 C 106.87 519.13 109.5 521.32 109.5 523.6 L 109.5 570.4 C 109.5 575.15 98.31 579 84.5 579 C 70.69 579 59.5 575.15 59.5 570.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 109.5 523.6 C 109.5 528.35 98.31 532.2 84.5 532.2 C 70.69 532.2 59.5 528.35 59.5 523.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-136"><g><path d="M 119.5 523.6 C 119.5 518.85 130.69 515 144.5 515 C 151.13 515 157.49 515.91 162.18 517.52 C 166.87 519.13 169.5 521.32 169.5 523.6 L 169.5 570.4 C 169.5 575.15 158.31 579 144.5 579 C 130.69 579 119.5 575.15 119.5 570.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 169.5 523.6 C 169.5 528.35 158.31 532.2 144.5 532.2 C 130.69 532.2 119.5 528.35 119.5 523.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-137"><g><path d="M 89.5 533.6 C 89.5 528.85 100.69 525 114.5 525 C 121.13 525 127.49 525.91 132.18 527.52 C 136.87 529.13 139.5 531.32 139.5 533.6 L 139.5 580.4 C 139.5 585.15 128.31 589 114.5 589 C 100.69 589 89.5 585.15 89.5 580.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 139.5 533.6 C 139.5 538.35 128.31 542.2 114.5 542.2 C 100.69 542.2 89.5 538.35 89.5 533.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-138"><g><rect x="40" y="506" width="150" height="105" rx="6.3" ry="6.3" fill="none" stroke="#000000" stroke-dasharray="3 3" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-139"><g><path d="M 210 547 L 196.37 547" fill="none" stroke="#000000" stroke-miterlimit="10" stroke-dasharray="3 3" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 191.12 547 L 198.12 543.5 L 196.37 547 L 198.12 550.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-140"><g><rect x="430" y="271" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 291px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">User Interface</div></div></div></foreignObject><image x="431" y="284.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-141"><g><path d="M 333.63 41 L 305.03 41 L 305 100.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 338.88 41 L 331.88 44.5 L 333.63 41 L 331.88 37.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 305 105.88 L 301.5 98.88 L 305 100.63 L 308.5 98.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-142"><g><ellipse cx="355" cy="7.5" rx="7.5" ry="7.5" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/><path d="M 355 15 L 355 40 M 355 20 L 340 20 M 355 20 L 370 20 M 355 40 L 340 60 M 355 40 L 370 60" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 67px; margin-left: 355px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: nowrap; ">Machine</div></div></div></foreignObject><image x="332.5" y="67.5" width="45" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-147"><g><path d="M 376.37 127 L 403.03 127 L 403.03 291 L 423.63 291" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 371.12 127 L 378.12 123.5 L 376.37 127 L 378.12 130.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 428.88 291 L 421.88 294.5 L 423.63 291 L 421.88 287.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-148"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 217px; margin-left: 403px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="388.5" y="211" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-149"><g><path d="M 423.63 137 L 417.03 137 L 417.03 288 C 420.93 288 420.93 294 417.03 294 L 417.03 294 L 417.03 328 C 420.93 328 420.93 334 417.03 334 L 417.03 334 L 417.03 408 C 420.93 408 420.93 414 417.03 414 L 417.03 414 L 417.03 418 C 420.93 418 420.93 424 417.03 424 L 417.03 424 L 417.03 445 L 430 445" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 428.88 137 L 421.88 140.5 L 423.63 137 L 421.88 133.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-150"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 237px; margin-left: 420px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">HTTP</div></div></div></foreignObject><image x="405.5" y="231" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g><g data-cell-id="a_cl7nsyDpLQFaXOHeFD-3"><g><path d="M 279.5 257.6 C 279.5 252.85 290.69 249 304.5 249 C 311.13 249 317.49 249.91 322.18 251.52 C 326.87 253.13 329.5 255.32 329.5 257.6 L 329.5 304.4 C 329.5 309.15 318.31 313 304.5 313 C 290.69 313 279.5 309.15 279.5 304.4 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 329.5 257.6 C 329.5 262.35 318.31 266.2 304.5 266.2 C 290.69 266.2 279.5 262.35 279.5 257.6" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="a_cl7nsyDpLQFaXOHeFD-4"><g><rect x="262" y="313" width="85" height="17" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 322px; margin-left: 260px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">metric-db</div></div></div></foreignObject><image x="260" y="315.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-6"><g><path d="M 570 127 L 550 127 L 580 127 L 564.87 127" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 561.12 127 L 566.12 124.5 L 564.87 127 L 566.12 129.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-5"><g><rect x="570" y="120" width="40" height="14" rx="2.1" ry="2.1" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 127px; margin-left: 571px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="571" y="120.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-9"><g><path d="M 570 373 L 550 373 L 580 373 L 564.87 373" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 561.12 373 L 566.12 370.5 L 564.87 373 L 566.12 375.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-8"><g><rect x="570" y="366.5" width="40" height="13" rx="1.95" ry="1.95" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 373px; margin-left: 571px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="571" y="366.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-11"><g><path d="M 40 209 L 60 209 L 29.49 209 L 44.63 209" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 48.38 209 L 43.38 211.5 L 44.63 209 L 43.38 206.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-10"><g><rect x="0" y="203" width="40" height="12" rx="1.8" ry="1.8" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 209px; margin-left: 1px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="1" y="202.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-12"><g><rect x="240" y="189" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 209px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Dashboard UI</b><div><i>grafana</i></div></div></div></div></foreignObject><image x="241" y="195" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-17"><g><path d="M 230 455 L 250 455 L 220 455 L 235.13 455" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 238.88 455 L 233.88 457.5 L 235.13 455 L 233.88 452.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-18"><g><path d="M 230 455 L 250 455 L 220 455 L 238.13 455" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 238.88 455 L 237.88 455.5 L 238.13 455 L 237.88 454.5 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-14"><g><rect x="190" y="448.5" width="40" height="13" rx="1.95" ry="1.95" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 38px; height: 1px; padding-top: 455px; margin-left: 191px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">init</div></div></div></foreignObject><image x="191" y="448.5" width="38" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-104"><g><rect x="240" y="435" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 455px; margin-left: 241px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Auth Service</b><br /><i>keycloak</i></div></div></div></foreignObject><image x="241" y="441" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-120"><g><rect x="49.5" y="189" width="130" height="40" rx="6" ry="6" fill="#e6e6e6" stroke="#000000" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 209px; margin-left: 51px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Storage Service</b><div><i>seaweedfs</i></div></div></div></div></foreignObject><image x="51" y="195" width="128" height="32" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-105"><g><rect x="430" y="107" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 127px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Search Service</div></div></div></foreignObject><image x="431" y="120.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="FWEJ_FGA9GBXbfwohBE8-108"><g><rect x="430" y="353" width="130" height="40" rx="6" ry="6" fill="#ffffff" stroke="#000000" pointer-events="all" style="fill: rgb(255, 255, 255); stroke: rgb(0, 0, 0);"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 128px; height: 1px; padding-top: 373px; margin-left: 431px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; "><b>Dashboard Service</b></div></div></div></foreignObject><image x="431" y="366.5" width="128" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-21"><g><rect x="452.5" y="588.61" width="85" height="20" fill="none" stroke="none" pointer-events="all"/></g><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 89px; height: 1px; padding-top: 599px; margin-left: 451px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; "><div style="display: inline-block; font-size: 12px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; white-space: normal; word-wrap: normal; ">data-db</div></div></div></foreignObject><image x="451" y="592.5" width="89" height="17" xlink:href=""/></switch></g></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-23"><g><path d="M 439.5 523.21 C 439.5 518.46 450.69 514.61 464.5 514.61 C 471.13 514.61 477.49 515.52 482.18 517.13 C 486.87 518.74 489.5 520.93 489.5 523.21 L 489.5 570.01 C 489.5 574.76 478.31 578.61 464.5 578.61 C 450.69 578.61 439.5 574.76 439.5 570.01 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 489.5 523.21 C 489.5 527.96 478.31 531.81 464.5 531.81 C 450.69 531.81 439.5 527.96 439.5 523.21" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-24"><g><path d="M 499.5 523.21 C 499.5 518.46 510.69 514.61 524.5 514.61 C 531.13 514.61 537.49 515.52 542.18 517.13 C 546.87 518.74 549.5 520.93 549.5 523.21 L 549.5 570.01 C 549.5 574.76 538.31 578.61 524.5 578.61 C 510.69 578.61 499.5 574.76 499.5 570.01 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 549.5 523.21 C 549.5 527.96 538.31 531.81 524.5 531.81 C 510.69 531.81 499.5 527.96 499.5 523.21" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-25"><g><path d="M 470.5 533.21 C 470.5 528.46 481.69 524.61 495.5 524.61 C 502.13 524.61 508.49 525.52 513.18 527.13 C 517.87 528.74 520.5 530.93 520.5 533.21 L 520.5 580.01 C 520.5 584.76 509.31 588.61 495.5 588.61 C 481.69 588.61 470.5 584.76 470.5 580.01 Z" fill="#e6e6e6" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(230, 230, 230); stroke: rgb(0, 0, 0);"/><path d="M 520.5 533.21 C 520.5 537.96 509.31 541.81 495.5 541.81 C 481.69 541.81 470.5 537.96 470.5 533.21" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="stroke: rgb(0, 0, 0);"/></g></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-29"><g><path d="M 494.86 481.37 L 494.86 518.63" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke" style="stroke: rgb(0, 0, 0);"/><path d="M 494.86 476.12 L 498.36 483.12 L 494.86 481.37 L 491.36 483.12 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/><path d="M 494.86 523.88 L 491.36 516.88 L 494.86 518.63 L 498.36 516.88 Z" fill="#000000" stroke="#000000" stroke-miterlimit="10" pointer-events="all" style="fill: rgb(0, 0, 0); stroke: rgb(0, 0, 0);"/></g><g data-cell-id="uDJ2bVtIrgoZBCZFZmDG-30"><g><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 497px; margin-left: 496px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; color: #000000; background-color: #ffffff; "><div style="display: inline-block; font-size: 11px; font-family: "Helvetica"; color: #000000; line-height: 1.2; pointer-events: all; background-color: #ffffff; white-space: nowrap; ">JDBC</div></div></div></foreignObject><image x="481.5" y="491" width="29" height="15.75" xlink:href=""/></switch></g></g></g></g></g></g></g></svg> \ No newline at end of file diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 8300ee192ada3bf6e2aced24053e843c191c2ba9..a0fe69487b196fd0fefdb6aad9fb3d12bf70dcb6 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -519,6 +519,22 @@ test-python-lib: junit: ./lib/python/coverage.xml coverage: '/TOTAL.*?([0-9]{1,3})%/' +test-storage-service-init: + image: docker.io/docker:${DOCKER_VERSION}-dind + stage: test + only: + - merge_requests + - master + variables: + PYTHONUNBUFFERED: 1 + before_script: + - "apk --no-cache add s3cmd bash libxml2-utils" + - "docker compose build dbrepo-storage-service-init" + - "mkdir -p /app/" + - "echo ${CI_S3_CONFIG} | base64 -d > /app/.s3cfg" + script: + - "bash ./dbrepo-storage-service/init/tests/test_integration_expire.sh" + test-ui: image: docker.io/docker:${DOCKER_VERSION}-dind stage: test diff --git a/dbrepo-analyse-service/Dockerfile b/dbrepo-analyse-service/Dockerfile index a140efd513760a68af887a2474591bc2f6fb20d3..26ea3ce65c2336bfd065e891c8d88ea47aaf73a3 100644 --- a/dbrepo-analyse-service/Dockerfile +++ b/dbrepo-analyse-service/Dockerfile @@ -1,8 +1,7 @@ FROM python:3.11-alpine3.21 LABEL org.opencontainers.image.authors="martin.weise@tuwien.ac.at" -RUN apk --no-cache \ - add \ +RUN apk --no-cache add \ bash \ curl \ openjdk8-jre diff --git a/dbrepo-analyse-service/Pipfile.lock b/dbrepo-analyse-service/Pipfile.lock index c43f7304c04408ec0ec87d895262cebcd84c3d33..ebab75e9e69f8cf4a017ba465f2ba01d139bf88d 100644 --- a/dbrepo-analyse-service/Pipfile.lock +++ b/dbrepo-analyse-service/Pipfile.lock @@ -180,20 +180,20 @@ }, "boto3": { "hashes": [ - "sha256:beea13db5a5f5eaacecfa905cd1e4e933c13802f776198264eef229d6dffcc42", - "sha256:c75d78013eb43b354662cbd5f30bf537ab06641d3ed37aaad6fcf55a529d2991" + "sha256:cf8997be0742a5cab9d33a138ef56e423a8ebd8881f6f73e95076b26656b36dc", + "sha256:dfee02b2f8f632a239a2f4ba6a2d568e2edd7f7464e9afd8a487fdb3fa9a0ad3" ], "index": "pypi", "markers": "python_version >= '3.8'", - "version": "==1.37.30" + "version": "==1.37.31" }, "botocore": { "hashes": [ - "sha256:2f43b61e0231abbb4fbe8917acb1af98cb83dbab8c264c0d1f5ca0f16fdbf219", - "sha256:d8ca899962d2079acd52483581f607322513910337a69bdae697766404b85b7d" + "sha256:598a33a7a0e5a014bd1416c999a0b9c634fbbba3d1363e2368e6a92da4544df4", + "sha256:eb3dfa44a87187bd82c3b493d568d8436270d4d000f237b49b669a01fcd8a21c" ], "markers": "python_version >= '3.8'", - "version": "==1.37.30" + "version": "==1.37.31" }, "certifi": { "hashes": [ @@ -425,7 +425,7 @@ }, "dbrepo": { "hashes": [ - "sha256:7e21d72d0b3e766aeecb286b636ea7530fa971d95b1b083b7ef8b9512b8300ef" + "sha256:22484d712e4a240a0114b90b5e8eaacbe47aa8f7fc79200557150f081faf7669" ], "path": "./lib/dbrepo-1.8.1.tar.gz" }, @@ -860,101 +860,113 @@ }, "multidict": { "hashes": [ - "sha256:0085b0afb2446e57050140240a8595846ed64d1cbd26cef936bfab3192c673b8", - "sha256:042028348dc5a1f2be6c666437042a98a5d24cee50380f4c0902215e5ec41844", - "sha256:05fefbc3cddc4e36da209a5e49f1094bbece9a581faa7f3589201fd95df40e5d", - "sha256:063be88bd684782a0715641de853e1e58a2f25b76388538bd62d974777ce9bc2", - "sha256:07bfa8bc649783e703263f783f73e27fef8cd37baaad4389816cf6a133141331", - "sha256:08549895e6a799bd551cf276f6e59820aa084f0f90665c0f03dd3a50db5d3c48", - "sha256:095a2eabe8c43041d3e6c2cb8287a257b5f1801c2d6ebd1dd877424f1e89cf29", - "sha256:0b183a959fb88ad1be201de2c4bdf52fa8e46e6c185d76201286a97b6f5ee65c", - "sha256:0c383d28857f66f5aebe3e91d6cf498da73af75fbd51cedbe1adfb85e90c0460", - "sha256:0d57a01a2a9fa00234aace434d8c131f0ac6e0ac6ef131eda5962d7e79edfb5b", - "sha256:0dc25a3293c50744796e87048de5e68996104d86d940bb24bc3ec31df281b191", - "sha256:0e5a644e50ef9fb87878d4d57907f03a12410d2aa3b93b3acdf90a741df52c49", - "sha256:0f249badb360b0b4d694307ad40f811f83df4da8cef7b68e429e4eea939e49dd", - "sha256:0f74f2fc51555f4b037ef278efc29a870d327053aba5cb7d86ae572426c7cccc", - "sha256:125dd82b40f8c06d08d87b3510beaccb88afac94e9ed4a6f6c71362dc7dbb04b", - "sha256:13551d0e2d7201f0959725a6a769b6f7b9019a168ed96006479c9ac33fe4096b", - "sha256:14ed9ed1bfedd72a877807c71113deac292bf485159a29025dfdc524c326f3e1", - "sha256:163f4604e76639f728d127293d24c3e208b445b463168af3d031b92b0998bb90", - "sha256:19e2819b0b468174de25c0ceed766606a07cedeab132383f1e83b9a4e96ccb4f", - "sha256:1e2a2193d3aa5cbf5758f6d5680a52aa848e0cf611da324f71e5e48a9695cc86", - "sha256:1f3c099d3899b14e1ce52262eb82a5f5cb92157bb5106bf627b618c090a0eadc", - "sha256:214207dcc7a6221d9942f23797fe89144128a71c03632bf713d918db99bd36de", - "sha256:2325105e16d434749e1be8022f942876a936f9bece4ec41ae244e3d7fae42aaf", - "sha256:2529ddbdaa424b2c6c2eb668ea684dd6b75b839d0ad4b21aad60c168269478d7", - "sha256:256d431fe4583c5f1e0f2e9c4d9c22f3a04ae96009b8cfa096da3a8723db0a16", - "sha256:25bb96338512e2f46f615a2bb7c6012fe92a4a5ebd353e5020836a7e33120349", - "sha256:2e87f1926e91855ae61769ba3e3f7315120788c099677e0842e697b0bfb659f2", - "sha256:2fc6af8e39f7496047c7876314f4317736eac82bf85b54c7c76cf1a6f8e35d98", - "sha256:3157126b028c074951839233647bd0e30df77ef1fedd801b48bdcad242a60f4e", - "sha256:32c9b4878f48be3e75808ea7e499d6223b1eea6d54c487a66bc10a1871e3dc6a", - "sha256:32ed748ff9ac682eae7859790d3044b50e3076c7d80e17a44239683769ff485e", - "sha256:3501621d5e86f1a88521ea65d5cad0a0834c77b26f193747615b7c911e5422d2", - "sha256:437c33561edb6eb504b5a30203daf81d4a9b727e167e78b0854d9a4e18e8950b", - "sha256:48d39b1824b8d6ea7de878ef6226efbe0773f9c64333e1125e0efcfdd18a24c7", - "sha256:4ac3fcf9a2d369bd075b2c2965544036a27ccd277fc3c04f708338cc57533081", - "sha256:4ccfd74957ef53fa7380aaa1c961f523d582cd5e85a620880ffabd407f8202c0", - "sha256:52b05e21ff05729fbea9bc20b3a791c3c11da61649ff64cce8257c82a020466d", - "sha256:5389445f0173c197f4a3613713b5fb3f3879df1ded2a1a2e4bc4b5b9c5441b7e", - "sha256:5c5e7d2e300d5cb3b2693b6d60d3e8c8e7dd4ebe27cd17c9cb57020cac0acb80", - "sha256:5d26547423e5e71dcc562c4acdc134b900640a39abd9066d7326a7cc2324c530", - "sha256:5dd7106d064d05896ce28c97da3f46caa442fe5a43bc26dfb258e90853b39b44", - "sha256:5f8cb1329f42fadfb40d6211e5ff568d71ab49be36e759345f91c69d1033d633", - "sha256:61d5541f27533f803a941d3a3f8a3d10ed48c12cf918f557efcbf3cd04ef265c", - "sha256:639556758c36093b35e2e368ca485dada6afc2bd6a1b1207d85ea6dfc3deab27", - "sha256:641cf2e3447c9ecff2f7aa6e9eee9eaa286ea65d57b014543a4911ff2799d08a", - "sha256:6aed763b6a1b28c46c055692836879328f0b334a6d61572ee4113a5d0c859872", - "sha256:6e2a2d6749e1ff2c9c76a72c6530d5baa601205b14e441e6d98011000f47a7ac", - "sha256:7243c5a6523c5cfeca76e063efa5f6a656d1d74c8b1fc64b2cd1e84e507f7e2a", - "sha256:76b34c12b013d813e6cb325e6bd4f9c984db27758b16085926bbe7ceeaace626", - "sha256:781b5dd1db18c9e9eacc419027b0acb5073bdec9de1675c0be25ceb10e2ad133", - "sha256:7c611345bbe7cb44aabb877cb94b63e86f2d0db03e382667dbd037866d44b4f8", - "sha256:83b78c680d4b15d33042d330c2fa31813ca3974197bddb3836a5c635a5fd013f", - "sha256:84e87a7d75fa36839a3a432286d719975362d230c70ebfa0948549cc38bd5b46", - "sha256:89b3857652183b8206a891168af47bac10b970d275bba1f6ee46565a758c078d", - "sha256:8cd1a0644ccaf27e9d2f6d9c9474faabee21f0578fe85225cc5af9a61e1653df", - "sha256:8de4d42dffd5ced9117af2ce66ba8722402541a3aa98ffdf78dde92badb68932", - "sha256:94a7bb972178a8bfc4055db80c51efd24baefaced5e51c59b0d598a004e8305d", - "sha256:98aa8325c7f47183b45588af9c434533196e241be0a4e4ae2190b06d17675c02", - "sha256:9e658d1373c424457ddf6d55ec1db93c280b8579276bebd1f72f113072df8a5d", - "sha256:9f49585f4abadd2283034fc605961f40c638635bc60f5162276fec075f2e37a4", - "sha256:9f6cad071960ba1914fa231677d21b1b4a3acdcce463cee41ea30bc82e6040cf", - "sha256:a0cc398350ef31167e03f3ca7c19313d4e40a662adcb98a88755e4e861170bdd", - "sha256:a1133414b771619aa3c3000701c11b2e4624a7f492f12f256aedde97c28331a2", - "sha256:a33273a541f1e1a8219b2a4ed2de355848ecc0254264915b9290c8d2de1c74e1", - "sha256:a3c0ff89fe40a152e77b191b83282c9664357dce3004032d42e68c514ceff27e", - "sha256:a49994481b99cd7dedde07f2e7e93b1d86c01c0fca1c32aded18f10695ae17eb", - "sha256:abf5b17bc0cf626a8a497d89ac691308dbd825d2ac372aa990b1ca114e470151", - "sha256:ac380cacdd3b183338ba63a144a34e9044520a6fb30c58aa14077157a033c13e", - "sha256:ad81012b24b88aad4c70b2cbc2dad84018783221b7f923e926f4690ff8569da3", - "sha256:b2c00ad31fbc2cbac85d7d0fcf90853b2ca2e69d825a2d3f3edb842ef1544a2c", - "sha256:b4c153863dd6569f6511845922c53e39c8d61f6e81f228ad5443e690fca403de", - "sha256:b4f3d66dd0354b79761481fc15bdafaba0b9d9076f1f42cc9ce10d7fcbda205a", - "sha256:b99aac6bb2c37db336fa03a39b40ed4ef2818bf2dfb9441458165ebe88b793af", - "sha256:b9f6392d98c0bd70676ae41474e2eecf4c7150cb419237a41f8f96043fcb81d1", - "sha256:c537da54ce4ff7c15e78ab1292e5799d0d43a2108e006578a57f531866f64025", - "sha256:ca23db5fb195b5ef4fd1f77ce26cadefdf13dba71dab14dadd29b34d457d7c44", - "sha256:cc826b9a8176e686b67aa60fd6c6a7047b0461cae5591ea1dc73d28f72332a8a", - "sha256:cca83a629f77402cfadd58352e394d79a61c8015f1694b83ab72237ec3941f88", - "sha256:cf8d370b2fea27fb300825ec3984334f7dd54a581bde6456799ba3776915a656", - "sha256:d1175b0e0d6037fab207f05774a176d71210ebd40b1c51f480a04b65ec5c786d", - "sha256:d1996ee1330e245cd3aeda0887b4409e3930524c27642b046e4fae88ffa66c5e", - "sha256:d5a36953389f35f0a4e88dc796048829a2f467c9197265504593f0e420571547", - "sha256:da51d8928ad8b4244926fe862ba1795f0b6e68ed8c42cd2f822d435db9c2a8f4", - "sha256:e16e7297f29a544f49340012d6fc08cf14de0ab361c9eb7529f6a57a30cbfda1", - "sha256:e25b11a0417475f093d0f0809a149aff3943c2c56da50fdf2c3c88d57fe3dfbd", - "sha256:e4371591e621579cb6da8401e4ea405b33ff25a755874a3567c4075ca63d56e2", - "sha256:e653d36b1bf48fa78c7fcebb5fa679342e025121ace8c87ab05c1cefd33b34fc", - "sha256:e7d91a230c7f8af86c904a5a992b8c064b66330544693fd6759c3d6162382ecf", - "sha256:e851e6363d0dbe515d8de81fd544a2c956fdec6f8a049739562286727d4a00c3", - "sha256:ef7d48207926edbf8b16b336f779c557dd8f5a33035a85db9c4b0febb0706817", - "sha256:f7716f7e7138252d88607228ce40be22660d6608d20fd365d596e7ca0738e019", - "sha256:facaf11f21f3a4c51b62931feb13310e6fe3475f85e20d9c9fdce0d2ea561b87" + "sha256:033edcc22211463be927ca407dc5c5f3aa84d3d093ed2d559a2e3c2d995d50e4", + "sha256:03cd2a3c446162678d0a6d14d69ad38204128414ba40722a5ff6f2107782b723", + "sha256:05dcc73739ae8096f64f08282c8980dab2cf9acb02eb838aacd8ac56b795c405", + "sha256:11d76b83dc93e98207514e1938b89854655087e3b27a09d89525fe17a0f1ce11", + "sha256:1247de19497e13063eabf1df67e87530ac31497b91e9bd08621852a57d9b5ee7", + "sha256:147c962e8ae339d5fa84c52cc1e59546cb2d0d9359f9a8e1b8eb7b5ffac8dba0", + "sha256:159dae860e4d34bd4f48e72a0c033d78ae9215b43d423c19cbf47b7db5972599", + "sha256:15c14a01dd95e860703a4ce78d4b0d49f18c14389eb91b4aa12444e31dfc2841", + "sha256:15ddde4242134f1aeb1455ad60cc529e0a9f5eb251ae7be7fc37debdb257182c", + "sha256:1a894aed57c6edc514c9222989cf09eebd9ea7acb6185a26cfeac2ece2ddf265", + "sha256:1c11e8460ff0629871f9703c87208e553fbfa6c9d92f94c20d4f86e56f021029", + "sha256:1cd34caed981a95964218e03a3f267537a0b1a2fae078949e880f757df9efe55", + "sha256:1f62882c6d06e5e75b82444ce14f59b830f5b017b31630cc13d8b0b01379385a", + "sha256:20050a17cc2f322598d181a5b2e2cf4787e4c2e3bf71aab5e96618b40665e8ae", + "sha256:205da0f812c9128155bc1b7be69cf89280a5bb2f5b84426bced76e7d860ed5dc", + "sha256:258414850b59fb820bd1e1e19a9b281409a6d0bd969d3fe7104cc87a7c08c191", + "sha256:27d45a6a8495f2cfcf64d6cc4fbcc78a6e87ed840e54a261430d0d4331d9aae0", + "sha256:285058a0cdd284ba5bbc1d10d75fb33e3b3087b15d5aa9d23fc4787dd3a48384", + "sha256:2e116fad10aa7c74aa3acc69adcdffe86f1415abb111653f85dd37171116b57d", + "sha256:38e165c4d79ac98cabb5c08d8a3a3e1dda3206bcec19ed072992b62b200b180d", + "sha256:3af088483bf2aba7f2886437d856a6ba4cd0c17946dd615cbe55d56552eaf187", + "sha256:3d17d8b2d4643d4f59629758b0dd229cda61e2319f81b470aa4a99717081ba0c", + "sha256:3e80621ebc9f045fab847a970b2430146f9121b95c3c695b044ade8488753126", + "sha256:4030f5319aacf20e924c5218377df446507b314f03676549891e12a9f832a9f1", + "sha256:44ee27fb416c3d8981b7c3c97b9813d40b06575f6d477f4da21726a30aabb562", + "sha256:458b235ae7af880e18c1476f968ef571689a574720eb9e6e8873d138fbba9c58", + "sha256:4660b75286c11b8f38c90b98ccf7541b7030dbec32b28f05031f8abebf7fc0e5", + "sha256:4748c017fa201e6a296c9ef75dc3668a01532adb8f5c27a0bef4835dfa62f8e7", + "sha256:48f775443154d99e1b1c727ea20137ddc1e4b29448a9b24875b2a348cc143b85", + "sha256:49e01d212be64ceee18a45e8baef441aa86cc9bd365fb92fb8b214e5fa5bc08b", + "sha256:4a0ba21b315113d39f7aa3ca4eb804f7984dab33c42ea14d07d790a640f81e77", + "sha256:4aca2ab0969dc3781fefe523ce70c5d245b915ba0708ce2713e8ac561f9448e0", + "sha256:5055e039ebfc6e4589115717c4a6d1dd2f195327b8d5a3e21a68f374d79dbed9", + "sha256:52bd2b6681beb34115eebbcbdcbd170ebc3fc98c4eb0dd789f2c01d4d6b189c0", + "sha256:54a291428e25f775193704f95a94f21a42a28ffb09c1bdc91e152c6b1faf4a91", + "sha256:58f74a195b99189c9f7e2bc83cc95fcf169a43a63c5c8cad63c4027bf3233118", + "sha256:614021ba98b8052d4eb3d5900d3bd953421edf41b2aa85d37c1dc67bcee1ea9d", + "sha256:64fccd2fa3cfd49c442c4995d58189e578560705b9b632faad8ffd9aaa390007", + "sha256:64fdd7a4aef8f14e4a6917a434d0a4766345f5d544d0c0c0e53b14eb1e4be0ac", + "sha256:693858c9584cedc1685e67e78fa9e50285504e8d4bbfde7290ca04dbbac939a8", + "sha256:6d168a6693c1b9b950d9584178d12095bfbaf290748eb6e2726c914bc1d0d4f1", + "sha256:6da367181104a57e77140ebf736652ed9a97c7bcb77c7640cf8a168893561bd2", + "sha256:6ed731286f0ae399e65e3172c5808732b9ae5d896b3ab7f692eb686bba6bc9df", + "sha256:70d695f62a55f90ee894fdf1ede51ccdda3abbe25b43b667b51747b6f61b8da7", + "sha256:71dae164819f8aede109a596db84d508e670d7e0a968901aaf22445e87ae7519", + "sha256:75bb804375e0b6c5db4e474fa0b5052414b6cbc3e70394d11a7ce9a7f6a18a91", + "sha256:796d1b070211554cc8193bd6764d2b44594ff7c7522989012eacf3fde778e5cf", + "sha256:79dc3f9893e32fcc564c60bb34c4e393daede2cdf0337a5b4627ed162a237fb3", + "sha256:7a3165a5bae6577d10858c35f6add83333ead621e8286a5d15f7d567ef44be78", + "sha256:7a74764881276904564f8725da3dd2b82924838a114738933f58b75082b55dd3", + "sha256:7cbc2e5116cdca0594bb39c64a8bd5e7f44d392cf76d19913216924688d42954", + "sha256:8223f74cf698f7992e1a71ab90ab4c169b508a0f25083ebab9259b9f33d7bdde", + "sha256:824b60427c92c44098cfbd58d8adf8a8c5a60ade16742dcb54385b43e6337b4e", + "sha256:8257f26cc2cc5d0426da488162060c6cea57079172b9d3eedf016fcb0cfdb830", + "sha256:8530ca574ba38478e97af20ff0f3fd04f59ffcad435b1548703424d71e2ed66a", + "sha256:858b68e475f8e73e4014c078e9feced502273032f07840117ca12d2230d27135", + "sha256:88ae724e79a524d1921b2799251f667e7fb0344a59637df3bec91dc303020467", + "sha256:8ce52f84e793ee83082c4aa127605070a47c31597821ca84dec5c0ac809e8509", + "sha256:93de2d3802a5ac7d5deadba1c956a93db29502f1b9f4e8d2e393747b9b28d881", + "sha256:93f4545347f79121e9ba98a0c33a55f469ebc22fb45ae62692e01d367219796b", + "sha256:9777e194be00313f5a86a0dd52d9987b72cf6c43c8a42d6bd838adc46c70e98b", + "sha256:99b2401166c3b2d997b80479cdc7449a093e21f3d4b2f9c6e6ceee956aa10d63", + "sha256:99f9b6596d2e126fa1777990868743fb4c1984ea5217606fabc153aff46160e6", + "sha256:9b4cd51b623b3dc8b55f9caef07424ac6d684b8047e601aca7053999e1b4a527", + "sha256:9f1edbf7e0d22a1ebf3c24ffaf0b8a39888bd630d6ff38c77c169272a3d4b9cc", + "sha256:a3da262f5b9f0dd01277575de4967683123ab47699fd7db2ce38cb1bb8f5c76f", + "sha256:aa613b270de6215f9fc850f0fb18dbc20ba297013012793cf3d2f1295e271e91", + "sha256:ac87e173c5f3aeac06d01eeebfb35c2b1bc5f536b21210dd8b032f1dc0726fbc", + "sha256:ad333e0b0d19294d3fc81d7aa9b65c45ebf49e6f8b3fab02db43284140d2b0a8", + "sha256:af55e557e722c962f70cdc6a482d0df44b1f6622af49003e33dd114340724875", + "sha256:b019f5c53471e8a010edf2fec321ece25ac6b079b535980b7228dcb9ee62d621", + "sha256:b0441ee8b9edc3fadb5cd9f181212edd72f7b016723bc549f9c1c00a9a8e6f93", + "sha256:b29a79f1e4313c397e00d89d4d83ff54fd377e7d654b640bbe9002b4272f205e", + "sha256:b622146bcfc6749944d14e8a61267dbea1bee96a9c7ca7605683506ed3817844", + "sha256:b8a87a3686de1d215506ba13dd388433695bfff534839e045419ba2f36437c0e", + "sha256:b9c5dfa5c7cdc26f6b777ac6210d3621d556e2e244f0a7358afe8ec0135f8640", + "sha256:b9d3d5de87a88768be67b7ec20aeb531707174ba0645697a938df3afc2c62b1f", + "sha256:bbd3cc064d272618b95c2f85ec61fe9d07e2a1de18c153c10923d3c2cdebff4c", + "sha256:bcd21a1b5cfb45170280e5fcd382c25519d75bdf4634656868b91c05d5e15b23", + "sha256:bdb621264758b22ae3aaa9d60937751069d80d610d713887ff94cf7487fc3f5f", + "sha256:c5fdcac25ae451af93e7f997678ed2282bf6b5ef892e253eea13bba59849f00e", + "sha256:c785581071f140d364821c210422ab5937d6c2c51d92e45a552a8e34b434a5a3", + "sha256:cbd06fb147030d7781f10bd7542f29bbf56cefb51a9f042713d5fc52e68b8afd", + "sha256:cf95ac57b44b6fb46a0151641b9905bbad27783314abc4f4b0b0a82f26b06b07", + "sha256:d6698fccb2f962021e467be6ba43fc02f7341f221e80545810303f5cc66461bb", + "sha256:d7533a9684e599b22a4beb699647dc3269d551e455886be8125f14f3c5a0869f", + "sha256:d7bf1d52c69f3051a0ebae9cca1e5be06e2ad4677d670a920454ecf6d20e2c8e", + "sha256:d8f47485264b1168ef852dd6bea619703409ff2cbc5e610dcb0f15fe3c6750bb", + "sha256:d8fc8c7c092a48044bf942735eea6da198cac0c655d7a06550619b2a7fec2ffd", + "sha256:d9e984f9542fba175bc4d98e320e9e2bd6e7480682aa84b274e9aee7fb6575b9", + "sha256:dc86a31e3215ce037ae306a338ff2156d897aae627d5d4e3dfa0c9eded4249e8", + "sha256:dd5240bea7d8de32e7ac95088b2ad95b89993a3825d9278d363d73ca40113cb3", + "sha256:df46fd268c765d186df8c7899bc4e0a2ee0d12458d356438af0329a49e6b15ca", + "sha256:dfb3870c5d4f5413988caf64243830f7ca13dc58ae2cf3eb48fe321ca6f26648", + "sha256:e36cfe9df4dfb6c2f4d80d20852ab6449257a01942e4808c3912ed413a4d40f7", + "sha256:e5ca936b70414dbee02f218be1d36a535a5953ba63fd82dc812135ca3f5a525f", + "sha256:e7ab7ea72c3f66ae1e930ae776ad2c6f4f78e0184781f64f196f17ecce113101", + "sha256:e80878904057edfd1d70ba31258f974d36c470fd95de2bcd98e0494942c4433e", + "sha256:ed8d6bd6f3c7991083e741fd55cecea70d670971c73b9563a673eab96e5356b4", + "sha256:f290e4eebf7764f8327a4bc6a459f09ca9a041cf7349bacfbb252da9feb0d37c", + "sha256:f915fc3287ddc23a5da8f61f5c2c3aaca0b754ce526c0ff81f55c27b25038cd5", + "sha256:fb8b1cba597398698ec494794091dadd76eb8011bb95f43578930466e7beb20b", + "sha256:fbd035ae06babb07c6b80535b0d4f6fe57eb73a23ae276eb4502b1f67f19e8ef", + "sha256:fd9521b70b50aac341f59799301ba24acbe2897b9157035d139668b6c43bc406" ], "markers": "python_version >= '3.9'", - "version": "==6.2.0" + "version": "==6.4.2" }, "numpy": { "hashes": [ diff --git a/dbrepo-analyse-service/lib/dbrepo-1.8.1-py3-none-any.whl b/dbrepo-analyse-service/lib/dbrepo-1.8.1-py3-none-any.whl index f77eea076ca6a24674d220d3f54624b5f9a09202..261fa7958ae481d4d85bc5efc152e519fa6af802 100644 Binary files a/dbrepo-analyse-service/lib/dbrepo-1.8.1-py3-none-any.whl and b/dbrepo-analyse-service/lib/dbrepo-1.8.1-py3-none-any.whl differ diff --git a/dbrepo-analyse-service/lib/dbrepo-1.8.1.tar.gz b/dbrepo-analyse-service/lib/dbrepo-1.8.1.tar.gz index 7065ba14b7eadea39293894488821e3f38e0ef35..0da3ea37a31f2f3cdeea212e768aab7793f29252 100644 Binary files a/dbrepo-analyse-service/lib/dbrepo-1.8.1.tar.gz and b/dbrepo-analyse-service/lib/dbrepo-1.8.1.tar.gz differ diff --git a/dbrepo-auth-service/init/tests/test_unit_app.py b/dbrepo-auth-service/init/tests/test_unit_app.py index fc454cfa3ef1a358f1ce3a41c82e3f2c5d53a167..b2b530964e462f25b804cff3901a732fc7121a82 100644 --- a/dbrepo-auth-service/init/tests/test_unit_app.py +++ b/dbrepo-auth-service/init/tests/test_unit_app.py @@ -1,8 +1,9 @@ +import os import unittest import requests_mock -from app import endpoint, fetch +from app import fetch class AppUnitTest(unittest.TestCase): @@ -17,10 +18,14 @@ class AppUnitTest(unittest.TestCase): "scope": "profile email" } + def endpoint(self): + return os.getenv('AUTH_SERVICE_ENDPOINT', 'http://localhost:8080') + def test_fetch_token_bad_request_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=400) + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=400) # test try: fetch('admin') @@ -30,7 +35,8 @@ class AppUnitTest(unittest.TestCase): def test_fetch_token_unauthorized_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=401) + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=401) # test try: fetch('admin') @@ -40,8 +46,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_user_not_found_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[], status_code=200) + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[], status_code=200) # test try: @@ -52,8 +59,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_user_too_much_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[{}, {}], status_code=200) + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[{}, {}], status_code=200) # test try: @@ -64,8 +72,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_user_not_ok_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[{}], status_code=202) + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[{}], status_code=202) # test try: @@ -76,8 +85,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_user_no_attrs_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[{ + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[{ "id": "5b516520-67cb-4aa0-86a6-d12f8b8f1a20" }], status_code=200) @@ -90,8 +100,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_user_empty_attrs_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[{ + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[{ "id": "5b516520-67cb-4aa0-86a6-d12f8b8f1a20", "attributes": {} }], status_code=200) @@ -105,8 +116,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_user_malformed_attr_fails(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[{ + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[{ "id": "5b516520-67cb-4aa0-86a6-d12f8b8f1a20", "attributes": { "LDAP_ID": [] @@ -122,8 +134,9 @@ class AppUnitTest(unittest.TestCase): def test_fetch_succeeds(self): with requests_mock.Mocker() as mock: # mock - mock.post(f'{endpoint}/realms/master/protocol/openid-connect/token', json=self.token_res, status_code=200) - mock.get(f'{endpoint}/admin/realms/dbrepo/users/?username=admin', json=[{ + mock.post(f'{self.endpoint()}/realms/master/protocol/openid-connect/token', json=self.token_res, + status_code=200) + mock.get(f'{self.endpoint()}/admin/realms/dbrepo/users/?username=admin', json=[{ "id": "5b516520-67cb-4aa0-86a6-d12f8b8f1a20", "attributes": { "LDAP_ID": ["7a0b4b7f-77cd-4f28-a665-2da443024621"] diff --git a/dbrepo-auth-service/listeners/target/create-event-listener.jar b/dbrepo-auth-service/listeners/target/create-event-listener.jar index 4c541f2eb5bd4606250425f72aa7971a40164662..0b0771d3657d44c05fe9fe8fc62f2c7aef23c85b 100644 Binary files a/dbrepo-auth-service/listeners/target/create-event-listener.jar and b/dbrepo-auth-service/listeners/target/create-event-listener.jar differ diff --git a/dbrepo-dashboard-service/Pipfile.lock b/dbrepo-dashboard-service/Pipfile.lock index acef9a8483c91f82626ee5c619a51472d038cfc2..211dd025b06e021c9aa540c64b2adfa3a51b2693 100644 --- a/dbrepo-dashboard-service/Pipfile.lock +++ b/dbrepo-dashboard-service/Pipfile.lock @@ -373,7 +373,7 @@ }, "dbrepo": { "hashes": [ - "sha256:7e21d72d0b3e766aeecb286b636ea7530fa971d95b1b083b7ef8b9512b8300ef" + "sha256:22484d712e4a240a0114b90b5e8eaacbe47aa8f7fc79200557150f081faf7669" ], "path": "./lib/dbrepo-1.8.1.tar.gz" }, @@ -777,101 +777,113 @@ }, "multidict": { "hashes": [ - "sha256:0085b0afb2446e57050140240a8595846ed64d1cbd26cef936bfab3192c673b8", - "sha256:042028348dc5a1f2be6c666437042a98a5d24cee50380f4c0902215e5ec41844", - "sha256:05fefbc3cddc4e36da209a5e49f1094bbece9a581faa7f3589201fd95df40e5d", - "sha256:063be88bd684782a0715641de853e1e58a2f25b76388538bd62d974777ce9bc2", - "sha256:07bfa8bc649783e703263f783f73e27fef8cd37baaad4389816cf6a133141331", - "sha256:08549895e6a799bd551cf276f6e59820aa084f0f90665c0f03dd3a50db5d3c48", - "sha256:095a2eabe8c43041d3e6c2cb8287a257b5f1801c2d6ebd1dd877424f1e89cf29", - "sha256:0b183a959fb88ad1be201de2c4bdf52fa8e46e6c185d76201286a97b6f5ee65c", - "sha256:0c383d28857f66f5aebe3e91d6cf498da73af75fbd51cedbe1adfb85e90c0460", - "sha256:0d57a01a2a9fa00234aace434d8c131f0ac6e0ac6ef131eda5962d7e79edfb5b", - "sha256:0dc25a3293c50744796e87048de5e68996104d86d940bb24bc3ec31df281b191", - "sha256:0e5a644e50ef9fb87878d4d57907f03a12410d2aa3b93b3acdf90a741df52c49", - "sha256:0f249badb360b0b4d694307ad40f811f83df4da8cef7b68e429e4eea939e49dd", - "sha256:0f74f2fc51555f4b037ef278efc29a870d327053aba5cb7d86ae572426c7cccc", - "sha256:125dd82b40f8c06d08d87b3510beaccb88afac94e9ed4a6f6c71362dc7dbb04b", - "sha256:13551d0e2d7201f0959725a6a769b6f7b9019a168ed96006479c9ac33fe4096b", - "sha256:14ed9ed1bfedd72a877807c71113deac292bf485159a29025dfdc524c326f3e1", - "sha256:163f4604e76639f728d127293d24c3e208b445b463168af3d031b92b0998bb90", - "sha256:19e2819b0b468174de25c0ceed766606a07cedeab132383f1e83b9a4e96ccb4f", - "sha256:1e2a2193d3aa5cbf5758f6d5680a52aa848e0cf611da324f71e5e48a9695cc86", - "sha256:1f3c099d3899b14e1ce52262eb82a5f5cb92157bb5106bf627b618c090a0eadc", - "sha256:214207dcc7a6221d9942f23797fe89144128a71c03632bf713d918db99bd36de", - "sha256:2325105e16d434749e1be8022f942876a936f9bece4ec41ae244e3d7fae42aaf", - "sha256:2529ddbdaa424b2c6c2eb668ea684dd6b75b839d0ad4b21aad60c168269478d7", - "sha256:256d431fe4583c5f1e0f2e9c4d9c22f3a04ae96009b8cfa096da3a8723db0a16", - "sha256:25bb96338512e2f46f615a2bb7c6012fe92a4a5ebd353e5020836a7e33120349", - "sha256:2e87f1926e91855ae61769ba3e3f7315120788c099677e0842e697b0bfb659f2", - "sha256:2fc6af8e39f7496047c7876314f4317736eac82bf85b54c7c76cf1a6f8e35d98", - "sha256:3157126b028c074951839233647bd0e30df77ef1fedd801b48bdcad242a60f4e", - "sha256:32c9b4878f48be3e75808ea7e499d6223b1eea6d54c487a66bc10a1871e3dc6a", - "sha256:32ed748ff9ac682eae7859790d3044b50e3076c7d80e17a44239683769ff485e", - "sha256:3501621d5e86f1a88521ea65d5cad0a0834c77b26f193747615b7c911e5422d2", - "sha256:437c33561edb6eb504b5a30203daf81d4a9b727e167e78b0854d9a4e18e8950b", - "sha256:48d39b1824b8d6ea7de878ef6226efbe0773f9c64333e1125e0efcfdd18a24c7", - "sha256:4ac3fcf9a2d369bd075b2c2965544036a27ccd277fc3c04f708338cc57533081", - "sha256:4ccfd74957ef53fa7380aaa1c961f523d582cd5e85a620880ffabd407f8202c0", - "sha256:52b05e21ff05729fbea9bc20b3a791c3c11da61649ff64cce8257c82a020466d", - "sha256:5389445f0173c197f4a3613713b5fb3f3879df1ded2a1a2e4bc4b5b9c5441b7e", - "sha256:5c5e7d2e300d5cb3b2693b6d60d3e8c8e7dd4ebe27cd17c9cb57020cac0acb80", - "sha256:5d26547423e5e71dcc562c4acdc134b900640a39abd9066d7326a7cc2324c530", - "sha256:5dd7106d064d05896ce28c97da3f46caa442fe5a43bc26dfb258e90853b39b44", - "sha256:5f8cb1329f42fadfb40d6211e5ff568d71ab49be36e759345f91c69d1033d633", - "sha256:61d5541f27533f803a941d3a3f8a3d10ed48c12cf918f557efcbf3cd04ef265c", - "sha256:639556758c36093b35e2e368ca485dada6afc2bd6a1b1207d85ea6dfc3deab27", - "sha256:641cf2e3447c9ecff2f7aa6e9eee9eaa286ea65d57b014543a4911ff2799d08a", - "sha256:6aed763b6a1b28c46c055692836879328f0b334a6d61572ee4113a5d0c859872", - "sha256:6e2a2d6749e1ff2c9c76a72c6530d5baa601205b14e441e6d98011000f47a7ac", - "sha256:7243c5a6523c5cfeca76e063efa5f6a656d1d74c8b1fc64b2cd1e84e507f7e2a", - "sha256:76b34c12b013d813e6cb325e6bd4f9c984db27758b16085926bbe7ceeaace626", - "sha256:781b5dd1db18c9e9eacc419027b0acb5073bdec9de1675c0be25ceb10e2ad133", - "sha256:7c611345bbe7cb44aabb877cb94b63e86f2d0db03e382667dbd037866d44b4f8", - "sha256:83b78c680d4b15d33042d330c2fa31813ca3974197bddb3836a5c635a5fd013f", - "sha256:84e87a7d75fa36839a3a432286d719975362d230c70ebfa0948549cc38bd5b46", - "sha256:89b3857652183b8206a891168af47bac10b970d275bba1f6ee46565a758c078d", - "sha256:8cd1a0644ccaf27e9d2f6d9c9474faabee21f0578fe85225cc5af9a61e1653df", - "sha256:8de4d42dffd5ced9117af2ce66ba8722402541a3aa98ffdf78dde92badb68932", - "sha256:94a7bb972178a8bfc4055db80c51efd24baefaced5e51c59b0d598a004e8305d", - "sha256:98aa8325c7f47183b45588af9c434533196e241be0a4e4ae2190b06d17675c02", - "sha256:9e658d1373c424457ddf6d55ec1db93c280b8579276bebd1f72f113072df8a5d", - "sha256:9f49585f4abadd2283034fc605961f40c638635bc60f5162276fec075f2e37a4", - "sha256:9f6cad071960ba1914fa231677d21b1b4a3acdcce463cee41ea30bc82e6040cf", - "sha256:a0cc398350ef31167e03f3ca7c19313d4e40a662adcb98a88755e4e861170bdd", - "sha256:a1133414b771619aa3c3000701c11b2e4624a7f492f12f256aedde97c28331a2", - "sha256:a33273a541f1e1a8219b2a4ed2de355848ecc0254264915b9290c8d2de1c74e1", - "sha256:a3c0ff89fe40a152e77b191b83282c9664357dce3004032d42e68c514ceff27e", - "sha256:a49994481b99cd7dedde07f2e7e93b1d86c01c0fca1c32aded18f10695ae17eb", - "sha256:abf5b17bc0cf626a8a497d89ac691308dbd825d2ac372aa990b1ca114e470151", - "sha256:ac380cacdd3b183338ba63a144a34e9044520a6fb30c58aa14077157a033c13e", - "sha256:ad81012b24b88aad4c70b2cbc2dad84018783221b7f923e926f4690ff8569da3", - "sha256:b2c00ad31fbc2cbac85d7d0fcf90853b2ca2e69d825a2d3f3edb842ef1544a2c", - "sha256:b4c153863dd6569f6511845922c53e39c8d61f6e81f228ad5443e690fca403de", - "sha256:b4f3d66dd0354b79761481fc15bdafaba0b9d9076f1f42cc9ce10d7fcbda205a", - "sha256:b99aac6bb2c37db336fa03a39b40ed4ef2818bf2dfb9441458165ebe88b793af", - "sha256:b9f6392d98c0bd70676ae41474e2eecf4c7150cb419237a41f8f96043fcb81d1", - "sha256:c537da54ce4ff7c15e78ab1292e5799d0d43a2108e006578a57f531866f64025", - "sha256:ca23db5fb195b5ef4fd1f77ce26cadefdf13dba71dab14dadd29b34d457d7c44", - "sha256:cc826b9a8176e686b67aa60fd6c6a7047b0461cae5591ea1dc73d28f72332a8a", - "sha256:cca83a629f77402cfadd58352e394d79a61c8015f1694b83ab72237ec3941f88", - "sha256:cf8d370b2fea27fb300825ec3984334f7dd54a581bde6456799ba3776915a656", - "sha256:d1175b0e0d6037fab207f05774a176d71210ebd40b1c51f480a04b65ec5c786d", - "sha256:d1996ee1330e245cd3aeda0887b4409e3930524c27642b046e4fae88ffa66c5e", - "sha256:d5a36953389f35f0a4e88dc796048829a2f467c9197265504593f0e420571547", - "sha256:da51d8928ad8b4244926fe862ba1795f0b6e68ed8c42cd2f822d435db9c2a8f4", - "sha256:e16e7297f29a544f49340012d6fc08cf14de0ab361c9eb7529f6a57a30cbfda1", - "sha256:e25b11a0417475f093d0f0809a149aff3943c2c56da50fdf2c3c88d57fe3dfbd", - "sha256:e4371591e621579cb6da8401e4ea405b33ff25a755874a3567c4075ca63d56e2", - "sha256:e653d36b1bf48fa78c7fcebb5fa679342e025121ace8c87ab05c1cefd33b34fc", - "sha256:e7d91a230c7f8af86c904a5a992b8c064b66330544693fd6759c3d6162382ecf", - "sha256:e851e6363d0dbe515d8de81fd544a2c956fdec6f8a049739562286727d4a00c3", - "sha256:ef7d48207926edbf8b16b336f779c557dd8f5a33035a85db9c4b0febb0706817", - "sha256:f7716f7e7138252d88607228ce40be22660d6608d20fd365d596e7ca0738e019", - "sha256:facaf11f21f3a4c51b62931feb13310e6fe3475f85e20d9c9fdce0d2ea561b87" + "sha256:033edcc22211463be927ca407dc5c5f3aa84d3d093ed2d559a2e3c2d995d50e4", + "sha256:03cd2a3c446162678d0a6d14d69ad38204128414ba40722a5ff6f2107782b723", + "sha256:05dcc73739ae8096f64f08282c8980dab2cf9acb02eb838aacd8ac56b795c405", + "sha256:11d76b83dc93e98207514e1938b89854655087e3b27a09d89525fe17a0f1ce11", + "sha256:1247de19497e13063eabf1df67e87530ac31497b91e9bd08621852a57d9b5ee7", + "sha256:147c962e8ae339d5fa84c52cc1e59546cb2d0d9359f9a8e1b8eb7b5ffac8dba0", + "sha256:159dae860e4d34bd4f48e72a0c033d78ae9215b43d423c19cbf47b7db5972599", + "sha256:15c14a01dd95e860703a4ce78d4b0d49f18c14389eb91b4aa12444e31dfc2841", + "sha256:15ddde4242134f1aeb1455ad60cc529e0a9f5eb251ae7be7fc37debdb257182c", + "sha256:1a894aed57c6edc514c9222989cf09eebd9ea7acb6185a26cfeac2ece2ddf265", + "sha256:1c11e8460ff0629871f9703c87208e553fbfa6c9d92f94c20d4f86e56f021029", + "sha256:1cd34caed981a95964218e03a3f267537a0b1a2fae078949e880f757df9efe55", + "sha256:1f62882c6d06e5e75b82444ce14f59b830f5b017b31630cc13d8b0b01379385a", + "sha256:20050a17cc2f322598d181a5b2e2cf4787e4c2e3bf71aab5e96618b40665e8ae", + "sha256:205da0f812c9128155bc1b7be69cf89280a5bb2f5b84426bced76e7d860ed5dc", + "sha256:258414850b59fb820bd1e1e19a9b281409a6d0bd969d3fe7104cc87a7c08c191", + "sha256:27d45a6a8495f2cfcf64d6cc4fbcc78a6e87ed840e54a261430d0d4331d9aae0", + "sha256:285058a0cdd284ba5bbc1d10d75fb33e3b3087b15d5aa9d23fc4787dd3a48384", + "sha256:2e116fad10aa7c74aa3acc69adcdffe86f1415abb111653f85dd37171116b57d", + "sha256:38e165c4d79ac98cabb5c08d8a3a3e1dda3206bcec19ed072992b62b200b180d", + "sha256:3af088483bf2aba7f2886437d856a6ba4cd0c17946dd615cbe55d56552eaf187", + "sha256:3d17d8b2d4643d4f59629758b0dd229cda61e2319f81b470aa4a99717081ba0c", + "sha256:3e80621ebc9f045fab847a970b2430146f9121b95c3c695b044ade8488753126", + "sha256:4030f5319aacf20e924c5218377df446507b314f03676549891e12a9f832a9f1", + "sha256:44ee27fb416c3d8981b7c3c97b9813d40b06575f6d477f4da21726a30aabb562", + "sha256:458b235ae7af880e18c1476f968ef571689a574720eb9e6e8873d138fbba9c58", + "sha256:4660b75286c11b8f38c90b98ccf7541b7030dbec32b28f05031f8abebf7fc0e5", + "sha256:4748c017fa201e6a296c9ef75dc3668a01532adb8f5c27a0bef4835dfa62f8e7", + "sha256:48f775443154d99e1b1c727ea20137ddc1e4b29448a9b24875b2a348cc143b85", + "sha256:49e01d212be64ceee18a45e8baef441aa86cc9bd365fb92fb8b214e5fa5bc08b", + "sha256:4a0ba21b315113d39f7aa3ca4eb804f7984dab33c42ea14d07d790a640f81e77", + "sha256:4aca2ab0969dc3781fefe523ce70c5d245b915ba0708ce2713e8ac561f9448e0", + "sha256:5055e039ebfc6e4589115717c4a6d1dd2f195327b8d5a3e21a68f374d79dbed9", + "sha256:52bd2b6681beb34115eebbcbdcbd170ebc3fc98c4eb0dd789f2c01d4d6b189c0", + "sha256:54a291428e25f775193704f95a94f21a42a28ffb09c1bdc91e152c6b1faf4a91", + "sha256:58f74a195b99189c9f7e2bc83cc95fcf169a43a63c5c8cad63c4027bf3233118", + "sha256:614021ba98b8052d4eb3d5900d3bd953421edf41b2aa85d37c1dc67bcee1ea9d", + "sha256:64fccd2fa3cfd49c442c4995d58189e578560705b9b632faad8ffd9aaa390007", + "sha256:64fdd7a4aef8f14e4a6917a434d0a4766345f5d544d0c0c0e53b14eb1e4be0ac", + "sha256:693858c9584cedc1685e67e78fa9e50285504e8d4bbfde7290ca04dbbac939a8", + "sha256:6d168a6693c1b9b950d9584178d12095bfbaf290748eb6e2726c914bc1d0d4f1", + "sha256:6da367181104a57e77140ebf736652ed9a97c7bcb77c7640cf8a168893561bd2", + "sha256:6ed731286f0ae399e65e3172c5808732b9ae5d896b3ab7f692eb686bba6bc9df", + "sha256:70d695f62a55f90ee894fdf1ede51ccdda3abbe25b43b667b51747b6f61b8da7", + "sha256:71dae164819f8aede109a596db84d508e670d7e0a968901aaf22445e87ae7519", + "sha256:75bb804375e0b6c5db4e474fa0b5052414b6cbc3e70394d11a7ce9a7f6a18a91", + "sha256:796d1b070211554cc8193bd6764d2b44594ff7c7522989012eacf3fde778e5cf", + "sha256:79dc3f9893e32fcc564c60bb34c4e393daede2cdf0337a5b4627ed162a237fb3", + "sha256:7a3165a5bae6577d10858c35f6add83333ead621e8286a5d15f7d567ef44be78", + "sha256:7a74764881276904564f8725da3dd2b82924838a114738933f58b75082b55dd3", + "sha256:7cbc2e5116cdca0594bb39c64a8bd5e7f44d392cf76d19913216924688d42954", + "sha256:8223f74cf698f7992e1a71ab90ab4c169b508a0f25083ebab9259b9f33d7bdde", + "sha256:824b60427c92c44098cfbd58d8adf8a8c5a60ade16742dcb54385b43e6337b4e", + "sha256:8257f26cc2cc5d0426da488162060c6cea57079172b9d3eedf016fcb0cfdb830", + "sha256:8530ca574ba38478e97af20ff0f3fd04f59ffcad435b1548703424d71e2ed66a", + "sha256:858b68e475f8e73e4014c078e9feced502273032f07840117ca12d2230d27135", + "sha256:88ae724e79a524d1921b2799251f667e7fb0344a59637df3bec91dc303020467", + "sha256:8ce52f84e793ee83082c4aa127605070a47c31597821ca84dec5c0ac809e8509", + "sha256:93de2d3802a5ac7d5deadba1c956a93db29502f1b9f4e8d2e393747b9b28d881", + "sha256:93f4545347f79121e9ba98a0c33a55f469ebc22fb45ae62692e01d367219796b", + "sha256:9777e194be00313f5a86a0dd52d9987b72cf6c43c8a42d6bd838adc46c70e98b", + "sha256:99b2401166c3b2d997b80479cdc7449a093e21f3d4b2f9c6e6ceee956aa10d63", + "sha256:99f9b6596d2e126fa1777990868743fb4c1984ea5217606fabc153aff46160e6", + "sha256:9b4cd51b623b3dc8b55f9caef07424ac6d684b8047e601aca7053999e1b4a527", + "sha256:9f1edbf7e0d22a1ebf3c24ffaf0b8a39888bd630d6ff38c77c169272a3d4b9cc", + "sha256:a3da262f5b9f0dd01277575de4967683123ab47699fd7db2ce38cb1bb8f5c76f", + "sha256:aa613b270de6215f9fc850f0fb18dbc20ba297013012793cf3d2f1295e271e91", + "sha256:ac87e173c5f3aeac06d01eeebfb35c2b1bc5f536b21210dd8b032f1dc0726fbc", + "sha256:ad333e0b0d19294d3fc81d7aa9b65c45ebf49e6f8b3fab02db43284140d2b0a8", + "sha256:af55e557e722c962f70cdc6a482d0df44b1f6622af49003e33dd114340724875", + "sha256:b019f5c53471e8a010edf2fec321ece25ac6b079b535980b7228dcb9ee62d621", + "sha256:b0441ee8b9edc3fadb5cd9f181212edd72f7b016723bc549f9c1c00a9a8e6f93", + "sha256:b29a79f1e4313c397e00d89d4d83ff54fd377e7d654b640bbe9002b4272f205e", + "sha256:b622146bcfc6749944d14e8a61267dbea1bee96a9c7ca7605683506ed3817844", + "sha256:b8a87a3686de1d215506ba13dd388433695bfff534839e045419ba2f36437c0e", + "sha256:b9c5dfa5c7cdc26f6b777ac6210d3621d556e2e244f0a7358afe8ec0135f8640", + "sha256:b9d3d5de87a88768be67b7ec20aeb531707174ba0645697a938df3afc2c62b1f", + "sha256:bbd3cc064d272618b95c2f85ec61fe9d07e2a1de18c153c10923d3c2cdebff4c", + "sha256:bcd21a1b5cfb45170280e5fcd382c25519d75bdf4634656868b91c05d5e15b23", + "sha256:bdb621264758b22ae3aaa9d60937751069d80d610d713887ff94cf7487fc3f5f", + "sha256:c5fdcac25ae451af93e7f997678ed2282bf6b5ef892e253eea13bba59849f00e", + "sha256:c785581071f140d364821c210422ab5937d6c2c51d92e45a552a8e34b434a5a3", + "sha256:cbd06fb147030d7781f10bd7542f29bbf56cefb51a9f042713d5fc52e68b8afd", + "sha256:cf95ac57b44b6fb46a0151641b9905bbad27783314abc4f4b0b0a82f26b06b07", + "sha256:d6698fccb2f962021e467be6ba43fc02f7341f221e80545810303f5cc66461bb", + "sha256:d7533a9684e599b22a4beb699647dc3269d551e455886be8125f14f3c5a0869f", + "sha256:d7bf1d52c69f3051a0ebae9cca1e5be06e2ad4677d670a920454ecf6d20e2c8e", + "sha256:d8f47485264b1168ef852dd6bea619703409ff2cbc5e610dcb0f15fe3c6750bb", + "sha256:d8fc8c7c092a48044bf942735eea6da198cac0c655d7a06550619b2a7fec2ffd", + "sha256:d9e984f9542fba175bc4d98e320e9e2bd6e7480682aa84b274e9aee7fb6575b9", + "sha256:dc86a31e3215ce037ae306a338ff2156d897aae627d5d4e3dfa0c9eded4249e8", + "sha256:dd5240bea7d8de32e7ac95088b2ad95b89993a3825d9278d363d73ca40113cb3", + "sha256:df46fd268c765d186df8c7899bc4e0a2ee0d12458d356438af0329a49e6b15ca", + "sha256:dfb3870c5d4f5413988caf64243830f7ca13dc58ae2cf3eb48fe321ca6f26648", + "sha256:e36cfe9df4dfb6c2f4d80d20852ab6449257a01942e4808c3912ed413a4d40f7", + "sha256:e5ca936b70414dbee02f218be1d36a535a5953ba63fd82dc812135ca3f5a525f", + "sha256:e7ab7ea72c3f66ae1e930ae776ad2c6f4f78e0184781f64f196f17ecce113101", + "sha256:e80878904057edfd1d70ba31258f974d36c470fd95de2bcd98e0494942c4433e", + "sha256:ed8d6bd6f3c7991083e741fd55cecea70d670971c73b9563a673eab96e5356b4", + "sha256:f290e4eebf7764f8327a4bc6a459f09ca9a041cf7349bacfbb252da9feb0d37c", + "sha256:f915fc3287ddc23a5da8f61f5c2c3aaca0b754ce526c0ff81f55c27b25038cd5", + "sha256:fb8b1cba597398698ec494794091dadd76eb8011bb95f43578930466e7beb20b", + "sha256:fbd035ae06babb07c6b80535b0d4f6fe57eb73a23ae276eb4502b1f67f19e8ef", + "sha256:fd9521b70b50aac341f59799301ba24acbe2897b9157035d139668b6c43bc406" ], "markers": "python_version >= '3.9'", - "version": "==6.2.0" + "version": "==6.4.2" }, "niquests": { "hashes": [ @@ -1651,11 +1663,11 @@ }, "urllib3-future": { "hashes": [ - "sha256:3adfa22c5718caee5ca69bc7f7461dc529f4396494d4d9b1db8af7c56cd3ac34", - "sha256:9cd79ce61da77b5d56681bc126f42955c2153e9c0da2f0a62bca8e0a05641f92" + "sha256:1a31156dc1f87d13483272cd7fe381664ded124b3b5e3d65385c23a309a1584e", + "sha256:60d1c48846c7fd5dbddfae38196fd1c43ffc83fb987ba477361254b93913ccbc" ], "markers": "python_version >= '3.7'", - "version": "==2.12.915" + "version": "==2.12.916" }, "verlib2": { "hashes": [ diff --git a/dbrepo-dashboard-service/app.py b/dbrepo-dashboard-service/app.py index 21916f758242acf55e0622bbbe859f7c1c92aafb..fafca139f43f7763a3757a4a33c24c31a3456c0c 100644 --- a/dbrepo-dashboard-service/app.py +++ b/dbrepo-dashboard-service/app.py @@ -154,8 +154,9 @@ headers = {'Content-Type': 'application/json'} def dashboard_client(): - return DashboardServiceClient(os.getenv('DASHBOARD_UI_ENDPOINT', 'http://localhost:3000'), - os.getenv('SYSTEM_USERNAME', 'admin'), os.getenv('SYSTEM_PASSWORD', 'admin')) + return DashboardServiceClient(endpoint=os.getenv('DASHBOARD_UI_ENDPOINT', 'http://localhost:3000'), + username=os.getenv('SYSTEM_USERNAME', 'admin'), + password=os.getenv('SYSTEM_PASSWORD', 'admin')) def auth_client(): @@ -201,13 +202,14 @@ def create_dashboard(): is_public = bool(request.json['is_public']) is_schema_public = bool(request.json['is_schema_public']) owner_username = request.json['owner_username'] - logging.debug( - f"endpoint create dashboard, is_public={is_public}, is_schema_public={is_schema_public}, owner_username={owner_username}") + logging.debug(f"endpoint create dashboard, is_public={is_public}, is_schema_public={is_schema_public}, " + f"owner_username={owner_username}") try: db = dashboard_client().create(request.json['database_name']) dashboard_client().update_anonymous_read_access(db['uid'], is_public, is_schema_public) return Response(dumps(db)), 201, headers except GrafanaClientError as e: + logging.error(f"Failed to create dashboard: {e.response['message']}") dto = ApiError(status=HTTPStatus(e.status_code).phrase.upper(), message=f"Failed to create dashboard: {e.response['message']}", code="error.dashboard.create") if e.status_code == 409 or e.status_code == 412: diff --git a/dbrepo-dashboard-service/init/Pipfile.lock b/dbrepo-dashboard-service/init/Pipfile.lock index c6b2da7b4079bcf9759202b9925fb7c8aa31cd9e..4769507d32af65c823f66f0158ebb5ac7e855e42 100644 --- a/dbrepo-dashboard-service/init/Pipfile.lock +++ b/dbrepo-dashboard-service/init/Pipfile.lock @@ -259,7 +259,7 @@ }, "dbrepo": { "hashes": [ - "sha256:7e21d72d0b3e766aeecb286b636ea7530fa971d95b1b083b7ef8b9512b8300ef" + "sha256:22484d712e4a240a0114b90b5e8eaacbe47aa8f7fc79200557150f081faf7669" ], "path": "./lib/dbrepo-1.8.1.tar.gz" }, @@ -655,101 +655,113 @@ }, "multidict": { "hashes": [ - "sha256:0085b0afb2446e57050140240a8595846ed64d1cbd26cef936bfab3192c673b8", - "sha256:042028348dc5a1f2be6c666437042a98a5d24cee50380f4c0902215e5ec41844", - "sha256:05fefbc3cddc4e36da209a5e49f1094bbece9a581faa7f3589201fd95df40e5d", - "sha256:063be88bd684782a0715641de853e1e58a2f25b76388538bd62d974777ce9bc2", - "sha256:07bfa8bc649783e703263f783f73e27fef8cd37baaad4389816cf6a133141331", - "sha256:08549895e6a799bd551cf276f6e59820aa084f0f90665c0f03dd3a50db5d3c48", - "sha256:095a2eabe8c43041d3e6c2cb8287a257b5f1801c2d6ebd1dd877424f1e89cf29", - "sha256:0b183a959fb88ad1be201de2c4bdf52fa8e46e6c185d76201286a97b6f5ee65c", - "sha256:0c383d28857f66f5aebe3e91d6cf498da73af75fbd51cedbe1adfb85e90c0460", - "sha256:0d57a01a2a9fa00234aace434d8c131f0ac6e0ac6ef131eda5962d7e79edfb5b", - "sha256:0dc25a3293c50744796e87048de5e68996104d86d940bb24bc3ec31df281b191", - "sha256:0e5a644e50ef9fb87878d4d57907f03a12410d2aa3b93b3acdf90a741df52c49", - "sha256:0f249badb360b0b4d694307ad40f811f83df4da8cef7b68e429e4eea939e49dd", - "sha256:0f74f2fc51555f4b037ef278efc29a870d327053aba5cb7d86ae572426c7cccc", - "sha256:125dd82b40f8c06d08d87b3510beaccb88afac94e9ed4a6f6c71362dc7dbb04b", - "sha256:13551d0e2d7201f0959725a6a769b6f7b9019a168ed96006479c9ac33fe4096b", - "sha256:14ed9ed1bfedd72a877807c71113deac292bf485159a29025dfdc524c326f3e1", - "sha256:163f4604e76639f728d127293d24c3e208b445b463168af3d031b92b0998bb90", - "sha256:19e2819b0b468174de25c0ceed766606a07cedeab132383f1e83b9a4e96ccb4f", - "sha256:1e2a2193d3aa5cbf5758f6d5680a52aa848e0cf611da324f71e5e48a9695cc86", - "sha256:1f3c099d3899b14e1ce52262eb82a5f5cb92157bb5106bf627b618c090a0eadc", - "sha256:214207dcc7a6221d9942f23797fe89144128a71c03632bf713d918db99bd36de", - "sha256:2325105e16d434749e1be8022f942876a936f9bece4ec41ae244e3d7fae42aaf", - "sha256:2529ddbdaa424b2c6c2eb668ea684dd6b75b839d0ad4b21aad60c168269478d7", - "sha256:256d431fe4583c5f1e0f2e9c4d9c22f3a04ae96009b8cfa096da3a8723db0a16", - "sha256:25bb96338512e2f46f615a2bb7c6012fe92a4a5ebd353e5020836a7e33120349", - "sha256:2e87f1926e91855ae61769ba3e3f7315120788c099677e0842e697b0bfb659f2", - "sha256:2fc6af8e39f7496047c7876314f4317736eac82bf85b54c7c76cf1a6f8e35d98", - "sha256:3157126b028c074951839233647bd0e30df77ef1fedd801b48bdcad242a60f4e", - "sha256:32c9b4878f48be3e75808ea7e499d6223b1eea6d54c487a66bc10a1871e3dc6a", - "sha256:32ed748ff9ac682eae7859790d3044b50e3076c7d80e17a44239683769ff485e", - "sha256:3501621d5e86f1a88521ea65d5cad0a0834c77b26f193747615b7c911e5422d2", - "sha256:437c33561edb6eb504b5a30203daf81d4a9b727e167e78b0854d9a4e18e8950b", - "sha256:48d39b1824b8d6ea7de878ef6226efbe0773f9c64333e1125e0efcfdd18a24c7", - "sha256:4ac3fcf9a2d369bd075b2c2965544036a27ccd277fc3c04f708338cc57533081", - "sha256:4ccfd74957ef53fa7380aaa1c961f523d582cd5e85a620880ffabd407f8202c0", - "sha256:52b05e21ff05729fbea9bc20b3a791c3c11da61649ff64cce8257c82a020466d", - "sha256:5389445f0173c197f4a3613713b5fb3f3879df1ded2a1a2e4bc4b5b9c5441b7e", - "sha256:5c5e7d2e300d5cb3b2693b6d60d3e8c8e7dd4ebe27cd17c9cb57020cac0acb80", - "sha256:5d26547423e5e71dcc562c4acdc134b900640a39abd9066d7326a7cc2324c530", - "sha256:5dd7106d064d05896ce28c97da3f46caa442fe5a43bc26dfb258e90853b39b44", - "sha256:5f8cb1329f42fadfb40d6211e5ff568d71ab49be36e759345f91c69d1033d633", - "sha256:61d5541f27533f803a941d3a3f8a3d10ed48c12cf918f557efcbf3cd04ef265c", - "sha256:639556758c36093b35e2e368ca485dada6afc2bd6a1b1207d85ea6dfc3deab27", - "sha256:641cf2e3447c9ecff2f7aa6e9eee9eaa286ea65d57b014543a4911ff2799d08a", - "sha256:6aed763b6a1b28c46c055692836879328f0b334a6d61572ee4113a5d0c859872", - "sha256:6e2a2d6749e1ff2c9c76a72c6530d5baa601205b14e441e6d98011000f47a7ac", - "sha256:7243c5a6523c5cfeca76e063efa5f6a656d1d74c8b1fc64b2cd1e84e507f7e2a", - "sha256:76b34c12b013d813e6cb325e6bd4f9c984db27758b16085926bbe7ceeaace626", - "sha256:781b5dd1db18c9e9eacc419027b0acb5073bdec9de1675c0be25ceb10e2ad133", - "sha256:7c611345bbe7cb44aabb877cb94b63e86f2d0db03e382667dbd037866d44b4f8", - "sha256:83b78c680d4b15d33042d330c2fa31813ca3974197bddb3836a5c635a5fd013f", - "sha256:84e87a7d75fa36839a3a432286d719975362d230c70ebfa0948549cc38bd5b46", - "sha256:89b3857652183b8206a891168af47bac10b970d275bba1f6ee46565a758c078d", - "sha256:8cd1a0644ccaf27e9d2f6d9c9474faabee21f0578fe85225cc5af9a61e1653df", - "sha256:8de4d42dffd5ced9117af2ce66ba8722402541a3aa98ffdf78dde92badb68932", - "sha256:94a7bb972178a8bfc4055db80c51efd24baefaced5e51c59b0d598a004e8305d", - "sha256:98aa8325c7f47183b45588af9c434533196e241be0a4e4ae2190b06d17675c02", - "sha256:9e658d1373c424457ddf6d55ec1db93c280b8579276bebd1f72f113072df8a5d", - "sha256:9f49585f4abadd2283034fc605961f40c638635bc60f5162276fec075f2e37a4", - "sha256:9f6cad071960ba1914fa231677d21b1b4a3acdcce463cee41ea30bc82e6040cf", - "sha256:a0cc398350ef31167e03f3ca7c19313d4e40a662adcb98a88755e4e861170bdd", - "sha256:a1133414b771619aa3c3000701c11b2e4624a7f492f12f256aedde97c28331a2", - "sha256:a33273a541f1e1a8219b2a4ed2de355848ecc0254264915b9290c8d2de1c74e1", - "sha256:a3c0ff89fe40a152e77b191b83282c9664357dce3004032d42e68c514ceff27e", - "sha256:a49994481b99cd7dedde07f2e7e93b1d86c01c0fca1c32aded18f10695ae17eb", - "sha256:abf5b17bc0cf626a8a497d89ac691308dbd825d2ac372aa990b1ca114e470151", - "sha256:ac380cacdd3b183338ba63a144a34e9044520a6fb30c58aa14077157a033c13e", - "sha256:ad81012b24b88aad4c70b2cbc2dad84018783221b7f923e926f4690ff8569da3", - "sha256:b2c00ad31fbc2cbac85d7d0fcf90853b2ca2e69d825a2d3f3edb842ef1544a2c", - "sha256:b4c153863dd6569f6511845922c53e39c8d61f6e81f228ad5443e690fca403de", - "sha256:b4f3d66dd0354b79761481fc15bdafaba0b9d9076f1f42cc9ce10d7fcbda205a", - "sha256:b99aac6bb2c37db336fa03a39b40ed4ef2818bf2dfb9441458165ebe88b793af", - "sha256:b9f6392d98c0bd70676ae41474e2eecf4c7150cb419237a41f8f96043fcb81d1", - "sha256:c537da54ce4ff7c15e78ab1292e5799d0d43a2108e006578a57f531866f64025", - "sha256:ca23db5fb195b5ef4fd1f77ce26cadefdf13dba71dab14dadd29b34d457d7c44", - "sha256:cc826b9a8176e686b67aa60fd6c6a7047b0461cae5591ea1dc73d28f72332a8a", - "sha256:cca83a629f77402cfadd58352e394d79a61c8015f1694b83ab72237ec3941f88", - "sha256:cf8d370b2fea27fb300825ec3984334f7dd54a581bde6456799ba3776915a656", - "sha256:d1175b0e0d6037fab207f05774a176d71210ebd40b1c51f480a04b65ec5c786d", - "sha256:d1996ee1330e245cd3aeda0887b4409e3930524c27642b046e4fae88ffa66c5e", - "sha256:d5a36953389f35f0a4e88dc796048829a2f467c9197265504593f0e420571547", - "sha256:da51d8928ad8b4244926fe862ba1795f0b6e68ed8c42cd2f822d435db9c2a8f4", - "sha256:e16e7297f29a544f49340012d6fc08cf14de0ab361c9eb7529f6a57a30cbfda1", - "sha256:e25b11a0417475f093d0f0809a149aff3943c2c56da50fdf2c3c88d57fe3dfbd", - "sha256:e4371591e621579cb6da8401e4ea405b33ff25a755874a3567c4075ca63d56e2", - "sha256:e653d36b1bf48fa78c7fcebb5fa679342e025121ace8c87ab05c1cefd33b34fc", - "sha256:e7d91a230c7f8af86c904a5a992b8c064b66330544693fd6759c3d6162382ecf", - "sha256:e851e6363d0dbe515d8de81fd544a2c956fdec6f8a049739562286727d4a00c3", - "sha256:ef7d48207926edbf8b16b336f779c557dd8f5a33035a85db9c4b0febb0706817", - "sha256:f7716f7e7138252d88607228ce40be22660d6608d20fd365d596e7ca0738e019", - "sha256:facaf11f21f3a4c51b62931feb13310e6fe3475f85e20d9c9fdce0d2ea561b87" + "sha256:033edcc22211463be927ca407dc5c5f3aa84d3d093ed2d559a2e3c2d995d50e4", + "sha256:03cd2a3c446162678d0a6d14d69ad38204128414ba40722a5ff6f2107782b723", + "sha256:05dcc73739ae8096f64f08282c8980dab2cf9acb02eb838aacd8ac56b795c405", + "sha256:11d76b83dc93e98207514e1938b89854655087e3b27a09d89525fe17a0f1ce11", + "sha256:1247de19497e13063eabf1df67e87530ac31497b91e9bd08621852a57d9b5ee7", + "sha256:147c962e8ae339d5fa84c52cc1e59546cb2d0d9359f9a8e1b8eb7b5ffac8dba0", + "sha256:159dae860e4d34bd4f48e72a0c033d78ae9215b43d423c19cbf47b7db5972599", + "sha256:15c14a01dd95e860703a4ce78d4b0d49f18c14389eb91b4aa12444e31dfc2841", + "sha256:15ddde4242134f1aeb1455ad60cc529e0a9f5eb251ae7be7fc37debdb257182c", + "sha256:1a894aed57c6edc514c9222989cf09eebd9ea7acb6185a26cfeac2ece2ddf265", + "sha256:1c11e8460ff0629871f9703c87208e553fbfa6c9d92f94c20d4f86e56f021029", + "sha256:1cd34caed981a95964218e03a3f267537a0b1a2fae078949e880f757df9efe55", + "sha256:1f62882c6d06e5e75b82444ce14f59b830f5b017b31630cc13d8b0b01379385a", + "sha256:20050a17cc2f322598d181a5b2e2cf4787e4c2e3bf71aab5e96618b40665e8ae", + "sha256:205da0f812c9128155bc1b7be69cf89280a5bb2f5b84426bced76e7d860ed5dc", + "sha256:258414850b59fb820bd1e1e19a9b281409a6d0bd969d3fe7104cc87a7c08c191", + "sha256:27d45a6a8495f2cfcf64d6cc4fbcc78a6e87ed840e54a261430d0d4331d9aae0", + "sha256:285058a0cdd284ba5bbc1d10d75fb33e3b3087b15d5aa9d23fc4787dd3a48384", + "sha256:2e116fad10aa7c74aa3acc69adcdffe86f1415abb111653f85dd37171116b57d", + "sha256:38e165c4d79ac98cabb5c08d8a3a3e1dda3206bcec19ed072992b62b200b180d", + "sha256:3af088483bf2aba7f2886437d856a6ba4cd0c17946dd615cbe55d56552eaf187", + "sha256:3d17d8b2d4643d4f59629758b0dd229cda61e2319f81b470aa4a99717081ba0c", + "sha256:3e80621ebc9f045fab847a970b2430146f9121b95c3c695b044ade8488753126", + "sha256:4030f5319aacf20e924c5218377df446507b314f03676549891e12a9f832a9f1", + "sha256:44ee27fb416c3d8981b7c3c97b9813d40b06575f6d477f4da21726a30aabb562", + "sha256:458b235ae7af880e18c1476f968ef571689a574720eb9e6e8873d138fbba9c58", + "sha256:4660b75286c11b8f38c90b98ccf7541b7030dbec32b28f05031f8abebf7fc0e5", + "sha256:4748c017fa201e6a296c9ef75dc3668a01532adb8f5c27a0bef4835dfa62f8e7", + "sha256:48f775443154d99e1b1c727ea20137ddc1e4b29448a9b24875b2a348cc143b85", + "sha256:49e01d212be64ceee18a45e8baef441aa86cc9bd365fb92fb8b214e5fa5bc08b", + "sha256:4a0ba21b315113d39f7aa3ca4eb804f7984dab33c42ea14d07d790a640f81e77", + "sha256:4aca2ab0969dc3781fefe523ce70c5d245b915ba0708ce2713e8ac561f9448e0", + "sha256:5055e039ebfc6e4589115717c4a6d1dd2f195327b8d5a3e21a68f374d79dbed9", + "sha256:52bd2b6681beb34115eebbcbdcbd170ebc3fc98c4eb0dd789f2c01d4d6b189c0", + "sha256:54a291428e25f775193704f95a94f21a42a28ffb09c1bdc91e152c6b1faf4a91", + "sha256:58f74a195b99189c9f7e2bc83cc95fcf169a43a63c5c8cad63c4027bf3233118", + "sha256:614021ba98b8052d4eb3d5900d3bd953421edf41b2aa85d37c1dc67bcee1ea9d", + "sha256:64fccd2fa3cfd49c442c4995d58189e578560705b9b632faad8ffd9aaa390007", + "sha256:64fdd7a4aef8f14e4a6917a434d0a4766345f5d544d0c0c0e53b14eb1e4be0ac", + "sha256:693858c9584cedc1685e67e78fa9e50285504e8d4bbfde7290ca04dbbac939a8", + "sha256:6d168a6693c1b9b950d9584178d12095bfbaf290748eb6e2726c914bc1d0d4f1", + "sha256:6da367181104a57e77140ebf736652ed9a97c7bcb77c7640cf8a168893561bd2", + "sha256:6ed731286f0ae399e65e3172c5808732b9ae5d896b3ab7f692eb686bba6bc9df", + "sha256:70d695f62a55f90ee894fdf1ede51ccdda3abbe25b43b667b51747b6f61b8da7", + "sha256:71dae164819f8aede109a596db84d508e670d7e0a968901aaf22445e87ae7519", + "sha256:75bb804375e0b6c5db4e474fa0b5052414b6cbc3e70394d11a7ce9a7f6a18a91", + "sha256:796d1b070211554cc8193bd6764d2b44594ff7c7522989012eacf3fde778e5cf", + "sha256:79dc3f9893e32fcc564c60bb34c4e393daede2cdf0337a5b4627ed162a237fb3", + "sha256:7a3165a5bae6577d10858c35f6add83333ead621e8286a5d15f7d567ef44be78", + "sha256:7a74764881276904564f8725da3dd2b82924838a114738933f58b75082b55dd3", + "sha256:7cbc2e5116cdca0594bb39c64a8bd5e7f44d392cf76d19913216924688d42954", + "sha256:8223f74cf698f7992e1a71ab90ab4c169b508a0f25083ebab9259b9f33d7bdde", + "sha256:824b60427c92c44098cfbd58d8adf8a8c5a60ade16742dcb54385b43e6337b4e", + "sha256:8257f26cc2cc5d0426da488162060c6cea57079172b9d3eedf016fcb0cfdb830", + "sha256:8530ca574ba38478e97af20ff0f3fd04f59ffcad435b1548703424d71e2ed66a", + "sha256:858b68e475f8e73e4014c078e9feced502273032f07840117ca12d2230d27135", + "sha256:88ae724e79a524d1921b2799251f667e7fb0344a59637df3bec91dc303020467", + "sha256:8ce52f84e793ee83082c4aa127605070a47c31597821ca84dec5c0ac809e8509", + "sha256:93de2d3802a5ac7d5deadba1c956a93db29502f1b9f4e8d2e393747b9b28d881", + "sha256:93f4545347f79121e9ba98a0c33a55f469ebc22fb45ae62692e01d367219796b", + "sha256:9777e194be00313f5a86a0dd52d9987b72cf6c43c8a42d6bd838adc46c70e98b", + "sha256:99b2401166c3b2d997b80479cdc7449a093e21f3d4b2f9c6e6ceee956aa10d63", + "sha256:99f9b6596d2e126fa1777990868743fb4c1984ea5217606fabc153aff46160e6", + "sha256:9b4cd51b623b3dc8b55f9caef07424ac6d684b8047e601aca7053999e1b4a527", + "sha256:9f1edbf7e0d22a1ebf3c24ffaf0b8a39888bd630d6ff38c77c169272a3d4b9cc", + "sha256:a3da262f5b9f0dd01277575de4967683123ab47699fd7db2ce38cb1bb8f5c76f", + "sha256:aa613b270de6215f9fc850f0fb18dbc20ba297013012793cf3d2f1295e271e91", + "sha256:ac87e173c5f3aeac06d01eeebfb35c2b1bc5f536b21210dd8b032f1dc0726fbc", + "sha256:ad333e0b0d19294d3fc81d7aa9b65c45ebf49e6f8b3fab02db43284140d2b0a8", + "sha256:af55e557e722c962f70cdc6a482d0df44b1f6622af49003e33dd114340724875", + "sha256:b019f5c53471e8a010edf2fec321ece25ac6b079b535980b7228dcb9ee62d621", + "sha256:b0441ee8b9edc3fadb5cd9f181212edd72f7b016723bc549f9c1c00a9a8e6f93", + "sha256:b29a79f1e4313c397e00d89d4d83ff54fd377e7d654b640bbe9002b4272f205e", + "sha256:b622146bcfc6749944d14e8a61267dbea1bee96a9c7ca7605683506ed3817844", + "sha256:b8a87a3686de1d215506ba13dd388433695bfff534839e045419ba2f36437c0e", + "sha256:b9c5dfa5c7cdc26f6b777ac6210d3621d556e2e244f0a7358afe8ec0135f8640", + "sha256:b9d3d5de87a88768be67b7ec20aeb531707174ba0645697a938df3afc2c62b1f", + "sha256:bbd3cc064d272618b95c2f85ec61fe9d07e2a1de18c153c10923d3c2cdebff4c", + "sha256:bcd21a1b5cfb45170280e5fcd382c25519d75bdf4634656868b91c05d5e15b23", + "sha256:bdb621264758b22ae3aaa9d60937751069d80d610d713887ff94cf7487fc3f5f", + "sha256:c5fdcac25ae451af93e7f997678ed2282bf6b5ef892e253eea13bba59849f00e", + "sha256:c785581071f140d364821c210422ab5937d6c2c51d92e45a552a8e34b434a5a3", + "sha256:cbd06fb147030d7781f10bd7542f29bbf56cefb51a9f042713d5fc52e68b8afd", + "sha256:cf95ac57b44b6fb46a0151641b9905bbad27783314abc4f4b0b0a82f26b06b07", + "sha256:d6698fccb2f962021e467be6ba43fc02f7341f221e80545810303f5cc66461bb", + "sha256:d7533a9684e599b22a4beb699647dc3269d551e455886be8125f14f3c5a0869f", + "sha256:d7bf1d52c69f3051a0ebae9cca1e5be06e2ad4677d670a920454ecf6d20e2c8e", + "sha256:d8f47485264b1168ef852dd6bea619703409ff2cbc5e610dcb0f15fe3c6750bb", + "sha256:d8fc8c7c092a48044bf942735eea6da198cac0c655d7a06550619b2a7fec2ffd", + "sha256:d9e984f9542fba175bc4d98e320e9e2bd6e7480682aa84b274e9aee7fb6575b9", + "sha256:dc86a31e3215ce037ae306a338ff2156d897aae627d5d4e3dfa0c9eded4249e8", + "sha256:dd5240bea7d8de32e7ac95088b2ad95b89993a3825d9278d363d73ca40113cb3", + "sha256:df46fd268c765d186df8c7899bc4e0a2ee0d12458d356438af0329a49e6b15ca", + "sha256:dfb3870c5d4f5413988caf64243830f7ca13dc58ae2cf3eb48fe321ca6f26648", + "sha256:e36cfe9df4dfb6c2f4d80d20852ab6449257a01942e4808c3912ed413a4d40f7", + "sha256:e5ca936b70414dbee02f218be1d36a535a5953ba63fd82dc812135ca3f5a525f", + "sha256:e7ab7ea72c3f66ae1e930ae776ad2c6f4f78e0184781f64f196f17ecce113101", + "sha256:e80878904057edfd1d70ba31258f974d36c470fd95de2bcd98e0494942c4433e", + "sha256:ed8d6bd6f3c7991083e741fd55cecea70d670971c73b9563a673eab96e5356b4", + "sha256:f290e4eebf7764f8327a4bc6a459f09ca9a041cf7349bacfbb252da9feb0d37c", + "sha256:f915fc3287ddc23a5da8f61f5c2c3aaca0b754ce526c0ff81f55c27b25038cd5", + "sha256:fb8b1cba597398698ec494794091dadd76eb8011bb95f43578930466e7beb20b", + "sha256:fbd035ae06babb07c6b80535b0d4f6fe57eb73a23ae276eb4502b1f67f19e8ef", + "sha256:fd9521b70b50aac341f59799301ba24acbe2897b9157035d139668b6c43bc406" ], "markers": "python_version >= '3.9'", - "version": "==6.2.0" + "version": "==6.4.2" }, "niquests": { "hashes": [ @@ -1521,11 +1533,11 @@ }, "urllib3-future": { "hashes": [ - "sha256:3adfa22c5718caee5ca69bc7f7461dc529f4396494d4d9b1db8af7c56cd3ac34", - "sha256:9cd79ce61da77b5d56681bc126f42955c2153e9c0da2f0a62bca8e0a05641f92" + "sha256:1a31156dc1f87d13483272cd7fe381664ded124b3b5e3d65385c23a309a1584e", + "sha256:60d1c48846c7fd5dbddfae38196fd1c43ffc83fb987ba477361254b93913ccbc" ], "markers": "python_version >= '3.7'", - "version": "==2.12.915" + "version": "==2.12.916" }, "verlib2": { "hashes": [ @@ -2240,11 +2252,11 @@ }, "urllib3-future": { "hashes": [ - "sha256:3adfa22c5718caee5ca69bc7f7461dc529f4396494d4d9b1db8af7c56cd3ac34", - "sha256:9cd79ce61da77b5d56681bc126f42955c2153e9c0da2f0a62bca8e0a05641f92" + "sha256:1a31156dc1f87d13483272cd7fe381664ded124b3b5e3d65385c23a309a1584e", + "sha256:60d1c48846c7fd5dbddfae38196fd1c43ffc83fb987ba477361254b93913ccbc" ], "markers": "python_version >= '3.7'", - "version": "==2.12.915" + "version": "==2.12.916" }, "verlib2": { "hashes": [ diff --git a/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1-py3-none-any.whl b/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1-py3-none-any.whl index f77eea076ca6a24674d220d3f54624b5f9a09202..261fa7958ae481d4d85bc5efc152e519fa6af802 100644 Binary files a/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1-py3-none-any.whl and b/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1-py3-none-any.whl differ diff --git a/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1.tar.gz b/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1.tar.gz index 7065ba14b7eadea39293894488821e3f38e0ef35..0da3ea37a31f2f3cdeea212e768aab7793f29252 100644 Binary files a/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1.tar.gz and b/dbrepo-dashboard-service/init/lib/dbrepo-1.8.1.tar.gz differ diff --git a/dbrepo-dashboard-service/lib/dbrepo-1.8.1-py3-none-any.whl b/dbrepo-dashboard-service/lib/dbrepo-1.8.1-py3-none-any.whl index f77eea076ca6a24674d220d3f54624b5f9a09202..261fa7958ae481d4d85bc5efc152e519fa6af802 100644 Binary files a/dbrepo-dashboard-service/lib/dbrepo-1.8.1-py3-none-any.whl and b/dbrepo-dashboard-service/lib/dbrepo-1.8.1-py3-none-any.whl differ diff --git a/dbrepo-dashboard-service/lib/dbrepo-1.8.1.tar.gz b/dbrepo-dashboard-service/lib/dbrepo-1.8.1.tar.gz index 7065ba14b7eadea39293894488821e3f38e0ef35..0da3ea37a31f2f3cdeea212e768aab7793f29252 100644 Binary files a/dbrepo-dashboard-service/lib/dbrepo-1.8.1.tar.gz and b/dbrepo-dashboard-service/lib/dbrepo-1.8.1.tar.gz differ diff --git a/dbrepo-dashboard-service/tests/test_integration_app.py b/dbrepo-dashboard-service/tests/test_integration_app.py index 768fd6a1ec8d1c7b70a6e7ad98d4ab7ced68532b..c345e00dee1fdc88f5a4bc9d6277d7cef430b36f 100644 --- a/dbrepo-dashboard-service/tests/test_integration_app.py +++ b/dbrepo-dashboard-service/tests/test_integration_app.py @@ -68,7 +68,7 @@ class AppIntegrationTest(unittest.TestCase): 'roles': roles } } - with open('../tests/rsa/rs256.key', 'rb') as fh: + with open('./tests/rsa/rs256.key', 'rb') as fh: return jwt.JWT().encode(claims, jwt.jwk_from_pem(fh.read()), alg='RS256') def dashboard_client(self): @@ -214,9 +214,14 @@ class AppIntegrationTest(unittest.TestCase): self.assertEqual('link', dashboard['links'][0]['type']) self.assertEqual('info', dashboard['links'][0]['icon']) self.assertEqual(f'http://localhost/database/{req.id}', dashboard['links'][0]['url']) - self.assertEqual(1, len(dashboard['panels'])) - self.assertEqual('row', dashboard['panels'][0]['type']) - self.assertEqual('Generated Statistics', dashboard['panels'][0]['title']) + self.assertEqual(2, len(dashboard['panels'])) + panel0 = dashboard['panels'][0] + self.assertEqual('row', panel0['type']) + self.assertEqual('Generated Dashboard', panel0['title']) + panel1 = dashboard['panels'][1] + self.assertEqual('stat', panel1['type']) + self.assertEqual('Datasources', panel1['title']) + self.assertEqual('Auto-generated', panel1['description']) def test_update_dashboard_unmanaged_succeeds(self): req = Database(id="209acf92-5c9b-4633-ad99-113c86f6e948", diff --git a/dbrepo-dashboard-ui/Dockerfile b/dbrepo-dashboard-ui/Dockerfile index 099089718df942f95abe604db148fab6364c3915..daf9ef46dd808a99eb6bb776945f014cdf6f9c8f 100644 --- a/dbrepo-dashboard-ui/Dockerfile +++ b/dbrepo-dashboard-ui/Dockerfile @@ -1,9 +1,7 @@ -FROM docker.io/bitnami/grafana:11 AS runtime +FROM docker.io/bitnami/grafana:11.5.3 AS runtime LABEL org.opencontainers.image.authors="martin.weise@tuwien.ac.at" -WORKDIR /app - -COPY --chown=grafana:grafana ./grafana.ini /opt/bitnami/grafana/conf/grafana.ini -COPY --chown=grafana:grafana ./ldap.toml /opt/bitnami/grafana/conf/ldap.toml +COPY --chown=grafana:grafana ./grafana.ini ./conf/grafana.ini +COPY --chown=grafana:grafana ./ldap.toml ./conf/ldap.toml COPY --chown=grafana:grafana ./dashboards /app/dashboards -COPY --chown=grafana:grafana ./provisioning /opt/bitnami/grafana/conf/ +COPY --chown=grafana:grafana ./provisioning ./conf/provisioning diff --git a/dbrepo-dashboard-ui/grafana.ini b/dbrepo-dashboard-ui/grafana.ini index 81fcee0a36f3b33df460e3903dfc4077b5fb86df..f0d0539a1ec2644c9d6caa1adb9ef437a7dd0431 100644 --- a/dbrepo-dashboard-ui/grafana.ini +++ b/dbrepo-dashboard-ui/grafana.ini @@ -1,9 +1,15 @@ +# order of config evaluation is grafana.ini < defaults.ini + [security] disable_initial_admin_creation = true [auth.ldap] enabled = true -config_file = /etc/grafana/ldap.toml +config_file = /opt/bitnami/grafana/conf/ldap.toml + +[live] +max_connections = 100 +allowed_origins = [auth.anonymous] enabled = true @@ -12,7 +18,7 @@ hide_version = true [dashboards] enabled = true -path = /app/dashboards +path = /opt/bitnami/grafana/conf/dashboards -#[log] -#filters = ldap:trace \ No newline at end of file +[log] +mode = console file diff --git a/dbrepo-data-service/pom.xml b/dbrepo-data-service/pom.xml index 548854d01b827a89cd4b5e6848875ddc82252ead..6f67e74b7043a9df43bd38d0a5a2bbd3cd4e1050 100644 --- a/dbrepo-data-service/pom.xml +++ b/dbrepo-data-service/pom.xml @@ -44,7 +44,7 @@ <rabbitmq.version>5.20.0</rabbitmq.version> <jackson-datatype.version>2.15.0</jackson-datatype.version> <commons-io.version>2.17.0</commons-io.version> - <commons-validator.version>1.8.1</commons-validator.version> + <commons-validator.version>1.8.0</commons-validator.version> <jacoco.version>0.8.12</jacoco.version> <jwt.version>4.3.0</jwt.version> <opencsv.version>5.7.1</opencsv.version> diff --git a/dbrepo-data-service/rest-service/src/main/resources/application.yml b/dbrepo-data-service/rest-service/src/main/resources/application.yml index 22524f6290514e8c483fffb165eef62ed04b6794..41d23f4c7f6cdf97c8c6ebef2becd2f6d82cce8b 100644 --- a/dbrepo-data-service/rest-service/src/main/resources/application.yml +++ b/dbrepo-data-service/rest-service/src/main/resources/application.yml @@ -64,8 +64,6 @@ dbrepo: accessKeyId: "${S3_ACCESS_KEY_ID:seaweedfsadmin}" secretAccessKey: "${S3_SECRET_ACCESS_KEY:seaweedfsadmin}" bucket: "${S3_BUCKET:dbrepo}" - maxAge: "${S3_MAX_AGE:86400}" - cron: "${S3_STALE_CRON:0 */60 * * * *}" system: username: "${SYSTEM_USERNAME:admin}" password: "${SYSTEM_PASSWORD:admin}" diff --git a/dbrepo-data-service/rest-service/src/test/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageServiceIntegrationTest.java b/dbrepo-data-service/rest-service/src/test/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageServiceIntegrationTest.java index 7dec246c26e7a61e11eccfa785b3aa22b833d89e..1ebd52e3b8fae44aaf84b21a1d4d576001431181 100644 --- a/dbrepo-data-service/rest-service/src/test/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageServiceIntegrationTest.java +++ b/dbrepo-data-service/rest-service/src/test/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageServiceIntegrationTest.java @@ -1,12 +1,12 @@ package at.ac.tuwien.ac.at.ifs.dbrepo.service; +import at.ac.tuwien.ac.at.ifs.dbrepo.config.S3Config; import at.ac.tuwien.ifs.dbrepo.core.api.ExportResourceDto; import at.ac.tuwien.ifs.dbrepo.core.exception.MalformedException; import at.ac.tuwien.ifs.dbrepo.core.exception.StorageNotFoundException; import at.ac.tuwien.ifs.dbrepo.core.exception.StorageUnavailableException; import at.ac.tuwien.ifs.dbrepo.core.exception.TableMalformedException; import at.ac.tuwien.ifs.dbrepo.core.test.BaseTest; -import at.ac.tuwien.ac.at.ifs.dbrepo.config.S3Config; import lombok.extern.log4j.Log4j2; import org.apache.commons.io.FileUtils; import org.apache.spark.sql.Dataset; @@ -28,10 +28,11 @@ import org.springframework.test.context.junit.jupiter.SpringExtension; import org.testcontainers.containers.MinIOContainer; import org.testcontainers.junit.jupiter.Container; import org.testcontainers.junit.jupiter.Testcontainers; +import software.amazon.awssdk.core.ResponseInputStream; import software.amazon.awssdk.core.sync.RequestBody; import software.amazon.awssdk.services.s3.S3Client; import software.amazon.awssdk.services.s3.model.CreateBucketRequest; -import software.amazon.awssdk.services.s3.model.ListObjectsRequest; +import software.amazon.awssdk.services.s3.model.GetObjectResponse; import software.amazon.awssdk.services.s3.model.PutObjectRequest; import java.io.*; @@ -233,35 +234,6 @@ public class StorageServiceIntegrationTest extends BaseTest { assertEquals("", lines.get(0)); } - @Test - public void deleteStaleObjects_none_succeeds() { - - /* mock */ - s3Client.putObject(PutObjectRequest.builder() - .key("s3key") - .bucket(s3Config.getS3Bucket()) - .build(), RequestBody.fromFile(new File("src/test/resources/csv/weather_aus.csv"))); - - /* test */ - storageService.deleteStaleObjects(); - assertEquals(1, s3Client.listObjects(ListObjectsRequest.builder().bucket(s3Config.getS3Bucket()).build()).contents().size()); - } - - @Test - public void deleteStaleObjects_succeeds() throws InterruptedException { - - /* mock */ - s3Client.putObject(PutObjectRequest.builder() - .key("s3key") - .bucket(s3Config.getS3Bucket()) - .build(), RequestBody.fromFile(new File("src/test/resources/csv/weather_aus.csv"))); - - /* test */ - Thread.sleep(4000); - storageService.deleteStaleObjects(); - assertEquals(0, s3Client.listObjects(ListObjectsRequest.builder().bucket(s3Config.getS3Bucket()).build()).contents().size()); - } - @ParameterizedTest @Disabled("cannot fix") @MethodSource("loadDataset_arguments") diff --git a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/config/S3Config.java b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/config/S3Config.java index b8d8a3732fb071054d9a792554338c89a3afb22c..c9f8a5d49bc9efcf38b2314a50c4b0540f083d47 100644 --- a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/config/S3Config.java +++ b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/config/S3Config.java @@ -30,9 +30,6 @@ public class S3Config { @Value("${dbrepo.s3.bucket}") private String s3Bucket; - @Value("${dbrepo.s3.maxAge}") - private Integer maxAge; - @Bean public S3Client s3client() { final AwsCredentialsProvider credentialsProvider = StaticCredentialsProvider.create( diff --git a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageService.java b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageService.java index 73c2d89980a911e7364ce74489c33fc593c2cbbf..88a3fd4d2901e642ab7674988f3f776d687a30b1 100644 --- a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageService.java +++ b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/StorageService.java @@ -49,8 +49,6 @@ public interface StorageService { void deleteObject(String bucket, String key); - void deleteStaleObjects(); - /** * Loads an object of the default export bucket from the Storage Service into an export resource. * diff --git a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/impl/StorageServiceS3Impl.java b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/impl/StorageServiceS3Impl.java index 5e2d0e10a38f0565680c753dba3f255c5c04dc52..94cf2b43db8ae6ec3d13da1edaa2eec8bbebbbc8 100644 --- a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/impl/StorageServiceS3Impl.java +++ b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/service/impl/StorageServiceS3Impl.java @@ -1,14 +1,15 @@ package at.ac.tuwien.ac.at.ifs.dbrepo.service.impl; +import at.ac.tuwien.ac.at.ifs.dbrepo.config.S3Config; +import at.ac.tuwien.ac.at.ifs.dbrepo.service.StorageService; import at.ac.tuwien.ifs.dbrepo.core.api.ExportResourceDto; import at.ac.tuwien.ifs.dbrepo.core.exception.MalformedException; import at.ac.tuwien.ifs.dbrepo.core.exception.StorageNotFoundException; import at.ac.tuwien.ifs.dbrepo.core.exception.StorageUnavailableException; import at.ac.tuwien.ifs.dbrepo.core.exception.TableMalformedException; -import at.ac.tuwien.ac.at.ifs.dbrepo.config.S3Config; -import at.ac.tuwien.ac.at.ifs.dbrepo.service.StorageService; import lombok.extern.log4j.Log4j2; import org.apache.commons.lang3.RandomStringUtils; +import org.apache.james.mime4j.dom.datetime.DateTime; import org.apache.spark.sql.*; import org.apache.spark.sql.catalyst.ExtendedAnalysisException; import org.apache.spark.sql.types.StructField; @@ -99,21 +100,6 @@ public class StorageServiceS3Impl implements StorageService { .build()); } - @Override - public void deleteStaleObjects() { - log.trace("list stale objects in bucket: {}", s3Config.getS3Bucket()); - final List<String> keys = s3Client.listObjects(ListObjectsRequest.builder() - .bucket(s3Config.getS3Bucket()) - .build()) - .contents() - .stream() - .filter(o -> o.lastModified().isBefore(Instant.now().minus(s3Config.getMaxAge(), ChronoUnit.SECONDS))) - .map(S3Object::key) - .toList(); - keys.forEach(key -> deleteObject(s3Config.getS3Bucket(), key)); - log.info("Deleted {} stale object(s) in bucket: {}", keys.size(), s3Config.getS3Bucket()); - } - @Override public ExportResourceDto getResource(String key) throws StorageNotFoundException, StorageUnavailableException { return getResource(s3Config.getS3Bucket(), key); diff --git a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/timer/StaleObjectTimer.java b/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/timer/StaleObjectTimer.java deleted file mode 100644 index 2d1ca62b6a9cc7c5c181aed69c80bf421fc63b27..0000000000000000000000000000000000000000 --- a/dbrepo-data-service/services/src/main/java/at/ac/tuwien/ac/at/ifs/dbrepo/timer/StaleObjectTimer.java +++ /dev/null @@ -1,25 +0,0 @@ -package at.ac.tuwien.ac.at.ifs.dbrepo.timer; - -import at.ac.tuwien.ac.at.ifs.dbrepo.service.StorageService; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.scheduling.annotation.Scheduled; -import org.springframework.stereotype.Component; - -@Log4j2 -@Component -public class StaleObjectTimer { - - private final StorageService storageService; - - @Autowired - public StaleObjectTimer(StorageService storageService) { - this.storageService = storageService; - } - - @Scheduled(cron = "${dbrepo.s3.cron}") - public void deleteStaleObjects() { - storageService.deleteStaleObjects(); - } - -} diff --git a/dbrepo-gateway-service/dbrepo.conf b/dbrepo-gateway-service/dbrepo.conf index d77507fa09f053e4c5ca0221258e0a53b4a01178..0ee5bfdfb5fb5c8950e61fff324abc4044a5bc1d 100644 --- a/dbrepo-gateway-service/dbrepo.conf +++ b/dbrepo-gateway-service/dbrepo.conf @@ -17,6 +17,7 @@ server { server_name _; location /dashboard/ { + proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Host $host; @@ -26,7 +27,9 @@ server { } # Proxy Grafana Live WebSocket connections. - location /dashboard/api/live/ { + location /dashboard/api/live/ws { + rewrite ^/dashboard/(.*) /$1 break; + proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Host $host; diff --git a/dbrepo-grafana-service/.dockerignore b/dbrepo-grafana-service/.dockerignore deleted file mode 100644 index fcdfe8de55e91b3b65fcf598c5980ae256087910..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/.dockerignore +++ /dev/null @@ -1 +0,0 @@ -rest-service/src/main/resources/*.csv \ No newline at end of file diff --git a/dbrepo-grafana-service/.gitignore b/dbrepo-grafana-service/.gitignore deleted file mode 100644 index d39a47ee0fab72fbe4fd7f5ae968ff2f3bc3de78..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/.gitignore +++ /dev/null @@ -1,43 +0,0 @@ -HELP.md -target/ -!.mvn/wrapper/maven-wrapper.jar -!**/src/main/**/target/ -!**/src/test/**/target/ - -### Environment ### -.env - -### Generated ### -ready -mapping.xml -schema.xsd -*.versionsBackup -metrics.txt - -### STS ### -.apt_generated -.classpath -.factorypath -.project -.settings -.springBeans -.sts4-cache - -### IntelliJ IDEA ### -.idea -*.iws -*.iml -*.ipr - -### NetBeans ### -/nbproject/private/ -/nbbuild/ -/dist/ -/nbdist/ -/.nb-gradle/ -build/ -!**/src/main/**/build/ -!**/src/test/**/build/ - -### VS Code ### -.vscode/ diff --git a/dbrepo-grafana-service/.mvn/wrapper/MavenWrapperDownloader.java b/dbrepo-grafana-service/.mvn/wrapper/MavenWrapperDownloader.java deleted file mode 100644 index a45eb6ba269cd38f8965cef786729790945d9537..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/.mvn/wrapper/MavenWrapperDownloader.java +++ /dev/null @@ -1,118 +0,0 @@ -/* - * Copyright 2007-present the original author or authors. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * https://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -import java.net.*; -import java.io.*; -import java.nio.channels.*; -import java.util.Properties; - -public class MavenWrapperDownloader { - - private static final String WRAPPER_VERSION = "0.5.6"; - /** - * Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided. - */ - private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/" - + WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar"; - - /** - * Path to the maven-wrapper.properties file, which might contain a downloadUrl property to - * use instead of the default one. - */ - private static final String MAVEN_WRAPPER_PROPERTIES_PATH = - ".mvn/wrapper/maven-wrapper.properties"; - - /** - * Path where the maven-wrapper.jar will be saved to. - */ - private static final String MAVEN_WRAPPER_JAR_PATH = - ".mvn/wrapper/maven-wrapper.jar"; - - /** - * Name of the property which should be used to override the default download url for the wrapper. - */ - private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl"; - - public static void main(String args[]) { - System.out.println("- Downloader started"); - File baseDirectory = new File(args[0]); - System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath()); - - // If the maven-wrapper.properties exists, read it and check if it contains a custom - // wrapperUrl parameter. - File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH); - String url = DEFAULT_DOWNLOAD_URL; - if (mavenWrapperPropertyFile.exists()) { - FileInputStream mavenWrapperPropertyFileInputStream = null; - try { - mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile); - Properties mavenWrapperProperties = new Properties(); - mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream); - url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url); - } catch (IOException e) { - System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'"); - } finally { - try { - if (mavenWrapperPropertyFileInputStream != null) { - mavenWrapperPropertyFileInputStream.close(); - } - } catch (IOException e) { - // Ignore ... - } - } - } - System.out.println("- Downloading from: " + url); - - File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH); - if (!outputFile.getParentFile().exists()) { - if (!outputFile.getParentFile().mkdirs()) { - System.out.println( - "- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'"); - } - } - System.out.println("- Downloading to: " + outputFile.getAbsolutePath()); - try { - downloadFileFromURL(url, outputFile); - System.out.println("Done"); - System.exit(0); - } catch (Throwable e) { - System.out.println("- Error downloading"); - e.printStackTrace(); - System.exit(1); - } - } - - private static void downloadFileFromURL(String urlString, File destination) throws Exception { - if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) { - String username = System.getenv("MVNW_USERNAME"); - char[] password = System.getenv("MVNW_PASSWORD").toCharArray(); - Authenticator.setDefault(new Authenticator() { - @Override - protected PasswordAuthentication getPasswordAuthentication() { - return new PasswordAuthentication(username, password); - } - }); - } - URL website = new URL(urlString); - ReadableByteChannel rbc; - rbc = Channels.newChannel(website.openStream()); - FileOutputStream fos = new FileOutputStream(destination); - fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE); - fos.close(); - rbc.close(); - } - -} diff --git a/dbrepo-grafana-service/.mvn/wrapper/maven-wrapper.jar b/dbrepo-grafana-service/.mvn/wrapper/maven-wrapper.jar deleted file mode 100644 index 2cc7d4a55c0cd0092912bf49ae38b3a9e3fd0054..0000000000000000000000000000000000000000 Binary files a/dbrepo-grafana-service/.mvn/wrapper/maven-wrapper.jar and /dev/null differ diff --git a/dbrepo-grafana-service/.mvn/wrapper/maven-wrapper.properties b/dbrepo-grafana-service/.mvn/wrapper/maven-wrapper.properties deleted file mode 100644 index 642d572ce90e5085986bdd9c9204b9404f028084..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/.mvn/wrapper/maven-wrapper.properties +++ /dev/null @@ -1,2 +0,0 @@ -distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip -wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar diff --git a/dbrepo-grafana-service/Dockerfile b/dbrepo-grafana-service/Dockerfile deleted file mode 100644 index b01544827f1cdda6398eb0d8e0b927b88fa176f1..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/Dockerfile +++ /dev/null @@ -1,31 +0,0 @@ -###### FIRST STAGE ###### -FROM dbrepo-metadata-service:build AS dependency -MAINTAINER Martin Weise <martin.weise@tuwien.ac.at> - -FROM maven:3-openjdk-17 AS build -MAINTAINER Martin Weise <martin.weise@tuwien.ac.at> - -COPY ./pom.xml ./ - -RUN mvn -fn -B dependency:go-offline - -COPY ./rest-service ./rest-service -COPY --from=dependency /root/.m2/repository/at/tuwien /root/.m2/repository/at/tuwien - -# Make sure it compiles -RUN mvn clean package -DskipTests - -###### SECOND STAGE ###### -FROM eclipse-temurin:17-jdk AS runtime -MAINTAINER Martin Weise <martin.weise@tuwien.ac.at> - -WORKDIR /app - -USER 65534 - -COPY --from=build --chown=65534 ./rest-service/target/dbrepo-grafana-service-rest-service-*.jar ./grafana-service.jar - -# non-root port -EXPOSE 8080 - -ENTRYPOINT ["java", "-Dlog4j2.formatMsgNoLookups=true", "-jar", "./grafana-service.jar"] \ No newline at end of file diff --git a/dbrepo-grafana-service/README.md b/dbrepo-grafana-service/README.md deleted file mode 100644 index 7160f7bbbc743d2bb6425773566c98eb86005143..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/README.md +++ /dev/null @@ -1,38 +0,0 @@ -# Metadata Service - -## Test - -Run all unit and integration tests and create an HTML+TXT coverage report located in the `report` module: - -```bash -mvn -pl rest-service clean test verify -``` - -Or run only unit tests -in [`KeycloakGatewayUnitTest.java`](https://gitlab.phaidra.org/fair-data-austria-db-repository/fda-services/-/blob/master/dbrepo-metadata-service/rest-service/src/test/java/at/tuwien/gateway/BrokerServiceGatewayTest.java): - -```bash -mvn -pl rest-service -Dtest="KeycloakGatewayUnitTest" clean test -``` - -## Run - -Start the Metadata Database before and then run the Metadata Service: - -```bash -mvn -pl rest-service clean spring-boot:run -Dspring-boot.run.profiles=local -``` - -### Endpoints - -#### Actuator - -- Info: http://localhost:9099/actuator/info -- Health: http://localhost:9099/actuator/health - - Readiness: http://localhost:9099/actuator/health/readiness - - Liveness: http://localhost:9099/actuator/health/liveness -- Prometheus: http://localhost:9099/actuator/prometheus - -#### OpenAPI - -- OpenAPI v3 as .yaml: http://localhost:9099/v3/api-docs.yaml \ No newline at end of file diff --git a/dbrepo-grafana-service/mvnw b/dbrepo-grafana-service/mvnw deleted file mode 100755 index a16b5431b4c3cab50323a3f558003fd0abd87dad..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/mvnw +++ /dev/null @@ -1,310 +0,0 @@ -#!/bin/sh -# ---------------------------------------------------------------------------- -# Licensed to the Apache Software Foundation (ASF) under one -# or more contributor license agreements. See the NOTICE file -# distributed with this work for additional information -# regarding copyright ownership. The ASF licenses this file -# to you under the Apache License, Version 2.0 (the -# "License"); you may not use this file except in compliance -# with the License. You may obtain a copy of the License at -# -# https://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, -# software distributed under the License is distributed on an -# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -# KIND, either express or implied. See the License for the -# specific language governing permissions and limitations -# under the License. -# ---------------------------------------------------------------------------- - -# ---------------------------------------------------------------------------- -# Maven Start Up Batch script -# -# Required ENV vars: -# ------------------ -# JAVA_HOME - location of a JDK home dir -# -# Optional ENV vars -# ----------------- -# M2_HOME - location of maven2's installed home dir -# MAVEN_OPTS - parameters passed to the Java VM when running Maven -# e.g. to debug Maven itself, use -# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 -# MAVEN_SKIP_RC - flag to disable loading of mavenrc files -# ---------------------------------------------------------------------------- - -if [ -z "$MAVEN_SKIP_RC" ] ; then - - if [ -f /etc/mavenrc ] ; then - . /etc/mavenrc - fi - - if [ -f "$HOME/.mavenrc" ] ; then - . "$HOME/.mavenrc" - fi - -fi - -# OS specific support. $var _must_ be set to either true or false. -cygwin=false; -darwin=false; -mingw=false -case "`uname`" in - CYGWIN*) cygwin=true ;; - MINGW*) mingw=true;; - Darwin*) darwin=true - # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home - # See https://developer.apple.com/library/mac/qa/qa1170/_index.html - if [ -z "$JAVA_HOME" ]; then - if [ -x "/usr/libexec/java_home" ]; then - export JAVA_HOME="`/usr/libexec/java_home`" - else - export JAVA_HOME="/Library/Java/Home" - fi - fi - ;; -esac - -if [ -z "$JAVA_HOME" ] ; then - if [ -r /etc/gentoo-release ] ; then - JAVA_HOME=`java-config --jre-home` - fi -fi - -if [ -z "$M2_HOME" ] ; then - ## resolve links - $0 may be a link to maven's home - PRG="$0" - - # need this for relative symlinks - while [ -h "$PRG" ] ; do - ls=`ls -ld "$PRG"` - link=`expr "$ls" : '.*-> \(.*\)$'` - if expr "$link" : '/.*' > /dev/null; then - PRG="$link" - else - PRG="`dirname "$PRG"`/$link" - fi - done - - saveddir=`pwd` - - M2_HOME=`dirname "$PRG"`/.. - - # make it fully qualified - M2_HOME=`cd "$M2_HOME" && pwd` - - cd "$saveddir" - # echo Using m2 at $M2_HOME -fi - -# For Cygwin, ensure paths are in UNIX format before anything is touched -if $cygwin ; then - [ -n "$M2_HOME" ] && - M2_HOME=`cygpath --unix "$M2_HOME"` - [ -n "$JAVA_HOME" ] && - JAVA_HOME=`cygpath --unix "$JAVA_HOME"` - [ -n "$CLASSPATH" ] && - CLASSPATH=`cygpath --path --unix "$CLASSPATH"` -fi - -# For Mingw, ensure paths are in UNIX format before anything is touched -if $mingw ; then - [ -n "$M2_HOME" ] && - M2_HOME="`(cd "$M2_HOME"; pwd)`" - [ -n "$JAVA_HOME" ] && - JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" -fi - -if [ -z "$JAVA_HOME" ]; then - javaExecutable="`which javac`" - if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then - # readlink(1) is not available as standard on Solaris 10. - readLink=`which readlink` - if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then - if $darwin ; then - javaHome="`dirname \"$javaExecutable\"`" - javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" - else - javaExecutable="`readlink -f \"$javaExecutable\"`" - fi - javaHome="`dirname \"$javaExecutable\"`" - javaHome=`expr "$javaHome" : '\(.*\)/bin'` - JAVA_HOME="$javaHome" - export JAVA_HOME - fi - fi -fi - -if [ -z "$JAVACMD" ] ; then - if [ -n "$JAVA_HOME" ] ; then - if [ -x "$JAVA_HOME/jre/sh/java" ] ; then - # IBM's JDK on AIX uses strange locations for the executables - JAVACMD="$JAVA_HOME/jre/sh/java" - else - JAVACMD="$JAVA_HOME/bin/java" - fi - else - JAVACMD="`which java`" - fi -fi - -if [ ! -x "$JAVACMD" ] ; then - echo "Error: JAVA_HOME is not defined correctly." >&2 - echo " We cannot execute $JAVACMD" >&2 - exit 1 -fi - -if [ -z "$JAVA_HOME" ] ; then - echo "Warning: JAVA_HOME environment variable is not set." -fi - -CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher - -# traverses directory structure from process work directory to filesystem root -# first directory with .mvn subdirectory is considered project base directory -find_maven_basedir() { - - if [ -z "$1" ] - then - echo "Path not specified to find_maven_basedir" - return 1 - fi - - basedir="$1" - wdir="$1" - while [ "$wdir" != '/' ] ; do - if [ -d "$wdir"/.mvn ] ; then - basedir=$wdir - break - fi - # workaround for JBEAP-8937 (on Solaris 10/Sparc) - if [ -d "${wdir}" ]; then - wdir=`cd "$wdir/.."; pwd` - fi - # end of workaround - done - echo "${basedir}" -} - -# concatenates all lines of a file -concat_lines() { - if [ -f "$1" ]; then - echo "$(tr -s '\n' ' ' < "$1")" - fi -} - -BASE_DIR=`find_maven_basedir "$(pwd)"` -if [ -z "$BASE_DIR" ]; then - exit 1; -fi - -########################################################################################## -# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central -# This allows using the maven wrapper in projects that prohibit checking in binary data. -########################################################################################## -if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then - if [ "$MVNW_VERBOSE" = true ]; then - echo "Found .mvn/wrapper/maven-wrapper.jar" - fi -else - if [ "$MVNW_VERBOSE" = true ]; then - echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." - fi - if [ -n "$MVNW_REPOURL" ]; then - jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" - else - jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" - fi - while IFS="=" read key value; do - case "$key" in (wrapperUrl) jarUrl="$value"; break ;; - esac - done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" - if [ "$MVNW_VERBOSE" = true ]; then - echo "Downloading from: $jarUrl" - fi - wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" - if $cygwin; then - wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"` - fi - - if command -v wget > /dev/null; then - if [ "$MVNW_VERBOSE" = true ]; then - echo "Found wget ... using wget" - fi - if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then - wget "$jarUrl" -O "$wrapperJarPath" - else - wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" - fi - elif command -v curl > /dev/null; then - if [ "$MVNW_VERBOSE" = true ]; then - echo "Found curl ... using curl" - fi - if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then - curl -o "$wrapperJarPath" "$jarUrl" -f - else - curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f - fi - - else - if [ "$MVNW_VERBOSE" = true ]; then - echo "Falling back to using Java to download" - fi - javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" - # For Cygwin, switch paths to Windows format before running javac - if $cygwin; then - javaClass=`cygpath --path --windows "$javaClass"` - fi - if [ -e "$javaClass" ]; then - if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then - if [ "$MVNW_VERBOSE" = true ]; then - echo " - Compiling MavenWrapperDownloader.java ..." - fi - # Compiling the Java class - ("$JAVA_HOME/bin/javac" "$javaClass") - fi - if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then - # Running the downloader - if [ "$MVNW_VERBOSE" = true ]; then - echo " - Running MavenWrapperDownloader.java ..." - fi - ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") - fi - fi - fi -fi -########################################################################################## -# End of extension -########################################################################################## - -export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} -if [ "$MVNW_VERBOSE" = true ]; then - echo $MAVEN_PROJECTBASEDIR -fi -MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" - -# For Cygwin, switch paths to Windows format before running java -if $cygwin; then - [ -n "$M2_HOME" ] && - M2_HOME=`cygpath --path --windows "$M2_HOME"` - [ -n "$JAVA_HOME" ] && - JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` - [ -n "$CLASSPATH" ] && - CLASSPATH=`cygpath --path --windows "$CLASSPATH"` - [ -n "$MAVEN_PROJECTBASEDIR" ] && - MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` -fi - -# Provide a "standardized" way to retrieve the CLI args that will -# work with both Windows and non-Windows executions. -MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@" -export MAVEN_CMD_LINE_ARGS - -WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain - -exec "$JAVACMD" \ - $MAVEN_OPTS \ - -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ - "-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ - ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" diff --git a/dbrepo-grafana-service/mvnw.cmd b/dbrepo-grafana-service/mvnw.cmd deleted file mode 100644 index c8d43372c986d97911cdc21bd87e0cbe3d83bdda..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/mvnw.cmd +++ /dev/null @@ -1,182 +0,0 @@ -@REM ---------------------------------------------------------------------------- -@REM Licensed to the Apache Software Foundation (ASF) under one -@REM or more contributor license agreements. See the NOTICE file -@REM distributed with this work for additional information -@REM regarding copyright ownership. The ASF licenses this file -@REM to you under the Apache License, Version 2.0 (the -@REM "License"); you may not use this file except in compliance -@REM with the License. You may obtain a copy of the License at -@REM -@REM https://www.apache.org/licenses/LICENSE-2.0 -@REM -@REM Unless required by applicable law or agreed to in writing, -@REM software distributed under the License is distributed on an -@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -@REM KIND, either express or implied. See the License for the -@REM specific language governing permissions and limitations -@REM under the License. -@REM ---------------------------------------------------------------------------- - -@REM ---------------------------------------------------------------------------- -@REM Maven Start Up Batch script -@REM -@REM Required ENV vars: -@REM JAVA_HOME - location of a JDK home dir -@REM -@REM Optional ENV vars -@REM M2_HOME - location of maven2's installed home dir -@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands -@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending -@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven -@REM e.g. to debug Maven itself, use -@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 -@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files -@REM ---------------------------------------------------------------------------- - -@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on' -@echo off -@REM set title of command window -title %0 -@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on' -@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO% - -@REM set %HOME% to equivalent of $HOME -if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%") - -@REM Execute a user defined script before this one -if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre -@REM check for pre script, once with legacy .bat ending and once with .cmd ending -if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat" -if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd" -:skipRcPre - -@setlocal - -set ERROR_CODE=0 - -@REM To isolate internal variables from possible post scripts, we use another setlocal -@setlocal - -@REM ==== START VALIDATION ==== -if not "%JAVA_HOME%" == "" goto OkJHome - -echo. -echo Error: JAVA_HOME not found in your environment. >&2 -echo Please set the JAVA_HOME variable in your environment to match the >&2 -echo location of your Java installation. >&2 -echo. -goto error - -:OkJHome -if exist "%JAVA_HOME%\bin\java.exe" goto init - -echo. -echo Error: JAVA_HOME is set to an invalid directory. >&2 -echo JAVA_HOME = "%JAVA_HOME%" >&2 -echo Please set the JAVA_HOME variable in your environment to match the >&2 -echo location of your Java installation. >&2 -echo. -goto error - -@REM ==== END VALIDATION ==== - -:init - -@REM Find the project base dir, i.e. the directory that contains the folder ".mvn". -@REM Fallback to current working directory if not found. - -set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR% -IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir - -set EXEC_DIR=%CD% -set WDIR=%EXEC_DIR% -:findBaseDir -IF EXIST "%WDIR%"\.mvn goto baseDirFound -cd .. -IF "%WDIR%"=="%CD%" goto baseDirNotFound -set WDIR=%CD% -goto findBaseDir - -:baseDirFound -set MAVEN_PROJECTBASEDIR=%WDIR% -cd "%EXEC_DIR%" -goto endDetectBaseDir - -:baseDirNotFound -set MAVEN_PROJECTBASEDIR=%EXEC_DIR% -cd "%EXEC_DIR%" - -:endDetectBaseDir - -IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig - -@setlocal EnableExtensions EnableDelayedExpansion -for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a -@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS% - -:endReadAdditionalConfig - -SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" -set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" -set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain - -set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" - -FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( - IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B -) - -@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central -@REM This allows using the maven wrapper in projects that prohibit checking in binary data. -if exist %WRAPPER_JAR% ( - if "%MVNW_VERBOSE%" == "true" ( - echo Found %WRAPPER_JAR% - ) -) else ( - if not "%MVNW_REPOURL%" == "" ( - SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar" - ) - if "%MVNW_VERBOSE%" == "true" ( - echo Couldn't find %WRAPPER_JAR%, downloading it ... - echo Downloading from: %DOWNLOAD_URL% - ) - - powershell -Command "&{"^ - "$webclient = new-object System.Net.WebClient;"^ - "if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^ - "$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^ - "}"^ - "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^ - "}" - if "%MVNW_VERBOSE%" == "true" ( - echo Finished downloading %WRAPPER_JAR% - ) -) -@REM End of extension - -@REM Provide a "standardized" way to retrieve the CLI args that will -@REM work with both Windows and non-Windows executions. -set MAVEN_CMD_LINE_ARGS=%* - -%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %* -if ERRORLEVEL 1 goto error -goto end - -:error -set ERROR_CODE=1 - -:end -@endlocal & set ERROR_CODE=%ERROR_CODE% - -if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost -@REM check for post script, once with legacy .bat ending and once with .cmd ending -if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat" -if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd" -:skipRcPost - -@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on' -if "%MAVEN_BATCH_PAUSE%" == "on" pause - -if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE% - -exit /B %ERROR_CODE% diff --git a/dbrepo-grafana-service/pom.xml b/dbrepo-grafana-service/pom.xml deleted file mode 100644 index 763aa408f075814db2312778f6112e71b1b3072a..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/pom.xml +++ /dev/null @@ -1,299 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" - xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> - <modelVersion>4.0.0</modelVersion> - <parent> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-parent</artifactId> - <version>3.0.13</version> - </parent> - - <groupId>at.tuwien</groupId> - <artifactId>dbrepo-grafana-service</artifactId> - <name>dbrepo-grafana-service</name> - <version>1.4.4</version> - - <description>Service that creates automated grafana dashboards</description> - - <packaging>pom</packaging> - <modules> - <module>rest-service</module> - </modules> - - <properties> - <java.version>17</java.version> - <spring-cloud.version>4.0.2</spring-cloud.version> - <mapstruct.version>1.5.5.Final</mapstruct.version> - <rabbitmq.version>5.20.0</rabbitmq.version> - <jackson-datatype.version>2.15.0</jackson-datatype.version> - <commons-io.version>2.15.0</commons-io.version> - <commons-validator.version>1.8.0</commons-validator.version> - <jacoco.version>0.8.11</jacoco.version> - <jwt.version>4.3.0</jwt.version> - <opencsv.version>5.7.1</opencsv.version> - <super-csv.version>2.4.0</super-csv.version> - <jsql.version>4.6</jsql.version> - <springdoc-openapi.version>2.3.0</springdoc-openapi.version> - <hsqldb.version>2.7.2</hsqldb.version> - <testcontainers.version>1.19.1</testcontainers.version> - <jackson.version>2.15.2</jackson.version> - <c3p0.version>0.9.5.5</c3p0.version> - <c3p0-hibernate.version>6.2.2.Final</c3p0-hibernate.version> - <aws-s3.version>2.25.23</aws-s3.version> - <minio.version>8.5.7</minio.version> - <apache-commons.version>1.10.0</apache-commons.version> - </properties> - - <dependencies> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-validation</artifactId> - </dependency> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-web</artifactId> - </dependency> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-security</artifactId> - </dependency> - <dependency> - <groupId>org.springframework.security</groupId> - <artifactId>spring-security-test</artifactId> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.springframework.cloud</groupId> - <artifactId>spring-cloud-starter-bootstrap</artifactId> - <version>${spring-cloud.version}</version> - </dependency> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-data-jpa</artifactId> - </dependency> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-actuator</artifactId> - </dependency> - <dependency> - <groupId>org.apache.commons</groupId> - <artifactId>commons-text</artifactId> - <version>${apache-commons.version}</version> - - </dependency> - <!-- Caching --> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-data-redis</artifactId> - </dependency> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-cache</artifactId> - </dependency> - <dependency> - <groupId>redis.clients</groupId> - <artifactId>jedis</artifactId> - </dependency> - <!-- Open API --> - <dependency> - <groupId>org.springdoc</groupId> - <artifactId>springdoc-openapi-starter-webmvc-api</artifactId> - <version>${springdoc-openapi.version}</version> - </dependency> - <!-- Data Source --> - <dependency> - <groupId>com.h2database</groupId> - <artifactId>h2</artifactId> - </dependency> - <dependency> - <groupId>com.mchange</groupId> - <artifactId>c3p0</artifactId> - <version>${c3p0.version}</version> - </dependency> - <dependency> - <groupId>org.hibernate.orm</groupId> - <artifactId>hibernate-c3p0</artifactId> - <version>${c3p0-hibernate.version}</version> - </dependency> - <!-- Monitoring --> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-aop</artifactId> - </dependency> - <dependency> - <groupId>io.micrometer</groupId> - <artifactId>micrometer-registry-prometheus</artifactId> - <version>${micrometer.version}</version> - </dependency> - <dependency> - <groupId>io.micrometer</groupId> - <artifactId>micrometer-observation-test</artifactId> - <version>${micrometer.version}</version> - <scope>test</scope> - </dependency> - <!-- IDE --> - <dependency> - <groupId>org.projectlombok</groupId> - <artifactId>lombok</artifactId> - <scope>compile</scope> - </dependency> - <!-- Mapping --> - <dependency> - <groupId>org.mapstruct</groupId> - <artifactId>mapstruct-processor</artifactId> - <version>${mapstruct.version}</version> - <optional>true</optional> - </dependency> - <dependency> - <groupId>org.mapstruct</groupId> - <artifactId>mapstruct</artifactId> - <version>${mapstruct.version}</version> - </dependency> - <dependency> - <groupId>com.fasterxml.jackson.datatype</groupId> - <artifactId>jackson-datatype-jsr310</artifactId> - <version>${jackson-datatype.version}</version> - </dependency> - <dependency> - <groupId>commons-io</groupId> - <artifactId>commons-io</artifactId> - <version>${commons-io.version}</version> - </dependency> - <dependency> - <groupId>commons-validator</groupId> - <artifactId>commons-validator</artifactId> - <version>${commons-validator.version}</version> - </dependency> - <!-- Authentication --> - <dependency> - <groupId>com.auth0</groupId> - <artifactId>java-jwt</artifactId> - <version>${jwt.version}</version> - </dependency> - <!-- DTOs --> - <dependency> - <groupId>at.tuwien</groupId> - <artifactId>dbrepo-metadata-service-api</artifactId> - <version>${project.version}</version> - </dependency> - <!-- AMPQ --> - <dependency> - <groupId>org.springframework.amqp</groupId> - <artifactId>spring-rabbit</artifactId> - </dependency> - <dependency> - <groupId>com.rabbitmq</groupId> - <artifactId>amqp-client</artifactId> - <version>${rabbitmq.version}</version> - </dependency> - <!-- Storage --> - <dependency> - <groupId>software.amazon.awssdk</groupId> - <artifactId>s3</artifactId> - <version>${aws-s3.version}</version> - </dependency> - <!-- Testing --> - <dependency> - <groupId>com.github.jsqlparser</groupId> - <artifactId>jsqlparser</artifactId> - <version>${jsql.version}</version> - </dependency> - <dependency> - <groupId>at.tuwien</groupId> - <artifactId>dbrepo-metadata-service-test</artifactId> - <version>${project.version}</version> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-starter-test</artifactId> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.testcontainers</groupId> - <artifactId>rabbitmq</artifactId> - <version>${testcontainers.version}</version> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.testcontainers</groupId> - <artifactId>junit-jupiter</artifactId> - <version>${testcontainers.version}</version> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.testcontainers</groupId> - <artifactId>mariadb</artifactId> - <version>${testcontainers.version}</version> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.testcontainers</groupId> - <artifactId>minio</artifactId> - <version>${testcontainers.version}</version> - </dependency> - <dependency> - <groupId>org.jacoco</groupId> - <artifactId>jacoco-maven-plugin</artifactId> - <version>${jacoco.version}</version> - </dependency> - <dependency> - <groupId>org.apache.httpcomponents</groupId> - <artifactId>httpclient</artifactId> - </dependency> - </dependencies> - <build> - <resources> - <resource> - <directory>${basedir}/src/main/resources</directory> - <filtering>true</filtering> - <includes> - <include>**/application*.yml</include> - <include>**/rdf/*</include> - <include>**/templates/*.txt</include> - <include>**/templates/*.xml</include> - </includes> - </resource> - </resources> - <plugins> - <plugin> - <groupId>org.jacoco</groupId> - <artifactId>jacoco-maven-plugin</artifactId> - <version>${jacoco.version}</version> - <configuration> - <excludes> - <exclude>at/tuwien/utils/**/*</exclude> - <exclude>at/tuwien/seeder/**/*</exclude> - <exclude>at/tuwien/mapper/**/*</exclude> - <exclude>at/tuwien/handlers/**/*</exclude> - <exclude>at/tuwien/exception/**/*</exclude> - <exclude>at/tuwien/converters/**/*</exclude> - <exclude>at/tuwien/utils/**/*</exclude> - <exclude>at/tuwien/config/**/*</exclude> - <exclude>at/tuwien/auth/**/*</exclude> - <exclude>at/tuwien/gateway/impl/ApiTemplateInterceptorImpl.class</exclude> - <exclude>**/testcontainers.properties</exclude> - <exclude>**/HibernateConnector.class</exclude> - <exclude>**/DbrepoMetadataServiceApplication.class</exclude> - </excludes> - </configuration> - <executions> - <execution> - <id>default-prepare-agent</id> - <goals> - <goal>prepare-agent</goal> - </goals> - </execution> - <execution> - <id>report</id> - <phase>verify</phase> - <goals> - <goal>report</goal> - </goals> - </execution> - </executions> - </plugin> - </plugins> - </build> - -</project> diff --git a/dbrepo-grafana-service/rest-service/pom.xml b/dbrepo-grafana-service/rest-service/pom.xml deleted file mode 100644 index ace7de5a1cb287e104a93100059b506caba3ab77..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/pom.xml +++ /dev/null @@ -1,35 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<project xmlns="http://maven.apache.org/POM/4.0.0" - xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" - xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> - <modelVersion>4.0.0</modelVersion> - <parent> - <artifactId>dbrepo-grafana-service</artifactId> - <groupId>at.tuwien</groupId> - <version>1.4.4</version> - </parent> - - <artifactId>dbrepo-grafana-service-rest-service</artifactId> - <name>dbrepo-grafana-service-rest</name> - <version>1.4.4</version> - - <dependencies> - </dependencies> - - <build> - <plugins> - <plugin> - <groupId>org.springframework.boot</groupId> - <artifactId>spring-boot-maven-plugin</artifactId> - <executions> - <execution> - <goals> - <goal>repackage</goal><!-- to make it exuteable with $ java -jar ./app.jar --> - </goals> - </execution> - </executions> - </plugin> - </plugins> - </build> - -</project> \ No newline at end of file diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/DbrepoGrafanaServiceApplication.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/DbrepoGrafanaServiceApplication.java deleted file mode 100644 index 79c50fa5ef00adf1cd5c0c4efa9355500e76dba1..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/DbrepoGrafanaServiceApplication.java +++ /dev/null @@ -1,13 +0,0 @@ -package at.tuwien; - -import org.springframework.boot.SpringApplication; -import org.springframework.boot.autoconfigure.SpringBootApplication; -import org.springframework.cache.annotation.EnableCaching; - -@SpringBootApplication -@EnableCaching -public class DbrepoGrafanaServiceApplication { - public static void main(String[] args) { - SpringApplication.run(DbrepoGrafanaServiceApplication.class, args); - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/auth/AuthTokenFilter.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/auth/AuthTokenFilter.java deleted file mode 100644 index 46ec0e6a24bdd2bc2a9a88f8fad4815467ebff08..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/auth/AuthTokenFilter.java +++ /dev/null @@ -1,96 +0,0 @@ -package at.tuwien.auth; - -import at.tuwien.api.auth.RealmAccessDto; -import at.tuwien.api.user.UserDetailsDto; -import com.auth0.jwt.JWT; -import com.auth0.jwt.JWTVerifier; -import com.auth0.jwt.algorithms.Algorithm; -import com.auth0.jwt.interfaces.DecodedJWT; -import com.auth0.jwt.interfaces.Verification; -import jakarta.servlet.FilterChain; -import jakarta.servlet.ServletException; -import jakarta.servlet.http.HttpServletRequest; -import jakarta.servlet.http.HttpServletResponse; -import lombok.extern.slf4j.Slf4j; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; -import org.springframework.security.core.authority.SimpleGrantedAuthority; -import org.springframework.security.core.context.SecurityContextHolder; -import org.springframework.security.core.userdetails.UserDetails; -import org.springframework.security.web.authentication.WebAuthenticationDetailsSource; -import org.springframework.util.StringUtils; -import org.springframework.web.filter.OncePerRequestFilter; - -import java.io.IOException; -import java.security.KeyFactory; -import java.security.NoSuchAlgorithmException; -import java.security.interfaces.RSAPublicKey; -import java.security.spec.InvalidKeySpecException; -import java.security.spec.X509EncodedKeySpec; -import java.util.Arrays; -import java.util.Base64; -import java.util.stream.Collectors; - -@Slf4j -public class AuthTokenFilter extends OncePerRequestFilter { - - @Value("${dbrepo.jwt.public_key}") - private String publicKey; - - @Override - protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) - throws ServletException, IOException { - final String jwt = parseJwt(request); - if (jwt != null) { - final UserDetails userDetails = verifyJwt(jwt); - final UsernamePasswordAuthenticationToken authentication = new UsernamePasswordAuthenticationToken( - userDetails, null, userDetails.getAuthorities()); - authentication.setDetails(new WebAuthenticationDetailsSource().buildDetails(request)); - - SecurityContextHolder.getContext().setAuthentication(authentication); - } - filterChain.doFilter(request, response); - } - - public UserDetails verifyJwt(String token) throws ServletException { - final KeyFactory kf; - try { - kf = KeyFactory.getInstance("RSA"); - } catch (NoSuchAlgorithmException e) { - log.error("Failed to find RSA algorithm"); - throw new ServletException("Failed to find RSA algorithm", e); - } - final X509EncodedKeySpec keySpecX509 = new X509EncodedKeySpec(Base64.getDecoder().decode(publicKey)); - final RSAPublicKey pubKey; - try { - pubKey = (RSAPublicKey) kf.generatePublic(keySpecX509); - } catch (InvalidKeySpecException e) { - log.error("Provided public key is invalid"); - throw new ServletException("Provided public key is invalid", e); - } - final Algorithm algorithm = Algorithm.RSA256(pubKey, null); - final Verification verification = JWT.require(algorithm); - final JWTVerifier verifier = verification.build(); - final DecodedJWT jwt = verifier.verify(token); - final RealmAccessDto realmAccess = jwt.getClaim("realm_access").as(RealmAccessDto.class); - return UserDetailsDto.builder() - .id(jwt.getSubject()) - .username(jwt.getClaim("client_id").asString()) - .authorities(Arrays.stream(realmAccess.getRoles()).map(SimpleGrantedAuthority::new).collect(Collectors.toList())) - .build(); - } - - /** - * Parses the token from the HTTP header of the request - * - * @param request The request. - * @return The token. - */ - public String parseJwt(HttpServletRequest request) { - String headerAuth = request.getHeader("Authorization"); - if (StringUtils.hasText(headerAuth) && headerAuth.startsWith("Bearer ")) { - return headerAuth.substring(7, headerAuth.length()); - } - return null; - } -} \ No newline at end of file diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/auth/BasicAuthenticationProvider.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/auth/BasicAuthenticationProvider.java deleted file mode 100644 index 6cd55e9ef768e47f3d3463001ba99b5378f5351e..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/auth/BasicAuthenticationProvider.java +++ /dev/null @@ -1,60 +0,0 @@ -package at.tuwien.auth; - -import at.tuwien.api.keycloak.TokenDto; -import at.tuwien.api.user.UserDetailsDto; -import at.tuwien.config.GatewayConfig; -import at.tuwien.exception.ServiceConnectionException; -import at.tuwien.exception.ServiceException; -import at.tuwien.gateway.KeycloakGateway; -import jakarta.servlet.ServletException; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.security.authentication.AuthenticationManager; -import org.springframework.security.authentication.BadCredentialsException; -import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; -import org.springframework.security.core.Authentication; -import org.springframework.security.core.AuthenticationException; -import org.springframework.security.core.authority.SimpleGrantedAuthority; -import org.springframework.security.core.userdetails.UserDetails; -import org.springframework.stereotype.Component; - -import java.util.List; - -@Log4j2 -@Component -public class BasicAuthenticationProvider implements AuthenticationManager { - - private final GatewayConfig gatewayConfig; - private final AuthTokenFilter authTokenFilter; - private final KeycloakGateway keycloakGateway; - - @Autowired - public BasicAuthenticationProvider(GatewayConfig gatewayConfig, AuthTokenFilter authTokenFilter, - KeycloakGateway keycloakGateway) { - this.gatewayConfig = gatewayConfig; - this.authTokenFilter = authTokenFilter; - this.keycloakGateway = keycloakGateway; - } - - @Override - public Authentication authenticate(Authentication auth) throws AuthenticationException { - if (auth.getName().equals(gatewayConfig.getAdminUsername()) - && auth.getCredentials().toString().equals(gatewayConfig.getAdminPassword())) { - log.trace("current user is {}: skip authentication", gatewayConfig.getAdminUsername()); - final UserDetails userDetails = UserDetailsDto.builder() - .username(auth.getName()) - .authorities(List.of(new SimpleGrantedAuthority("admin"))) - .build(); - return new UsernamePasswordAuthenticationToken(userDetails, null, userDetails.getAuthorities()); - } - log.trace("current user is {}: begin authentication", auth.getName()); - try { - final TokenDto tokenDto = keycloakGateway.obtainUserToken(auth.getName(), auth.getCredentials().toString()); - final UserDetails userDetails = authTokenFilter.verifyJwt(tokenDto.getAccessToken()); - return new UsernamePasswordAuthenticationToken(userDetails, null, userDetails.getAuthorities()); - } catch (ServletException | ServiceConnectionException | ServiceException e) { - throw new BadCredentialsException("Failed to authenticate with authentication service", e); - } - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/CacheConfig.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/CacheConfig.java deleted file mode 100644 index dafb08dafc955fabde7a4ac6df6f16857b5ec173..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/CacheConfig.java +++ /dev/null @@ -1,40 +0,0 @@ -package at.tuwien.config; - -import org.springframework.cache.CacheManager; -import org.springframework.cache.annotation.EnableCaching; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.data.redis.cache.RedisCacheConfiguration; -import org.springframework.data.redis.cache.RedisCacheManager; -import org.springframework.data.redis.connection.RedisConnectionFactory; -import org.springframework.data.redis.core.RedisTemplate; -import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; -import org.springframework.data.redis.serializer.StringRedisSerializer; - -import java.time.Duration; - - -@Configuration -@EnableCaching -public class CacheConfig { - - @Bean - public CacheManager cacheManager(RedisConnectionFactory connectionFactory) { - return RedisCacheManager.RedisCacheManagerBuilder - .fromConnectionFactory(connectionFactory) - .withCacheConfiguration("myCache", - RedisCacheConfiguration.defaultCacheConfig() - .entryTtl(Duration.ofSeconds(30)) - ) - .build(); - } - - @Bean - public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) { - RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); - redisTemplate.setConnectionFactory(redisConnectionFactory); - redisTemplate.setKeySerializer(new StringRedisSerializer()); - redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()); - return redisTemplate; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/GatewayConfig.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/GatewayConfig.java deleted file mode 100644 index 1692f53b296ffe86b9c6b2cb49f9a44225c82a6b..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/GatewayConfig.java +++ /dev/null @@ -1,104 +0,0 @@ -package at.tuwien.config; - -import at.tuwien.interceptor.KeycloakInterceptor; -import lombok.Getter; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.http.HttpEntity; -import org.springframework.http.HttpHeaders; -import org.springframework.http.MediaType; -import org.springframework.http.client.ClientHttpRequestInterceptor; -import org.springframework.http.client.support.BasicAuthenticationInterceptor; -import org.springframework.web.client.RestTemplate; -import org.springframework.web.util.DefaultUriBuilderFactory; - -import java.security.KeyManagementException; -import java.security.NoSuchAlgorithmException; -import java.util.List; - -@Log4j2 -@Getter -@Configuration -public class GatewayConfig { - - @Value("${dbrepo.endpoints.gatewayService}") - private String gatewayEndpoint; - - @Value("${dbrepo.endpoints.grafana}") - private String grafanaEndpoint; - - @Value("${dbrepo.admin.username}") - private String adminUsername; - - @Value("${dbrepo.admin.password}") - private String adminPassword; - - @Value("${dbrepo.endpoints.dataService}") - private String dataEndpoint; - - @Value("${dbrepo.endpoints.metadataService}") - private String metaDataEndpoint; - - @Value("${dbrepo.grafana.username}") - private String grafanaUsername; - - @Value("${dbrepo.grafana.password}") - private String grafanaPassword; - - @Bean - public RestTemplate restTemplate() { - return new RestTemplate(); - } - - @Bean("grafanaTemplate") - public RestTemplate grafanaTemplate() { - final RestTemplate restTemplate = new RestTemplate(); - restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory(grafanaEndpoint)); - restTemplate.getInterceptors().add(grafanaHttpRequestInterceptor()); - return restTemplate; - } - - @Bean - public ClientHttpRequestInterceptor clientHttpRequestInterceptor() { - return (request, body, execution) -> { - final HttpHeaders headers = request.getHeaders(); - headers.add("Accept", MediaType.APPLICATION_JSON_VALUE); - return execution.execute(request, body); - }; - } - - @Bean - public ClientHttpRequestInterceptor grafanaHttpRequestInterceptor() { - return (request, body, execution) -> { - final HttpHeaders headers = request.getHeaders(); - headers.add("Accept", MediaType.APPLICATION_JSON_VALUE); - headers.setContentType(MediaType.APPLICATION_JSON); - headers.setBasicAuth(grafanaUsername, grafanaPassword); - return execution.execute(request, body); - }; - } - - @Bean("dataServiceRestTemplate") - public RestTemplate dataServiceRestTemplate() { - final RestTemplate restTemplate = new RestTemplate(); - restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory(dataEndpoint)); - log.debug("add basic authentication for internal data service: username={}, password=(hidden)", adminUsername); - - restTemplate.getInterceptors() - .addAll(List.of(new BasicAuthenticationInterceptor(adminUsername, adminPassword), - clientHttpRequestInterceptor())); - - return restTemplate; - } - - @Bean("metaDataServiceRestTemplate") - public RestTemplate metaDataServiceRestTemplate() { - final RestTemplate restTemplate = new RestTemplate(); - restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory(metaDataEndpoint)); - restTemplate.getInterceptors().add(clientHttpRequestInterceptor()); - return restTemplate; - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/KeycloakConfig.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/KeycloakConfig.java deleted file mode 100644 index 4d258d496aa6ebe825ac2d84a1f00a1b4f9c0298..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/KeycloakConfig.java +++ /dev/null @@ -1,50 +0,0 @@ -package at.tuwien.config; - -import at.tuwien.interceptor.KeycloakInterceptor; -import lombok.Getter; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.http.client.ClientHttpRequestInterceptor; -import org.springframework.web.client.RestTemplate; -import org.springframework.web.util.DefaultUriBuilderFactory; - -import java.util.List; - -@Getter -@Configuration -public class KeycloakConfig { - - @Value("${dbrepo.endpoints.authService}") - private String keycloakEndpoint; - - @Value("${dbrepo.keycloak.username}") - private String keycloakUsername; - - @Value("${dbrepo.keycloak.password}") - private String keycloakPassword; - - @Value("${dbrepo.keycloak.client}") - private String keycloakClient; - - @Value("${dbrepo.keycloak.clientSecret}") - private String keycloakClientSecret; - - private final ClientHttpRequestInterceptor clientHttpRequestInterceptor; - - @Autowired - public KeycloakConfig(ClientHttpRequestInterceptor clientHttpRequestInterceptor) { - this.clientHttpRequestInterceptor = clientHttpRequestInterceptor; - } - - @Bean("keycloakRestTemplate") - public RestTemplate brokerRestTemplate() { - final RestTemplate restTemplate = new RestTemplate(); - restTemplate.setUriTemplateHandler(new DefaultUriBuilderFactory(keycloakEndpoint)); - restTemplate.getInterceptors() - .addAll(List.of(new KeycloakInterceptor(keycloakUsername, keycloakPassword, keycloakEndpoint), - clientHttpRequestInterceptor)); - return restTemplate; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/WebSecurityConfig.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/WebSecurityConfig.java deleted file mode 100644 index 5bb4b2e9705f36d0e4168f5688ac42ca13de8882..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/config/WebSecurityConfig.java +++ /dev/null @@ -1,107 +0,0 @@ -package at.tuwien.config; - -import at.tuwien.auth.AuthTokenFilter; -import at.tuwien.auth.BasicAuthenticationProvider; -import at.tuwien.gateway.KeycloakGateway; -import io.swagger.v3.oas.annotations.enums.SecuritySchemeType; -import io.swagger.v3.oas.annotations.security.SecurityScheme; -import jakarta.servlet.http.HttpServletResponse; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity; -import org.springframework.security.config.annotation.web.builders.HttpSecurity; -import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; -import org.springframework.security.config.http.SessionCreationPolicy; -import org.springframework.security.web.SecurityFilterChain; -import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter; -import org.springframework.security.web.authentication.www.BasicAuthenticationFilter; -import org.springframework.security.web.util.matcher.AntPathRequestMatcher; -import org.springframework.security.web.util.matcher.OrRequestMatcher; -import org.springframework.web.cors.CorsConfiguration; -import org.springframework.web.cors.UrlBasedCorsConfigurationSource; -import org.springframework.web.filter.CorsFilter; - -@Configuration -@EnableWebSecurity -@EnableGlobalMethodSecurity(prePostEnabled = true) -@SecurityScheme( - name = "bearerAuth", - type = SecuritySchemeType.HTTP, - bearerFormat = "JWT", - scheme = "bearer" -) -@SecurityScheme( - name = "basicAuth", - type = SecuritySchemeType.HTTP, - scheme = "basic" -) -public class WebSecurityConfig { - - @Bean - public AuthTokenFilter authTokenFilter() { - return new AuthTokenFilter(); - } - - @Bean - public SecurityFilterChain filterChain(HttpSecurity http, KeycloakGateway keycloakGateway, - GatewayConfig gatewayConfig) throws Exception { - final OrRequestMatcher internalEndpoints = new OrRequestMatcher( - new AntPathRequestMatcher("/actuator/**", "GET"), - new AntPathRequestMatcher("/v3/api-docs.yaml"), - new AntPathRequestMatcher("/v3/api-docs/**"), - new AntPathRequestMatcher("/swagger-ui/**"), - new AntPathRequestMatcher("/swagger-ui.html") - ); - final OrRequestMatcher publicEndpoints = new OrRequestMatcher( - new AntPathRequestMatcher("/api/**", "GET"), - new AntPathRequestMatcher("/api/**", "HEAD") - ); - /* enable CORS and disable CSRF */ - http = http.cors().and().csrf().disable(); - /* set session management to stateless */ - http = http - .sessionManagement() - .sessionCreationPolicy(SessionCreationPolicy.STATELESS) - .and(); - /* set unauthorized requests exception handler */ - http = http - .exceptionHandling() - .authenticationEntryPoint( - (request, response, ex) -> { - response.sendError(HttpServletResponse.SC_UNAUTHORIZED, - ex.getMessage() - ); - } - ).and(); - /* set permissions on endpoints */ - http.authorizeHttpRequests() - /* our internal endpoints */ - .requestMatchers(internalEndpoints).permitAll() - /* our public endpoints */ - .requestMatchers(publicEndpoints).permitAll() - /* our private endpoints */ - .anyRequest().authenticated(); - /* add JWT token filter */ - http.addFilterBefore(authTokenFilter(), - UsernamePasswordAuthenticationFilter.class - ); - http.addFilterBefore(new BasicAuthenticationFilter(new BasicAuthenticationProvider(gatewayConfig, - authTokenFilter(), keycloakGateway)), - UsernamePasswordAuthenticationFilter.class - ); - return http.build(); - } - - @Bean - public CorsFilter corsFilter() { - final UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); - final CorsConfiguration config = new CorsConfiguration(); - config.setAllowCredentials(true); - config.addAllowedOriginPattern("*"); - config.addAllowedHeader("*"); - config.addAllowedMethod("*"); - source.registerCorsConfiguration("/**", config); - return new CorsFilter(source); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/DashboardConfigDto.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/DashboardConfigDto.java deleted file mode 100644 index e93c50362c3e149defa5bd973c4e252176680a4e..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/DashboardConfigDto.java +++ /dev/null @@ -1,46 +0,0 @@ -package at.tuwien.dto; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -import java.util.List; -import java.util.Map; - -@Data -@NoArgsConstructor -@AllArgsConstructor -public class DashboardConfigDto { - /** - * Map containing information to create time series data. - * <p> - * The key of the map represents the table id. - * The value is a list of {@link TimeSeriesDto} objects in this table. - */ - private Map<Long, List<TimeSeriesDto>> timeSeriesDto; - - /** - * Map containing information about params for the PieChartPanel. - * <p> - * The key of the map represents the table id. - * The value is a Map with key = column id and value = {@link PieChartConfigDto}. - */ - private Map<Long, Map<Long, PieChartConfigDto>> pieChartConfigDto; - - /** - * Map containing information about params for the Histogram. - * <p> - * The key of the map represents the table id. - * The value is a Map with key = column id and value = {@link HistogramConfigDto}. - */ - private Map<Long, Map<Long, HistogramConfigDto>> histogramConfigDto; - - /** - * Map containing information about params for the tables. - * <p> - * The key of the map represents the table id. - * The value is a dto {@link TableConfigDto} holding the properties. - */ - private Map<Long, TableConfigDto> tableConfigDto; - private Integer refreshRate; -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/HistogramConfigDto.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/HistogramConfigDto.java deleted file mode 100644 index be6f3b21e8e0920671fb5ba2746a622818f1119a..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/HistogramConfigDto.java +++ /dev/null @@ -1,14 +0,0 @@ -package at.tuwien.dto; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -@Data -@NoArgsConstructor -@AllArgsConstructor -public class HistogramConfigDto { - private Integer min; - private Integer max; - private Long size; -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/PieChartConfigDto.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/PieChartConfigDto.java deleted file mode 100644 index 487d7042bf24244083c3297ca21e463ec5f08a26..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/PieChartConfigDto.java +++ /dev/null @@ -1,14 +0,0 @@ -package at.tuwien.dto; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -@Data -@NoArgsConstructor -@AllArgsConstructor -public class PieChartConfigDto { - private String limit; - private String decimalPlace; - private Long size; -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TableConfigDto.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TableConfigDto.java deleted file mode 100644 index 0b21d8571da0b964f6f95d924546e86e65b55de8..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TableConfigDto.java +++ /dev/null @@ -1,12 +0,0 @@ -package at.tuwien.dto; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -@Data -@NoArgsConstructor -@AllArgsConstructor -public class TableConfigDto { - private Long size; -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TimeDto.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TimeDto.java deleted file mode 100644 index f78cb3d1c57d9a6a0f47a2de53728fe9c81a59bd..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TimeDto.java +++ /dev/null @@ -1,17 +0,0 @@ -package at.tuwien.dto; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -@Data -@NoArgsConstructor -@AllArgsConstructor -public class TimeDto { - private Long yearColId; - private Long monthColId; - private Long dayColId; - private Long hourColId; - private Long minuteColId; - private Long secondColId; -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TimeSeriesDto.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TimeSeriesDto.java deleted file mode 100644 index dd4356d70b9e1e31f8b8ada04afee215b82d72de..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/dto/TimeSeriesDto.java +++ /dev/null @@ -1,14 +0,0 @@ -package at.tuwien.dto; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -@Data -@NoArgsConstructor -@AllArgsConstructor -public class TimeSeriesDto { - private TimeDto timeDto; - private Long valueColId; - private Long size; -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/endpoints/DashboardEndpoint.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/endpoints/DashboardEndpoint.java deleted file mode 100644 index bd9cc68b24a39edf8e1d90d5ef19433286e301bd..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/endpoints/DashboardEndpoint.java +++ /dev/null @@ -1,92 +0,0 @@ -package at.tuwien.endpoints; - -import at.tuwien.api.error.ApiErrorDto; -import at.tuwien.dto.DashboardConfigDto; -import at.tuwien.service.DashboardService; -import io.swagger.v3.oas.annotations.Operation; -import io.swagger.v3.oas.annotations.media.Content; -import io.swagger.v3.oas.annotations.media.Schema; -import io.swagger.v3.oas.annotations.responses.ApiResponse; -import io.swagger.v3.oas.annotations.responses.ApiResponses; -import io.swagger.v3.oas.annotations.security.SecurityRequirement; -import jakarta.validation.constraints.NotBlank; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.http.HttpStatus; -import org.springframework.http.ResponseEntity; -import org.springframework.web.bind.annotation.*; - -@Log4j2 -@RestController -@CrossOrigin(origins = "*") -@RequestMapping(path = "/api/dashboard") -public class DashboardEndpoint { - private final DashboardService dashboardService; - - @Autowired - public DashboardEndpoint(DashboardService dashboardService) { - this.dashboardService = dashboardService; - } - - @PostMapping("/generate/{dbId}") - @Operation(summary = "Generate dashboard", - description = "Generates dashboard for a provided database id.", - security = {@SecurityRequirement(name = "bearerAuth")}) - @ApiResponses(value = { - @ApiResponse(responseCode = "201", - description = "Created a new dashboard", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = String.class))}), - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public ResponseEntity<String> generateDashboard(@RequestHeader("Authorization") String token, - @NotBlank @PathVariable("dbId") Long dbId, - @RequestBody(required = false) DashboardConfigDto configDto) { - - return ResponseEntity.status(HttpStatus.CREATED) - .body(this.dashboardService.generateDashboard(dbId, token, configDto)); - } - - @RequestMapping(value = "/exists/{dbId}", method = {RequestMethod.GET, RequestMethod.HEAD}) - @Operation(summary = "Check if dashboard exists", - description = "Checks if a dashboard for a provided database id exists.") - @ApiResponses(value = { - @ApiResponse(responseCode = "200", - description = "Returns Boolean if dashboard exsists", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = Boolean.class))}), - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public ResponseEntity<Boolean> checkIfDashboardExists(@NotBlank @PathVariable("dbId") Long dbId) { - return ResponseEntity.status(HttpStatus.OK) - .body(this.dashboardService.checkIfDashboardExists(dbId)); - } - - @DeleteMapping("/{dbId}") - @Operation(summary = "Delete dashboard in Grafana", - description = "Deletes a dashboard in Grafana for a provided id.", - security = {@SecurityRequirement(name = "bearerAuth")}) - @ApiResponses(value = { - @ApiResponse(responseCode = "202", - description = "Deleted grafana dashbaord"), - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}), - }) - public ResponseEntity<Void> removeDashboard(@NotBlank @PathVariable("dbId") Long dbId) { - this.dashboardService.removeDashboard(dbId); - return ResponseEntity.status(HttpStatus.ACCEPTED).build(); - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/endpoints/DataEndpoint.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/endpoints/DataEndpoint.java deleted file mode 100644 index 6e698347df1c0ab5ebb6d16d5e816c09ca4aaf9c..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/endpoints/DataEndpoint.java +++ /dev/null @@ -1,157 +0,0 @@ -package at.tuwien.endpoints; - -import at.tuwien.api.error.ApiErrorDto; -import at.tuwien.panels.*; -import at.tuwien.service.DataService; -import io.swagger.v3.oas.annotations.Operation; -import io.swagger.v3.oas.annotations.media.Content; -import io.swagger.v3.oas.annotations.media.Schema; -import io.swagger.v3.oas.annotations.responses.ApiResponse; -import io.swagger.v3.oas.annotations.responses.ApiResponses; -import jakarta.validation.constraints.NotBlank; -import lombok.extern.slf4j.Slf4j; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.web.bind.annotation.*; - -import org.springframework.web.bind.annotation.RestController; - -import java.util.List; -import java.util.Map; - -@Slf4j -@RestController -@CrossOrigin(origins = "*") -@RequestMapping(path = DataEndpoint.API_PREFIX) -public class DataEndpoint { - public static final String API_PREFIX = "/api/dashboard/data"; - private final DataService dataService; - private static final Long DEFAULT_RESPONSE_SIZE = 100L; - - @Autowired - public DataEndpoint(DataService dataService) { - this.dataService = dataService; - } - - @GetMapping(PieChartPanel.RELATIVE_PATH + "/{dbId}/{viewId}") - @Operation(summary = "Returns data for Pie Chart", - description = "Returns data for Pie Chart for a specific database and view") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public Map<String, Object> getPieChart(@NotBlank @PathVariable Long dbId, @NotBlank @PathVariable Long viewId, - @RequestParam(required = false) Long size) { - if (size == null) { - size = DEFAULT_RESPONSE_SIZE; - } - - return dataService.getPieChartData(dbId, viewId, size); - } - - @GetMapping(CntAllPanel.RELATIVE_PATH + "/{dbId}/{viewId}") - @Operation(summary = "Returns data for the Count All Stats Visualization", - description = "Returns data for the Count All Stats Visualization for a specific database and view") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public Map<String, Object> getCntAll(@NotBlank @PathVariable Long dbId, @NotBlank @PathVariable Long viewId) { - - return dataService.getCntAllData(dbId, viewId); - } - - @GetMapping(TablePanel.RELATIVE_PATH + "/{dbId}/{tableId}") - @Operation(summary = "Returns data for the Table Visualization", - description = "Returns data for the Table Visualization for a specific database and table") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public List<Map<String, Object>> getTable(@NotBlank @PathVariable Long dbId, - @NotBlank @PathVariable Long tableId, - @RequestParam(required = false) Long size) { - if (size == null) { - size = DEFAULT_RESPONSE_SIZE; - } - - return dataService.getTableData(dbId, tableId, size); - } - - @GetMapping(HistogramPanel.RELATIVE_PATH + "/{dbId}/{viewId}") - @Operation(summary = "Returns data for the Histogram Visualization", - description = "Returns data for the Histogram Visualization for a specific database and view") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public Map<String, List<Object>> getHistogram(@NotBlank @PathVariable Long dbId, @NotBlank @PathVariable Long viewId, - @RequestParam(required = false) Long size) { - if (size == null) { - size = DEFAULT_RESPONSE_SIZE; - } - - return dataService.getHistogramData(dbId, viewId, size); - } - - @GetMapping(StatsPanel.RELATIVE_PATH + "/{dbId}/{tableId}") - @Operation(summary = "Returns data for the Stats Visualization", - description = "Returns data for the Stats Visualization for a specific database and table") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public List<Map<String, Object>> getStats(@NotBlank @PathVariable Long dbId, @NotBlank @PathVariable Long tableId) { - return dataService.getStatsData(dbId, tableId); - } - - @GetMapping(TimeSeriesPanel.RELATIVE_PATH + "/{dbId}/{viewId}") - @Operation(summary = "Returns data for the Time Visualization", - description = "Returns data for the Time Visualization for a specific database and view") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public Map<String, List<Map<String, Object>>> getTimeSeries(@NotBlank @PathVariable Long dbId, @NotBlank @PathVariable Long viewId, - @RequestParam(required = false) Long size) { - if (size == null) { - size = DEFAULT_RESPONSE_SIZE; - } - return dataService.getTimeSeriesData(dbId, viewId, size); - } - - @GetMapping(MultiTimeSeriesPanel.RELATIVE_PATH + "/{dbId}/{viewId}") - @Operation(summary = "Returns data for the Multi Time Visualization", - description = "Returns data for the MUlti Time Visualization for a specific database and view") - @ApiResponses(value = { - @ApiResponse(responseCode = "500", - description = "Internal error", - content = {@Content( - mediaType = "application/json", - schema = @Schema(implementation = ApiErrorDto.class))}) - }) - public Map<String, List<Map<String, Object>>> getMultiTimeSeries(@NotBlank @PathVariable Long dbId, @NotBlank @PathVariable Long viewId, - @RequestParam(required = false) Long size) { - if (size == null) { - size = DEFAULT_RESPONSE_SIZE; - } - return dataService.getMultiTimeSeriesData(dbId, viewId, size); - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ContainerNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ContainerNotFoundException.java deleted file mode 100644 index a15fcfb8a9ebd2790036be9c1df295176d339ee3..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ContainerNotFoundException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.NOT_FOUND) -public class ContainerNotFoundException extends Exception { - - public ContainerNotFoundException(String message) { - super(message); - } - - public ContainerNotFoundException(String message, Throwable thr) { - super(message, thr); - } - - public ContainerNotFoundException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseMalformedException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseMalformedException.java deleted file mode 100644 index 1ead17c389ee59b69ce6c6c4d994885b2b4e153c..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseMalformedException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class DatabaseMalformedException extends Exception { - - public DatabaseMalformedException(String message) { - super(message); - } - - public DatabaseMalformedException(String message, Throwable thr) { - super(message, thr); - } - - public DatabaseMalformedException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseNotFoundException.java deleted file mode 100644 index cb9075c80af9cc4156905350506af772f19bf49a..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseNotFoundException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.NOT_FOUND) -public class DatabaseNotFoundException extends Exception { - - public DatabaseNotFoundException(String message) { - super(message); - } - - public DatabaseNotFoundException(String message, Throwable thr) { - super(message, thr); - } - - public DatabaseNotFoundException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseUnavailableException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseUnavailableException.java deleted file mode 100644 index e584390ec9b1fb5ad51529a9c32eade744a35681..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/DatabaseUnavailableException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.SERVICE_UNAVAILABLE) -public class DatabaseUnavailableException extends Exception { - - public DatabaseUnavailableException(String message) { - super(message); - } - - public DatabaseUnavailableException(String message, Throwable thr) { - super(message, thr); - } - - public DatabaseUnavailableException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/FormatNotAvailableException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/FormatNotAvailableException.java deleted file mode 100644 index 4ca41e346daebd26e5e369d72e8b31260e791d1b..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/FormatNotAvailableException.java +++ /dev/null @@ -1,23 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -import java.io.IOException; - -@ResponseStatus(code = HttpStatus.NOT_ACCEPTABLE) -public class FormatNotAvailableException extends IOException { - - public FormatNotAvailableException(String msg) { - super(msg); - } - - public FormatNotAvailableException(String msg, Throwable thr) { - super(msg + ": " + thr.getLocalizedMessage(), thr); - } - - public FormatNotAvailableException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/JsonProcessingException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/JsonProcessingException.java deleted file mode 100644 index 66f414018f443dbb63610812797f554badab5783..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/JsonProcessingException.java +++ /dev/null @@ -1,17 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.INTERNAL_SERVER_ERROR) -public class JsonProcessingException extends RuntimeException { - - public JsonProcessingException(String message) { - super(message); - } - - public JsonProcessingException(String message, Throwable thr) { - super(message, thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/NotAllowedException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/NotAllowedException.java deleted file mode 100644 index 341b93a6443e06121d8ba639212aa7e69a6da7af..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/NotAllowedException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.FORBIDDEN) -public class NotAllowedException extends Exception { - - public NotAllowedException(String message) { - super(message); - } - - public NotAllowedException(String message, Throwable thr) { - super(message, thr); - } - - public NotAllowedException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/PaginationException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/PaginationException.java deleted file mode 100644 index b47c66c5b37fd78eabb2a6f056cd8050f81e19d1..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/PaginationException.java +++ /dev/null @@ -1,22 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class PaginationException extends Exception { - - public PaginationException(String msg) { - super(msg); - } - - public PaginationException(String msg, Throwable thr) { - super(msg + ": " + thr.getLocalizedMessage(), thr); - } - - public PaginationException(Throwable thr) { - super(thr); - } - -} - diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryMalformedException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryMalformedException.java deleted file mode 100644 index 4d89f64f9478bc0e4284980233f8b79f4adbbfc8..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryMalformedException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class QueryMalformedException extends Exception { - - public QueryMalformedException(String message) { - super(message); - } - - public QueryMalformedException(String message, Throwable thr) { - super(message, thr); - } - - public QueryMalformedException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryNotFoundException.java deleted file mode 100644 index 44fcbf4ceebecf53423624e2374ffe2ae0f99c18..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryNotFoundException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.NOT_FOUND) -public class QueryNotFoundException extends Exception { - - public QueryNotFoundException(String message) { - super(message); - } - - public QueryNotFoundException(String message, Throwable thr) { - super(message, thr); - } - - public QueryNotFoundException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreCreateException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreCreateException.java deleted file mode 100644 index e7166363e02e94facafbee299226ec2f45fcfb9c..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreCreateException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class QueryStoreCreateException extends Exception { - - public QueryStoreCreateException(String message) { - super(message); - } - - public QueryStoreCreateException(String message, Throwable thr) { - super(message, thr); - } - - public QueryStoreCreateException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreGCException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreGCException.java deleted file mode 100644 index d1d25bbde1efbd916c8233de0aaf569d9e86ee3d..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreGCException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class QueryStoreGCException extends Exception { - - public QueryStoreGCException(String message) { - super(message); - } - - public QueryStoreGCException(String message, Throwable thr) { - super(message, thr); - } - - public QueryStoreGCException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreInsertException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreInsertException.java deleted file mode 100644 index 95c621493e7540df465c0715537409b704bada27..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStoreInsertException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class QueryStoreInsertException extends Exception { - - public QueryStoreInsertException(String message) { - super(message); - } - - public QueryStoreInsertException(String message, Throwable thr) { - super(message, thr); - } - - public QueryStoreInsertException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStorePersistException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStorePersistException.java deleted file mode 100644 index b9250ffefced58fa0833db10df630dace773ff46..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/QueryStorePersistException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class QueryStorePersistException extends Exception { - - public QueryStorePersistException(String message) { - super(message); - } - - public QueryStorePersistException(String message, Throwable thr) { - super(message, thr); - } - - public QueryStorePersistException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/RemoteUnavailableException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/RemoteUnavailableException.java deleted file mode 100644 index d007a65c02b927515a14b0703d4f0b26b2825a39..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/RemoteUnavailableException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.SERVICE_UNAVAILABLE) -public class RemoteUnavailableException extends Exception { - - public RemoteUnavailableException(String message) { - super(message); - } - - public RemoteUnavailableException(String message, Throwable thr) { - super(message, thr); - } - - public RemoteUnavailableException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/RestTemplateExchangeException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/RestTemplateExchangeException.java deleted file mode 100644 index 6724c3f260f60ac889d2cd6e86b46a1ca683ec95..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/RestTemplateExchangeException.java +++ /dev/null @@ -1,17 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.INTERNAL_SERVER_ERROR) -public class RestTemplateExchangeException extends RuntimeException { - - public RestTemplateExchangeException(String message) { - super(message); - } - - public RestTemplateExchangeException(String message, Throwable thr) { - super(message, thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ServiceConnectionException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ServiceConnectionException.java deleted file mode 100644 index ec36c03e3a0b4cca4b8bd495ba94d8e5bb05ac62..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ServiceConnectionException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_GATEWAY) -public class ServiceConnectionException extends Exception { - - public ServiceConnectionException(String msg) { - super(msg); - } - - public ServiceConnectionException(String msg, Throwable thr) { - super(msg + ": " + thr.getLocalizedMessage(), thr); - } - - public ServiceConnectionException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ServiceException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ServiceException.java deleted file mode 100644 index 56004d6a47361250a248cc1d89b155a47ad295d2..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/ServiceException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.SERVICE_UNAVAILABLE) -public class ServiceException extends Exception { - - public ServiceException(String message) { - super(message); - } - - public ServiceException(String message, Throwable thr) { - super(message, thr); - } - - public ServiceException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SidecarExportException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SidecarExportException.java deleted file mode 100644 index 88ac95e2e9476d4b4855ae6aa8c3d150fe292994..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SidecarExportException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.SERVICE_UNAVAILABLE) -public class SidecarExportException extends Exception { - - public SidecarExportException(String message) { - super(message); - } - - public SidecarExportException(String message, Throwable thr) { - super(message, thr); - } - - public SidecarExportException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SidecarImportException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SidecarImportException.java deleted file mode 100644 index 8dd9a832be21fea6442043e500a3a77eb1399f64..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SidecarImportException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.SERVICE_UNAVAILABLE) -public class SidecarImportException extends Exception { - - public SidecarImportException(String message) { - super(message); - } - - public SidecarImportException(String message, Throwable thr) { - super(message, thr); - } - - public SidecarImportException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/StorageNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/StorageNotFoundException.java deleted file mode 100644 index 79c3608adcdcfb9d2582e92cb9950f814db97991..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/StorageNotFoundException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.NOT_FOUND) -public class StorageNotFoundException extends Exception { - - public StorageNotFoundException(String message) { - super(message); - } - - public StorageNotFoundException(String message, Throwable thr) { - super(message, thr); - } - - public StorageNotFoundException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/StorageUnavailableException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/StorageUnavailableException.java deleted file mode 100644 index 96a33f11754716229f87e88d94434b2d6b692b4d..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/StorageUnavailableException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.SERVICE_UNAVAILABLE) -public class StorageUnavailableException extends Exception { - - public StorageUnavailableException(String message) { - super(message); - } - - public StorageUnavailableException(String message, Throwable thr) { - super(message, thr); - } - - public StorageUnavailableException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SyncDatabaseNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SyncDatabaseNotFoundException.java deleted file mode 100644 index f0bedd46ece4c4ff98917aea36b4fc7c84c651e7..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/SyncDatabaseNotFoundException.java +++ /dev/null @@ -1,17 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.INTERNAL_SERVER_ERROR) -public class SyncDatabaseNotFoundException extends RuntimeException { - - public SyncDatabaseNotFoundException(String message) { - super(message); - } - - public SyncDatabaseNotFoundException(String message, Throwable thr) { - super(message, thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableExistsException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableExistsException.java deleted file mode 100644 index dbbe0b86e18088992dd7da0236ffcca7b9c8181a..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableExistsException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.CONFLICT) -public class TableExistsException extends Exception { - - public TableExistsException(String message) { - super(message); - } - - public TableExistsException(String message, Throwable thr) { - super(message, thr); - } - - public TableExistsException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableMalformedException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableMalformedException.java deleted file mode 100644 index 6c959fc55b7a68c2a1a6dc5a9cd7b3df5f1f4a86..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableMalformedException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.BAD_REQUEST) -public class TableMalformedException extends Exception { - - public TableMalformedException(String message) { - super(message); - } - - public TableMalformedException(String message, Throwable thr) { - super(message, thr); - } - - public TableMalformedException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableNotFoundException.java deleted file mode 100644 index 05547bdfe27b63054ef282a79dfeababe11f2618..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/TableNotFoundException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.NOT_FOUND) -public class TableNotFoundException extends Exception { - - public TableNotFoundException(String message) { - super(message); - } - - public TableNotFoundException(String message, Throwable thr) { - super(message, thr); - } - - public TableNotFoundException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/UserNotFoundException.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/UserNotFoundException.java deleted file mode 100644 index f3bece1e142206253a058e34d4a8e27ece6103a5..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/exception/UserNotFoundException.java +++ /dev/null @@ -1,21 +0,0 @@ -package at.tuwien.exception; - -import org.springframework.http.HttpStatus; -import org.springframework.web.bind.annotation.ResponseStatus; - -@ResponseStatus(code = HttpStatus.NOT_FOUND) -public class UserNotFoundException extends Exception { - - public UserNotFoundException(String message) { - super(message); - } - - public UserNotFoundException(String message, Throwable thr) { - super(message, thr); - } - - public UserNotFoundException(Throwable thr) { - super(thr); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/gateway/KeycloakGateway.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/gateway/KeycloakGateway.java deleted file mode 100644 index a05a75a6ff890feba33e1d14f2bd1a9407845861..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/gateway/KeycloakGateway.java +++ /dev/null @@ -1,11 +0,0 @@ -package at.tuwien.gateway; - -import at.tuwien.api.keycloak.TokenDto; -import at.tuwien.exception.ServiceConnectionException; -import at.tuwien.exception.ServiceException; - -public interface KeycloakGateway { - - TokenDto obtainUserToken(String username, String password) throws ServiceConnectionException, ServiceException; - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/gateway/impl/KeycloakGatewayImpl.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/gateway/impl/KeycloakGatewayImpl.java deleted file mode 100644 index 76f3e83cef138b8d64151757e303fd05555a4591..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/gateway/impl/KeycloakGatewayImpl.java +++ /dev/null @@ -1,81 +0,0 @@ -package at.tuwien.gateway.impl; - -import at.tuwien.api.keycloak.TokenDto; -import at.tuwien.config.KeycloakConfig; -import at.tuwien.exception.ServiceConnectionException; -import at.tuwien.exception.ServiceException; -import at.tuwien.gateway.KeycloakGateway; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Qualifier; -import org.springframework.http.*; -import org.springframework.stereotype.Service; -import org.springframework.util.LinkedMultiValueMap; -import org.springframework.util.MultiValueMap; -import org.springframework.web.client.HttpServerErrorException; -import org.springframework.web.client.ResourceAccessException; -import org.springframework.web.client.RestTemplate; - -@Log4j2 -@Service -public class KeycloakGatewayImpl implements KeycloakGateway { - - private final RestTemplate restTemplate; - private final KeycloakConfig keycloakConfig; - - public KeycloakGatewayImpl(@Qualifier("keycloakRestTemplate") RestTemplate restTemplate, - KeycloakConfig keycloakConfig) { - this.restTemplate = restTemplate; - this.keycloakConfig = keycloakConfig; - } - - public TokenDto obtainToken() throws ServiceConnectionException, ServiceException { - final HttpHeaders headers = new HttpHeaders(); - headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED); - final MultiValueMap<String, String> payload = new LinkedMultiValueMap<>(); - payload.add("username", keycloakConfig.getKeycloakUsername()); - payload.add("password", keycloakConfig.getKeycloakPassword()); - payload.add("grant_type", "password"); - payload.add("client_id", "admin-cli"); - final String url = keycloakConfig.getKeycloakEndpoint() + "/realms/master/protocol/openid-connect/token"; - log.debug("request admin token from url {}", url); - final ResponseEntity<TokenDto> response; - try { - response = restTemplate.exchange(url, HttpMethod.POST, new HttpEntity<>(payload, headers), TokenDto.class); - } catch (ResourceAccessException | HttpServerErrorException.ServiceUnavailable e) { - log.error("Failed to obtain admin token: {}", e.getMessage()); - throw new ServiceConnectionException("Failed to obtain admin token: " + e.getMessage(), e); - } catch (Exception e) { - log.error("Failed to obtain admin token: remote host answered unexpected: {}", e.getMessage(), e); - throw new ServiceException("Failed to obtain admin token: remote host answered unexpected: " + e.getMessage(), e); - } - return response.getBody(); - } - - @Override - public TokenDto obtainUserToken(String username, String password) throws ServiceConnectionException, ServiceException { - final HttpHeaders headers = new HttpHeaders(); - headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED); - final MultiValueMap<String, String> payload = new LinkedMultiValueMap<>(); - payload.add("username", username); - payload.add("password", password); - payload.add("grant_type", "password"); - payload.add("scope", "openid roles attributes"); - payload.add("client_id", keycloakConfig.getKeycloakClient()); - payload.add("client_secret", keycloakConfig.getKeycloakClientSecret()); - final String url = keycloakConfig.getKeycloakEndpoint() + "/realms/dbrepo/protocol/openid-connect/token"; - log.debug("request user token from url {}", url); - final ResponseEntity<TokenDto> response; - try { - response = new RestTemplate() - .exchange(url, HttpMethod.POST, new HttpEntity<>(payload, headers), TokenDto.class); - } catch (ResourceAccessException | HttpServerErrorException.ServiceUnavailable e) { - log.error("Failed to obtain user token: {}", e.getMessage()); - throw new ServiceConnectionException("Failed to obtain user token: " + e.getMessage(), e); - } catch (Exception e) { - log.error("Failed to obtain user token: unexpected response: {}", e.getMessage(), e); - throw new ServiceException("Failed to obtain user token: unexpected response: " + e.getMessage(), e); - } - return response.getBody(); - } - -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/handlers/DashboardApiExceptionHandler.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/handlers/DashboardApiExceptionHandler.java deleted file mode 100644 index 80c834f77c8078d9c7d99bddeb438229caabe726..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/handlers/DashboardApiExceptionHandler.java +++ /dev/null @@ -1,52 +0,0 @@ -package at.tuwien.handlers; - -import at.tuwien.api.error.ApiErrorDto; -import at.tuwien.exception.RestTemplateExchangeException; -import at.tuwien.exception.JsonProcessingException; -import at.tuwien.exception.SyncDatabaseNotFoundException; -import io.swagger.v3.oas.annotations.Hidden; -import lombok.extern.log4j.Log4j2; -import org.springframework.http.HttpHeaders; -import org.springframework.http.HttpStatus; -import org.springframework.http.ResponseEntity; -import org.springframework.web.bind.annotation.ControllerAdvice; -import org.springframework.web.bind.annotation.ExceptionHandler; -import org.springframework.web.bind.annotation.ResponseStatus; - -@Log4j2 -@ControllerAdvice -public class DashboardApiExceptionHandler { - - @Hidden - @ResponseStatus(code = HttpStatus.INTERNAL_SERVER_ERROR) - @ExceptionHandler(JsonProcessingException.class) - public ResponseEntity<ApiErrorDto> handle(JsonProcessingException e) { - return genericHandle(e.getClass(), e.getLocalizedMessage()); - } - - @Hidden - @ResponseStatus(code = HttpStatus.INTERNAL_SERVER_ERROR) - @ExceptionHandler(RestTemplateExchangeException.class) - public ResponseEntity<ApiErrorDto> handle(RestTemplateExchangeException e) { - return genericHandle(e.getClass(), e.getLocalizedMessage()); - } - - @Hidden - @ResponseStatus(code = HttpStatus.INTERNAL_SERVER_ERROR) - @ExceptionHandler(SyncDatabaseNotFoundException.class) - public ResponseEntity<ApiErrorDto> handle(SyncDatabaseNotFoundException e) { - return genericHandle(e.getClass(), e.getLocalizedMessage()); - } - - private ResponseEntity<ApiErrorDto> genericHandle(Class<?> exceptionClass, String message) { - final HttpHeaders headers = new HttpHeaders(); - headers.set("Content-Type", "application/problem+json"); - final ResponseStatus annotation = exceptionClass.getAnnotation(ResponseStatus.class); - final ApiErrorDto response = ApiErrorDto.builder() - .status(annotation.code()) - .message(message) - .code(annotation.reason()) - .build(); - return new ResponseEntity<>(response, headers, response.getStatus()); - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/interceptor/KeycloakInterceptor.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/interceptor/KeycloakInterceptor.java deleted file mode 100644 index 78fb5adc61fd2420cfc62e72cb4aa4c700c3b82b..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/interceptor/KeycloakInterceptor.java +++ /dev/null @@ -1,55 +0,0 @@ -package at.tuwien.interceptor; - -import at.tuwien.api.keycloak.TokenDto; -import lombok.extern.log4j.Log4j2; -import org.springframework.http.*; -import org.springframework.http.client.ClientHttpRequestExecution; -import org.springframework.http.client.ClientHttpRequestInterceptor; -import org.springframework.http.client.ClientHttpResponse; -import org.springframework.util.LinkedMultiValueMap; -import org.springframework.util.MultiValueMap; -import org.springframework.web.client.HttpServerErrorException; -import org.springframework.web.client.ResourceAccessException; -import org.springframework.web.client.RestTemplate; - -import java.io.IOException; - -@Log4j2 -public class KeycloakInterceptor implements ClientHttpRequestInterceptor { - - private final String adminUsername; - private final String adminPassword; - private final String keycloakEndpoint; - - public KeycloakInterceptor(String adminUsername, String adminPassword, String keycloakEndpoint) { - this.adminUsername = adminUsername; - this.adminPassword = adminPassword; - this.keycloakEndpoint = keycloakEndpoint; - } - - @Override - public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) - throws IOException { - final RestTemplate restTemplate = new RestTemplate(); - final HttpHeaders headers = new HttpHeaders(); - headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED); - final MultiValueMap<String, String> payload = new LinkedMultiValueMap<>(); - payload.add("username", adminUsername); - payload.add("password", adminPassword); - payload.add("grant_type", "password"); - payload.add("client_id", "admin-cli"); - final ResponseEntity<TokenDto> response; - try { - response = restTemplate.exchange(keycloakEndpoint + "/realms/master/protocol/openid-connect/token", - HttpMethod.POST, new HttpEntity<>(payload, headers), TokenDto.class); - } catch (ResourceAccessException | HttpServerErrorException.ServiceUnavailable e) { - log.error("Failed to obtain admin token: {}", e.getMessage()); - return execution.execute(request, body); - } - if (response.getBody() == null) { - return execution.execute(request, body); - } - request.getHeaders().set("Authorization", "Bearer " + response.getBody().getAccessToken()); - return execution.execute(request, body); - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/AbstractPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/AbstractPanel.java deleted file mode 100644 index 7d45e439226cdb82abc8c87d99f21b19461c57d7..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/AbstractPanel.java +++ /dev/null @@ -1,47 +0,0 @@ -package at.tuwien.panels; - -import lombok.Setter; - -public abstract class AbstractPanel { - @Setter - protected static String dataEndpoint; - public static final String DATASRC_UID = "infinityDataSrc"; - - protected static int x; - protected static int y; - private static int prevHeight = -1; - - public static void resetCoordinates() { - x = 0; - y = 0; - } - - public static void addRowPlaceHolder() { - y += 1; - } - - public static void markNewRow() { - x = 0; - } - - - public static void handleOverflow(int height, int width) { - if ( (x + width) > 24) { - x = 0; - y += prevHeight == -1 ? height : prevHeight; - prevHeight = height; - } - } - - public static void updateCoords(int height, int width) { - x += width; - - if (x > 24) { - x = 0; - y += prevHeight == -1 ? height : prevHeight; - } - prevHeight = height; - } - - public abstract String getConstructedPanel(); -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/CntAllPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/CntAllPanel.java deleted file mode 100644 index f5af7d56e4afb6047b2b1bf6c18ea21a5ff1fcaa..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/CntAllPanel.java +++ /dev/null @@ -1,69 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class CntAllPanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/cntAll"; - private static final int HEIGHT = 8; - private static final int WIDTH = 5; - private final String dataAPI; - - public CntAllPanel(Long dbId, Long vId) { - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, vId); - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = "{\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"fieldConfig\": {\n" + - " \"defaults\": {\n" + - " \"color\": {\n" + - " \"fixedColor\": \"#FFFFFF\",\n" + - " \"mode\": \"fixed\"\n" + - " },\n" + - " \"mappings\": []\n" + - " },\n" + - " \"overrides\": []\n" + - " },\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - " \"targets\": [\n" + - " {\n" + - " \"columns\": [],\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"filters\": [],\n" + - " \"format\": \"table\",\n" + - " \"global_query_id\": \"\",\n" + - " \"refId\": \"A\",\n" + - " \"root_selector\": \"\",\n" + - " \"source\": \"url\",\n" + - " \"type\": \"json\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"data\": \"\",\n" + - " \"method\": \"GET\"\n" + - " }\n" + - " }\n" + - " ],\n" + - " \"title\": \"Total elements\",\n" + - " \"type\": \"stat\"\n" + - " }"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/Dashboard.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/Dashboard.java deleted file mode 100644 index 322485b9094dc76b8867b75d6c2b13f052796e22..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/Dashboard.java +++ /dev/null @@ -1,29 +0,0 @@ -package at.tuwien.panels; - -import java.util.List; - -public class Dashboard { - - public String getDashboard(List<String> panels, Long dbId, int refreshrate) { - - return "{\n" + - " \"dashboard\": {\n" + - " \"id\": null,\n" + - " \"uid\": \"" + dbId + "\",\n" + - " \"title\": \"automated dashboard_" + dbId + "\",\n" + - " \"tags\": [\n" + - " \"templated\"\n" + - " ],\n" + - " \"timezone\": \"browser\",\n" + - " \"schemaVersion\": 16,\n" + - " \"refresh\": \"" + (refreshrate == 0 ? "" : refreshrate + "s") + "\",\n" + - " \"panels\": [" + - String.join(", ", panels) + - " ]" + - " \n" + - " },\n" + - " \"message\": \"automated creation of dashboard\",\n" + - " \"overwrite\": false\n" + - "}"; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/HistogramPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/HistogramPanel.java deleted file mode 100644 index e021f0ab6b98b20eef7694c5b862f014db2cd870..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/HistogramPanel.java +++ /dev/null @@ -1,110 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.dto.HistogramConfigDto; -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class HistogramPanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/histogram"; - private static final int HEIGHT = 8; - private static final int WIDTH = 5; - private String dataAPI; - private final String colName; - private Integer min; - private Integer max; - - public HistogramPanel(Long dbId, Long vId, String colName, HistogramConfigDto configDto) { - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, vId); - this.colName = colName; - - if (configDto != null) { - if (configDto.getMin() != null) { - this.min = configDto.getMin(); - } - - if (configDto.getMax() != null) { - this.max = configDto.getMax(); - } - - if (configDto.getSize() != null) { - dataAPI += String.format("?size=%d", configDto.getSize()); - } - } - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = "{\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"fieldConfig\": {\n" + - " \"defaults\": {\n" + - " \"color\": {\n" + - " \"mode\": \"palette-classic\"\n" + - " },\n" + - " \"custom\": {\n" + - " \"fillOpacity\": 80,\n" + - " \"gradientMode\": \"none\",\n" + - " \"hideFrom\": {\n" + - " \"legend\": false,\n" + - " \"tooltip\": true,\n" + - " \"viz\": false\n" + - " },\n" + - " \"lineWidth\": 1\n" + - " },\n" + - " \"mappings\": [],\n" + - " \"max\": " + ((max == null) ? "null" : max) + ",\n" + - " \"min\": " + ((min == null) ? "null" : min) + "\n" + - " },\n" + - " \"overrides\": []\n" + - " },\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - " \"id\": null,\n" + - " \"description\": \"" + "Each bar represents a bucket, and the bar height represents " + - "the frequency of the values from the column " + this.colName + " that fell into that bucket's interval.\",\n" + - " \"options\": {\n" + - " \"legend\": {\n" + - " \"calcs\": [],\n" + - " \"displayMode\": \"list\",\n" + - " \"placement\": \"bottom\",\n" + - " \"showLegend\": false\n" + - " }\n" + - " },\n" + - " \"targets\": [\n" + - " {\n" + - " \"columns\": [],\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"filters\": [],\n" + - " \"format\": \"table\",\n" + - " \"global_query_id\": \"\",\n" + - " \"refId\": \"A\",\n" + - " \"root_selector\": \"values\",\n" + - " \"source\": \"url\",\n" + - " \"type\": \"json\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"data\": \"\",\n" + - " \"method\": \"GET\"\n" + - " }\n" + - " }\n" + - " ],\n" + - " \"title\": \"" + "Distribution of " + this.colName + " \",\n" + - " \"type\": \"histogram\"\n" + - " }"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/MultiTimeSeriesPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/MultiTimeSeriesPanel.java deleted file mode 100644 index 70be0650ee1b026702d74c01fb997b7c368210db..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/MultiTimeSeriesPanel.java +++ /dev/null @@ -1,90 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class MultiTimeSeriesPanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/multitimeseries"; - public static final String VIEW_MULTI_TIMECOL = "timecol"; - public static final String VIEW_MULTI_SELECTOR_TIME = "time"; - public static final String VIEW_MULTI_SELECTOR_VALUE = "value"; - public static final String VIEW_MULTI_SELECTOR_NAME = "name"; - - - private static final int HEIGHT = 8; - private static final int WIDTH = 5; - private String dataAPI; - - public MultiTimeSeriesPanel(Long dbId, Long vId) { - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, vId); - dataAPI += String.format("?size=%d", 100); - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = " {\n" + - "\"datasource\": {\n" + - " \"uid\": \"" + DATASRC_UID + "\",\n" + - " \"type\": \"yesoreyeram-infinity-datasource\"\n" + - " },\n" + - " \"type\": \"timeseries\",\n" + - " \"title\": \"Time Series\",\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - "\"options\": {\n" + - " \"legend\": {\n" + - " \"calcs\": [],\n" + - " \"displayMode\": \"list\",\n" + - " \"placement\": \"bottom\",\n" + - " \"showLegend\": true\n" + - " },\n" + - " \"tooltip\": {\n" + - " \"mode\": \"single\",\n" + - " \"sort\": \"none\"\n" + - " }\n" + - " },\n" + - " \"targets\": [\n" + - " {\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"refId\": \"A\",\n" + - " \"type\": \"json\",\n" + - " \"source\": \"url\",\n" + - " \"format\": \"timeseries\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"method\": \"GET\",\n" + - " \"data\": \"\"\n" + - " },\n" + - " \"root_selector\": \"time_series\",\n" + - " \"columns\": [\n" + - " {\n" + - " \"selector\": \"" + VIEW_MULTI_SELECTOR_TIME + "\",\n" + - " \"type\": \"timestamp\"\n" + - " },\n" + - " {\n" + - " \"selector\": \"" + VIEW_MULTI_SELECTOR_VALUE + "\",\n" + - " \"type\": \"number\"\n" + - " },\n" + - " {\n" + - " \"selector\": \"" + VIEW_MULTI_SELECTOR_NAME + "\",\n" + - " \"type\": \"string\"\n" + - " }\n" + - " ],\n" + - " \"filters\": [],\n" + - " \"global_query_id\": \"\"\n" + - " }\n" + - " ]}"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/PieChartPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/PieChartPanel.java deleted file mode 100644 index 3b98dec4d0b0bfe94461e6d06b791420c8475ed0..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/PieChartPanel.java +++ /dev/null @@ -1,110 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.dto.PieChartConfigDto; -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class PieChartPanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/piechart"; - public static final String VIEW_PIE_PERCENTAGE_COL = "percentage"; - - private static final int HEIGHT = 8; - private static final int WIDTH = 7; - private String dataAPI; - private final String colName; - - public PieChartPanel(Long dbId, Long vId, String colName, PieChartConfigDto config) { - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, vId); - this.colName = colName; - - if (config != null && config.getSize() != null) { - dataAPI += String.format("?size=%d", config.getSize()); - } - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = "{\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"fieldConfig\": {\n" + - " \"defaults\": {\n" + - " \"color\": {\n" + - " \"mode\": \"palette-classic\"\n" + - " },\n" + - " \"custom\": {\n" + - " \"hideFrom\": {\n" + - " \"legend\": false,\n" + - " \"tooltip\": false,\n" + - " \"viz\": false\n" + - " }\n" + - " },\n" + - " \"mappings\": []\n" + - " },\n" + - " \"overrides\": []\n" + - " },\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - " \"options\": {\n" + - " \"displayLabels\": [\n" + - " \"percent\"\n" + - " ],\n" + - " \"legend\": {\n" + - " \"calcs\": [],\n" + - " \"displayMode\": \"list\",\n" + - " \"placement\": \"right\",\n" + - " \"showLegend\": true,\n" + - " \"values\": [\n" + - " \"value\"\n" + - " ]\n" + - " },\n" + - " \"pieType\": \"pie\",\n" + - " \"reduceOptions\": {\n" + - " \"calcs\": [\n" + - " \"lastNotNull\"\n" + - " ],\n" + - " \"fields\": \"\",\n" + - " \"values\": false\n" + - " },\n" + - " \"tooltip\": {\n" + - " \"mode\": \"single\",\n" + - " \"sort\": \"none\"\n" + - " }\n" + - " },\n" + - " \"targets\": [\n" + - " {\n" + - " \"columns\": [],\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"filters\": [],\n" + - " \"format\": \"table\",\n" + - " \"global_query_id\": \"\",\n" + - " \"refId\": \"A\",\n" + - " \"root_selector\": \"\",\n" + - " \"source\": \"url\",\n" + - " \"type\": \"json\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"data\": \"\",\n" + - " \"method\": \"GET\"\n" + - " }\n" + - " }\n" + - " ],\n" + - " \"title\": \"Distribution of Most Frequent " + this.colName + "\",\n" + - " \"type\": \"piechart\"\n" + - " }"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/RowPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/RowPanel.java deleted file mode 100644 index 94ae55b74b10243a0daa8085acc602663a11adea..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/RowPanel.java +++ /dev/null @@ -1,52 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.exception.JsonProcessingException; -import com.fasterxml.jackson.databind.JsonNode; -import com.fasterxml.jackson.databind.ObjectMapper; -import lombok.extern.log4j.Log4j2; - -import java.util.List; - -@Log4j2 -public class RowPanel extends AbstractPanel { - private static final int HEIGHT = 1; - private static final int WIDTH = 24; - private final String name; - private final List<String> tablePanels; - private final ObjectMapper mapper; - - public RowPanel(String name, List<String> tablePanels) { - this.name = name; - this.tablePanels = tablePanels; - this.mapper = new ObjectMapper(); - } - - @Override - public String getConstructedPanel() { - - int rowY = -1; - try{ - JsonNode rootNode = mapper.readTree(tablePanels.get(0)); - rowY = rootNode.path("gridPos").path("y").asInt() - 1; - } catch (Exception e) { - log.debug("failed to read json of table panel"); - throw new JsonProcessingException("Failed to parse table panel"); - } - - return "{\n" + - " \"collapsed\": true,\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + 0 + ",\n" + - " \"y\": " + rowY + "\n" + - " },\n" + - " \"id\": null,\n" + - " \"panels\": [" + - String.join(", ", tablePanels) + - "],\n" + - " \"title\": \"" + name + "\",\n" + - " \"type\": \"row\"\n" + - " }"; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/StatsPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/StatsPanel.java deleted file mode 100644 index 81e920433647d9ee9bf2b2098ac85e2429c52f88..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/StatsPanel.java +++ /dev/null @@ -1,183 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class StatsPanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/stats"; - public static final String HEADER_COL = "column"; - public static final String HEADER_MIN = "min"; - public static final String HEADER_MAX = "max"; - public static final String HEADER_STDDEV = "stddev"; - public static final String HEADER_AVG = "median"; - - private static final int HEIGHT = 8; - private static final int WIDTH = 9; - private final String dataAPI; - private final String name; - - public StatsPanel(Long dbId, Long tId, String name) { - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, tId); - this.name = name; - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = " {\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"fieldConfig\": {\n" + - " \"defaults\": {\n" + - " \"custom\": {\n" + - " \"align\": \"auto\",\n" + - " \"filterable\": \"true\",\n" + - " \"cellOptions\": {\n" + - " \"type\": \"auto\"\n" + - " },\n" + - " \"inspect\": false\n" + - " },\n" + - " \"mappings\": [],\n" + - " \"thresholds\": {\n" + - " \"mode\": \"absolute\",\n" + - " \"steps\": [\n" + - " {\n" + - " \"color\": \"green\",\n" + - " \"value\": null\n" + - " },\n" + - " {\n" + - " \"color\": \"red\",\n" + - " \"value\": 80\n" + - " }\n" + - " ]\n" + - " }\n" + - " },\n" + - " \"overrides\": [\n" + - " {\n" + - " \"matcher\": {\n" + - " \"id\": \"byName\",\n" + - " \"options\": \"" + HEADER_COL + "\"\n" + - " },\n" + - " \"properties\": [\n" + - " {\n" + - " \"id\": \"custom.align\",\n" + - " \"value\": \"center\"\n" + - " }\n" + - " ]\n" + - " },\n" + - " {\n" + - " \"matcher\": {\n" + - " \"id\": \"byName\",\n" + - " \"options\": \"" + HEADER_MIN + "\"\n" + - " },\n" + - " \"properties\": [\n" + - " {\n" + - " \"id\": \"custom.width\",\n" + - " \"value\": 115\n" + - " }\n" + - " ]\n" + - " },\n" + - " {\n" + - " \"matcher\": {\n" + - " \"id\": \"byName\",\n" + - " \"options\": \"" + HEADER_MAX + "\"\n" + - " },\n" + - " \"properties\": [\n" + - " {\n" + - " \"id\": \"custom.width\",\n" + - " \"value\": 115\n" + - " }\n" + - " ]\n" + - " },\n" + - " {\n" + - " \"matcher\": {\n" + - " \"id\": \"byName\",\n" + - " \"options\": \"" + HEADER_AVG + "\"\n" + - " },\n" + - " \"properties\": [\n" + - " {\n" + - " \"id\": \"custom.width\",\n" + - " \"value\": 115\n" + - " }\n" + - " ]\n" + - " },\n" + - " {\n" + - " \"matcher\": {\n" + - " \"id\": \"byName\",\n" + - " \"options\": \"" + HEADER_STDDEV + "\"\n" + - " },\n" + - " \"properties\": [\n" + - " {\n" + - " \"id\": \"custom.width\",\n" + - " \"value\": 115\n" + - " }\n" + - " ]\n" + - " }\n" + - " ]\n" + - " },\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - " \"options\": {\n" + - " \"cellHeight\": \"sm\",\n" + - " \"footer\": {\n" + - " \"countRows\": false,\n" + - " \"fields\": \"\",\n" + - " \"reducer\": [\n" + - " \"sum\"\n" + - " ],\n" + - " \"show\": false\n" + - " },\n" + - " \"showHeader\": true\n" + - " },\n" + - " \"targets\": [\n" + - " {\n" + - " \"columns\": [],\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"filters\": [],\n" + - " \"format\": \"table\",\n" + - " \"global_query_id\": \"\",\n" + - " \"refId\": \"A\",\n" + - " \"root_selector\": \"\",\n" + - " \"source\": \"url\",\n" + - " \"type\": \"json\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"data\": \"\",\n" + - " \"method\": \"GET\"\n" + - " }\n" + - " }\n" + - " ],\n" + - " \"title\": \"Stats for " + name + "\",\n" + - " \"transformations\": [\n" + - " {\n" + - " \"id\": \"organize\",\n" + - " \"options\": {\n" + - " \"excludeByName\": {},\n" + - " \"includeByName\": {},\n" + - " \"indexByName\": {\n" + - " \"" + HEADER_AVG + "\": 3,\n" + - " \"" + HEADER_COL + "\": 0,\n" + - " \"" + HEADER_STDDEV + "\": 4,\n" + - " \"" + HEADER_MAX + "\": 2,\n" + - " \"" + HEADER_MIN + "\": 1\n" + - " }\n" + - " }\n" + - " }\n" + - " ],\n" + - " \"type\": \"table\"\n" + - " }"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/TablePanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/TablePanel.java deleted file mode 100644 index 7295f1528d750c6bbdc26708e075535a4162dfe7..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/TablePanel.java +++ /dev/null @@ -1,73 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class TablePanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/tablepanel"; - private static final int HEIGHT = 8; - private static final int WIDTH = 16; - private final String name; - - private String dataAPI; - - public TablePanel(Long dbId, Long tId, String name, Long size) { - this.name = name; - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, tId); - if (size != null) { - dataAPI += String.format("?size=%d", size); - } - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = "{\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"fieldConfig\": {\n" + - " \"defaults\": {\n" + - " \"custom\": {\n" + - " \"filterable\": true\n" + - " }\n" + - " }\n" + - " }," + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - " \"id\": null,\n" + - " \"targets\": [\n" + - " {\n" + - " \"columns\": [],\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"filters\": [],\n" + - " \"format\": \"table\",\n" + - " \"global_query_id\": \"\",\n" + - " \"refId\": \"A\",\n" + - " \"root_selector\": \"\",\n" + - " \"source\": \"url\",\n" + - " \"type\": \"json\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"data\": \"\",\n" + - " \"method\": \"GET\"\n" + - " }\n" + - " }\n" + - " ],\n" + - " \"title\": \"" + name + "\",\n" + - " \"type\": \"table\"\n" + - " }"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/TimeSeriesPanel.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/TimeSeriesPanel.java deleted file mode 100644 index e0f5b305eaf1716af353aa3497bddc6fb04617a5..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/panels/TimeSeriesPanel.java +++ /dev/null @@ -1,93 +0,0 @@ -package at.tuwien.panels; - -import at.tuwien.endpoints.DataEndpoint; -import lombok.extern.log4j.Log4j2; - -@Log4j2 -public class TimeSeriesPanel extends AbstractPanel { - public static final String RELATIVE_PATH = "/timeseries"; - public static final String TIME_VAL_COL = "value"; - public static final String TIME_YEAR_COL = "year"; - public static final String TIME_MONTH_COL = "month"; - public static final String TIME_DAY_COL = "day"; - public static final String TIME_HOUR_COL = "hour"; - public static final String TIME_MIN_COL = "min"; - public static final String TIME_SECOND_COL = "sec"; - private final String value; - - private static final int HEIGHT = 8; - private static final int WIDTH = 5; - private String dataAPI; - - public TimeSeriesPanel(Long dbId, Long vId, String value, Long size) { - this.dataAPI = String.format("%s%s%s/%d/%d", dataEndpoint, DataEndpoint.API_PREFIX, RELATIVE_PATH, dbId, vId); - this.value = value; - if (size != null) { - dataAPI += String.format("?size=%d", size); - } - } - - @Override - public String getConstructedPanel() { - handleOverflow(HEIGHT, WIDTH); - String panelJson = " {\n" + - "\"datasource\": {\n" + - " \"uid\": \"" + DATASRC_UID + "\",\n" + - " \"type\": \"yesoreyeram-infinity-datasource\"\n" + - " },\n" + - " \"type\": \"timeseries\",\n" + - " \"title\": \"Time Series\",\n" + - " \"gridPos\": {\n" + - " \"h\": " + HEIGHT + ",\n" + - " \"w\": " + WIDTH + ",\n" + - " \"x\": " + x + ",\n" + - " \"y\": " + y + "\n" + - " },\n" + - "\"options\": {\n" + - " \"legend\": {\n" + - " \"calcs\": [],\n" + - " \"displayMode\": \"list\",\n" + - " \"placement\": \"bottom\",\n" + - " \"showLegend\": true\n" + - " },\n" + - " \"tooltip\": {\n" + - " \"mode\": \"single\",\n" + - " \"sort\": \"none\"\n" + - " }\n" + - " },\n" + - " \"targets\": [\n" + - " {\n" + - " \"datasource\": {\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"uid\": \"" + DATASRC_UID + "\"" + - " },\n" + - " \"refId\": \"A\",\n" + - " \"type\": \"json\",\n" + - " \"source\": \"url\",\n" + - " \"format\": \"table\",\n" + - " \"url\": \"" + this.dataAPI + "\",\n" + - " \"url_options\": {\n" + - " \"method\": \"GET\",\n" + - " \"data\": \"\"\n" + - " },\n" + - " \"root_selector\": \"time_series\",\n" + - " \"columns\": [\n" + - " {\n" + - " \"selector\": \"time\",\n" + - " \"type\": \"timestamp\"\n" + - " },\n" + - " {\n" + - " \"text\": \"" + value + "\",\n" + - " \"selector\": \"value\",\n" + - " \"type\": \"number\"\n" + - " }\n" + - " ],\n" + - " \"filters\": [],\n" + - " \"global_query_id\": \"\"\n" + - " }\n" + - " ]}"; - - updateCoords(HEIGHT, WIDTH); - return panelJson; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DashboardService.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DashboardService.java deleted file mode 100644 index 26c66d4efeec34e2bc1b1a6fa5bdf7cc84105af2..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DashboardService.java +++ /dev/null @@ -1,9 +0,0 @@ -package at.tuwien.service; - -import at.tuwien.dto.DashboardConfigDto; - -public interface DashboardService { - String generateDashboard(Long dbId, String token, DashboardConfigDto configDto); - Boolean checkIfDashboardExists(Long dbId); - void removeDashboard(Long dbId); -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DataService.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DataService.java deleted file mode 100644 index 253fde5ebb351e42299f28adcc9ac5575bed99d0..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DataService.java +++ /dev/null @@ -1,14 +0,0 @@ -package at.tuwien.service; - -import java.util.List; -import java.util.Map; - -public interface DataService { - Map<String, Object> getPieChartData(Long dbId, Long viewId, Long size); - Map<String, Object> getCntAllData(Long dbId, Long viewId); - List<Map<String, Object>> getTableData(Long dbId, Long tableId, Long size); - Map<String, List<Object>> getHistogramData(Long dbId, Long viewId, Long size); - List<Map<String, Object>> getStatsData(Long dbId, Long tableId); - Map<String, List<Map<String, Object>>> getTimeSeriesData(Long dbId, Long viewId, Long size); - Map<String, List<Map<String, Object>>> getMultiTimeSeriesData(Long dbId, Long viewId, Long size); -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DataSourceService.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DataSourceService.java deleted file mode 100644 index 070ba1f1d5a0923382d02d0d8da6be4c2e15314d..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/DataSourceService.java +++ /dev/null @@ -1,7 +0,0 @@ -package at.tuwien.service; - - -public interface DataSourceService { - String addDatasource(); - String getDatasource(); -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/TableService.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/TableService.java deleted file mode 100644 index 49a5b773dead2d454eb6a34455ac40fe6b03eb8a..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/TableService.java +++ /dev/null @@ -1,16 +0,0 @@ -package at.tuwien.service; - - -import at.tuwien.api.database.table.TableBriefDto; -import at.tuwien.api.database.table.TableDto; - -import java.util.List; -import java.util.Map; - - -public interface TableService { - - List<TableBriefDto> getAllTables(Long dbId); - TableDto getTableSchemas(Long dbId, Long tId); - List<Map<String, Object>> getTableData(Long dbId, Long tId, Long size); -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/ViewGeneratorService.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/ViewGeneratorService.java deleted file mode 100644 index ef7def1323201c0cac13c56b683d42fd50dfd4bf..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/ViewGeneratorService.java +++ /dev/null @@ -1,15 +0,0 @@ -package at.tuwien.service; - -import at.tuwien.dto.PieChartConfigDto; - -import java.util.List; -import java.util.Map; - -public interface ViewGeneratorService { - Long genCntAllView(Long dbId, String tableName, String token); - Long genPieChartView(Long dbId, String tableName, String colName, PieChartConfigDto config, String token); - Long genHistogramView(Long dbId, String tableName, String colName, String token); - Long genStatisticsView(Long dbId, String tableName, String colName, String token); - Long genTimeSeriesView(Long dbId, String tableName, Map<String, String> timeMap, String token); - Long genMultiTimeSeriesView(Long dbId, String tableName, String timeCol, List<String> numValues, String token); -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DashboardServiceImpl.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DashboardServiceImpl.java deleted file mode 100644 index b373a8c0f8e42550515863c48af066866e7216ad..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DashboardServiceImpl.java +++ /dev/null @@ -1,408 +0,0 @@ -package at.tuwien.service.impl; - -import at.tuwien.api.database.query.QueryResultDto; -import at.tuwien.api.database.table.TableBriefDto; -import at.tuwien.api.database.table.TableDto; -import at.tuwien.api.database.table.columns.ColumnDto; -import at.tuwien.api.database.table.columns.ColumnTypeDto; -import at.tuwien.dto.*; -import at.tuwien.exception.JsonProcessingException; -import at.tuwien.panels.*; -import at.tuwien.service.*; -import com.fasterxml.jackson.databind.JsonNode; -import com.fasterxml.jackson.databind.ObjectMapper; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Qualifier; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.http.*; -import org.springframework.stereotype.Service; -import org.springframework.web.client.*; - -import java.util.*; -import java.util.stream.Collectors; - -import static at.tuwien.panels.TimeSeriesPanel.*; - -@Log4j2 -@Service -public class DashboardServiceImpl implements DashboardService { - - @Value("${dbrepo.endpoints.grafanaService}") - private String grafanaServiceEndpoint; - - @Value("${application.baseurl}") - private String baseUrl; - - @Value("${dbrepo.endpoints.grafanaPort}") - private String grafanaPort; - - @Value("${dbrepo.grafana.default_refreshrate}") - private int defaultRefreshrate; - - private final RestTemplate grafanaRestTemplate; - private final TableService tableService; - private final DataSourceService dataSourceService; - private final ViewGeneratorService viewGeneratorService; - private String token = ""; - - @Autowired - public DashboardServiceImpl(@Qualifier("grafanaTemplate") RestTemplate grafanaRestTemplate, - DataSourceService dataSourceService, TableService tableService, - ViewGeneratorService viewGeneratorService) { - this.grafanaRestTemplate = grafanaRestTemplate; - this.dataSourceService = dataSourceService; - this.tableService = tableService; - this.viewGeneratorService = viewGeneratorService; - } - - @Override - public Boolean checkIfDashboardExists(Long dbId) { - return this.checkForSync(dbId) != null; - } - - @Override - public void removeDashboard(Long dbId) { - String path = String.format("/api/dashboards/uid/%d", dbId); - - try { - ResponseEntity<String> responseEntity = grafanaRestTemplate.exchange( - path, - HttpMethod.DELETE, - null, - String.class - ); - - log.warn(responseEntity.getBody()); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.DELETE, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.DELETE, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.DELETE, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public String generateDashboard(Long dbId, String token, DashboardConfigDto configDto) { - this.token = token; - addDatasourceIfNotPresent(); - - String url = this.checkForSync(dbId); - if (url != null) { - return String.format("%s:%s%s%n", baseUrl, grafanaPort, url); - } - - Map<Long, List<TimeSeriesDto>> timeSeriesParamMap = new HashMap<>(); - Map<Long, Map<Long, PieChartConfigDto>> pieChartParamMap = new HashMap<>(); - Map<Long, Map<Long, HistogramConfigDto>> histogramParamMap = new HashMap<>(); - Map<Long, TableConfigDto> tableParamMap = new HashMap<>(); - DashboardConfigDto dashboardConfigDto = new DashboardConfigDto(); - - if (configDto != null) { - dashboardConfigDto = configDto; - } - - if (dashboardConfigDto.getTimeSeriesDto() != null) { - timeSeriesParamMap = dashboardConfigDto.getTimeSeriesDto(); - } - - if (dashboardConfigDto.getPieChartConfigDto() != null) { - pieChartParamMap = dashboardConfigDto.getPieChartConfigDto(); - } - - if (dashboardConfigDto.getHistogramConfigDto() != null) { - histogramParamMap = dashboardConfigDto.getHistogramConfigDto(); - } - - if (dashboardConfigDto.getTableConfigDto() != null) { - tableParamMap = dashboardConfigDto.getTableConfigDto(); - } - - List<TableBriefDto> tableIds = this.tableService.getAllTables(dbId); - List<Long> idList = tableIds.stream() - .map(TableBriefDto::getId) - .toList(); - - AbstractPanel.setDataEndpoint(grafanaServiceEndpoint); - AbstractPanel.resetCoordinates(); - List<String> rowPanels = new ArrayList<>(); - List<String> tablePanels; - - for (var tId : idList) { - tablePanels = new ArrayList<>(); - TableDto tableSchema = this.tableService.getTableSchemas(dbId, tId); - String tableName = tableSchema.getInternalName(); - - List<ColumnDto> columns = tableSchema.getColumns(); - Set<Long> primaryKeys = tableSchema.getConstraints().getPrimaryKey().stream() - .map(pkDto -> pkDto.getColumn().getId()) - .collect(Collectors.toSet()); - - columns.removeIf(column -> primaryKeys.contains(column.getId())); - - AbstractPanel.addRowPlaceHolder(); - - if (tableParamMap.containsKey(tId)) { - tablePanels.add(generateTablePanel(dbId, tId, tableName, tableParamMap.get(tId).getSize())); - } else { - tablePanels.add(generateTablePanel(dbId, tId, tableName, null)); - } - - tablePanels.add(generateCntAllPanel(dbId, tableName)); - tablePanels.add(generateStatsPanel(dbId, tId, tableName)); - - if (timeSeriesParamMap.containsKey(tId)) { - addTimeSeriesPanel(dbId, tId, tableName, columns, timeSeriesParamMap, tablePanels); - } - - for (var col : columns) { - ColumnTypeDto columnType = col.getColumnType(); - - if (isNumericalColumn(columnType)) { - - if (histogramParamMap.containsKey(tId) && histogramParamMap.get(tId).containsKey(col.getId())) { - tablePanels.add(generateHistogramPanel(dbId, tableName, col.getInternalName(), histogramParamMap.get(tId).get(col.getId()))); - } else { - tablePanels.add(generateHistogramPanel(dbId, tableName, col.getInternalName(), null)); - } - } else if (isStringColumn(columnType)) { - - if (pieChartParamMap.containsKey(tId) && pieChartParamMap.get(tId).containsKey(col.getId())) { - tablePanels.add(generatePieChartPanel(dbId, tableName, col.getInternalName(), pieChartParamMap.get(tId).get(col.getId()))); - } else { - tablePanels.add(generatePieChartPanel(dbId, tableName, col.getInternalName(), null)); - } - } else if (isTimeStamp(columnType)) { - List<String> numColumns = new ArrayList<>(); - - for(var other : columns) { - if (isNumericalColumn(other.getColumnType())) { - numColumns.add(other.getInternalName()); - } - } - - tablePanels.add(generateMultiTimeSeriesPanel(dbId, tableName, col.getInternalName(), numColumns)); - } - } - - rowPanels.add(new RowPanel(tableName, tablePanels).getConstructedPanel()); - AbstractPanel.markNewRow(); - } - - int refreshRate = defaultRefreshrate; - if (dashboardConfigDto.getRefreshRate() != null) { - refreshRate = dashboardConfigDto.getRefreshRate(); - } - - Dashboard d = new Dashboard(); - String dashboardJson = d.getDashboard(rowPanels, dbId, refreshRate); - - String relativeUrl = createDashboard(dashboardJson); - - return String.format("%s:%s%s%n", baseUrl, grafanaPort, relativeUrl); - } - - private String generateCntAllPanel(Long dbId, String tableName) { - Long viewId = this.viewGeneratorService.genCntAllView(dbId, tableName, this.token); - - CntAllPanel panel = new CntAllPanel(dbId, viewId); - return panel.getConstructedPanel(); - } - - private String generatePieChartPanel(Long dbId, String tableName, String colName, PieChartConfigDto config) { - Long viewId = this.viewGeneratorService.genPieChartView(dbId, tableName, colName, config, this.token); - PieChartPanel panel = new PieChartPanel(dbId, viewId, colName, config); - return panel.getConstructedPanel(); - } - - private String generateTablePanel(Long dbId, Long tId, String tableName, Long size) { - TablePanel panel = new TablePanel(dbId, tId, tableName, size); - return panel.getConstructedPanel(); - } - - private String generateHistogramPanel(Long dbId, String tableName, String colName, HistogramConfigDto config) { - Long viewId = this.viewGeneratorService.genHistogramView(dbId, tableName, colName, this.token); - HistogramPanel panel = new HistogramPanel(dbId, viewId, colName, config); - return panel.getConstructedPanel(); - } - - private String generateStatsPanel(Long dbId, Long tId, String tableName) { - StatsPanel panel = new StatsPanel(dbId, tId, tableName); - return panel.getConstructedPanel(); - } - - private String generateTimeSeriesPanel(Long dbId, String tableName, String valueName, Map<String, String> timeMap, Long size) { - Long viewId = this.viewGeneratorService.genTimeSeriesView(dbId, tableName, timeMap, this.token); - TimeSeriesPanel panel = new TimeSeriesPanel(dbId, viewId, valueName, size); - return panel.getConstructedPanel(); - } - - private String generateMultiTimeSeriesPanel(Long dbId, String tableName, String timeCol, List<String> numValues) { - Long viewId = this.viewGeneratorService.genMultiTimeSeriesView(dbId, tableName, timeCol, numValues, this.token); - MultiTimeSeriesPanel panel = new MultiTimeSeriesPanel(dbId, viewId); - return panel.getConstructedPanel(); - } - - private boolean isNumericalColumn(ColumnTypeDto type) { - return switch (type) { - case TINYINT, SMALLINT, MEDIUMINT, INT, BIGINT, FLOAT, DOUBLE, DECIMAL -> true; - default -> false; - }; - } - - private boolean isStringColumn(ColumnTypeDto type) { - return switch (type) { - case CHAR, VARCHAR, TINYTEXT, TEXT, MEDIUMTEXT, LONGTEXT -> true; - default -> false; - }; - } - - private boolean isTimeStamp(ColumnTypeDto type) { - return switch (type) { - case TIMESTAMP -> true; - default -> false; - }; - } - - private void addDatasourceIfNotPresent() { - String jsonString = dataSourceService.getDatasource(); - ObjectMapper objectMapper = new ObjectMapper(); - try { - JsonNode rootNode = objectMapper.readTree(jsonString); - - if (rootNode.isArray()) { - for (JsonNode node : rootNode) { - if (node.has("uid") && node.get("uid").asText().equals(AbstractPanel.DATASRC_UID)) { - return; - } - } - } - - dataSourceService.addDatasource(); - } catch (Exception e) { - log.error("failed to read json of datasource"); - throw new JsonProcessingException("Failed to process datasource json"); - } - } - - private void addTimeSeriesPanel(Long dbId, Long tId, String tableName, List<ColumnDto> columns, - Map<Long, List<TimeSeriesDto>> timeSeriesMap, List<String> tablePanels) { - List<TimeSeriesDto> timeSeriesDtos = timeSeriesMap.get(tId); - - for (TimeSeriesDto timeSeriesDto : timeSeriesDtos) { - TimeDto timeDto = timeSeriesDto.getTimeDto(); - - Map<String, String> timeMap = new HashMap<>(); - String valueName = null; - if (timeDto != null) { - - for (var col : columns) { - Long colId = col.getId(); - String colName = col.getInternalName(); - - if (Objects.equals(timeDto.getYearColId(), colId)) { - timeMap.put(TIME_YEAR_COL, colName); - } else if (Objects.equals(timeDto.getMonthColId(), colId)) { - timeMap.put(TIME_MONTH_COL, colName); - } else if (Objects.equals(timeDto.getDayColId(), colId)) { - timeMap.put(TIME_DAY_COL, colName); - } else if (Objects.equals(timeDto.getHourColId(), colId)) { - timeMap.put(TIME_HOUR_COL, colName); - } else if (Objects.equals(timeDto.getMinuteColId(), colId)) { - timeMap.put(TIME_MIN_COL, colName); - } else if (Objects.equals(timeDto.getSecondColId(), colId)) { - timeMap.put(TIME_SECOND_COL, colName); - } else if (Objects.equals(timeSeriesDto.getValueColId(), colId)) { - valueName = colName; - timeMap.put(TIME_VAL_COL, valueName); - } - } - - if (!timeMap.isEmpty()) { - tablePanels.add(generateTimeSeriesPanel(dbId, tableName, valueName, timeMap, timeSeriesDto.getSize())); - } - } - } - } - - private String checkForSync(Long dbId) { - String path = String.format("/api/dashboards/uid/%d", dbId); - - ResponseEntity<String> responseEntity = null; - try { - responseEntity = grafanaRestTemplate.exchange( - path, - HttpMethod.GET, - null, - String.class - ); - - if (responseEntity.getStatusCode() == HttpStatus.OK) { - log.debug("dashboard with id {} already present", dbId); - - ObjectMapper mapper = new ObjectMapper(); - JsonNode rootNode = mapper.readTree(responseEntity.getBody()); - - return rootNode.get("meta").get("url").asText(); - } - } catch (RestClientException e) { - - if (e.getMessage().startsWith("404")) { - log.debug("dashboard with id {} not present", dbId); - return null; - } - - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.GET, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.GET, e); - throw new ResourceAccessException("Exception occurred"); - } - - return null; - } - - private String createDashboard(String dashboardJson) { - String path = "/api/dashboards/db"; - - HttpEntity<String> requestEntity = new HttpEntity<>(dashboardJson); - - try { - ResponseEntity<String> responseEntity = grafanaRestTemplate.exchange( - path, - HttpMethod.POST, - requestEntity, - String.class - ); - - ObjectMapper mapper = new ObjectMapper(); - String jsonString = responseEntity.getBody(); - JsonNode rootNode = mapper.readTree(jsonString); - - return rootNode.get("url").asText(); - - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - -} \ No newline at end of file diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DataServiceImpl.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DataServiceImpl.java deleted file mode 100644 index 797483b04233281f564f5d49db395a9c7608d4a2..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DataServiceImpl.java +++ /dev/null @@ -1,405 +0,0 @@ -package at.tuwien.service.impl; - -import at.tuwien.api.database.query.QueryResultDto; -import at.tuwien.api.database.table.TableStatisticDto; -import at.tuwien.api.database.table.columns.ColumnStatisticDto; -import at.tuwien.panels.StatsPanel; -import at.tuwien.service.DataService; -import at.tuwien.service.TableService; -import lombok.extern.log4j.Log4j2; -import org.json.JSONObject; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Qualifier; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.data.redis.core.RedisTemplate; -import org.springframework.http.HttpMethod; -import org.springframework.http.ResponseEntity; -import org.springframework.stereotype.Service; -import org.springframework.web.client.*; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.Map; -import java.util.List; -import java.util.concurrent.TimeUnit; -import java.util.stream.Collectors; - -import static at.tuwien.panels.MultiTimeSeriesPanel.*; -import static at.tuwien.panels.PieChartPanel.VIEW_PIE_PERCENTAGE_COL; -import static at.tuwien.panels.TimeSeriesPanel.*; - -@Log4j2 -@Service -public class DataServiceImpl implements DataService { - private final RestTemplate dataRestTemplate; - private final TableService tableService; - private final RestTemplate grafanaRestTemplate; - - @Autowired - public DataServiceImpl(@Qualifier("dataServiceRestTemplate") RestTemplate dataRestTemplate, - @Qualifier("grafanaTemplate") RestTemplate grafanaRestTemplate, - TableService tableService) { - this.dataRestTemplate = dataRestTemplate; - this.grafanaRestTemplate = grafanaRestTemplate; - this.tableService = tableService; - } - - @Override - public Map<String, Object> getPieChartData(Long dbId, Long viewId, Long size) { - - Long page = 0L; - String path = String.format("/api/database/%d/view/%d/data?page=%d&size=%d", dbId, viewId, page, size); - - try { - ResponseEntity<QueryResultDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - QueryResultDto.class - ); - QueryResultDto queryResultDto = responseEntity.getBody(); - assert queryResultDto != null; - - List<Map<String, Object>> res = queryResultDto.getResult(); - Map<String, Object> pieDataMap = new HashMap<>(); - double sum = 0; - - for (Map<String, Object> map : res) { - String key = null; - Object value = null; - - for (Map.Entry<String, Object> entry : map.entrySet()) { - if (!entry.getKey().equals(VIEW_PIE_PERCENTAGE_COL)) { // string column - key = (String) entry.getValue(); - } else { - value = entry.getValue(); - sum += (double) value; - } - } - - if (key != null && value != null) { - pieDataMap.put(key, value); - } - } - - pieDataMap.put("Others", 100 - sum); - return pieDataMap; - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public Map<String, Object> getCntAllData(Long dbId, Long viewId) { - - String path = String.format("/api/database/%d/view/%d/data", dbId, viewId); - - try { - ResponseEntity<QueryResultDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - QueryResultDto.class - ); - QueryResultDto queryResultDto = responseEntity.getBody(); - assert queryResultDto != null; - return queryResultDto.getResult().get(0); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public List<Map<String, Object>> getTableData(Long dbId, Long tableId, Long size) { - return tableService.getTableData(dbId, tableId, size); - } - - @Override - public Map<String, List<Object>> getHistogramData(Long dbId, Long viewId, Long size) { - - Long page = 0L; - String path = String.format("/api/database/%d/view/%d/data?page=%d&size=%d", dbId, viewId, page, size); - - try { - ResponseEntity<QueryResultDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - QueryResultDto.class - ); - QueryResultDto queryResultDto = responseEntity.getBody(); - assert queryResultDto != null; - - List<Map<String, Object>> resultMap = queryResultDto.getResult(); - List<Object> valueList = new ArrayList<>(); - - for (Map<String, Object> map : resultMap) { - if (!map.isEmpty()) { - valueList.add(map.entrySet().iterator().next().getValue()); - } - } - - return Map.of("values", valueList); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public List<Map<String, Object>> getStatsData(Long dbId, Long tableId) { - - String path = String.format("/api/database/%d/table/%d/statistic", dbId, tableId); - - try { - ResponseEntity<TableStatisticDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - TableStatisticDto.class - ); - TableStatisticDto columnStatisticDto = responseEntity.getBody(); - assert columnStatisticDto != null; - Map<String, ColumnStatisticDto> map = columnStatisticDto.getColumns(); - - map = map.entrySet().stream() - .filter(entry -> entry.getValue().getMin() != null) - .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue)); - - List<Map<String, Object>> res = new ArrayList<>(); - Map<String, Object> row; - for (Map.Entry<String, ColumnStatisticDto> entry : map.entrySet()) { - row = new HashMap<>(); - - row.put(StatsPanel.HEADER_COL, entry.getKey()); - row.put(StatsPanel.HEADER_MIN, entry.getValue().getMin()); - row.put(StatsPanel.HEADER_MAX, entry.getValue().getMax()); - row.put(StatsPanel.HEADER_AVG, entry.getValue().getMedian()); - row.put(StatsPanel.HEADER_STDDEV, entry.getValue().getStdDev()); - - res.add(row); - } - - return res; - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public Map<String, List<Map<String, Object>>> getTimeSeriesData(Long dbId, Long viewId, Long size) { - - Long page = 0L; - String path = String.format("/api/database/%d/view/%d/data?page=%d&size=%d", dbId, viewId, page, size); - - try { - ResponseEntity<QueryResultDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - QueryResultDto.class - ); - QueryResultDto queryResultDto = responseEntity.getBody(); - assert queryResultDto != null; - - List<Map<String, Object>> resultMap = queryResultDto.getResult(); - - - Map<String, List<Map<String, Object>>> res = new HashMap<>(); - res.put("time_series", formatTimeData(resultMap)); - - return res; - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - public Map<String, List<Map<String, Object>>> getMultiTimeSeriesData(Long dbId, Long viewId, Long size) { - Long page = 0L; - String path = String.format("/api/database/%d/view/%d/data?page=%d&size=%d", dbId, viewId, page, size); - - try { - ResponseEntity<QueryResultDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - QueryResultDto.class - ); - QueryResultDto queryResultDto = responseEntity.getBody(); - assert queryResultDto != null; - - List<Map<String, Object>> resultMap = queryResultDto.getResult(); - List<Map<String, Object>> timeMap = new ArrayList<>(); - - for (Map<String, Object> map : resultMap) { - Object time = map.get(VIEW_MULTI_TIMECOL); - - for (Map.Entry<String, Object> entry : map.entrySet()) { - Map<String, Object> multiTimeEntry = new HashMap<>(); - if (!entry.getKey().equals(VIEW_MULTI_TIMECOL)) { - multiTimeEntry.put(VIEW_MULTI_SELECTOR_NAME, entry.getKey()); - multiTimeEntry.put(VIEW_MULTI_SELECTOR_VALUE, entry.getValue()); - multiTimeEntry.put(VIEW_MULTI_SELECTOR_TIME, time); - - timeMap.add(multiTimeEntry); - } - } - } - Map<String, List<Map<String, Object>>> res = new HashMap<>(); - res.put("time_series", timeMap); - - return res; - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - private List<Map<String, Object>> formatTimeData(List<Map<String, Object>> resultMap) { - int year, month, day, hour, min, sec; - Object val; - - List<Map<String, Object>> timeValues = new ArrayList<>(); - Map<String, Object> timeValue; - - for (Map<String, Object> map : resultMap) { - year = 0; - month = 1; - day = 1; - hour = 0; - min = 0; - sec = 0; - val = null; - timeValue = new HashMap<>(); - - if(map.containsKey(TIME_YEAR_COL)) { - Object y = map.get(TIME_YEAR_COL); - if (y instanceof Integer) { - year = (int) y; - } - } - - if(map.containsKey(TIME_MONTH_COL)) { - Object m = map.get(TIME_MONTH_COL); - if (m instanceof String) { - month = getMonth(m.toString()); - } else if (m instanceof Integer) { - month = (int) m; - } - } - - if(map.containsKey(TIME_DAY_COL)) { - Object d = map.get(TIME_DAY_COL); - if (d instanceof Integer) { - day = (int) d; - } - } - - if(map.containsKey(TIME_HOUR_COL)) { - Object h = map.get(TIME_HOUR_COL); - if (h instanceof Integer) { - hour = (int) h; - } - } - - if(map.containsKey(TIME_MIN_COL)) { - Object m = map.get(TIME_MIN_COL); - if (m instanceof Integer) { - min = (int) m; - } - } - - if(map.containsKey(TIME_SECOND_COL)) { - Object s = map.get(TIME_SECOND_COL); - if (s instanceof Integer) { - sec = (int) s; - } - } - - if(map.containsKey(TIME_VAL_COL)) { - val = map.get(TIME_VAL_COL); - } - - timeValue.put("time", String.format("%d-%02d-%02d %02d:%02d:%02d", year, month, day, hour, min, sec)); - timeValue.put("value", val); - timeValues.add(timeValue); - } - - return timeValues; - } - - private int getMonth(String month) { - return switch (month.toLowerCase()) { - case "february" -> 2; - case "march" -> 3; - case "april" -> 4; - case "may" -> 5; - case "june" -> 6; - case "july" -> 7; - case "august" -> 8; - case "september" -> 9; - case "october" -> 10; - case "november" -> 11; - case "december" -> 12; - default -> 1; - }; - } -} diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DataSourceServiceImpl.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DataSourceServiceImpl.java deleted file mode 100644 index f4fde957b38c50fa79edf698d0f6500bb2d8d198..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/DataSourceServiceImpl.java +++ /dev/null @@ -1,99 +0,0 @@ -package at.tuwien.service.impl; - -import at.tuwien.api.database.query.QueryResultDto; -import at.tuwien.panels.AbstractPanel; -import at.tuwien.service.DataService; -import at.tuwien.service.DataSourceService; -import com.fasterxml.jackson.databind.JsonNode; -import com.fasterxml.jackson.databind.ObjectMapper; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Qualifier; -import org.springframework.cache.annotation.Cacheable; -import org.springframework.http.HttpEntity; -import org.springframework.http.HttpMethod; -import org.springframework.http.ResponseEntity; -import org.springframework.stereotype.Service; -import org.springframework.web.client.*; - -import java.time.LocalDateTime; -import java.time.format.DateTimeFormatter; -import java.util.HashMap; -import java.util.Map; - -@Log4j2 -@Service -public class DataSourceServiceImpl implements DataSourceService { - - private final RestTemplate grafanaRestTemplate; - private String addDatasourceJSON = "{\n" + - " \"id\": null,\n" + - " \"uid\": \"" + AbstractPanel.DATASRC_UID + "\",\n" + - " \"name\": \"infinity datasource\",\n" + - " \"type\": \"yesoreyeram-infinity-datasource\",\n" + - " \"access\": \"proxy\"\n" + - "}"; - - @Autowired - public DataSourceServiceImpl(@Qualifier("grafanaTemplate") RestTemplate grafanaRestTemplate) { - this.grafanaRestTemplate = grafanaRestTemplate; - } - - @Override - public String addDatasource() { - String path = "/api/datasources"; - - HttpEntity<String> requestEntity = new HttpEntity<>(addDatasourceJSON); - - try { - ResponseEntity<String> responseEntity = grafanaRestTemplate.exchange( - path, - HttpMethod.POST, - requestEntity, - String.class - ); - return responseEntity.getBody(); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public String getDatasource() { - String path = "/api/datasources"; - - try { - ResponseEntity<String> responseEntity = grafanaRestTemplate.exchange( - path, - HttpMethod.GET, - null, - String.class - ); - - return responseEntity.getBody(); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - -} \ No newline at end of file diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/TableServiceImpl.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/TableServiceImpl.java deleted file mode 100644 index a3c8fc8622aa8fe8a7fb4e63fe0520cadeb004e4..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/TableServiceImpl.java +++ /dev/null @@ -1,121 +0,0 @@ -package at.tuwien.service.impl; - -import at.tuwien.api.database.query.QueryResultDto; -import at.tuwien.api.database.table.TableBriefDto; -import at.tuwien.api.database.table.TableDto; -import at.tuwien.service.TableService; -import lombok.extern.log4j.Log4j2; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Qualifier; -import org.springframework.core.ParameterizedTypeReference; -import org.springframework.http.*; -import org.springframework.stereotype.Service; -import org.springframework.util.LinkedMultiValueMap; -import org.springframework.util.MultiValueMap; -import org.springframework.web.client.*; -import org.springframework.web.util.UriComponentsBuilder; - -import java.util.*; - -@Log4j2 -@Service -public class TableServiceImpl implements TableService { - private final RestTemplate dataRestTemplate; - private final RestTemplate metaDataRestTemplate; - - @Autowired - public TableServiceImpl(@Qualifier("dataServiceRestTemplate") RestTemplate dataRestTemplate, - @Qualifier("metaDataServiceRestTemplate") RestTemplate metaDataRestTemplate) { - this.dataRestTemplate = dataRestTemplate; - this.metaDataRestTemplate = metaDataRestTemplate; - } - - @Override - public List<TableBriefDto> getAllTables(Long dbId) { - String path = String.format("/api/database/%d/table", dbId); - - try { - ResponseEntity<List<TableBriefDto>> responseEntity = metaDataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - new ParameterizedTypeReference<List<TableBriefDto>>() {} - ); - return responseEntity.getBody(); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - - @Override - public TableDto getTableSchemas(Long dbId, Long tId) { - String path = String.format("/api/database/%d/table/%d", dbId, tId); - try { - ResponseEntity<TableDto> responseEntity = metaDataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - TableDto.class - ); - - return responseEntity.getBody(); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - - @Override - public List<Map<String, Object>> getTableData(Long dbId, Long tId, Long size) { - Long page = 0L; - String path = String.format("/api/database/%d/table/%d/data?page=%d&size=%d", dbId, tId, page, size); - - try { - // Send GET request with query parameters - ResponseEntity<QueryResultDto> responseEntity = dataRestTemplate.exchange( - path, - HttpMethod.GET, - null, - QueryResultDto.class - ); - - QueryResultDto responseBody = responseEntity.getBody(); - - return responseBody.getResult(); - - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - -} \ No newline at end of file diff --git a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/ViewGeneratorServiceImpl.java b/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/ViewGeneratorServiceImpl.java deleted file mode 100644 index baa258460c157053e6ae3fc31ec441d11dc5adf1..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/java/at/tuwien/service/impl/ViewGeneratorServiceImpl.java +++ /dev/null @@ -1,225 +0,0 @@ -package at.tuwien.service.impl; - -import at.tuwien.api.database.ViewBriefDto; -import at.tuwien.api.database.ViewCreateDto; -import at.tuwien.dto.PieChartConfigDto; -import at.tuwien.panels.StatsPanel; -import at.tuwien.service.ViewGeneratorService; -import lombok.extern.log4j.Log4j2; -import org.apache.commons.text.StringSubstitutor; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.annotation.Qualifier; -import org.springframework.http.HttpEntity; -import org.springframework.http.HttpHeaders; -import org.springframework.http.HttpMethod; -import org.springframework.http.ResponseEntity; -import org.springframework.stereotype.Service; -import org.springframework.web.client.*; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; - -import static at.tuwien.panels.MultiTimeSeriesPanel.VIEW_MULTI_TIMECOL; -import static at.tuwien.panels.PieChartPanel.VIEW_PIE_PERCENTAGE_COL; -import static at.tuwien.panels.TimeSeriesPanel.TIME_VAL_COL; - -@Log4j2 -@Service -public class ViewGeneratorServiceImpl implements ViewGeneratorService { - - private final RestTemplate metaDataRestTemplate; - private static final String PIE_DEFAULT_LIMIT = "10"; - private static final String PIE_DEFAULT_DEC_PLACE = "2"; - - @Autowired - public ViewGeneratorServiceImpl(@Qualifier("metaDataServiceRestTemplate") RestTemplate metaDataRestTemplate) { - this.metaDataRestTemplate = metaDataRestTemplate; - } - - @Override - public Long genCntAllView(Long dbId, String tableName, String token) { - final String query = String.format("select count(*) from %s", tableName); - - ViewCreateDto viewCreateDto = new ViewCreateDto(); - viewCreateDto.setName(String.format("%d_cntAll_%s", dbId, tableName)); - viewCreateDto.setQuery(query); - viewCreateDto.setIsPublic(true); - - ViewBriefDto createdView = createView(dbId, viewCreateDto, token); - if (createdView == null) { - log.warn("failed to create view {}", viewCreateDto); - return -1L; - } - - return createdView.getId(); - } - - @Override - public Long genPieChartView(Long dbId, String tableName, String colName, PieChartConfigDto config, String token) { - Map<String, String> valueMap = new HashMap<>(); - valueMap.put("col_name", colName); - valueMap.put("table_name", tableName); - valueMap.put("limit", (config != null && config.getLimit() != null) ? config.getLimit() : PIE_DEFAULT_LIMIT); - valueMap.put("dec_place", (config != null && config.getDecimalPlace() != null) ? config.getDecimalPlace() : PIE_DEFAULT_DEC_PLACE); - valueMap.put("percentage", VIEW_PIE_PERCENTAGE_COL); - - final String templateQuery = - "SELECT\n" + - " ${col_name},\n" + - " ROUND( (COUNT(*) / total_count) * 100, ${dec_place}) AS ${percentage}\n" + - " FROM\n" + - " ${table_name},\n" + - " (SELECT COUNT(*) AS total_count FROM ${table_name}) AS t\n" + - " GROUP BY\n" + - " ${col_name}\n" + - " ORDER BY\n" + - " ${percentage} DESC\n" + - " LIMIT ${limit}"; - - StringSubstitutor sub = new StringSubstitutor(valueMap); - - ViewCreateDto viewCreateDto = new ViewCreateDto(); - viewCreateDto.setName(String.format("%d_piechart_%s_%s", dbId, tableName, colName)); - viewCreateDto.setQuery(sub.replace(templateQuery)); - viewCreateDto.setIsPublic(true); - - ViewBriefDto createdView = createView(dbId, viewCreateDto, token); - if (createdView == null) { - log.warn("failed to create view {}", viewCreateDto); - return -1L; - } - - return createdView.getId(); - } - - @Override - public Long genHistogramView(Long dbId, String tableName, String colName, String token) { - final String query = String.format("select %s from %s", colName, tableName); - - ViewCreateDto viewCreateDto = new ViewCreateDto(); - viewCreateDto.setName(String.format("%d_histogram_%s_%s", dbId, tableName, colName)); - viewCreateDto.setQuery(query); - viewCreateDto.setIsPublic(true); - - ViewBriefDto createdView = createView(dbId, viewCreateDto, token); - if (createdView == null) { - log.warn("failed to create view {}", viewCreateDto); - return -1L; - } - - return createdView.getId(); - } - - @Override - public Long genStatisticsView(Long dbId, String tableName, String colName, String token) { - Map<String, String> valueMap = new HashMap<>(); - valueMap.put("col_name", colName); - valueMap.put("table_name", tableName); - valueMap.put("header_col", StatsPanel.HEADER_COL); - valueMap.put("header_min", StatsPanel.HEADER_MIN); - valueMap.put("header_max", StatsPanel.HEADER_MAX); - valueMap.put("header_avg", StatsPanel.HEADER_AVG); - valueMap.put("header_stddev", StatsPanel.HEADER_STDDEV); - - final String templateQuery = "select " + - "min(${col_name}) as ${header_min}, " + - "max(${col_name}) as ${header_max}, " + - "avg(${col_name}) as ${header_avg}, " + - "STDDEV(${col_name}) as ${header_stddev} " + - "from ${table_name}"; - - StringSubstitutor sub = new StringSubstitutor(valueMap); - - ViewCreateDto viewCreateDto = new ViewCreateDto(); - viewCreateDto.setName(String.format("%d_statschart_%s_%s", dbId, tableName, colName)); - viewCreateDto.setQuery(sub.replace(templateQuery)); - viewCreateDto.setIsPublic(true); - - ViewBriefDto createdView = createView(dbId, viewCreateDto, token); - if (createdView == null) { - log.warn("failed to create view {}", viewCreateDto); - return -1L; - } - - return createdView.getId(); - } - - @Override - public Long genTimeSeriesView(Long dbId, String tableName, Map<String, String> timeMap, String token) { - - List<String> colNames = new ArrayList<>(); - for (Map.Entry<String, String> entry : timeMap.entrySet()) { - colNames.add(String.format("%s AS %s", entry.getValue(), entry.getKey())); - } - - final String query = String.format("select %s from %s", String.join(",", colNames), tableName); - - ViewCreateDto viewCreateDto = new ViewCreateDto(); - viewCreateDto.setName(String.format("%d_timeseries_%s_%s", dbId, tableName, timeMap.get(TIME_VAL_COL))); - viewCreateDto.setQuery(query); - viewCreateDto.setIsPublic(true); - - ViewBriefDto createdView = createView(dbId, viewCreateDto, token); - if (createdView == null) { - log.warn("failed to create view {}", viewCreateDto); - return -1L; - } - - return createdView.getId(); - } - - @Override - public Long genMultiTimeSeriesView(Long dbId, String tableName, String timeCol, List<String> numValues, String token) { - - final String query = String.format("select %s AS %s, %s from %s", timeCol, VIEW_MULTI_TIMECOL, String.join(",", numValues), tableName); - ViewCreateDto viewCreateDto = new ViewCreateDto(); - viewCreateDto.setName(String.format("%d_multitimeseries_%s_%s", dbId, tableName, timeCol)); - viewCreateDto.setQuery(query); - viewCreateDto.setIsPublic(true); - - ViewBriefDto createdView = createView(dbId, viewCreateDto, token); - if (createdView == null) { - log.warn("failed to create view {}", viewCreateDto); - return -1L; - } - - return createdView.getId(); - } - - - private ViewBriefDto createView(Long dbId, ViewCreateDto viewCreateDto, String token) { - String path = String.format("/api/database/%d/view", dbId); - - HttpHeaders headers = new HttpHeaders(); - headers.set("Authorization", token); - headers.set("Content-Type", "application/json"); - - HttpEntity<ViewCreateDto> requestEntity = new HttpEntity<>(viewCreateDto, headers); - - try { - ResponseEntity<ViewBriefDto> responseEntity = metaDataRestTemplate.exchange( - path, - HttpMethod.POST, - requestEntity, - ViewBriefDto.class - ); - - return responseEntity.getBody(); - } catch (ResourceAccessException e) { - log.error("Resource access error for accessing URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Resource access error occurred"); - } catch (RestClientException e) { - log.error("RestClient Exception occurred URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("RestClient Exception occurred"); - } catch (Exception e) { - log.error("Exception occurred, URL: {}, Exception message: {}, Request method: {}, Stack Trace: {}", - path, e.getMessage(), HttpMethod.POST, e); - throw new ResourceAccessException("Exception occurred"); - } - } - -} \ No newline at end of file diff --git a/dbrepo-grafana-service/rest-service/src/main/resources/application-local.yml b/dbrepo-grafana-service/rest-service/src/main/resources/application-local.yml deleted file mode 100644 index 8e99c2d0a9fe8711e142bdc9ba2863337f4f2f5b..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/resources/application-local.yml +++ /dev/null @@ -1,89 +0,0 @@ -application: - title: DBRepo - version: '@project.version@' -spring: - datasource: - url: jdbc:h2:mem:fda;DB_CLOSE_ON_EXIT=FALSE;INIT=CREATE SCHEMA IF NOT EXISTS FDA;NON_KEYWORDS=value - driver-class-name: org.h2.Driver - username: sa - password: password - rabbitmq: - host: "${BROKER_HOST:broker-service}" - virtual-host: "${BROKER_VIRTUALHOST:dbrepo}" - password: "${BROKER_PASSWORD:fda}" - username: "${BROKER_USERNAME:fda}" - port: ${BROKER_PORT:5672} - jpa: - show-sql: false - database-platform: org.hibernate.dialect.H2Dialect - open-in-view: false - properties: - hibernate: - default_schema: fda - jdbc: - time_zone: UTC - application: - name: grafana-service - main: - banner-mode: off -management: - endpoints: - web: - exposure: - include: health,info,prometheus - endpoint: - health: - probes: - enabled: true - health: - readinessState: - enabled: true - livenessState: - enabled: true -server: - port: 1880 -logging: - pattern.console: "%d %highlight(%-5level) %msg%n" - level: - root: debug - at.tuwien.: "${LOG_LEVEL:info}" - org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver: debug -dbrepo: - endpoints: - grafana: http://grafana:3000 - dataService: http://data-service:8080 - gatewayService: "${GATEWAY_SERVICE_ENDPOINT:http://gateway-service}" - storageService: "${S3_ENDPOINT:http://storage-service:9000}" - authService: "${AUTH_SERVICE_HOST:http://auth-service:8080}" - s3: - accessKeyId: "${S3_ACCESS_KEY_ID:seaweedfsadmin}" - secretAccessKey: "${S3_SECRET_ACCESS_KEY:seaweedfsadmin}" - importBucket: "${S3_IMPORT_BUCKET:dbrepo-upload}" - exportBucket: "${S3_EXPORT_BUCKET:dbrepo-download}" - filePath: "${S3_FILE_PATH:/tmp}" - admin: - username: "${ADMIN_USERNAME:admin}" - password: "${ADMIN_PASSWORD:admin}" - jwt: - public_key: "${JWT_PUBKEY:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAqqnHQ2BWWW9vDNLRCcxD++xZg/16oqMo/c1l+lcFEjjAIJjJp/HqrPYU/U9GvquGE6PbVFtTzW1KcKawOW+FJNOA3CGo8Q1TFEfz43B8rZpKsFbJKvQGVv1Z4HaKPvLUm7iMm8Hv91cLduuoWx6Q3DPe2vg13GKKEZe7UFghF+0T9u8EKzA/XqQ0OiICmsmYPbwvf9N3bCKsB/Y10EYmZRb8IhCoV9mmO5TxgWgiuNeCTtNCv2ePYqL/U0WvyGFW0reasIK8eg3KrAUj8DpyOgPOVBn3lBGf+3KFSYi+0bwZbJZWqbC/Xlk20Go1YfeJPRIt7ImxD27R/lNjgDO/MwIDAQAB}" - keycloak: - username: "${AUTH_SERVICE_ADMIN:fda}" - password: "${AUTH_SERVICE_ADMIN_PASSWORD:fda}" - client: "${AUTH_SERVICE_CLIENT:dbrepo-client}" - clientSecret: "${AUTH_SERVICE_CLIENT_SECRET:MUwRc7yfXSJwX8AdRMWaQC3Nep1VjwgG}" - sql: - forbidden: "${NOT_SUPPORTED_KEYWORDS:\\*,AVG,BIT_AND,BIT_OR,BIT_XOR,COUNT,COUNTDISTINCT,GROUP_CONCAT,JSON_ARRAYAGG,JSON_OBJECTAGG,MAX,MIN,STD,STDDEV,STDDEV_POP,STDDEV_SAMP,SUM,VARIANCE,VAR_POP,VAR_SAMP,--}" - grant: - default: - read: "${GRANT_DEFAULT_READ:SELECT}" - write: "${GRANT_DEFAULT_WRITE:SELECT, CREATE, CREATE VIEW, CREATE ROUTINE, CREATE TEMPORARY TABLES, LOCK TABLES, INDEX, TRIGGER, INSERT, UPDATE, DELETE}" - minConcurrent: "${MIN_CONCURRENT_CONSUMERS:2}" - maxConcurrent: "${MAX_CONCURRENT_CONSUMERS:6}" - requeueRejected: ${REQUEUE_REJECTED:false} - queueName: "${BROKER_QUEUE_NAME:dbrepo}" - exchangeName: "${BROKER_EXCHANGE_NAME:dbrepo}" - routingKey: "${BROKER_ROUTING_KEY:#}" - connectionTimeout: ${CONNECTION_TIMEOUT:10000} - defaultDateFormatId: "${DEFAULT_DATE_FORMAT_ID:3}" - defaultTimeFormatId: "${DEFAULT_TIME_FORMAT_ID:4}" - defaultTimestampFormatId: "${DEFAULT_TIMESTAMP_FORMAT_ID:1}" diff --git a/dbrepo-grafana-service/rest-service/src/main/resources/application.yml b/dbrepo-grafana-service/rest-service/src/main/resources/application.yml deleted file mode 100644 index b8fcf710c7234ae063c4f2ec4f91baae22150c35..0000000000000000000000000000000000000000 --- a/dbrepo-grafana-service/rest-service/src/main/resources/application.yml +++ /dev/null @@ -1,107 +0,0 @@ -application: - title: DBRepo - version: '@project.version@' - baseurl: ${BASE_URL:http://localhost} -spring: - datasource: - url: jdbc:h2:mem:fda;DB_CLOSE_ON_EXIT=FALSE;INIT=CREATE SCHEMA IF NOT EXISTS FDA;NON_KEYWORDS=value - driver-class-name: org.h2.Driver - username: sa - password: password - rabbitmq: - host: "${BROKER_HOST:broker-service}" - virtual-host: "${BROKER_VIRTUALHOST:dbrepo}" - password: "${BROKER_PASSWORD:fda}" - username: "${BROKER_USERNAME:fda}" - port: ${BROKER_PORT:5672} - jpa: - show-sql: false - database-platform: org.hibernate.dialect.H2Dialect - open-in-view: false - properties: - hibernate: - default_schema: fda - jdbc: - time_zone: UTC - application: - name: grafana-service - main: - banner-mode: off - data: - redis: - host: redis - port: 6379 -management: - endpoints: - web: - exposure: - include: health,info,prometheus - endpoint: - health: - probes: - enabled: true - health: - readinessState: - enabled: true - livenessState: - enabled: true -server: - port: 8080 -logging: - pattern.console: "%d %highlight(%-5level) %msg%n" - level: - root: warn - at.tuwien.: "${LOG_LEVEL:info}" - org: - springframework: - web: - client: - RestTemplate: DEBUG - org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver: debug -dbrepo: - endpoints: - grafana: http://grafana:3000 - grafanaPort: 3000 - grafanaService: http://grafana-service:8080 - dataService: http://data-service:8080 - metadataService: http://metadata-service:8080 - gatewayService: "${GATEWAY_SERVICE_ENDPOINT:http://gateway-service}" - storageService: "${S3_ENDPOINT:http://storage-service:9000}" - authService: "${AUTH_SERVICE_HOST:http://auth-service:8080}" - s3: - accessKeyId: "${S3_ACCESS_KEY_ID:seaweedfsadmin}" - secretAccessKey: "${S3_SECRET_ACCESS_KEY:seaweedfsadmin}" - importBucket: "${S3_IMPORT_BUCKET:dbrepo-upload}" - exportBucket: "${S3_EXPORT_BUCKET:dbrepo-download}" - filePath: "${S3_FILE_PATH:/tmp}" - admin: - username: "${ADMIN_USERNAME:kper}" - password: "${ADMIN_PASSWORD:k1a1r1l1o1}" - jwt: - public_key: "${JWT_PUBKEY:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAqqnHQ2BWWW9vDNLRCcxD++xZg/16oqMo/c1l+lcFEjjAIJjJp/HqrPYU/U9GvquGE6PbVFtTzW1KcKawOW+FJNOA3CGo8Q1TFEfz43B8rZpKsFbJKvQGVv1Z4HaKPvLUm7iMm8Hv91cLduuoWx6Q3DPe2vg13GKKEZe7UFghF+0T9u8EKzA/XqQ0OiICmsmYPbwvf9N3bCKsB/Y10EYmZRb8IhCoV9mmO5TxgWgiuNeCTtNCv2ePYqL/U0WvyGFW0reasIK8eg3KrAUj8DpyOgPOVBn3lBGf+3KFSYi+0bwZbJZWqbC/Xlk20Go1YfeJPRIt7ImxD27R/lNjgDO/MwIDAQAB}" - keycloak: - username: "${AUTH_SERVICE_ADMIN:fda}" - password: "${AUTH_SERVICE_ADMIN_PASSWORD:fda}" - client: "${AUTH_SERVICE_CLIENT:dbrepo-client}" - clientSecret: "${AUTH_SERVICE_CLIENT_SECRET:MUwRc7yfXSJwX8AdRMWaQC3Nep1VjwgG}" - grafana: - username: "${GRAFANA_USERNAME:admin}" - password: "${GRAFANA_PASSWORD:admin}" - default_refreshrate: 0 - sql: - forbidden: "${NOT_SUPPORTED_KEYWORDS:\\*,AVG,BIT_AND,BIT_OR,BIT_XOR,COUNT,COUNTDISTINCT,GROUP_CONCAT,JSON_ARRAYAGG,JSON_OBJECTAGG,MAX,MIN,STD,STDDEV,STDDEV_POP,STDDEV_SAMP,SUM,VARIANCE,VAR_POP,VAR_SAMP,--}" - grant: - default: - read: "${GRANT_DEFAULT_READ:SELECT}" - write: "${GRANT_DEFAULT_WRITE:SELECT, CREATE, CREATE VIEW, CREATE ROUTINE, CREATE TEMPORARY TABLES, LOCK TABLES, INDEX, TRIGGER, INSERT, UPDATE, DELETE}" - minConcurrent: "${MIN_CONCURRENT_CONSUMERS:2}" - maxConcurrent: "${MAX_CONCURRENT_CONSUMERS:6}" - requeueRejected: ${REQUEUE_REJECTED:false} - queueName: "${BROKER_QUEUE_NAME:dbrepo}" - exchangeName: "${BROKER_EXCHANGE_NAME:dbrepo}" - routingKey: "${BROKER_ROUTING_KEY:#}" - connectionTimeout: ${CONNECTION_TIMEOUT:10000} - defaultDateFormatId: "${DEFAULT_DATE_FORMAT_ID:3}" - defaultTimeFormatId: "${DEFAULT_TIME_FORMAT_ID:4}" - defaultTimestampFormatId: "${DEFAULT_TIMESTAMP_FORMAT_ID:1}" - diff --git a/dbrepo-grafana-service/rest-service/src/test/resources/application.properties b/dbrepo-grafana-service/rest-service/src/test/resources/application.properties deleted file mode 100644 index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..0000000000000000000000000000000000000000 diff --git a/dbrepo-metadata-service/pom.xml b/dbrepo-metadata-service/pom.xml index dfc122745e398654107bb490c84887e5872f32dd..313d6d0db530caa829e6325cef263d1077b954e8 100644 --- a/dbrepo-metadata-service/pom.xml +++ b/dbrepo-metadata-service/pom.xml @@ -43,7 +43,7 @@ <mapstruct.version>1.6.3</mapstruct.version> <rabbitmq.version>5.20.0</rabbitmq.version> <commons-io.version>2.17.0</commons-io.version> - <commons-validator.version>1.8.1</commons-validator.version> + <commons-validator.version>1.8.0</commons-validator.version> <guava.version>33.0.0-jre</guava.version> <jacoco.version>0.8.12</jacoco.version> <jwt.version>4.3.0</jwt.version> @@ -62,6 +62,7 @@ ./report/target/site/jacoco-aggregate/jacoco.xml </sonar.coverage.jacoco.xmlReportPaths> <CodeCacheSize>128m</CodeCacheSize> + <extraJavaTestArgs></extraJavaTestArgs> </properties> <dependencies> diff --git a/dbrepo-search-service/Pipfile.lock b/dbrepo-search-service/Pipfile.lock index 1408b9e1a7a3804132c4f06a2faa737bff18385b..00b29bcf7f9f6e99d68df9e8a0dfdabf74de51c9 100644 --- a/dbrepo-search-service/Pipfile.lock +++ b/dbrepo-search-service/Pipfile.lock @@ -373,7 +373,7 @@ }, "dbrepo": { "hashes": [ - "sha256:7e21d72d0b3e766aeecb286b636ea7530fa971d95b1b083b7ef8b9512b8300ef" + "sha256:22484d712e4a240a0114b90b5e8eaacbe47aa8f7fc79200557150f081faf7669" ], "path": "./lib/dbrepo-1.8.1.tar.gz" }, @@ -879,101 +879,113 @@ }, "multidict": { "hashes": [ - "sha256:0085b0afb2446e57050140240a8595846ed64d1cbd26cef936bfab3192c673b8", - "sha256:042028348dc5a1f2be6c666437042a98a5d24cee50380f4c0902215e5ec41844", - "sha256:05fefbc3cddc4e36da209a5e49f1094bbece9a581faa7f3589201fd95df40e5d", - "sha256:063be88bd684782a0715641de853e1e58a2f25b76388538bd62d974777ce9bc2", - "sha256:07bfa8bc649783e703263f783f73e27fef8cd37baaad4389816cf6a133141331", - "sha256:08549895e6a799bd551cf276f6e59820aa084f0f90665c0f03dd3a50db5d3c48", - "sha256:095a2eabe8c43041d3e6c2cb8287a257b5f1801c2d6ebd1dd877424f1e89cf29", - "sha256:0b183a959fb88ad1be201de2c4bdf52fa8e46e6c185d76201286a97b6f5ee65c", - "sha256:0c383d28857f66f5aebe3e91d6cf498da73af75fbd51cedbe1adfb85e90c0460", - "sha256:0d57a01a2a9fa00234aace434d8c131f0ac6e0ac6ef131eda5962d7e79edfb5b", - "sha256:0dc25a3293c50744796e87048de5e68996104d86d940bb24bc3ec31df281b191", - "sha256:0e5a644e50ef9fb87878d4d57907f03a12410d2aa3b93b3acdf90a741df52c49", - "sha256:0f249badb360b0b4d694307ad40f811f83df4da8cef7b68e429e4eea939e49dd", - "sha256:0f74f2fc51555f4b037ef278efc29a870d327053aba5cb7d86ae572426c7cccc", - "sha256:125dd82b40f8c06d08d87b3510beaccb88afac94e9ed4a6f6c71362dc7dbb04b", - "sha256:13551d0e2d7201f0959725a6a769b6f7b9019a168ed96006479c9ac33fe4096b", - "sha256:14ed9ed1bfedd72a877807c71113deac292bf485159a29025dfdc524c326f3e1", - "sha256:163f4604e76639f728d127293d24c3e208b445b463168af3d031b92b0998bb90", - "sha256:19e2819b0b468174de25c0ceed766606a07cedeab132383f1e83b9a4e96ccb4f", - "sha256:1e2a2193d3aa5cbf5758f6d5680a52aa848e0cf611da324f71e5e48a9695cc86", - "sha256:1f3c099d3899b14e1ce52262eb82a5f5cb92157bb5106bf627b618c090a0eadc", - "sha256:214207dcc7a6221d9942f23797fe89144128a71c03632bf713d918db99bd36de", - "sha256:2325105e16d434749e1be8022f942876a936f9bece4ec41ae244e3d7fae42aaf", - "sha256:2529ddbdaa424b2c6c2eb668ea684dd6b75b839d0ad4b21aad60c168269478d7", - "sha256:256d431fe4583c5f1e0f2e9c4d9c22f3a04ae96009b8cfa096da3a8723db0a16", - "sha256:25bb96338512e2f46f615a2bb7c6012fe92a4a5ebd353e5020836a7e33120349", - "sha256:2e87f1926e91855ae61769ba3e3f7315120788c099677e0842e697b0bfb659f2", - "sha256:2fc6af8e39f7496047c7876314f4317736eac82bf85b54c7c76cf1a6f8e35d98", - "sha256:3157126b028c074951839233647bd0e30df77ef1fedd801b48bdcad242a60f4e", - "sha256:32c9b4878f48be3e75808ea7e499d6223b1eea6d54c487a66bc10a1871e3dc6a", - "sha256:32ed748ff9ac682eae7859790d3044b50e3076c7d80e17a44239683769ff485e", - "sha256:3501621d5e86f1a88521ea65d5cad0a0834c77b26f193747615b7c911e5422d2", - "sha256:437c33561edb6eb504b5a30203daf81d4a9b727e167e78b0854d9a4e18e8950b", - "sha256:48d39b1824b8d6ea7de878ef6226efbe0773f9c64333e1125e0efcfdd18a24c7", - "sha256:4ac3fcf9a2d369bd075b2c2965544036a27ccd277fc3c04f708338cc57533081", - "sha256:4ccfd74957ef53fa7380aaa1c961f523d582cd5e85a620880ffabd407f8202c0", - "sha256:52b05e21ff05729fbea9bc20b3a791c3c11da61649ff64cce8257c82a020466d", - "sha256:5389445f0173c197f4a3613713b5fb3f3879df1ded2a1a2e4bc4b5b9c5441b7e", - "sha256:5c5e7d2e300d5cb3b2693b6d60d3e8c8e7dd4ebe27cd17c9cb57020cac0acb80", - "sha256:5d26547423e5e71dcc562c4acdc134b900640a39abd9066d7326a7cc2324c530", - "sha256:5dd7106d064d05896ce28c97da3f46caa442fe5a43bc26dfb258e90853b39b44", - "sha256:5f8cb1329f42fadfb40d6211e5ff568d71ab49be36e759345f91c69d1033d633", - "sha256:61d5541f27533f803a941d3a3f8a3d10ed48c12cf918f557efcbf3cd04ef265c", - "sha256:639556758c36093b35e2e368ca485dada6afc2bd6a1b1207d85ea6dfc3deab27", - "sha256:641cf2e3447c9ecff2f7aa6e9eee9eaa286ea65d57b014543a4911ff2799d08a", - "sha256:6aed763b6a1b28c46c055692836879328f0b334a6d61572ee4113a5d0c859872", - "sha256:6e2a2d6749e1ff2c9c76a72c6530d5baa601205b14e441e6d98011000f47a7ac", - "sha256:7243c5a6523c5cfeca76e063efa5f6a656d1d74c8b1fc64b2cd1e84e507f7e2a", - "sha256:76b34c12b013d813e6cb325e6bd4f9c984db27758b16085926bbe7ceeaace626", - "sha256:781b5dd1db18c9e9eacc419027b0acb5073bdec9de1675c0be25ceb10e2ad133", - "sha256:7c611345bbe7cb44aabb877cb94b63e86f2d0db03e382667dbd037866d44b4f8", - "sha256:83b78c680d4b15d33042d330c2fa31813ca3974197bddb3836a5c635a5fd013f", - "sha256:84e87a7d75fa36839a3a432286d719975362d230c70ebfa0948549cc38bd5b46", - "sha256:89b3857652183b8206a891168af47bac10b970d275bba1f6ee46565a758c078d", - "sha256:8cd1a0644ccaf27e9d2f6d9c9474faabee21f0578fe85225cc5af9a61e1653df", - "sha256:8de4d42dffd5ced9117af2ce66ba8722402541a3aa98ffdf78dde92badb68932", - "sha256:94a7bb972178a8bfc4055db80c51efd24baefaced5e51c59b0d598a004e8305d", - "sha256:98aa8325c7f47183b45588af9c434533196e241be0a4e4ae2190b06d17675c02", - "sha256:9e658d1373c424457ddf6d55ec1db93c280b8579276bebd1f72f113072df8a5d", - "sha256:9f49585f4abadd2283034fc605961f40c638635bc60f5162276fec075f2e37a4", - "sha256:9f6cad071960ba1914fa231677d21b1b4a3acdcce463cee41ea30bc82e6040cf", - "sha256:a0cc398350ef31167e03f3ca7c19313d4e40a662adcb98a88755e4e861170bdd", - "sha256:a1133414b771619aa3c3000701c11b2e4624a7f492f12f256aedde97c28331a2", - "sha256:a33273a541f1e1a8219b2a4ed2de355848ecc0254264915b9290c8d2de1c74e1", - "sha256:a3c0ff89fe40a152e77b191b83282c9664357dce3004032d42e68c514ceff27e", - "sha256:a49994481b99cd7dedde07f2e7e93b1d86c01c0fca1c32aded18f10695ae17eb", - "sha256:abf5b17bc0cf626a8a497d89ac691308dbd825d2ac372aa990b1ca114e470151", - "sha256:ac380cacdd3b183338ba63a144a34e9044520a6fb30c58aa14077157a033c13e", - "sha256:ad81012b24b88aad4c70b2cbc2dad84018783221b7f923e926f4690ff8569da3", - "sha256:b2c00ad31fbc2cbac85d7d0fcf90853b2ca2e69d825a2d3f3edb842ef1544a2c", - "sha256:b4c153863dd6569f6511845922c53e39c8d61f6e81f228ad5443e690fca403de", - "sha256:b4f3d66dd0354b79761481fc15bdafaba0b9d9076f1f42cc9ce10d7fcbda205a", - "sha256:b99aac6bb2c37db336fa03a39b40ed4ef2818bf2dfb9441458165ebe88b793af", - "sha256:b9f6392d98c0bd70676ae41474e2eecf4c7150cb419237a41f8f96043fcb81d1", - "sha256:c537da54ce4ff7c15e78ab1292e5799d0d43a2108e006578a57f531866f64025", - "sha256:ca23db5fb195b5ef4fd1f77ce26cadefdf13dba71dab14dadd29b34d457d7c44", - "sha256:cc826b9a8176e686b67aa60fd6c6a7047b0461cae5591ea1dc73d28f72332a8a", - "sha256:cca83a629f77402cfadd58352e394d79a61c8015f1694b83ab72237ec3941f88", - "sha256:cf8d370b2fea27fb300825ec3984334f7dd54a581bde6456799ba3776915a656", - "sha256:d1175b0e0d6037fab207f05774a176d71210ebd40b1c51f480a04b65ec5c786d", - "sha256:d1996ee1330e245cd3aeda0887b4409e3930524c27642b046e4fae88ffa66c5e", - "sha256:d5a36953389f35f0a4e88dc796048829a2f467c9197265504593f0e420571547", - "sha256:da51d8928ad8b4244926fe862ba1795f0b6e68ed8c42cd2f822d435db9c2a8f4", - "sha256:e16e7297f29a544f49340012d6fc08cf14de0ab361c9eb7529f6a57a30cbfda1", - "sha256:e25b11a0417475f093d0f0809a149aff3943c2c56da50fdf2c3c88d57fe3dfbd", - "sha256:e4371591e621579cb6da8401e4ea405b33ff25a755874a3567c4075ca63d56e2", - "sha256:e653d36b1bf48fa78c7fcebb5fa679342e025121ace8c87ab05c1cefd33b34fc", - "sha256:e7d91a230c7f8af86c904a5a992b8c064b66330544693fd6759c3d6162382ecf", - "sha256:e851e6363d0dbe515d8de81fd544a2c956fdec6f8a049739562286727d4a00c3", - "sha256:ef7d48207926edbf8b16b336f779c557dd8f5a33035a85db9c4b0febb0706817", - "sha256:f7716f7e7138252d88607228ce40be22660d6608d20fd365d596e7ca0738e019", - "sha256:facaf11f21f3a4c51b62931feb13310e6fe3475f85e20d9c9fdce0d2ea561b87" + "sha256:033edcc22211463be927ca407dc5c5f3aa84d3d093ed2d559a2e3c2d995d50e4", + "sha256:03cd2a3c446162678d0a6d14d69ad38204128414ba40722a5ff6f2107782b723", + "sha256:05dcc73739ae8096f64f08282c8980dab2cf9acb02eb838aacd8ac56b795c405", + "sha256:11d76b83dc93e98207514e1938b89854655087e3b27a09d89525fe17a0f1ce11", + "sha256:1247de19497e13063eabf1df67e87530ac31497b91e9bd08621852a57d9b5ee7", + "sha256:147c962e8ae339d5fa84c52cc1e59546cb2d0d9359f9a8e1b8eb7b5ffac8dba0", + "sha256:159dae860e4d34bd4f48e72a0c033d78ae9215b43d423c19cbf47b7db5972599", + "sha256:15c14a01dd95e860703a4ce78d4b0d49f18c14389eb91b4aa12444e31dfc2841", + "sha256:15ddde4242134f1aeb1455ad60cc529e0a9f5eb251ae7be7fc37debdb257182c", + "sha256:1a894aed57c6edc514c9222989cf09eebd9ea7acb6185a26cfeac2ece2ddf265", + "sha256:1c11e8460ff0629871f9703c87208e553fbfa6c9d92f94c20d4f86e56f021029", + "sha256:1cd34caed981a95964218e03a3f267537a0b1a2fae078949e880f757df9efe55", + "sha256:1f62882c6d06e5e75b82444ce14f59b830f5b017b31630cc13d8b0b01379385a", + "sha256:20050a17cc2f322598d181a5b2e2cf4787e4c2e3bf71aab5e96618b40665e8ae", + "sha256:205da0f812c9128155bc1b7be69cf89280a5bb2f5b84426bced76e7d860ed5dc", + "sha256:258414850b59fb820bd1e1e19a9b281409a6d0bd969d3fe7104cc87a7c08c191", + "sha256:27d45a6a8495f2cfcf64d6cc4fbcc78a6e87ed840e54a261430d0d4331d9aae0", + "sha256:285058a0cdd284ba5bbc1d10d75fb33e3b3087b15d5aa9d23fc4787dd3a48384", + "sha256:2e116fad10aa7c74aa3acc69adcdffe86f1415abb111653f85dd37171116b57d", + "sha256:38e165c4d79ac98cabb5c08d8a3a3e1dda3206bcec19ed072992b62b200b180d", + "sha256:3af088483bf2aba7f2886437d856a6ba4cd0c17946dd615cbe55d56552eaf187", + "sha256:3d17d8b2d4643d4f59629758b0dd229cda61e2319f81b470aa4a99717081ba0c", + "sha256:3e80621ebc9f045fab847a970b2430146f9121b95c3c695b044ade8488753126", + "sha256:4030f5319aacf20e924c5218377df446507b314f03676549891e12a9f832a9f1", + "sha256:44ee27fb416c3d8981b7c3c97b9813d40b06575f6d477f4da21726a30aabb562", + "sha256:458b235ae7af880e18c1476f968ef571689a574720eb9e6e8873d138fbba9c58", + "sha256:4660b75286c11b8f38c90b98ccf7541b7030dbec32b28f05031f8abebf7fc0e5", + "sha256:4748c017fa201e6a296c9ef75dc3668a01532adb8f5c27a0bef4835dfa62f8e7", + "sha256:48f775443154d99e1b1c727ea20137ddc1e4b29448a9b24875b2a348cc143b85", + "sha256:49e01d212be64ceee18a45e8baef441aa86cc9bd365fb92fb8b214e5fa5bc08b", + "sha256:4a0ba21b315113d39f7aa3ca4eb804f7984dab33c42ea14d07d790a640f81e77", + "sha256:4aca2ab0969dc3781fefe523ce70c5d245b915ba0708ce2713e8ac561f9448e0", + "sha256:5055e039ebfc6e4589115717c4a6d1dd2f195327b8d5a3e21a68f374d79dbed9", + "sha256:52bd2b6681beb34115eebbcbdcbd170ebc3fc98c4eb0dd789f2c01d4d6b189c0", + "sha256:54a291428e25f775193704f95a94f21a42a28ffb09c1bdc91e152c6b1faf4a91", + "sha256:58f74a195b99189c9f7e2bc83cc95fcf169a43a63c5c8cad63c4027bf3233118", + "sha256:614021ba98b8052d4eb3d5900d3bd953421edf41b2aa85d37c1dc67bcee1ea9d", + "sha256:64fccd2fa3cfd49c442c4995d58189e578560705b9b632faad8ffd9aaa390007", + "sha256:64fdd7a4aef8f14e4a6917a434d0a4766345f5d544d0c0c0e53b14eb1e4be0ac", + "sha256:693858c9584cedc1685e67e78fa9e50285504e8d4bbfde7290ca04dbbac939a8", + "sha256:6d168a6693c1b9b950d9584178d12095bfbaf290748eb6e2726c914bc1d0d4f1", + "sha256:6da367181104a57e77140ebf736652ed9a97c7bcb77c7640cf8a168893561bd2", + "sha256:6ed731286f0ae399e65e3172c5808732b9ae5d896b3ab7f692eb686bba6bc9df", + "sha256:70d695f62a55f90ee894fdf1ede51ccdda3abbe25b43b667b51747b6f61b8da7", + "sha256:71dae164819f8aede109a596db84d508e670d7e0a968901aaf22445e87ae7519", + "sha256:75bb804375e0b6c5db4e474fa0b5052414b6cbc3e70394d11a7ce9a7f6a18a91", + "sha256:796d1b070211554cc8193bd6764d2b44594ff7c7522989012eacf3fde778e5cf", + "sha256:79dc3f9893e32fcc564c60bb34c4e393daede2cdf0337a5b4627ed162a237fb3", + "sha256:7a3165a5bae6577d10858c35f6add83333ead621e8286a5d15f7d567ef44be78", + "sha256:7a74764881276904564f8725da3dd2b82924838a114738933f58b75082b55dd3", + "sha256:7cbc2e5116cdca0594bb39c64a8bd5e7f44d392cf76d19913216924688d42954", + "sha256:8223f74cf698f7992e1a71ab90ab4c169b508a0f25083ebab9259b9f33d7bdde", + "sha256:824b60427c92c44098cfbd58d8adf8a8c5a60ade16742dcb54385b43e6337b4e", + "sha256:8257f26cc2cc5d0426da488162060c6cea57079172b9d3eedf016fcb0cfdb830", + "sha256:8530ca574ba38478e97af20ff0f3fd04f59ffcad435b1548703424d71e2ed66a", + "sha256:858b68e475f8e73e4014c078e9feced502273032f07840117ca12d2230d27135", + "sha256:88ae724e79a524d1921b2799251f667e7fb0344a59637df3bec91dc303020467", + "sha256:8ce52f84e793ee83082c4aa127605070a47c31597821ca84dec5c0ac809e8509", + "sha256:93de2d3802a5ac7d5deadba1c956a93db29502f1b9f4e8d2e393747b9b28d881", + "sha256:93f4545347f79121e9ba98a0c33a55f469ebc22fb45ae62692e01d367219796b", + "sha256:9777e194be00313f5a86a0dd52d9987b72cf6c43c8a42d6bd838adc46c70e98b", + "sha256:99b2401166c3b2d997b80479cdc7449a093e21f3d4b2f9c6e6ceee956aa10d63", + "sha256:99f9b6596d2e126fa1777990868743fb4c1984ea5217606fabc153aff46160e6", + "sha256:9b4cd51b623b3dc8b55f9caef07424ac6d684b8047e601aca7053999e1b4a527", + "sha256:9f1edbf7e0d22a1ebf3c24ffaf0b8a39888bd630d6ff38c77c169272a3d4b9cc", + "sha256:a3da262f5b9f0dd01277575de4967683123ab47699fd7db2ce38cb1bb8f5c76f", + "sha256:aa613b270de6215f9fc850f0fb18dbc20ba297013012793cf3d2f1295e271e91", + "sha256:ac87e173c5f3aeac06d01eeebfb35c2b1bc5f536b21210dd8b032f1dc0726fbc", + "sha256:ad333e0b0d19294d3fc81d7aa9b65c45ebf49e6f8b3fab02db43284140d2b0a8", + "sha256:af55e557e722c962f70cdc6a482d0df44b1f6622af49003e33dd114340724875", + "sha256:b019f5c53471e8a010edf2fec321ece25ac6b079b535980b7228dcb9ee62d621", + "sha256:b0441ee8b9edc3fadb5cd9f181212edd72f7b016723bc549f9c1c00a9a8e6f93", + "sha256:b29a79f1e4313c397e00d89d4d83ff54fd377e7d654b640bbe9002b4272f205e", + "sha256:b622146bcfc6749944d14e8a61267dbea1bee96a9c7ca7605683506ed3817844", + "sha256:b8a87a3686de1d215506ba13dd388433695bfff534839e045419ba2f36437c0e", + "sha256:b9c5dfa5c7cdc26f6b777ac6210d3621d556e2e244f0a7358afe8ec0135f8640", + "sha256:b9d3d5de87a88768be67b7ec20aeb531707174ba0645697a938df3afc2c62b1f", + "sha256:bbd3cc064d272618b95c2f85ec61fe9d07e2a1de18c153c10923d3c2cdebff4c", + "sha256:bcd21a1b5cfb45170280e5fcd382c25519d75bdf4634656868b91c05d5e15b23", + "sha256:bdb621264758b22ae3aaa9d60937751069d80d610d713887ff94cf7487fc3f5f", + "sha256:c5fdcac25ae451af93e7f997678ed2282bf6b5ef892e253eea13bba59849f00e", + "sha256:c785581071f140d364821c210422ab5937d6c2c51d92e45a552a8e34b434a5a3", + "sha256:cbd06fb147030d7781f10bd7542f29bbf56cefb51a9f042713d5fc52e68b8afd", + "sha256:cf95ac57b44b6fb46a0151641b9905bbad27783314abc4f4b0b0a82f26b06b07", + "sha256:d6698fccb2f962021e467be6ba43fc02f7341f221e80545810303f5cc66461bb", + "sha256:d7533a9684e599b22a4beb699647dc3269d551e455886be8125f14f3c5a0869f", + "sha256:d7bf1d52c69f3051a0ebae9cca1e5be06e2ad4677d670a920454ecf6d20e2c8e", + "sha256:d8f47485264b1168ef852dd6bea619703409ff2cbc5e610dcb0f15fe3c6750bb", + "sha256:d8fc8c7c092a48044bf942735eea6da198cac0c655d7a06550619b2a7fec2ffd", + "sha256:d9e984f9542fba175bc4d98e320e9e2bd6e7480682aa84b274e9aee7fb6575b9", + "sha256:dc86a31e3215ce037ae306a338ff2156d897aae627d5d4e3dfa0c9eded4249e8", + "sha256:dd5240bea7d8de32e7ac95088b2ad95b89993a3825d9278d363d73ca40113cb3", + "sha256:df46fd268c765d186df8c7899bc4e0a2ee0d12458d356438af0329a49e6b15ca", + "sha256:dfb3870c5d4f5413988caf64243830f7ca13dc58ae2cf3eb48fe321ca6f26648", + "sha256:e36cfe9df4dfb6c2f4d80d20852ab6449257a01942e4808c3912ed413a4d40f7", + "sha256:e5ca936b70414dbee02f218be1d36a535a5953ba63fd82dc812135ca3f5a525f", + "sha256:e7ab7ea72c3f66ae1e930ae776ad2c6f4f78e0184781f64f196f17ecce113101", + "sha256:e80878904057edfd1d70ba31258f974d36c470fd95de2bcd98e0494942c4433e", + "sha256:ed8d6bd6f3c7991083e741fd55cecea70d670971c73b9563a673eab96e5356b4", + "sha256:f290e4eebf7764f8327a4bc6a459f09ca9a041cf7349bacfbb252da9feb0d37c", + "sha256:f915fc3287ddc23a5da8f61f5c2c3aaca0b754ce526c0ff81f55c27b25038cd5", + "sha256:fb8b1cba597398698ec494794091dadd76eb8011bb95f43578930466e7beb20b", + "sha256:fbd035ae06babb07c6b80535b0d4f6fe57eb73a23ae276eb4502b1f67f19e8ef", + "sha256:fd9521b70b50aac341f59799301ba24acbe2897b9157035d139668b6c43bc406" ], "markers": "python_version >= '3.9'", - "version": "==6.2.0" + "version": "==6.4.2" }, "niquests": { "hashes": [ @@ -1865,11 +1877,11 @@ }, "urllib3-future": { "hashes": [ - "sha256:3adfa22c5718caee5ca69bc7f7461dc529f4396494d4d9b1db8af7c56cd3ac34", - "sha256:9cd79ce61da77b5d56681bc126f42955c2153e9c0da2f0a62bca8e0a05641f92" + "sha256:1a31156dc1f87d13483272cd7fe381664ded124b3b5e3d65385c23a309a1584e", + "sha256:60d1c48846c7fd5dbddfae38196fd1c43ffc83fb987ba477361254b93913ccbc" ], "markers": "python_version >= '3.7'", - "version": "==2.12.915" + "version": "==2.12.916" }, "verlib2": { "hashes": [ diff --git a/dbrepo-search-service/init/Pipfile.lock b/dbrepo-search-service/init/Pipfile.lock index ee7dcad638c31d4b646274c471626afb08800a77..900dbd5715e72bb8c38c69ca654a1a3119f2ef69 100644 --- a/dbrepo-search-service/init/Pipfile.lock +++ b/dbrepo-search-service/init/Pipfile.lock @@ -259,7 +259,7 @@ }, "dbrepo": { "hashes": [ - "sha256:7e21d72d0b3e766aeecb286b636ea7530fa971d95b1b083b7ef8b9512b8300ef" + "sha256:22484d712e4a240a0114b90b5e8eaacbe47aa8f7fc79200557150f081faf7669" ], "path": "./lib/dbrepo-1.8.1.tar.gz" }, @@ -604,101 +604,113 @@ }, "multidict": { "hashes": [ - "sha256:0085b0afb2446e57050140240a8595846ed64d1cbd26cef936bfab3192c673b8", - "sha256:042028348dc5a1f2be6c666437042a98a5d24cee50380f4c0902215e5ec41844", - "sha256:05fefbc3cddc4e36da209a5e49f1094bbece9a581faa7f3589201fd95df40e5d", - "sha256:063be88bd684782a0715641de853e1e58a2f25b76388538bd62d974777ce9bc2", - "sha256:07bfa8bc649783e703263f783f73e27fef8cd37baaad4389816cf6a133141331", - "sha256:08549895e6a799bd551cf276f6e59820aa084f0f90665c0f03dd3a50db5d3c48", - "sha256:095a2eabe8c43041d3e6c2cb8287a257b5f1801c2d6ebd1dd877424f1e89cf29", - "sha256:0b183a959fb88ad1be201de2c4bdf52fa8e46e6c185d76201286a97b6f5ee65c", - "sha256:0c383d28857f66f5aebe3e91d6cf498da73af75fbd51cedbe1adfb85e90c0460", - "sha256:0d57a01a2a9fa00234aace434d8c131f0ac6e0ac6ef131eda5962d7e79edfb5b", - "sha256:0dc25a3293c50744796e87048de5e68996104d86d940bb24bc3ec31df281b191", - "sha256:0e5a644e50ef9fb87878d4d57907f03a12410d2aa3b93b3acdf90a741df52c49", - "sha256:0f249badb360b0b4d694307ad40f811f83df4da8cef7b68e429e4eea939e49dd", - "sha256:0f74f2fc51555f4b037ef278efc29a870d327053aba5cb7d86ae572426c7cccc", - "sha256:125dd82b40f8c06d08d87b3510beaccb88afac94e9ed4a6f6c71362dc7dbb04b", - "sha256:13551d0e2d7201f0959725a6a769b6f7b9019a168ed96006479c9ac33fe4096b", - "sha256:14ed9ed1bfedd72a877807c71113deac292bf485159a29025dfdc524c326f3e1", - "sha256:163f4604e76639f728d127293d24c3e208b445b463168af3d031b92b0998bb90", - "sha256:19e2819b0b468174de25c0ceed766606a07cedeab132383f1e83b9a4e96ccb4f", - "sha256:1e2a2193d3aa5cbf5758f6d5680a52aa848e0cf611da324f71e5e48a9695cc86", - "sha256:1f3c099d3899b14e1ce52262eb82a5f5cb92157bb5106bf627b618c090a0eadc", - "sha256:214207dcc7a6221d9942f23797fe89144128a71c03632bf713d918db99bd36de", - "sha256:2325105e16d434749e1be8022f942876a936f9bece4ec41ae244e3d7fae42aaf", - "sha256:2529ddbdaa424b2c6c2eb668ea684dd6b75b839d0ad4b21aad60c168269478d7", - "sha256:256d431fe4583c5f1e0f2e9c4d9c22f3a04ae96009b8cfa096da3a8723db0a16", - "sha256:25bb96338512e2f46f615a2bb7c6012fe92a4a5ebd353e5020836a7e33120349", - "sha256:2e87f1926e91855ae61769ba3e3f7315120788c099677e0842e697b0bfb659f2", - "sha256:2fc6af8e39f7496047c7876314f4317736eac82bf85b54c7c76cf1a6f8e35d98", - "sha256:3157126b028c074951839233647bd0e30df77ef1fedd801b48bdcad242a60f4e", - "sha256:32c9b4878f48be3e75808ea7e499d6223b1eea6d54c487a66bc10a1871e3dc6a", - "sha256:32ed748ff9ac682eae7859790d3044b50e3076c7d80e17a44239683769ff485e", - "sha256:3501621d5e86f1a88521ea65d5cad0a0834c77b26f193747615b7c911e5422d2", - "sha256:437c33561edb6eb504b5a30203daf81d4a9b727e167e78b0854d9a4e18e8950b", - "sha256:48d39b1824b8d6ea7de878ef6226efbe0773f9c64333e1125e0efcfdd18a24c7", - "sha256:4ac3fcf9a2d369bd075b2c2965544036a27ccd277fc3c04f708338cc57533081", - "sha256:4ccfd74957ef53fa7380aaa1c961f523d582cd5e85a620880ffabd407f8202c0", - "sha256:52b05e21ff05729fbea9bc20b3a791c3c11da61649ff64cce8257c82a020466d", - "sha256:5389445f0173c197f4a3613713b5fb3f3879df1ded2a1a2e4bc4b5b9c5441b7e", - "sha256:5c5e7d2e300d5cb3b2693b6d60d3e8c8e7dd4ebe27cd17c9cb57020cac0acb80", - "sha256:5d26547423e5e71dcc562c4acdc134b900640a39abd9066d7326a7cc2324c530", - "sha256:5dd7106d064d05896ce28c97da3f46caa442fe5a43bc26dfb258e90853b39b44", - "sha256:5f8cb1329f42fadfb40d6211e5ff568d71ab49be36e759345f91c69d1033d633", - "sha256:61d5541f27533f803a941d3a3f8a3d10ed48c12cf918f557efcbf3cd04ef265c", - "sha256:639556758c36093b35e2e368ca485dada6afc2bd6a1b1207d85ea6dfc3deab27", - "sha256:641cf2e3447c9ecff2f7aa6e9eee9eaa286ea65d57b014543a4911ff2799d08a", - "sha256:6aed763b6a1b28c46c055692836879328f0b334a6d61572ee4113a5d0c859872", - "sha256:6e2a2d6749e1ff2c9c76a72c6530d5baa601205b14e441e6d98011000f47a7ac", - "sha256:7243c5a6523c5cfeca76e063efa5f6a656d1d74c8b1fc64b2cd1e84e507f7e2a", - "sha256:76b34c12b013d813e6cb325e6bd4f9c984db27758b16085926bbe7ceeaace626", - "sha256:781b5dd1db18c9e9eacc419027b0acb5073bdec9de1675c0be25ceb10e2ad133", - "sha256:7c611345bbe7cb44aabb877cb94b63e86f2d0db03e382667dbd037866d44b4f8", - "sha256:83b78c680d4b15d33042d330c2fa31813ca3974197bddb3836a5c635a5fd013f", - "sha256:84e87a7d75fa36839a3a432286d719975362d230c70ebfa0948549cc38bd5b46", - "sha256:89b3857652183b8206a891168af47bac10b970d275bba1f6ee46565a758c078d", - "sha256:8cd1a0644ccaf27e9d2f6d9c9474faabee21f0578fe85225cc5af9a61e1653df", - "sha256:8de4d42dffd5ced9117af2ce66ba8722402541a3aa98ffdf78dde92badb68932", - "sha256:94a7bb972178a8bfc4055db80c51efd24baefaced5e51c59b0d598a004e8305d", - "sha256:98aa8325c7f47183b45588af9c434533196e241be0a4e4ae2190b06d17675c02", - "sha256:9e658d1373c424457ddf6d55ec1db93c280b8579276bebd1f72f113072df8a5d", - "sha256:9f49585f4abadd2283034fc605961f40c638635bc60f5162276fec075f2e37a4", - "sha256:9f6cad071960ba1914fa231677d21b1b4a3acdcce463cee41ea30bc82e6040cf", - "sha256:a0cc398350ef31167e03f3ca7c19313d4e40a662adcb98a88755e4e861170bdd", - "sha256:a1133414b771619aa3c3000701c11b2e4624a7f492f12f256aedde97c28331a2", - "sha256:a33273a541f1e1a8219b2a4ed2de355848ecc0254264915b9290c8d2de1c74e1", - "sha256:a3c0ff89fe40a152e77b191b83282c9664357dce3004032d42e68c514ceff27e", - "sha256:a49994481b99cd7dedde07f2e7e93b1d86c01c0fca1c32aded18f10695ae17eb", - "sha256:abf5b17bc0cf626a8a497d89ac691308dbd825d2ac372aa990b1ca114e470151", - "sha256:ac380cacdd3b183338ba63a144a34e9044520a6fb30c58aa14077157a033c13e", - "sha256:ad81012b24b88aad4c70b2cbc2dad84018783221b7f923e926f4690ff8569da3", - "sha256:b2c00ad31fbc2cbac85d7d0fcf90853b2ca2e69d825a2d3f3edb842ef1544a2c", - "sha256:b4c153863dd6569f6511845922c53e39c8d61f6e81f228ad5443e690fca403de", - "sha256:b4f3d66dd0354b79761481fc15bdafaba0b9d9076f1f42cc9ce10d7fcbda205a", - "sha256:b99aac6bb2c37db336fa03a39b40ed4ef2818bf2dfb9441458165ebe88b793af", - "sha256:b9f6392d98c0bd70676ae41474e2eecf4c7150cb419237a41f8f96043fcb81d1", - "sha256:c537da54ce4ff7c15e78ab1292e5799d0d43a2108e006578a57f531866f64025", - "sha256:ca23db5fb195b5ef4fd1f77ce26cadefdf13dba71dab14dadd29b34d457d7c44", - "sha256:cc826b9a8176e686b67aa60fd6c6a7047b0461cae5591ea1dc73d28f72332a8a", - "sha256:cca83a629f77402cfadd58352e394d79a61c8015f1694b83ab72237ec3941f88", - "sha256:cf8d370b2fea27fb300825ec3984334f7dd54a581bde6456799ba3776915a656", - "sha256:d1175b0e0d6037fab207f05774a176d71210ebd40b1c51f480a04b65ec5c786d", - "sha256:d1996ee1330e245cd3aeda0887b4409e3930524c27642b046e4fae88ffa66c5e", - "sha256:d5a36953389f35f0a4e88dc796048829a2f467c9197265504593f0e420571547", - "sha256:da51d8928ad8b4244926fe862ba1795f0b6e68ed8c42cd2f822d435db9c2a8f4", - "sha256:e16e7297f29a544f49340012d6fc08cf14de0ab361c9eb7529f6a57a30cbfda1", - "sha256:e25b11a0417475f093d0f0809a149aff3943c2c56da50fdf2c3c88d57fe3dfbd", - "sha256:e4371591e621579cb6da8401e4ea405b33ff25a755874a3567c4075ca63d56e2", - "sha256:e653d36b1bf48fa78c7fcebb5fa679342e025121ace8c87ab05c1cefd33b34fc", - "sha256:e7d91a230c7f8af86c904a5a992b8c064b66330544693fd6759c3d6162382ecf", - "sha256:e851e6363d0dbe515d8de81fd544a2c956fdec6f8a049739562286727d4a00c3", - "sha256:ef7d48207926edbf8b16b336f779c557dd8f5a33035a85db9c4b0febb0706817", - "sha256:f7716f7e7138252d88607228ce40be22660d6608d20fd365d596e7ca0738e019", - "sha256:facaf11f21f3a4c51b62931feb13310e6fe3475f85e20d9c9fdce0d2ea561b87" + "sha256:033edcc22211463be927ca407dc5c5f3aa84d3d093ed2d559a2e3c2d995d50e4", + "sha256:03cd2a3c446162678d0a6d14d69ad38204128414ba40722a5ff6f2107782b723", + "sha256:05dcc73739ae8096f64f08282c8980dab2cf9acb02eb838aacd8ac56b795c405", + "sha256:11d76b83dc93e98207514e1938b89854655087e3b27a09d89525fe17a0f1ce11", + "sha256:1247de19497e13063eabf1df67e87530ac31497b91e9bd08621852a57d9b5ee7", + "sha256:147c962e8ae339d5fa84c52cc1e59546cb2d0d9359f9a8e1b8eb7b5ffac8dba0", + "sha256:159dae860e4d34bd4f48e72a0c033d78ae9215b43d423c19cbf47b7db5972599", + "sha256:15c14a01dd95e860703a4ce78d4b0d49f18c14389eb91b4aa12444e31dfc2841", + "sha256:15ddde4242134f1aeb1455ad60cc529e0a9f5eb251ae7be7fc37debdb257182c", + "sha256:1a894aed57c6edc514c9222989cf09eebd9ea7acb6185a26cfeac2ece2ddf265", + "sha256:1c11e8460ff0629871f9703c87208e553fbfa6c9d92f94c20d4f86e56f021029", + "sha256:1cd34caed981a95964218e03a3f267537a0b1a2fae078949e880f757df9efe55", + "sha256:1f62882c6d06e5e75b82444ce14f59b830f5b017b31630cc13d8b0b01379385a", + "sha256:20050a17cc2f322598d181a5b2e2cf4787e4c2e3bf71aab5e96618b40665e8ae", + "sha256:205da0f812c9128155bc1b7be69cf89280a5bb2f5b84426bced76e7d860ed5dc", + "sha256:258414850b59fb820bd1e1e19a9b281409a6d0bd969d3fe7104cc87a7c08c191", + "sha256:27d45a6a8495f2cfcf64d6cc4fbcc78a6e87ed840e54a261430d0d4331d9aae0", + "sha256:285058a0cdd284ba5bbc1d10d75fb33e3b3087b15d5aa9d23fc4787dd3a48384", + "sha256:2e116fad10aa7c74aa3acc69adcdffe86f1415abb111653f85dd37171116b57d", + "sha256:38e165c4d79ac98cabb5c08d8a3a3e1dda3206bcec19ed072992b62b200b180d", + "sha256:3af088483bf2aba7f2886437d856a6ba4cd0c17946dd615cbe55d56552eaf187", + "sha256:3d17d8b2d4643d4f59629758b0dd229cda61e2319f81b470aa4a99717081ba0c", + "sha256:3e80621ebc9f045fab847a970b2430146f9121b95c3c695b044ade8488753126", + "sha256:4030f5319aacf20e924c5218377df446507b314f03676549891e12a9f832a9f1", + "sha256:44ee27fb416c3d8981b7c3c97b9813d40b06575f6d477f4da21726a30aabb562", + "sha256:458b235ae7af880e18c1476f968ef571689a574720eb9e6e8873d138fbba9c58", + "sha256:4660b75286c11b8f38c90b98ccf7541b7030dbec32b28f05031f8abebf7fc0e5", + "sha256:4748c017fa201e6a296c9ef75dc3668a01532adb8f5c27a0bef4835dfa62f8e7", + "sha256:48f775443154d99e1b1c727ea20137ddc1e4b29448a9b24875b2a348cc143b85", + "sha256:49e01d212be64ceee18a45e8baef441aa86cc9bd365fb92fb8b214e5fa5bc08b", + "sha256:4a0ba21b315113d39f7aa3ca4eb804f7984dab33c42ea14d07d790a640f81e77", + "sha256:4aca2ab0969dc3781fefe523ce70c5d245b915ba0708ce2713e8ac561f9448e0", + "sha256:5055e039ebfc6e4589115717c4a6d1dd2f195327b8d5a3e21a68f374d79dbed9", + "sha256:52bd2b6681beb34115eebbcbdcbd170ebc3fc98c4eb0dd789f2c01d4d6b189c0", + "sha256:54a291428e25f775193704f95a94f21a42a28ffb09c1bdc91e152c6b1faf4a91", + "sha256:58f74a195b99189c9f7e2bc83cc95fcf169a43a63c5c8cad63c4027bf3233118", + "sha256:614021ba98b8052d4eb3d5900d3bd953421edf41b2aa85d37c1dc67bcee1ea9d", + "sha256:64fccd2fa3cfd49c442c4995d58189e578560705b9b632faad8ffd9aaa390007", + "sha256:64fdd7a4aef8f14e4a6917a434d0a4766345f5d544d0c0c0e53b14eb1e4be0ac", + "sha256:693858c9584cedc1685e67e78fa9e50285504e8d4bbfde7290ca04dbbac939a8", + "sha256:6d168a6693c1b9b950d9584178d12095bfbaf290748eb6e2726c914bc1d0d4f1", + "sha256:6da367181104a57e77140ebf736652ed9a97c7bcb77c7640cf8a168893561bd2", + "sha256:6ed731286f0ae399e65e3172c5808732b9ae5d896b3ab7f692eb686bba6bc9df", + "sha256:70d695f62a55f90ee894fdf1ede51ccdda3abbe25b43b667b51747b6f61b8da7", + "sha256:71dae164819f8aede109a596db84d508e670d7e0a968901aaf22445e87ae7519", + "sha256:75bb804375e0b6c5db4e474fa0b5052414b6cbc3e70394d11a7ce9a7f6a18a91", + "sha256:796d1b070211554cc8193bd6764d2b44594ff7c7522989012eacf3fde778e5cf", + "sha256:79dc3f9893e32fcc564c60bb34c4e393daede2cdf0337a5b4627ed162a237fb3", + "sha256:7a3165a5bae6577d10858c35f6add83333ead621e8286a5d15f7d567ef44be78", + "sha256:7a74764881276904564f8725da3dd2b82924838a114738933f58b75082b55dd3", + "sha256:7cbc2e5116cdca0594bb39c64a8bd5e7f44d392cf76d19913216924688d42954", + "sha256:8223f74cf698f7992e1a71ab90ab4c169b508a0f25083ebab9259b9f33d7bdde", + "sha256:824b60427c92c44098cfbd58d8adf8a8c5a60ade16742dcb54385b43e6337b4e", + "sha256:8257f26cc2cc5d0426da488162060c6cea57079172b9d3eedf016fcb0cfdb830", + "sha256:8530ca574ba38478e97af20ff0f3fd04f59ffcad435b1548703424d71e2ed66a", + "sha256:858b68e475f8e73e4014c078e9feced502273032f07840117ca12d2230d27135", + "sha256:88ae724e79a524d1921b2799251f667e7fb0344a59637df3bec91dc303020467", + "sha256:8ce52f84e793ee83082c4aa127605070a47c31597821ca84dec5c0ac809e8509", + "sha256:93de2d3802a5ac7d5deadba1c956a93db29502f1b9f4e8d2e393747b9b28d881", + "sha256:93f4545347f79121e9ba98a0c33a55f469ebc22fb45ae62692e01d367219796b", + "sha256:9777e194be00313f5a86a0dd52d9987b72cf6c43c8a42d6bd838adc46c70e98b", + "sha256:99b2401166c3b2d997b80479cdc7449a093e21f3d4b2f9c6e6ceee956aa10d63", + "sha256:99f9b6596d2e126fa1777990868743fb4c1984ea5217606fabc153aff46160e6", + "sha256:9b4cd51b623b3dc8b55f9caef07424ac6d684b8047e601aca7053999e1b4a527", + "sha256:9f1edbf7e0d22a1ebf3c24ffaf0b8a39888bd630d6ff38c77c169272a3d4b9cc", + "sha256:a3da262f5b9f0dd01277575de4967683123ab47699fd7db2ce38cb1bb8f5c76f", + "sha256:aa613b270de6215f9fc850f0fb18dbc20ba297013012793cf3d2f1295e271e91", + "sha256:ac87e173c5f3aeac06d01eeebfb35c2b1bc5f536b21210dd8b032f1dc0726fbc", + "sha256:ad333e0b0d19294d3fc81d7aa9b65c45ebf49e6f8b3fab02db43284140d2b0a8", + "sha256:af55e557e722c962f70cdc6a482d0df44b1f6622af49003e33dd114340724875", + "sha256:b019f5c53471e8a010edf2fec321ece25ac6b079b535980b7228dcb9ee62d621", + "sha256:b0441ee8b9edc3fadb5cd9f181212edd72f7b016723bc549f9c1c00a9a8e6f93", + "sha256:b29a79f1e4313c397e00d89d4d83ff54fd377e7d654b640bbe9002b4272f205e", + "sha256:b622146bcfc6749944d14e8a61267dbea1bee96a9c7ca7605683506ed3817844", + "sha256:b8a87a3686de1d215506ba13dd388433695bfff534839e045419ba2f36437c0e", + "sha256:b9c5dfa5c7cdc26f6b777ac6210d3621d556e2e244f0a7358afe8ec0135f8640", + "sha256:b9d3d5de87a88768be67b7ec20aeb531707174ba0645697a938df3afc2c62b1f", + "sha256:bbd3cc064d272618b95c2f85ec61fe9d07e2a1de18c153c10923d3c2cdebff4c", + "sha256:bcd21a1b5cfb45170280e5fcd382c25519d75bdf4634656868b91c05d5e15b23", + "sha256:bdb621264758b22ae3aaa9d60937751069d80d610d713887ff94cf7487fc3f5f", + "sha256:c5fdcac25ae451af93e7f997678ed2282bf6b5ef892e253eea13bba59849f00e", + "sha256:c785581071f140d364821c210422ab5937d6c2c51d92e45a552a8e34b434a5a3", + "sha256:cbd06fb147030d7781f10bd7542f29bbf56cefb51a9f042713d5fc52e68b8afd", + "sha256:cf95ac57b44b6fb46a0151641b9905bbad27783314abc4f4b0b0a82f26b06b07", + "sha256:d6698fccb2f962021e467be6ba43fc02f7341f221e80545810303f5cc66461bb", + "sha256:d7533a9684e599b22a4beb699647dc3269d551e455886be8125f14f3c5a0869f", + "sha256:d7bf1d52c69f3051a0ebae9cca1e5be06e2ad4677d670a920454ecf6d20e2c8e", + "sha256:d8f47485264b1168ef852dd6bea619703409ff2cbc5e610dcb0f15fe3c6750bb", + "sha256:d8fc8c7c092a48044bf942735eea6da198cac0c655d7a06550619b2a7fec2ffd", + "sha256:d9e984f9542fba175bc4d98e320e9e2bd6e7480682aa84b274e9aee7fb6575b9", + "sha256:dc86a31e3215ce037ae306a338ff2156d897aae627d5d4e3dfa0c9eded4249e8", + "sha256:dd5240bea7d8de32e7ac95088b2ad95b89993a3825d9278d363d73ca40113cb3", + "sha256:df46fd268c765d186df8c7899bc4e0a2ee0d12458d356438af0329a49e6b15ca", + "sha256:dfb3870c5d4f5413988caf64243830f7ca13dc58ae2cf3eb48fe321ca6f26648", + "sha256:e36cfe9df4dfb6c2f4d80d20852ab6449257a01942e4808c3912ed413a4d40f7", + "sha256:e5ca936b70414dbee02f218be1d36a535a5953ba63fd82dc812135ca3f5a525f", + "sha256:e7ab7ea72c3f66ae1e930ae776ad2c6f4f78e0184781f64f196f17ecce113101", + "sha256:e80878904057edfd1d70ba31258f974d36c470fd95de2bcd98e0494942c4433e", + "sha256:ed8d6bd6f3c7991083e741fd55cecea70d670971c73b9563a673eab96e5356b4", + "sha256:f290e4eebf7764f8327a4bc6a459f09ca9a041cf7349bacfbb252da9feb0d37c", + "sha256:f915fc3287ddc23a5da8f61f5c2c3aaca0b754ce526c0ff81f55c27b25038cd5", + "sha256:fb8b1cba597398698ec494794091dadd76eb8011bb95f43578930466e7beb20b", + "sha256:fbd035ae06babb07c6b80535b0d4f6fe57eb73a23ae276eb4502b1f67f19e8ef", + "sha256:fd9521b70b50aac341f59799301ba24acbe2897b9157035d139668b6c43bc406" ], "markers": "python_version >= '3.9'", - "version": "==6.2.0" + "version": "==6.4.2" }, "niquests": { "hashes": [ @@ -1299,11 +1311,11 @@ }, "urllib3-future": { "hashes": [ - "sha256:3adfa22c5718caee5ca69bc7f7461dc529f4396494d4d9b1db8af7c56cd3ac34", - "sha256:9cd79ce61da77b5d56681bc126f42955c2153e9c0da2f0a62bca8e0a05641f92" + "sha256:1a31156dc1f87d13483272cd7fe381664ded124b3b5e3d65385c23a309a1584e", + "sha256:60d1c48846c7fd5dbddfae38196fd1c43ffc83fb987ba477361254b93913ccbc" ], "markers": "python_version >= '3.7'", - "version": "==2.12.915" + "version": "==2.12.916" }, "verlib2": { "hashes": [ diff --git a/dbrepo-search-service/init/lib/dbrepo-1.8.1-py3-none-any.whl b/dbrepo-search-service/init/lib/dbrepo-1.8.1-py3-none-any.whl index f77eea076ca6a24674d220d3f54624b5f9a09202..261fa7958ae481d4d85bc5efc152e519fa6af802 100644 Binary files a/dbrepo-search-service/init/lib/dbrepo-1.8.1-py3-none-any.whl and b/dbrepo-search-service/init/lib/dbrepo-1.8.1-py3-none-any.whl differ diff --git a/dbrepo-search-service/init/lib/dbrepo-1.8.1.tar.gz b/dbrepo-search-service/init/lib/dbrepo-1.8.1.tar.gz index 7065ba14b7eadea39293894488821e3f38e0ef35..0da3ea37a31f2f3cdeea212e768aab7793f29252 100644 Binary files a/dbrepo-search-service/init/lib/dbrepo-1.8.1.tar.gz and b/dbrepo-search-service/init/lib/dbrepo-1.8.1.tar.gz differ diff --git a/dbrepo-search-service/lib/dbrepo-1.8.1-py3-none-any.whl b/dbrepo-search-service/lib/dbrepo-1.8.1-py3-none-any.whl index f77eea076ca6a24674d220d3f54624b5f9a09202..261fa7958ae481d4d85bc5efc152e519fa6af802 100644 Binary files a/dbrepo-search-service/lib/dbrepo-1.8.1-py3-none-any.whl and b/dbrepo-search-service/lib/dbrepo-1.8.1-py3-none-any.whl differ diff --git a/dbrepo-search-service/lib/dbrepo-1.8.1.tar.gz b/dbrepo-search-service/lib/dbrepo-1.8.1.tar.gz index 7065ba14b7eadea39293894488821e3f38e0ef35..0da3ea37a31f2f3cdeea212e768aab7793f29252 100644 Binary files a/dbrepo-search-service/lib/dbrepo-1.8.1.tar.gz and b/dbrepo-search-service/lib/dbrepo-1.8.1.tar.gz differ diff --git a/dbrepo-storage-service/init/Dockerfile b/dbrepo-storage-service/init/Dockerfile index 4c3c671a05f2071696c335696f6bbbfd7c3c9687..d064d048b84444610d3c342b302811dd2044a681 100644 --- a/dbrepo-storage-service/init/Dockerfile +++ b/dbrepo-storage-service/init/Dockerfile @@ -1,8 +1,9 @@ FROM docker.io/python:3.11-alpine3.21 AS runtime LABEL org.opencontainers.image.authors="martin.weise@tuwien.ac.at" -RUN apk add --no-cache bash \ - && pip install s3cmd +RUN apk --no-cache add \ + bash \ + s3cmd WORKDIR /app diff --git a/dbrepo-storage-service/init/init.sh b/dbrepo-storage-service/init/init.sh index 2339978957d4ffb02aa6e11a26f9c653dffd4da4..f7d8d21a4b6f8135e11409cfeb8fe337d0dd49c4 100644 --- a/dbrepo-storage-service/init/init.sh +++ b/dbrepo-storage-service/init/init.sh @@ -4,14 +4,20 @@ access_key = ${S3_ACCESS_KEY_ID} secret_key = ${S3_SECRET_ACCESS_KEY} # Setup endpoint host_base = ${STORAGE_ENDPOINT} -host_bucket = ${S3_BUCKET} +host_bucket = ${STORAGE_ENDPOINT} use_https = False # Enable S3 v4 signature APIs signature_v2 = False EOF -s3cmd --config=/app/.s3cfg ls | grep "s3://${S3_BUCKET}" + +# create bucket if s3cmd --config=/app/.s3cfg ls | grep -q "s3://${S3_BUCKET}"; then - echo "Bucket s3://${S3_BUCKET} already exists, skip." - exit 0 + echo "[INFO] Bucket s3://${S3_BUCKET} already exists, skip." +else + if ! s3cmd --config=/app/.s3cfg mb s3://${S3_BUCKET}; then + echo "[ERROR] Failed to create bucket s3://${S3_BUCKET}" + fi fi -s3cmd --config=/app/.s3cfg mb s3://${S3_BUCKET} \ No newline at end of file + +# expire daily +s3cmd --config=/app/.s3cfg expire s3://${S3_BUCKET} --expiry-prefix "" --expiry-days 1 \ No newline at end of file diff --git a/dbrepo-storage-service/init/tests/test_integration_expire.sh b/dbrepo-storage-service/init/tests/test_integration_expire.sh new file mode 100755 index 0000000000000000000000000000000000000000..b5e2c38573a159ea7a553235c8035da31c2d054d --- /dev/null +++ b/dbrepo-storage-service/init/tests/test_integration_expire.sh @@ -0,0 +1,67 @@ +#!/bin/bash +DOCKER_OPTS="--log-level ERROR" +S3CMD_OPTS="--config=/app/.s3cfg" + +export S3_ACCESS_KEY_ID="seaweedfsadmin" +export S3_BUCKET="dbrepo" +export S3_SECRET_ACCESS_KEY="seaweedfsadmin" +export STORAGE_ENDPOINT="localhost:9000" + +function clean () { + echo "[DEBUG] Shutting down environment ..." + docker $DOCKER_OPTS compose down + docker $DOCKER_OPTS rm $(docker volume ls -q) || true + echo "[DEBUG] Starting new environment ..." + docker $DOCKER_OPTS compose up -d dbrepo-storage-service-init + echo "[DEBUG] Waiting 10s ..." + sleep 10 +} + +# BeforeAll +clean + +# Test +echo "[DEBUG] run test init_succeeds" +bash ./dbrepo-storage-service/init/init.sh +if ! s3cmd $S3CMD_OPTS ls s3:// | grep -q "s3://${S3_BUCKET}"; then + echo "[ERROR] Failed to find bucket s3://${S3_BUCKET}" > /dev/stderr + exit 1 +fi + +# Test +echo "[DEBUG] run test init_idempotent_succeeds" +bash ./dbrepo-storage-service/init/init.sh +if ! s3cmd $S3CMD_OPTS ls s3:// | grep -q "s3://${S3_BUCKET}"; then + echo "[ERROR] Failed to find bucket s3://${S3_BUCKET}" > /dev/stderr + exit 1 +fi + +# Test +echo "[DEBUG] run test find_expiry_config_enabled_succeeds" +XPATH="string(//Rule/Status/text())" +RES=$(s3cmd $S3CMD_OPTS getlifecycle s3://${S3_BUCKET} | xmllint --xpath $XPATH -) +if [[ $RES != "Enabled" ]]; then + echo "[ERROR] Failed to find xpath $XPATH for bucket s3://${S3_BUCKET}" > /dev/stderr + exit 1 +fi + +# Test +echo "[DEBUG] run test find_expiry_config_prefix_succeeds" +XPATH="string(//Rule/Prefix/text())" +RES=$(s3cmd $S3CMD_OPTS getlifecycle s3://${S3_BUCKET} | xmllint --xpath $XPATH -) +if [[ $RES != "" ]]; then + echo "[ERROR] Failed to find xpath $XPATH for bucket s3://${S3_BUCKET}" > /dev/stderr + exit 1 +fi + +# Test +echo "[DEBUG] run test find_expiry_config_expiration_days_succeeds" +XPATH="number(//Rule/Expiration/Days/text())" +RES=$(s3cmd $S3CMD_OPTS getlifecycle s3://${S3_BUCKET} | xmllint --xpath $XPATH -) +if [[ $RES -ne 1 ]]; then + echo "[ERROR] Failed to find xpath $XPATH for bucket s3://${S3_BUCKET}" > /dev/stderr + exit 1 +fi + +echo "[INFO] Finished successfully" +exit 0 diff --git a/docker-compose.yml b/docker-compose.yml index 3d92b85c66168d465d45aa6955265718265172d1..aefe240d07c5d95ec474b4132adb78706f50da35 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -433,25 +433,22 @@ services: logging: driver: json-file - dbrepo-dashboard-service-init: + dbrepo-storage-service-init: restart: "no" init: true - container_name: dbrepo-dashboard-service-init - hostname: search-dashboard-init - image: dbrepo-dashboard-service-init:latest + container_name: dbrepo-storage-service-init + hostname: storage-service-init + image: dbrepo-storage-service-init:latest build: - context: ./dbrepo-dashboard-service/init + context: ./dbrepo-storage-service/init network: host environment: - LOG_LEVEL: ${LOG_LEVEL:-info} - DASHBOARD_UI_ENDPOINT: "${DASHBOARD_UI_ENDPOINT:-http://dashboard-ui:3000}" - METADATA_SERVICE_ENDPOINT: ${METADATA_SERVICE_ENDPOINT:-http://metadata-service:8080} - SYSTEM_USERNAME: "${SYSTEM_USERNAME:-admin}" - SYSTEM_PASSWORD: "${SYSTEM_PASSWORD:-admin}" + S3_ACCESS_KEY_ID: ${S3_ACCESS_KEY_ID:-seaweedfsadmin} + S3_BUCKET: "${S3_BUCKET:-dbrepo}" + S3_SECRET_ACCESS_KEY: ${S3_SECRET_ACCESS_KEY:-seaweedfsadmin} + STORAGE_ENDPOINT: ${STORAGE_ENDPOINT:-http://storage-service:9000} depends_on: - dbrepo-dashboard-ui: - condition: service_healthy - dbrepo-metadata-service: + dbrepo-storage-service: condition: service_healthy logging: driver: json-file @@ -491,26 +488,6 @@ services: logging: driver: json-file - dbrepo-storage-service-init: - restart: "no" - init: true - container_name: dbrepo-storage-service-init - hostname: storage-service-init - image: dbrepo-storage-service-init:latest - build: - context: ./dbrepo-storage-service/init - network: host - environment: - S3_ACCESS_KEY_ID: ${S3_ACCESS_KEY_ID:-seaweedfsadmin} - S3_BUCKET: "${S3_BUCKET:-dbrepo}" - S3_SECRET_ACCESS_KEY: ${S3_SECRET_ACCESS_KEY:-seaweedfsadmin} - STORAGE_ENDPOINT: ${STORAGE_ENDPOINT:-http://storage-service:9000} - depends_on: - dbrepo-storage-service: - condition: service_healthy - logging: - driver: json-file - dbrepo-data-service: restart: "no" container_name: dbrepo-data-service @@ -563,34 +540,26 @@ services: logging: driver: json-file - dbrepo-dashboard-ui: + dbrepo-dashboard-service-init: restart: "no" - container_name: dbrepo-dashboard-ui - hostname: dashboard-ui - image: dbrepo-dashboard-ui:latest + init: true + container_name: dbrepo-dashboard-service-init + hostname: search-dashboard-init + image: dbrepo-dashboard-service-init:latest build: - context: ./dbrepo-dashboard-ui + context: ./dbrepo-dashboard-service/init network: host - ports: - - "3000:3000" - volumes: - - dashboard-ui-data:/opt/bitnami/grafana/data environment: - BASE_URL: "${BASE_URL:-http://localhost}" - # do not attempt to set it in the grafana.ini, hours wasted here: 7 - GF_SERVER_ROOT_URL: http://dashboard-ui:3000/dashboard/ - GF_INSTALL_PLUGINS: "yesoreyeram-infinity-datasource" - GF_SECURITY_DISABLE_INITIAL_ADMIN_CREATION: "true" - LDAP_ADMIN_USERNAME: "${IDENTITY_SERVICE_ADMIN_USERNAME:-admin}" - LDAP_ADMIN_PASSWORD: "${IDENTITY_SERVICE_ADMIN_PASSWORD:-admin}" - LDAP_ROOT: "${IDENTITY_SERVICE_ROOT:-dc=dbrepo,dc=at}" - healthcheck: - test: curl -fsSL --head 127.0.0.1:3000 - interval: 10s - timeout: 5s - retries: 12 - extra_hosts: - - "localhost:host-gateway" + LOG_LEVEL: ${LOG_LEVEL:-info} + DASHBOARD_UI_ENDPOINT: "${DASHBOARD_UI_ENDPOINT:-http://dashboard-ui:3000}" + METADATA_SERVICE_ENDPOINT: ${METADATA_SERVICE_ENDPOINT:-http://metadata-service:8080} + SYSTEM_USERNAME: "${SYSTEM_USERNAME:-admin}" + SYSTEM_PASSWORD: "${SYSTEM_PASSWORD:-admin}" + depends_on: + dbrepo-dashboard-ui: + condition: service_healthy + dbrepo-metadata-service: + condition: service_healthy logging: driver: json-file @@ -620,3 +589,34 @@ services: condition: service_healthy logging: driver: json-file + + dbrepo-dashboard-ui: + restart: "no" + container_name: dbrepo-dashboard-ui + hostname: dashboard-ui + image: dbrepo-dashboard-ui:latest + build: + context: ./dbrepo-dashboard-ui + network: host + ports: + - "3000:3000" + volumes: + - dashboard-ui-data:/opt/bitnami/grafana/data + environment: + BASE_URL: "${BASE_URL:-http://localhost}" + # do not attempt to set it in the grafana.ini, hours wasted here: 7 + GF_SERVER_ROOT_URL: http://dashboard-ui:3000/dashboard/ + GF_INSTALL_PLUGINS: "yesoreyeram-infinity-datasource" + GF_SECURITY_DISABLE_INITIAL_ADMIN_CREATION: "true" + LDAP_ADMIN_USERNAME: "${IDENTITY_SERVICE_ADMIN_USERNAME:-admin}" + LDAP_ADMIN_PASSWORD: "${IDENTITY_SERVICE_ADMIN_PASSWORD:-admin}" + LDAP_ROOT: "${IDENTITY_SERVICE_ROOT:-dc=dbrepo,dc=at}" + healthcheck: + test: ps -o pid= -p 1 + interval: 10s + timeout: 5s + retries: 12 + extra_hosts: + - "localhost:host-gateway" + logging: + driver: json-file diff --git a/helm/dbrepo/charts/seaweedfs-4.2.1.tgz b/helm/dbrepo/charts/seaweedfs-4.2.1.tgz index 5d4eaf44f9d2cad626ea5ba966ebb777297f751f..6e3703cd38fdbc2e37da1dd76fb4b1e805e0baa0 100644 Binary files a/helm/dbrepo/charts/seaweedfs-4.2.1.tgz and b/helm/dbrepo/charts/seaweedfs-4.2.1.tgz differ diff --git a/helm/dbrepo/files/create-event-listener.jar b/helm/dbrepo/files/create-event-listener.jar index 4c541f2eb5bd4606250425f72aa7971a40164662..0b0771d3657d44c05fe9fe8fc62f2c7aef23c85b 100644 Binary files a/helm/dbrepo/files/create-event-listener.jar and b/helm/dbrepo/files/create-event-listener.jar differ diff --git a/helm/dbrepo/templates/gateway-configmap.yaml b/helm/dbrepo/templates/gateway-configmap.yaml index 328efdcd92706805ea42718edd16643ace769b6e..37863f85c45ae39134f5293687ca2f1bdb5e8223 100644 --- a/helm/dbrepo/templates/gateway-configmap.yaml +++ b/helm/dbrepo/templates/gateway-configmap.yaml @@ -31,18 +31,19 @@ data: } location /dashboard/ { - rewrite ^/dashboard/(.*) /$1 break; + proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Host $host; proxy_set_header X-Forwarded-Proto $scheme; - proxy_pass http://dashboard-ui; + proxy_pass http://dashboard-ui:3000/; proxy_read_timeout 90; } # Proxy Grafana Live WebSocket connections. - location /dashboard/api/live/ { + location /dashboard/api/live/ws { rewrite ^/dashboard/(.*) /$1 break; + proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Host $host; @@ -50,7 +51,7 @@ data: proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection $connection_upgrade; proxy_http_version 1.1; - proxy_pass http://dashboard-ui; + proxy_pass http://dashboard-ui:3000/; proxy_read_timeout 90; } diff --git a/helm/dbrepo/values.schema.json b/helm/dbrepo/values.schema.json index b4b53d788fde9e111eebf6702e965d16fcaec527..804354f21deb634c5055f9c4cc2a310cef0f5db9 100644 --- a/helm/dbrepo/values.schema.json +++ b/helm/dbrepo/values.schema.json @@ -605,19 +605,6 @@ } }, "type": "object" - }, - "service": { - "properties": { - "ports": { - "properties": { - "grafana": { - "type": "integer" - } - }, - "type": "object" - } - }, - "type": "object" } }, "type": "object" diff --git a/helm/dbrepo/values.yaml b/helm/dbrepo/values.yaml index 70df20979f83018c8992e559b409600df10b5869..62ce16d3de3933c1be25c7a5602ff55be9c5cbbe 100644 --- a/helm/dbrepo/values.yaml +++ b/helm/dbrepo/values.yaml @@ -997,10 +997,6 @@ dashboardui: type: Recreate ## @skip dashboardui.grafana.extraEnvVarsSecret extraEnvVarsSecret: dashboard-ui-secret - service: - ports: - ## @skip dashboardui.service.ports.grafana - grafana: 80 ## @section Metric Service diff --git a/helm/seaweedfs/Chart.lock b/helm/seaweedfs/Chart.lock index 8dd1eca11dc9946759c17aa45bbaad8a907a5b29..dfa3620f167709b52e2c54a4c5b55ef8dc6eb09b 100644 --- a/helm/seaweedfs/Chart.lock +++ b/helm/seaweedfs/Chart.lock @@ -4,9 +4,9 @@ dependencies: version: 20.4.2 - name: postgresql repository: oci://registry-1.docker.io/bitnamicharts - version: 16.6.2 + version: 16.6.3 - name: common repository: oci://registry-1.docker.io/bitnamicharts version: 2.30.0 -digest: sha256:cb37553e48186fba1bff1390779f26be6fe6b07639175192e1d8a413e51e9803 -generated: "2025-04-07T21:01:50.769214074+02:00" +digest: sha256:a1969ecd9ac27255060569f5e0e3f4ad93f999b8968e3f9c5e97d1536996ebd2 +generated: "2025-04-10T10:05:59.79430147+02:00" diff --git a/helm/seaweedfs/charts/postgresql-16.6.2.tgz b/helm/seaweedfs/charts/postgresql-16.6.2.tgz deleted file mode 100644 index 8fc7712307da4a39ac752f080251a103def4dc63..0000000000000000000000000000000000000000 Binary files a/helm/seaweedfs/charts/postgresql-16.6.2.tgz and /dev/null differ diff --git a/helm/seaweedfs/charts/postgresql-16.6.3.tgz b/helm/seaweedfs/charts/postgresql-16.6.3.tgz new file mode 100644 index 0000000000000000000000000000000000000000..36ca74dcb79a5d83a780bff787c379a488ef1875 Binary files /dev/null and b/helm/seaweedfs/charts/postgresql-16.6.3.tgz differ diff --git a/lib/python/dbrepo/core/client/dashboard.py b/lib/python/dbrepo/core/client/dashboard.py index 0797c0a76f00cecf4da7bb7eab90fe609cfdc9e1..b609da692bba7fc38ab45a507b1e7b52193b1ac4 100644 --- a/lib/python/dbrepo/core/client/dashboard.py +++ b/lib/python/dbrepo/core/client/dashboard.py @@ -9,9 +9,8 @@ from dbrepo.api.dto import Database, ColumnType, ViewColumn, View from dbrepo.core.api.dto import Permission from dbrepo.core.api.exceptions import DashboardNotFound -statistics_row_title = 'Generated Statistics' - -disclaimer = 'Generic auto-generated chart' +statistics_row_title = 'Generated Dashboard' +auto_generated_description = 'Auto-generated' number_types = [ColumnType.SERIAL, ColumnType.BIT, ColumnType.SMALLINT, ColumnType.MEDIUMINT, ColumnType.INT, ColumnType.BIGINT, ColumnType.FLOAT, ColumnType.DOUBLE, ColumnType.DECIMAL] @@ -72,6 +71,23 @@ def map_row(title: str, x: int = 0, y: int = 0) -> dict: y=y)) +def map_preview_image_panel(database_id: str, w: int = 4, h: int = 4, x: int = 20, y: int = 1) -> dict: + return dict(title='Preview Image', + type='text', + description=auto_generated_description, + gridPos=dict(h=h, + w=w, + x=x, + y=y), + fieldConfig=dict(defaults=dict(), + overrides=[]), + options=dict(mode="markdown", + code=dict(language="plaintext", + showLineNumbers=False, + showMiniMap=False), + content=f'<img src="/api/database/{database_id}/image" alt="" width="90" />')) + + class DashboardServiceClient: def __init__(self, endpoint: str, username: str, password: str, base_url: str = 'http://localhost', @@ -185,7 +201,7 @@ class DashboardServiceClient: if panel_type == 'histogram': fillOpacity = 60 return dict(title=panel_type.capitalize(), - description=disclaimer, + description=auto_generated_description, type=panel_type, datasource=datasource, targets=[dict(datasource=datasource, @@ -421,6 +437,48 @@ class DashboardServiceClient: y: int = 8) -> dict: return self._map_timeseries_panel(database_id, view, 'histogram', h, w, x, y) + def map_data_sources_panel(self, database_id: str, x: int = 0, y: int = 1) -> dict: + datasource = dict(uid=self.datasource_uid, + type='yesoreyeram-infinity-datasource') + return dict(title='Datasources', + description=auto_generated_description, + type='stat', + datasource=datasource, + targets=[dict(datasource=datasource, + columns=[], + filters=[], + format='table', + global_query_id='', + hide=False, + refId='A', + root_selector='$count(id)', + source='url', + type='json', + url=f'/api/database/{database_id}/view', + parser='backend', + url_options=dict(data='', + method='GET'))], + fieldConfig=dict(defaults=dict(mappings=[], + thresholds=dict(mode='absolute', + steps=[dict(color='blue', + value=None)])), + overrides=[]), + transformations=[], + gridPos=dict(h=4, + w=6, + x=x, + y=y), + options=dict(colorMode='background', + graphMode='area', + justifyMode='auto', + orientation='auto', + reduceOptions=dict(calcs=[], + fields='/.*/', + values=True), + showPercentChange=False, + textMode='auto', + wideLayout=True)) + def map_rows_panel(self, database_id: str, view_id: str, x: int = 18, y: int = 0) -> dict: return self._map_number_panel(database_id, view_id, 'Rows', 'total_rows', x, y) @@ -436,16 +494,19 @@ class DashboardServiceClient: except ValueError: logging.warning(f'No managed panels found') original_panels_size = len(panels) - panels.append(map_row(statistics_row_title, 0, 0)) # statistics row + panels.append(map_row(statistics_row_title, 0, 0)) + panels.append(self.map_data_sources_panel(database.id)) + if database.preview_image is not None: + panels.append(map_preview_image_panel(database.id)) for i, view in enumerate(database.views): # section - panels.append(map_row(view.name, 0, i * section_height + 0)) - panels.append(self.map_overview_panel(database.id, view.id, 0, i * section_height + 4)) - panels.append(self.map_rows_panel(database.id, view.id, 18, i * section_height + 0)) - panels.append(self.map_columns_panel(database.id, view.id, 18, i * section_height + 4)) - panels.append(self.map_statistics_panel(database.id, view.id, h=8, w=12, x=0, y=i * section_height + 8)) - panels.append(self.map_histogram_panel(database.id, view, h=8, w=12, x=12, y=i * section_height + 8)) - panels.append(self.map_timeseries_panel(database.id, view, h=8, w=8, x=0, y=i * section_height + 16)) - panels.append(self.map_pie_panel(database.id, view, h=8, w=8, x=8, y=i * section_height + 16)) + panels.append(map_row(view.name, 0, i * section_height + 4)) + panels.append(self.map_overview_panel(database.id, view.id, 0, i * section_height + 8)) + panels.append(self.map_rows_panel(database.id, view.id, 18, i * section_height + 4)) + panels.append(self.map_columns_panel(database.id, view.id, 18, i * section_height + 8)) + panels.append(self.map_statistics_panel(database.id, view.id, h=8, w=12, x=0, y=i * section_height + 12)) + panels.append(self.map_histogram_panel(database.id, view, h=8, w=12, x=12, y=i * section_height + 12)) + panels.append(self.map_timeseries_panel(database.id, view, h=8, w=8, x=0, y=i * section_height + 20)) + panels.append(self.map_pie_panel(database.id, view, h=8, w=8, x=8, y=i * section_height + 20)) logging.info(f'Added {len(panels) - original_panels_size} managed panel(s)') return panels diff --git a/lib/python/dbrepo/core/client/search.py b/lib/python/dbrepo/core/client/search.py index 033ed0beda53ffe6bc3e6263bb63bff90079ca70..c0c25966aecece2b4b839981284dca70825d5f21 100644 --- a/lib/python/dbrepo/core/client/search.py +++ b/lib/python/dbrepo/core/client/search.py @@ -6,15 +6,14 @@ import os from collections.abc import MutableMapping from json import dumps, load -from opensearchpy import OpenSearch, NotFoundError -from requests import head - from dbrepo.api.dto import Database from dbrepo.api.exceptions import ForbiddenError, NotExistsError from dbrepo.core.omlib.constants import OM_IDS from dbrepo.core.omlib.measure import om from dbrepo.core.omlib.omconstants import OM from dbrepo.core.omlib.unit import Unit +from opensearchpy import OpenSearch, NotFoundError +from requests import head class SearchServiceClient: @@ -23,14 +22,14 @@ class SearchServiceClient: """ instance: OpenSearch = None - def __init__(self, host: str = None, port: int = 9000, username: str = None, password: str = None): + def __init__(self, host: str = None, port: int = 9000, username: str = 'admin', password: str = 'admin'): if host is None: host = 'search-db' self.host = os.getenv('OPENSEARCH_HOST', host) self.metadata_endpoint = os.getenv('METADATA_SERVICE_ENDPOINT', 'http://metadata-service:8080') self.port = int(os.getenv('OPENSEARCH_PORT', port)) - self.system_username = os.getenv('SYSTEM_USERNAME', 'admin') - self.system_password = os.getenv('SYSTEM_PASSWORD', 'admin') + self.system_username = os.getenv('SYSTEM_USERNAME', username) + self.system_password = os.getenv('SYSTEM_PASSWORD', password) def _instance(self) -> OpenSearch: """ @@ -39,9 +38,9 @@ class SearchServiceClient: @returns: The opensearch instance singleton, if successful. """ if self.instance is None: - self.instance = SearchServiceClient(hosts=[{"host": self.host, "port": self.port}], - http_compress=True, - http_auth=(self.system_username, self.system_password)) + self.instance = OpenSearch(hosts=[{"host": self.host, "port": self.port}], + http_compress=True, + http_auth=(self.system_username, self.system_password)) return self.instance def database_exists(self, database_id: str):