- Install JDK version >= 17
- Install Maven
- Run this script to set it up
- Install Git
- Install Node.js and npm (with nvm)
- Configure default registry:
npm config set registry https://registry.npmjs.org/
- Configure default registry:
- Python version 2.7 + pip for Python 2
- Install Ansible (see Ansible)
Current version of VitamUI depends on Ansible version 2.7.0 in order to run installation scripts.
In order not to interfere with more recent Ansible version, deploy a Python VirtualEnv in which you install Ansible 2.7.0:
- Check that VirtualEnv executable is installed:
apt-get install python-virtualenv - In a directory of your choice, create the virtual environment:
virtualenv --python=python2.7 vitamUI-ansible - Activate the environment:
source vitamUI-ansible/bin/activate
- First remove older versions of Ansible before re-installing it:
pip uninstall ansible. - Si une version d'ansible a été installée via
apt-get install, il est nécessaire de la désinstaller :apt-get remove ansible
- Install Ansible 2.7.0:
pip install ansible==2.7.0 - Check the version of ansible:
ansible --version
Il est possible que l'ajout du lien vers ansible dans le PATH et/ou qu'un redémarrage soit nécessaire
- Clone project and change ownership:
sudo chown -R $USER vitam-ui/ - Build project using the "right" profile (see Maven profiles and Build)
- Set up environment variables :
SERVICE_NEXUS_URLandSERVICE_REPOSITORY_URL - Build project using
vitamprofile (see Build for Vitam developers) - Copy files:
collect-external-client.conf,access-external-client.conf,ingest-external-client.conf,keystore_ihm-demo.p12andtruststore_ihm-demo.jksintoapi/api-(iam|referential)/(iam|referential)/src/main/config/dev-vitam/ - Redirect
dev.vitamui.comURL defined in code tolocalhost: add this line127.0.0.1 dev.vitamui.comto yourhosts(/etc/hosts) file
/bin/sh: 1: /usr/bin/python: not found
=> Create symlink, for instance:
sudo ln -s /usr/bin/python2.7 /usr/bin/python
By default we use a self signed certificates with 3 years duration on development environments.
To generate PKI, bellow the steps:
-
Generate CA, certs and stores for dev
cd deployment ./pki/scripts/generate_ca_dev.sh true && ./pki/scripts/generate_certs_dev.sh environments/hosts.local true && ./generate_stores_dev.sh
N.B.: The "true" value is used to force regenerate CA & certs.
-
Re-generate MongoDB
After regenerating CA, certs and stores, the MongoDB must be re-generated.
In
mongo/tools, run (make sure you enabled your python env):restart_dev.sh
-
Add certificates in browser
In order for browsers (Chrome, Firefox) to recognize the certificates, add the following certificates in your browser:
- dev-deployment/environments/certs/server/ca/ca-intermediate.crt
- dev-deployment/environments/certs/server/ca/ca-root.crt
In Chrome:
- use certutil (install it from libnss3-tools package or equivalent if not already installed):
certutil -d sql:$HOME/.pki/nssdb -A -t "CT,c,c" -n "ca_root_server - vitamui" -i dev-deployment/environments/certs/server/ca/ca-root.crt certutil -d sql:$HOME/.pki/nssdb -A -t "CT,c,c" -n "ca_intermediate_server - vitamui" -i dev-deployment/environments/certs/server/ca/ca-intermediate.crt
- or (deprecated) chrome://settings/certificates -> Authorities -> Import
In Firefox: about:preferences#privacy -> Certificates -> Show Certificates -> Authorities -> Import
Without a profile, only Java projects are build.
This profile is used to build the entire project for dev purposes, backend & frontend included.
- UI modules are packaged with both Java & Angular.
- Angular projects are built without optimization in order to reduce global build time.
- Jasmine Karma tests are launched with the headless chrome.
This profile is used to build the entire project for prod purposes, backend/frontend included.
- UI modules are packaged with both Java & Angular.
- Angular projects are built with optimization.
- Jasmine Karma tests are launched with the headless chrome.
This profile is used to build rpm packages.
Only Maven modules with rpm.skip = false in their properties are eligible.
This profile is used to push the generated rpm package.
Only Maven modules with rpm.skip = false in their properties are eligible.
This profile is automatically activated if the option -DskipTests is used during Maven execution in order to disable Jasmine Karma tests execution.
This profile is used to update sonar information.
This profile is used to build the entire project, backend & frontend included.
- Angular projects are build without optimization in order to reduce global build time.
- Jasmine Karma tests are launched with the headless chrome.
- Jenkins can use this profile.
This profile is used to generate the swagger.json draft file for swagger documentation. It's only needed for API modules.
This profile is used to generate .html & .pdf swagger documentation in tools/swagger/docs/.
Only Maven modules with rpm.skip = false in their properties are eligible.
This is the profile to use for all Vitam internal developers.
No integration test is launched during the “normal” build of the project.
Integration tests need a full running environment in order to launch API tests & few UI tests also.
This profile should be used to launch integration tests in Jenkins. The configuration used for the tests is available in integration-tests/src/test/resources/application-integration.yml
This profile should be used to launch integration tests in our development environment. The configuration used for the tests is available in integration-tests/src/test/resources/application-dev.yml
This profile should be used to launch API IAM integration tests in our development environment. The configuration used for the tests is available in integration-tests/src/test/resources/application-dev.yml
This profile should be used to launch API Security integration tests in our development environment. The configuration used for the tests is available in integration-tests/src/test/resources/application-dev.yml
This profile should be used to launch UI integration tests in our development environment. The configuration used for the tests is available in integration-tests/src/test/resources/application-dev.yml
Execute this command to build the project with unit tests and without building our angular projects: mvn clean install
Execute this command to build the project without unit tests and without building our angular projects: mvn clean install -DskipTests
mvn clean install [-Ddependency-check.skip=true] -Denv.SERVICE_NEXUS_URL=... -Denv.SERVICE_REPOSITORY_URL=... [-DskipTests] -Pvitam
Use the dev maven profile to build the project with our angular projects.
For our angular projects, the build doesn't generate the sourcemap and doesn't optimize the build.
For the karma tests, we don't generate the code coverage and use the headless chrome.
mvn clean install -PdevUse the webpack maven profile to build the project with our angular projects.
For our angular projects, the build generate the sourcemap and doesn't optimize the build.
For the karma tests, we don't generate the code coverage and use the headless chrome.
mvn clean install -PwebpackUse the prod maven profile to build the project with our angular projects.
For our angular projects, the build generate the sourcemap and optimize the build.
For the karma tests, we don't generate the code coverage and use the headless chrome.
mvn clean install -PprodIf -DskipTests id added during the build of dev, webpack or prod, unit tests and karma tests are both ignored.
Use the dev-it maven profile to build the project with unit tests and integration tests.
mvn clean verify -Pdev-itFor more details see README in integration-tests module.
mvn clean verify -PintegrationUse the rpm and webpack maven profiles to build the project and package to RPM: mvn clean package -Prpm,webpack
mvn clean verify -PsonarYou can specify properties to change URL and login to sonar:
mvn clean verify -Psonar \
-Dsonar.host.url=http://localhost:9000 \
-Dsonar.login=<TOKEN AUTHENTICATION>Use the rpm and webpack maven profiles to build all artifacts and deploy to NEXUS use: mvn clean deploy -Prpm,webpack
To generate swagger.json: mvn test -Pswagger
ATTENTION: In case you change the model part of an object or an entity in one of the projects, it is not essential to regenerate the swagger.json file, you just have to modify it manually by adding the necessary information on the modifications we made on the model part.
To edit the file you can use this website.
To generate index.pdf and index.html from swagger.json: mvn generate-resources -Pswagger-docs
Pour lancer VITAM en mode développement et permettre à VITAMUI d'accéder à ces APIs, voir la configuration suivante.
├── tools
│ ├── docker
│ │ ├── mongo: './restart_dev.sh'
├── tools
│ ├── docker
│ │ ├── mail: './start.sh'
├── api
│ ├── api-security
│ │ ├── security: 'mvn clean spring-boot:run [-Puse-profile-here]' ou './run.sh'
├── api
│ ├── api-iam
│ │ ├── iam: 'mvn clean spring-boot:run [-Puse-profile-here]' ou './run.sh'
├── api
│ ├── api-collect
│ │ ├── collect: 'mvn clean spring-boot:run' ou './run.sh'
├── api
│ ├── api-ingest
│ │ ├── ingest: 'mvn clean spring-boot:run' ou './run.sh'
La surcharge faite sur CAS nous empêche de lancer avec le plugin spring-boot
INFO: CAS-Server dépend de security & iam
├── cas
│ ├── cas-server: './run.sh'
└── ui
├── ui-frontend: 'npm run start:portal'
└── ui
├── ui-frontend: 'npm run start:identity'
└── ui
├── ui-frontend: 'npm run start:ingest'
└── ui
├── ui-frontend: 'npm run start:archive-search'
└── ui
├── ui-frontend: 'npm run start:collect'
└── ui
├── ui-frontend: 'npm run start:pastis'
- UI-Frontend
- https://dev.vitamui.com:4200
- https://dev.vitamui.com:4201/user
- https://dev-vitamui.com:4208
- Ui-Back
- https://dev.vitamui.com:9000/
- https://dev.vitamui.com:9001/
- https://dev-vitamui.com:9008
Attention: Sans cette étape, le logout sur toutes les applications par CAS ne fonctionne pas.
17 - Lancer l'application 'design-system' contenant des exemples de composants graphiques du design system
└── ui
├── ui-frontend: 'npm run start:design-system'