This repository contains the source code for the National Data Directory of Norway.
The work is led by the Brønnøysund Register Centre and the Data Directory was launched November 2017.
The Data Directory contains metadata about the datasets that the various Governmental bodies maintain in their data catalogs.
We provide a search service that allow users to discover datasets and where they are kept.
The content of the data catalog is harvested once a day from several more specific data catalogs including the registration application.
The data catalogs are formatted according to the Norwegian profile DCAT-AP-NO 1.1
of the European profile of W3C's Data Catalog standard.
Three main applications are developed:
- A Search Application that allow users to search and browse metadata about the datasets.
- A Harvester Application that downloads data catalogs and makes them searchable.
- A Registration Application that allow users to register metadata about their datasets.
Norwegian description:
Felles datakatalog gir en oversikt over datasett fra virksomheter i Norge. Løsningen er utviklet av Brønnøysundregistrene i perioden 2016 til desember 2017. Løsningen ble lansert i november 2017. Det er en av flere felleskomponenten som utvikles i regi av Skate som skal bidra til å bedre integrasjon mellom offentlige virksomheter og bedre tjenester. Systemet er basert på en norsk profil DCAT-AP-NO 1.1, av en Europeisk profil av W3C Datakatalog standard for utveksling av datasettbeskrivelser.
If you have any questions please send them to fellesdatakatalog@brreg.no.
The search application is available here. The two other applications are only available for registered users. Any questions can be sent to fellesdatakatalog@brreg.no.
The search api can also be used.
Prerequisite: Make sure you have local admin on your computer, as gitbash has to be run as an administrator
-
Clone this repo
-
Install Java8, Maven and Docker.
-
If you are running Windows. Make sure you manually add the correct Maven path in windows "environment Variables"
-
Also make sure you have set correct JAVA_HOME path to environment variables.
-
After having installed Docker. Make sure you update the resource limits at Settings-Advanced. You need at least 4 CPU's and more than 8k MB of Memory.
-
If you have a Mac, running this script will install Java8 and Maven automatically:
./install-dependencies-mac.sh
-
-
Configure
.envrc
based on.envrc.template
. Optionally install direnv to lock the variables to the main working directory -
Compile, create docker images and run the entire project:
If you are running windows, you also need to make sure you have installed node.js: https://nodejs.org/en/download/
./runAll.sh
If you only want to recompile one module ("search-api" in this example), use the following:
./runDocker.sh search-api
Frontend applications such as search and registration-react are built and run the following way:
docker-compose up -d --build registration-react
-
If images are already built, project can be run:
docker-compose up -d
Restart a specific module after image rebuild,.
docker-compose up -d registration
Monitor logs
docker-compose logs -f registration
-
Open solution
Search site: http://localhost:8080
Registration site: https://localhost:8098
In order to have maintainable tests, the tests must equally well run in all environment configurationds:
-
Brower in host machine (windowed+headless), services in docker-compose
Make sure chromium is installed (for mac, TODO windows)
brew cask install chromium
Make sure services are running in docker-compose network and exposed to localhost (beware of port conflicts with services running in intelliJ
./runAll.sh # or docker-compose up -d
Ensure dependencies are installed
(cd applications/e2e ; npm i)
Run tests
# run tests in chromim headless (no window, just report) (cd applications/e2e ; npm t) # run tests in chromium window opened (cd applications/e2e ; npm run test:browser)
-
Browser in container (headless), services in docker-compose
# run docker-compose run e2e npm run test:in_container # build container (if changes in tests) docker-compose build e2e
Generate release notes and create release in GitHub:
git checkout develop
git pull
npm run release
git push --follow-tags origin
The Registration Application consists of the following main modules:
- registration, a React application which allow users to log in and edit or register metadata about datasets.
- registration-api, a Java Spring Boot service which supports a REST API
- registration-db, a Elasticsearch document database
The Search Application consists of the following modules
- search, a React application which allow users to search and view dataset descriptions.
- search-api, an Java Spring Boot service whit a REST API
- search-db, an Elasticsearch search and document database
The Harvester Application consist of the following modules
- harvester, a Java Spring Boot application which allow users to register which catalogs that should be harvested.
- harvester-api, a Java Spring Boot service which checks and harvests data catalogs and inserts them into the search-db
- harvester-db, a Fuseki RDF database which stores administration information about harvests and the incoming datasets
Common Services
- reference-data, a shared service which provides code lists, concepts and helptexts.
External Integrations
- Enhetsregisteret, for checking and collecting information about organizations
- IDPorten, for authentication of users
- Altinn, for authorization of users
There is a couple of scripts that automates build and run the various models ondocker. The scripts are:
./runDocker.sh search-api
to compile, build and run the search-api module on docker./runAll.sh
to run all the modules on docker, it actually downloads images from docker hub or builds them if you have made changes to the code.
docker-compose up -d search
This starts DCAT repositories, fuseki and elasticsearch, as well as the search-api service. To access the search application start a browser on http://localhost:8080. Be aware that there is no data registered in the repositories (see the harvester application)
docker-compose up -d harvester
This starts the harvester application with the corresponding harvester-api.
- Log in to the administration application on http://localhost:8082. You will need a username and a password for the application (test_user, password).
- Next you need to register a catalog to be harvested. You may use the registration application to register data about datasets which can be harvested here. http://registration-api:8080/catalogs/123456699 given your catalog has id 123456699.
docker-compose up -d registration
This starts the registration application with corresponding api services. The application can be accessed on http://localhost:8099 The regstration application requires authentication. The following test-user identifiers can be used: (03096000854, 01066800187, 23076102252)
docker-compose down
In IntelliJ, select module applications/end2end-test and click "run tests"
The repository is stored in a persistent volume, see data/esdata5 for elasticsearch repository and data/fuseki for the fuseki repository.
- Elasticsearch stores the data in JSON denormalized for search
- Fuseki stores the data in RDF/DCAT format
Some times docker can be a bit overworked and one might need to clean up.
Solution: remove old containers
bash: docker rm -f $(docker ps -aq)
Remove old images
bash: docker rmi -f $(docker images -q)
Docker is slow on mac: Docker needs at least 8G of memory
Docker -> Preferences -> Advanced -> Change memory to (8 GiB)
Error message: java.nio.file.AccessDeniedException: /usr/share/elasticsearch/data/nodes On windows platforms, this seems to be caused by some issue with credentials.
Solution - reset and reeenter the credentials: Rightclick docker->Settings->Shared Drives->Reset Credentials. Reselect the drive you want shared, and reenter credentials, and do a docker-compose stop elasticsearch5 and a docker-compose up -d