Welcome to data.altinn.no (DAN)! This repository has a solution file containing several components
DAN Core is the main component of DAN, implementing the public API. It utilizes that Altinn REST API for Service Owners for authorization (including consent) and maps requests for data sets to the relevant plugins implementing the codes.
The repository contains a .NET6 console application utilizing the isolated-process Azure Functions v4 runtime.
DAN Common contains all shared models and utilites used across all DAN projects. A nuget is built in Azure Devops which must be referred to in all plugin implementations.
DAN can be used with any IDE / editor of your choosing, but we recommend Visual Studio 2022 or later, Visual Studio Code or Jetbrains Rider.
In order to build an run functions locally, you will need to install the Azure Functions Core Tools which depends on NodeJS.
In order to run functions locally, you will need a Azure Storage Emulator, preferably Azurerite installed and running on 127.0.0.1:10000 (default)
Download and install the CosmosDB emulator. For Windows, click here to download. See this page for information about running on Linux / MacOS.
After installation you will ned to create the default database. Go to https://localhost:8081/_explorer/index.html, select Explorer, Select "New Container". Name the database "nadobe-dev", and the container id "Accreditations". Supply "/owner" as partition key.
DAN is utilizing Redis for caching. See https://github.com/ServiceStack/redis-windows for options for Windows. Redis is also available for Linux / MacOS, and should be installed and run with default settings.
The master
branch is locked and cannot be pushed to directly, instead you must create a feature branch to which you commit all your code.
Feature branches should be named with the prefix Feature/
and be named in a descriptive manner (details yet to be determined). When you have pushed your feature branch, create a pull request against master
and request a review from your team. When the pull request is approved, you may merge the branch.
Commits to master
will initiate a full test run (unit, functional, integration) and will upon successful completion tag and deploy the master branch to the dev
function slot in Azure.
Settings for the application is stored in Azure, and can be viewed in Azure Portal if you have access (this is not required for development). When developing and running functions locally, the settings are loaded from local.settings.json
. Note that while this is a part of the repository for your convenience, these settings are only used locally and not in Azure,