From 3e4368cb661d25b3b3654f4caf1e310717eb88a6 Mon Sep 17 00:00:00 2001 From: Martin Weise <martin.weise@tuwien.ac.at> Date: Tue, 12 Apr 2022 18:20:48 +0200 Subject: [PATCH] Updated style, updated logos, added content on getting started --- docs/getting-started.md | 63 +++++++++++++++++++++++++++++++++---- docs/images/favicon.png | Bin 0 -> 379 bytes docs/images/logo.png | Bin 4610 -> 3775 bytes docs/images/logo.psd | Bin 44289 -> 61688 bytes docs/index.md | 17 +++++----- docs/operation.md | 6 ---- docs/publications.md | 14 ++++----- docs/stylesheets/extra.css | 1 + docs/system.md | 6 ---- mkdocs.yml | 12 ++++--- 10 files changed, 81 insertions(+), 38 deletions(-) create mode 100644 docs/images/favicon.png diff --git a/docs/getting-started.md b/docs/getting-started.md index 130e1a1..8fe9167 100644 --- a/docs/getting-started.md +++ b/docs/getting-started.md @@ -45,7 +45,7 @@ And the following minimal software packages to operate the repository: dnf install make ``` -## Repository +## Deployment Next, clone the source code repository into your working directory: @@ -67,8 +67,59 @@ The system is auto-configured for a small, local, test deployment. You only need docker-compose up ``` -<style> - .md-content__button { - display: none; - } -</style> \ No newline at end of file +!!! bug "Some environments need additional configuration" + + In some cluster environments, it is necessary to set Docker's MTU to the main interface MTU. Find out by executing + + ```console + nmcli -f GENERAL device show eth0 | grep "MTU" + ``` + + Having the wrong MTU set leads to the containers to not downloading the Maven dependencies and the containers are + stuck. This can quickly be solved through setting the correct MTU (e.g. 1450). + + ```json title="/etc/docker/daemon.json" + { + "mtu": 1450 + } + ``` + +## Development + +We invite all open-source developers to help us fixing bugs and introducing features to the source code. Get involved by +sending a mail to Prof. [Andreas Rauber](mailto:andreas.rauber@tuwien.ac.at) +and Proj.Ass. [Martin Weise](mailto:martin.weise@tuwien.ac.at). Clone the repository and create a feature branch +from `dev` and implement your changes. + +## Requirements + +We develop all packages with the following software requirements: + +1. [Java OpenJDK](https://openjdk.java.net/) 11 +2. [Maven](https://maven.apache.org/) 3.0.0+ +3. [Node.js](https://nodejs.org/en/) 14+ +3. [Yarn](https://yarnpkg.com/getting-started/install#nodejs-1610-1) 1.21.0+ +4. [Postgres](https://www.postgresql.org/) 12+ +5. [MariaDB](https://mariadb.org/) 10+ + +## Building + +For local development you need to install the entities from the metadata database and the general DTOs that are +exchanged between the services by installing the package: + +```console +mvn -f ./fda-metadata-db/pom.xml clean install +``` + +All other services depend on this package. You have to build them later: + +```console +mvn -f ./fda-container-service/pom.xml clean package -DskipTests +... +``` + +Conviniently, you can build them all through [`make`](https://www.gnu.org/software/make/): + +```console +make build-backend +``` \ No newline at end of file diff --git a/docs/images/favicon.png b/docs/images/favicon.png new file mode 100644 index 0000000000000000000000000000000000000000..d53b2bc9810716b1c363cf6f4304720b0f6b10a4 GIT binary patch literal 379 zcmeAS@N?(olHy`uVBq!ia0y~yVDJE84rT@hh9qO>QU(SF#^NA%C&rs6b?O-y7&r?& zB8wRqxP?KOkzv*x2?hp+v;dzFR|W<KeZA?lMlxTO#TghFluCm9f*CenK6}1Sz-;?L zp2lW2z2jT&{{K5$#Od|ipYypaKHqkDdDHV^-A@Jvh6Ya;$B>FSZ*N!&H5rJwJrqa^ z5D=L<-RZ#J{2<|3(E$cL&ZYl8Jvq0%LE~s&^peN_&zw9pV@_}XbeCf$pAD~FkGb|p z>{aYk{{7EaPg?&qW_Fa@?Xrho{!ZK~e`sZNo16G6lXY$T9MFLDLfv?&-L;!GJpRTU Y8N501a=k?@0|Nttr>mdKI;Vst0Bi}1YXATM literal 0 HcmV?d00001 diff --git a/docs/images/logo.png b/docs/images/logo.png index 8ed93f837d93765c70d6c521ece6a7df22842a62..8c776cad97d7e0adc56c6e08ef691dbb4e13a543 100644 GIT binary patch literal 3775 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 My85}Sb4q9e0B!%uI{*Lx literal 4610 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 diff --git a/docs/images/logo.psd b/docs/images/logo.psd index 2c4c82cf515772a444a12bfa38fe18846a6fcbcc..10d0fe088f59777230e9899d06819abda2ee00b9 100644 GIT binary patch delta 27760 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 ArvLx| delta 10578 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 diff --git a/docs/index.md b/docs/index.md index e46315c..ce97b83 100644 --- a/docs/index.md +++ b/docs/index.md @@ -9,16 +9,19 @@ hide: ## Problem Statement +Having a rich history, digital repositories see themselves more frequently encountered with the problem of making +databases accessible in their collection. Challenges revolve around organizing, searching and retrieving content stored +within databases and constitute a major technical burden as their internal representation greatly differs from static +documents most digital repositories are designed for. + ## Application Areas +We present a database repository system that allows researchers to ingest data into a central, versioned repository +through common interfaces, provides efficient access to arbitrary subsets of data even when the underlying data store is +evolving, allows reproducing of query results and supports findable-, accessible-, interoperable- and reusable data. + [Get Started](/getting-started){ .action-button .md-button .md-button--primary } ## Demo -Public demonstration instance [https://dbrepo.ossdip.at](https://dbrepo.ossdip.at) - -<style> - .md-content__button { - display: none; - } -</style> \ No newline at end of file +Public demonstration instance [https://dbrepo.ossdip.at](https://dbrepo.ossdip.at) \ No newline at end of file diff --git a/docs/operation.md b/docs/operation.md index a1ce873..f42b701 100644 --- a/docs/operation.md +++ b/docs/operation.md @@ -16,9 +16,3 @@ docker-compose build fda-metadata-database docker-compose build --parallel docker-compose -f docker-compose.prod.yml up -d ``` - -<style> - .md-content__button { - display: none; - } -</style> \ No newline at end of file diff --git a/docs/publications.md b/docs/publications.md index eca7941..f15f0f4 100644 --- a/docs/publications.md +++ b/docs/publications.md @@ -16,11 +16,9 @@ hide: ### News -1. Gergely, E., 2021. Better Support for Research: Current Cooperation Projects. [Online]. - URL: [https://zid.univie.ac.at/it-news/artikel/news/cluster-forschungsdaten/](https://zid.univie.ac.at/it-news/artikel/news/cluster-forschungsdaten/), accessed 2022-04-12 - -<style> - .md-content__button { - display: none; - } -</style> \ No newline at end of file +1. Staudinger, M., 2022. DBRepo: A Repository to Save Research Databases. [Online]. + URL: [https://www.tuwien.at/en/tu-wien/news/news-articles/news/dbrepo](https://www.tuwien.at/en/tu-wien/news/news-articles/news/dbrepo) + accessed 2022-04-12 +2. Gergely, E., 2021. Better Support for Research: Current Cooperation Projects. [Online]. + URL: [https://zid.univie.ac.at/it-news/artikel/news/cluster-forschungsdaten/](https://zid.univie.ac.at/it-news/artikel/news/cluster-forschungsdaten/) + accessed 2022-04-12 diff --git a/docs/stylesheets/extra.css b/docs/stylesheets/extra.css index a325fac..858d47c 100644 --- a/docs/stylesheets/extra.css +++ b/docs/stylesheets/extra.css @@ -1,5 +1,6 @@ [data-md-color-scheme="default"] { --md-primary-fg-color: #ff5522; + --md-accent-fg-color: #332f95; } [data-md-color-scheme="slate"] { diff --git a/docs/system.md b/docs/system.md index 5b4dba8..d6d5d57 100644 --- a/docs/system.md +++ b/docs/system.md @@ -13,9 +13,3 @@ hide: We use Docker for deployment. The containers are packing all runtime dependencies, when starting them all necessary files are already present. For running the infrastructure we use Docker Compose. - -<style> - .md-content__button { - display: none; - } -</style> \ No newline at end of file diff --git a/mkdocs.yml b/mkdocs.yml index 7b2704f..3d15188 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -1,15 +1,17 @@ site_name: Database Repository -repo_url: https://github.com/fair-data-austria/dbrepo.git +repo_url: https://gitlab.phaidra.org/fair-data-austria-db-repository/fda-services repo_name: Repository -site_author: TU Wien Research Data Management -copyright: CC BY 4.0 TU Wien Research Data Management +site_author: FAIR Data Austria +copyright: CC BY 4.0 FAIR Data Austria extra: homepage: https://dbrepo.tuwien.ac.at social: - - icon: fontawesome/brands/github - link: https://github.com/fair-data-austria/dbrepo.git + - icon: fontawesome/brands/gitlab + link: https://gitlab.phaidra.org/fair-data-austria-db-repository/fda-services - icon: fontawesome/brands/twitter link: https://twitter.com/RDMTUWien + - icon: fontawesome/solid/globe + link: https://forschungsdaten.at/fda/ version: provider: mike default: stable -- GitLab