Installation Guide 
Guide to install Diveni on production environments.
System Requirements 
Using Docker is the preferred way to install Diveni.
Preferred Docker environment:
- Docker host: Linux, Windows, Mac
- Arch: amd64, arm64
- CPU: TBD
- Memory: TBD
- HDD space: TBD
Preconditions 
To install Diveni in combination with an issue tracker, some configuration is required to connect to the issue tracker. See below for details.
Connecting to an issue tracker is optional. Diveni can also be used without a connection.
JIRA Cloud Connector 
TBDJIRA Enterprise Connector 
For setting up the JIRA application, the steps described here should be sufficient: https://developer.atlassian.com/server/jira/platform/oauth/
It doesn't matter what you enter in remaining fields (URL, name, type, and so on). This is because we only want to retrieve data from Jira, therefore we only need to set up a one-way (incoming) link from the client to Jira.
Afterwards, you will see the client secret and ID, which needs to be provided for Diveni on JIRA-Server.
Azure DevOps Connector 
For setting up the Azure DevOps Connector, you have to generate a personal access token: https://learn.microsoft.com/en-us/azure/devops/organizations/accounts/use-personal-access-tokens-to-authenticate#create-a-pat
Afterwards you have to enter the used organisation in AZURE_ORGANIZATION and the personal access token in AZURE_CLIENTPAT in backend/.env.
Github Connector 
For setting up the Github Connector, you need to generate a personal access token. 
How to create a personal access token 
- Click on your profile picture in the top right corner
- Go to the settings menu
- Scroll a bit down to find the developer settings menu on the right
- Click on Personal access tokens -> Tokens(classic)
- Press on generate new token. Select classic as well.
- Give the access token a name
- Select the repo scope and you are ready to create the token.
Gitlab Connector 
For setting up the Gitlab Connector, you need to generate a personal access token. 
How to create a personal access token 
- Click on your profile picture in the top left corner
- Click on "Edit profile"
- Click on Access Tokens on the left menu bar
- Click on "Add new Token"
- Give the access token a name & an expiration date of your choice
- For the scopes select "api"
- Press on "Create personal access token"
Docker 
The infrastructure is divided in several Docker containers:
Docker Compose 
version: "3"
services:
  database:
    image: mongo:4
    container_name: diveni_database
    restart: unless-stopped
  backend:
    image: ghcr.io/sybit-education/diveni-backend:latest
    container_name: diveni_backend
    depends_on:
      - database
    restart: unless-stopped
    environment:
      - "SPRING_PROFILES_ACTIVE=prod" # required
  frontend:
    image: ghcr.io/sybit-education/diveni-frontend:latest
    container_name: diveni_frontend
    depends_on:
      - backend
    restart: unless-stopped
  proxy:
    image: ghcr.io/sybit-education/diveni_proxy:latest
    container_name: diveni_proxy
    depends_on:
      - frontend
      - backend
      - database
    restart: unless-stopped
    ports:
      - "80:80"Configuration 
Available configuration 
| Parameter | Description | Default value | 
|---|---|---|
| SERVER_URL | URL the server is running on, used for CORS-settings | null | 
| LOCALE | The locale the frontend should be set to, available locales=en,de,es,fr,it,pl,pt,uk | en | 
| JIRA_CLOUD_CLIENTID | ClientId is shown in the Atlassion Developer app settings | null | 
| JIRA_CLOUD_CLIENTSECRET | ClientSecret is shown in the Atlassion Developer app settings | null | 
| JIRA_CLOUD_ESTIMATIONFIELD | The estimation field is a customfield which is different for every Jira instance and must therefore be set manually | customfield_10016 | 
| JIRA_CLOUD_AUTHORIZE_URL | URL for the authorization server from Jira Cloud | null | 
| JIRA_SERVER_JIRAHOME | URL to the Jira Server instance | null | 
| JIRA_SERVER_CONSUMERKEY | Consumer key can be set in the Jira application link | OauthKey | 
| JIRA_SERVER_PRIVATEKEY | Private key from jira_privatekey.pcks8 | null | 
| JIRA_SERVER_ESTIMATIONFIELD | The estimation field is a customfield which is different for every Jira instance and must therefore be set manually | customfield_10111 | 
| JIRA_SERVER_RANKNAME | Used for ordering of the issues. Depends on the Jira language and is either RANK or RANG | RANK | 
| AZURE_ORGANIZATION | The name of the organization in Azure | null | 
| AZURE_CLIENTPAT | Azure Personal Access Token | null | 
Important:
- In order to use Jira Cloud all parameters with prefix JIRA_CLOUD_are required to be set.
- To use Jira Server all parameters with prefix JIRA_SERVER_have to be set.
- To use Azure DevOps all parameters with prefix AZURE_have to be set.
Add configuration to the Diveni instance 
Diveni with configuration via docker compose
Update Docker Compose to environment variables
[...]
  backend:
    image: ghcr.io/sybit-education/diveni-backend:latest
    container_name: diveni_backend
    depends_on:
      - database
    restart: unless-stopped
    environment:
      - "SPRING_PROFILES_ACTIVE=prod" # required
      - "SERVER_URL=http://localhost:8080"
      - "LOCALE=en"
      - "JIRA_CLOUD_CLIENTID=[xxx]"
      - "JIRA_CLOUD_CLIENTSECRET=[xxx]"
      - "JIRA_CLOUD_ESTIMATIONFIELD=customfield_10016"
      - "JIRA_CLOUD_AUTHORIZE_URL=https://auth.atlassian.com"
      - "JIRA_SERVER_JIRAHOME=https://jira.company.com"
      - "JIRA_SERVER_CONSUMERKEY=OauthKey"
      - "JIRA_SERVER_PRIVATEKEY=[xxx]"
      - "JIRA_SERVER_ESTIMATIONFIELD=customfield_10152"
      - "JIRA_SERVER_RANKNAME=RANG"
      - "AZURE_ORGANIZATION=organization"
      - "AZURE_CLIENTPAT=[xxx]"
[...]Diveni with configuration via .env
To configure your local environment, you have to add your configuration to /backend/.env
See below for example:
#URL the server is running on
SERVER_URL=http://localhost:8080
#The locale the frontend should be set to
LOCALE=en
#ClientId and ClientSecret are shown in the Atlassian Developer app settings
JIRA_CLOUD_CLIENTID=[xxx]
JIRA_CLOUD_CLIENTSECRET=[xxx]
#URL for the authorization server
JIRA_CLOUD_AUTHORIZE_URL=https://auth.atlassian.com/authorize?...
#The estimation field is a customfield which is different for every Jira instance and must therefore be set manually
JIRA_CLOUD_ESTIMATIONFIELD=customfield_10016
#URL to the Jira Server instance
JIRA_SERVER_JIRAHOME=https://jira.company.com
#Consumer key can be set in the Jira application link
JIRA_SERVER_CONSUMERKEY=OauthKey
#Private key from jira_privatekey.pcks8
JIRA_SERVER_PRIVATEKEY=[xxx]
#The estimation field is a customfield which is different for every Jira instance and must therefore be set manually
JIRA_SERVER_ESTIMATIONFIELD=customfield_10152
#Used for correct sortation of the issues. Depends on the Jira language e.g. RANK or RANG
JIRA_SERVER_RANKNAME=RANG
#The name of the organization in Azure
AZURE_ORGANIZATION=organization
#Azure Personal Access Token
AZURE_CLIENTPAT=xxxCopy the configured file to /backend/.env
Update Docker Compose to use .env
[...]
  backend:
    image: ghcr.io/sybit-education/diveni-backend:latest
    container_name: diveni_backend
    depends_on:
      - database
    restart: unless-stopped
    environment:
      - "SPRING_PROFILES_ACTIVE=prod" # required
    env_file:
      - ./backend/.env
[...]Starting App 
If all the configuration is done, Diveni could be started:
docker-compose up -d