Node 14.x.x
Express 4.17.2
Sequelize 6.12.2
ESLint 7.32.0
Babel 7.16.5
.github
: configuration de la CI avec Github Actions.husky
: scripts de hook de commit avec Husky/public
: stockage des ressources non dynamique accessible publiquement/src
/constants
: fichiers de constantes/controllers
: logiques métier de chaque use case de l'application/helpers
: fichier d'utilitaire lié aux use cases/jobs
: configuration des jobs asynchrones et gestions des jobs entrants/routes
: configuration des routes avec Express.js/db
: configuration de la base de données avec Sequelize/config
: configuration d'accès à la base de données/migrations
: fichiers de migration de la structure de la base/models
: fichiers modèles des objets en base
/utils
: fonctions utilitaires communesapp.js
: point d'entrée de lancement du serveurmainWorker.js
: point d'entrée de lancement du workerserver.js
: gestion du serveur
.babelrc
: configuration pour Babel.editorconfig
: configuration par défaut de la syntaxe du code de l'éditeur.env
: à ajouter pour gérer les variables d'environnements (cf. exemple).eslintignore
: configuration pour ESLint.eslintrc.json
: configuration pour ESLint.prettierignore
: configuration pour Prettier.prettierrc.json
: configuration pour Prettier.sequelizerc
: configuration pour Sequelize.slugignore
: dossiers ou fichiers à exclure du package finale pendant la compilationProcfile
: configuration des process Heroku à lancer après déploiement
Pour lancer le projet vous avez besoin de Docker ainsi que de NodeJs.
npm install
docker-compose up --build
npm run db-create
Pour lancer les migrations :
npm run db-migrate
APour remplir la base de données avec un utilisateur administrateur permettant la création par la suite d'autres utilisateurs :
npm run db-seed
La même chose que sans Docker, mais vous devez précéder les commandes par la suivante, et ne pas lancer la commande de création de DB:
docker exec -it api bash
Les identifiants de l'administrateur crée sont :
Adresse mail : admin@linkedout.fr
Mot de passe : Admin123!
psql -d linkedout -p 5432 -U linkedout -W
Entrez le mdp de la BD (dans le docker-compose: "linkedout"), puis exécutez la commande SQL.
Même chose que sans Docker, mais précédez par la commande suivante pour entrer dans le container de la DB:
docker exec -it db sh
npm run dev
docker-compose up
npm run build
npm start
Pour pouvoir utiliser le worker en local il faut lancer une instance de Redis en local : https://redis.io/docs/getting-started
Il faut également enlever les variables d'environnement REDIS_URL et REDIS_TLS_URL afin que les modules Redis et Bull utilisent leur configuration par défaut pour se connecter à Redis en local (127.0.0.1:6379
)
npm run dev-mainWorker
npm run mainWorker
npm run lint
npm run format
Ces deux commandes sont lancées par les hooks de commit.
ACTIONS_REMINDER_DELAY=
ADMIN_CANDIDATES_HZ=
ADMIN_CANDIDATES_LILLE=
ADMIN_CANDIDATES_LYON=
ADMIN_CANDIDATES_PARIS=
ADMIN_COMPANIES_HZ=
ADMIN_COMPANIES_LILLE=
ADMIN_COMPANIES_LYON=
ADMIN_COMPANIES_PARIS=
AIRTABLE_API_KEY=
AIRTABLE_BASE_ID=
AIRTABLE_OFFERS=
AUTO_RECOMMENDATIONS_ZONE=
AWS_LAMBA_URL=
AWSS3_BUCKET_NAME=
AWSS3_FILE_DIRECTORY=
AWSS3_ID=
AWSS3_IMAGE_DIRECTORY=
AWSS3_SECRET=
BITLY_TOKEN=
CDN_ID=
CHROME_PATH=
CV_10_REMINDER_DELAY=
CV_20_REMINDER_DELAY=
CV_START_DELAY=
DATABASE_URL=
EXTERNAL_OFFERS_REMINDER_DELAY=
FRONT_URL=
INTERVIEW_TRAINING_REMINDER_DELAY=
JWT_SECRET=
MAILCHIMP_API_KEY=
MAILCHIMP_AUDIENCE_ID=
MAILJET_CONTACT_EMAIL=
MAILJET_FROM_EMAIL=
MAILJET_FROM_NAME=
MAILJET_PUB=
MAILJET_SEC=
MAILJET_SMS_TOKEN=
MAILJET_SUPPORT_EMAIL=
OFFER_NO_RESPONSE_DELAY=
OFFER_REMINDER_DELAY=
PORT=
PUSHER_API_KEY=
PUSHER_API_SECRET=
PUSHER_APP_ID=
PUSHER_URL=
REDIS_TLS_URL=
REDIS_URL=
SALESFORCE_CLIENT_ID=
SALESFORCE_CLIENT_SECRET=
SALESFORCE_LOGIN_URL=
SALESFORCE_PASSWORD=
SALESFORCE_REDIRECT_URI=
SALESFORCE_SECURITY_TOKEN=
SALESFORCE_USERNAME=
SENTRY_DSN=
SERVER_TIMEOUT=
USE_MAILJET_SMS=
USE_SMS=
VIDEO_REMINDER_DELAY=
VONAGE_API_KEY=
VONAGE_API_SECRET=
docker run --name linkedout-db-test -e POSTGRES_PASSWORD=linkedout -e POSTGRES_USER=linkedout -e POSTGRES_DB=linkedout -d -p 54300:5432 postgres
Vous avez besoin des données du fichier .env.test
pour les tests en local, et de renseigner le champ DATABASE_URL (ex: postgresql://linkedout:linkedout@localhost:54300/linkedout
) avec l'adresse de l'instance Docker
NODE_ENV=dev-test npm run db-migrate
npm run test
est utilisé pour l'intégration continue pour lancer les tests avec les valeurs du fichier.env
npm run dev-test
pour lancer les tests en local, en utilisant le fichier.env.test
Le déploiement se fait automatiquement grâce à Github Actions et Heroku.
Si un commit est poussé sur develop
, l'application sera déployé sur la pre-production : https://entourage-job-preprod.herokuapp.com
Si un commit est poussé sur master
, l'application sera déployé sur la production : https://api.linkedout.fr
Les tests sont effectués sur Github Actions avant de déployer le projet sur Heroku.