Dématérialiser et simplifier les démarches administratives
Find a file
gregoirenovel 092df8e8af Change a reply_to email address
equipe@ is an internal email address
2018-03-14 11:50:22 +01:00
.circleci Bump ruby to 2.5.0 2018-03-02 15:42:20 +01:00
app Change a reply_to email address 2018-03-14 11:50:22 +01:00
bin Bump development gems 2018-03-06 16:17:22 +01:00
config Move CGU_URL to a new initializer 2018-03-12 18:13:23 +01:00
db Remove all references to old STI 2018-03-08 14:17:04 +01:00
doc Remove any reference to the SGMAP 2018-01-18 17:39:56 +01:00
lib [#1545] secure task for production 2018-03-09 19:02:47 +01:00
log First Commit 2015-08-10 11:05:06 +02:00
public Revert "Commit compiled assets" 2018-01-31 16:23:40 +01:00
spec [Fix #1577] logo link in navbar on gestionnaire UI should not link to admin UI 2018-03-08 14:10:26 +01:00
vendor/assets tps.apientreprise.fr -> demarches-simplifiees.fr 2018-03-01 10:33:53 +01:00
.editorconfig Add a .editorconfig file 2017-04-04 17:32:36 +02:00
.gitignore Gitignore: add storage/ 2018-02-26 10:17:08 +01:00
.haml-lint.yml Bump development gems 2018-01-23 16:26:56 +01:00
.rspec First Commit 2015-08-10 11:05:06 +02:00
.rubocop.yml Enable some Rails cops 2018-03-06 17:18:44 +01:00
.ruby-version Bump ruby to 2.5.0 2018-03-02 15:42:20 +01:00
.scss-lint.yml Add the direct_upload JS ans SCSS files 2018-02-15 11:14:03 +01:00
config.ru Delete redis and actioncable 2017-10-12 07:21:02 +02:00
Gemfile Fix XSS in delayed job web admin 2018-03-07 17:04:47 +01:00
Gemfile.lock Fix XSS in delayed job web admin 2018-03-07 17:04:47 +01:00
Guardfile Enable the Layout/EmptyLines cop 2017-06-13 10:35:20 +02:00
LICENSE.agpl-3.0.txt Add license 2017-04-03 11:05:37 +02:00
Procfile Add a Procfile and document usage of hivemind 2018-01-02 11:20:22 +01:00
Rakefile Bump development gems 2018-03-06 16:17:22 +01:00
README.md Add reference to AccessLint in the README 2018-03-08 15:42:18 +01:00

demarches-simplifiees.fr (anciennement Téléprocédures Simplifiées)

Context

demarches-simplifiees.fr est un site web conçue afin de répondre au besoin urgent de l'État d'appliquer la directive sur le 100 % dématérialisation pour les procédures administratives.

Dépendances

Tous environnements

  • postgresql

Développement

Tests

Initialisation de l'environnement de développement

Afin d'initialiser l'environnement de développement, éxécutez la commande suivante :

bundle install

Création de la base de données

Les informations nécessaire à l'initialisation de la base doivent être pré-configurées à la main grâce à la procédure suivante :

su - postgres
psql
> create user tps_development with password 'tps_development' superuser;
> create user tps_test with password 'tps_test' superuser;
> \q

Afin de générer la BDD de l'application, il est nécessaire d'éxécuter les commandes suivantes :

# Create and load the schema for both databases
rake db:create db:schema:load

# Migrate the development database and then the test database
rake db:migrate
rake db:migrate RAILS_ENV=test

Bouchonnage de lauthentification

Créer le fichier config/france_connect.yml avec le contenu

particulier_identifier: ''
particulier_secret: ''

particulier_redirect_uri: ''
particulier_authorization_endpoint: ''
particulier_token_endpoint: ''
particulier_userinfo_endpoint: ''
particulier_logout_endpoint: ''

Créer le fichier config/github_secrets.yml avec le contenu

client_id: ''
client_secret: ''

Note : les valeurs pour ces deux paramètres sont renseignées dans le Keepass

Création des comptes initiaux

rails c
> email = "<votre email>"
> password = "<votre mot de passe>"
> Administration.create(email: email, password: password)
> Administrateur.create(email: email, password: password)
> Gestionnaire.create(email: email, password: password)
> User.create(email: email, password: password)

Lancement de l'application

overmind s

Programmation des jobs

AutoArchiveProcedureJob.set(cron: "* * * * *").perform_later
WeeklyOverviewJob.set(cron: "0 8 * * 0").perform_later
AutoReceiveDossiersForProcedureJob.set(cron: "* * * * *").perform_later(procedure_declaratoire_id, 'en_instruction')
FindDubiousProceduresJob.set(cron: "0 0 * * *").perform_later

Exécution des tests (RSpec)

Pour exécuter les tests de l'application, plusieurs possibilités :

  • Lancer tous les tests

      rake spec
      rspec
    
  • Lancer un test en particulier

      rake spec SPEC=file_path/file_name_spec.rb:line_number
      rspec file_path/file_name_spec.rb:line_number
    
  • Lancer tous les tests d'un fichier

      rake spec SPEC=file_path/file_name_spec.rb
      rspec file_path/file_name_spec.rb
    

Debug

Une fois overmind lancé, et un breakpoint byebug inséré dans le code, il faut se connecter au process server dans un nouveau terminal afin d'intéragir avec byebug :

overmind connect server

Linting

  • Faire tourner RuboCop : bundle exec rubocop
  • Faire tourner Brakeman : bundle exec brakeman
  • Linter les fichiers HAML : bundle exec haml-lint app/views/
  • Linter les fichiers SCSS : bundle exec scss-lint app/assets/stylesheets/
  • AccessLint tourne automatiquement sur les PRs

Déploiement

  • Tout nouveau commit ajouté à la branche dev est automatiquement déployé en intégration
  • Tout nouveau commit ajouté à la branche master est automatiquement déployé en production

Régénérer les binstubs

bundle binstub railties --force
rake rails:update:bin

Tâches Super Admin

  • ajouter un compte super admin : bundle exec rake admin:create_admin[email-du-compte-github@exemple.com]

  • lister les comptes super admin : bundle exec rake admin:list

  • supprimer un compte super admin : bundle exec rake admin:delete_admin[email-du-compte-github@exemple.com]

Compatibilité navigateurs

L'application supporte les navigateurs récents Firefox, Chrome, Internet Explorer (Edge, 11).

La compatibilité est testée par Browserstack.

Performance

View performance data on Skylight

Nous utilisons Skylight pour suivre les performances de notre application.