demarches-normaliennes/config/routes.rb

477 lines
15 KiB
Ruby
Raw Normal View History

2015-08-10 11:05:06 +02:00
Rails.application.routes.draw do
2021-02-16 16:14:43 +01:00
# For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html
2020-11-12 16:09:21 +01:00
get '/saml/auth' => 'saml_idp#new'
post '/saml/auth' => 'saml_idp#create'
get '/saml/metadata' => 'saml_idp#metadata'
2018-07-31 11:48:58 +02:00
#
# Manager
#
2017-12-28 19:44:11 +01:00
namespace :manager do
resources :procedures, only: [:index, :show] do
2018-01-10 17:42:21 +01:00
post 'whitelist', on: :member
post 'draft', on: :member
2020-03-26 09:08:52 +01:00
post 'discard', on: :member
post 'restore', on: :member
post 'add_administrateur', on: :member
post 'change_piece_justificative_template', on: :member
get 'export_mail_brouillons', on: :member
end
resources :dossiers, only: [:index, :show] do
post 'discard', on: :member
post 'restore', on: :member
post 'repasser_en_instruction', on: :member
end
2018-01-18 10:04:34 +01:00
resources :administrateurs, only: [:index, :show, :new, :create] do
post 'reinvite', on: :member
delete 'delete', on: :member
2018-01-18 10:04:34 +01:00
end
2017-12-28 19:44:11 +01:00
resources :users, only: [:index, :show, :edit, :update] do
2020-01-08 10:50:16 +01:00
delete 'delete', on: :member
post 'resend_confirmation_instructions', on: :member
2019-07-04 12:36:17 +02:00
put 'enable_feature', on: :member
get 'emails', on: :member
put 'unblock_email'
end
resources :instructeurs, only: [:index, :show] do
2018-06-14 16:41:10 +02:00
post 'reinvite', on: :member
delete 'delete', on: :member
2018-06-14 16:41:10 +02:00
end
2018-05-31 15:18:06 +02:00
resources :dossiers, only: [:show]
resources :demandes, only: [:index]
2018-10-02 16:04:14 +02:00
resources :bill_signatures, only: [:index]
2018-10-02 16:04:14 +02:00
resources :services, only: [:index, :show]
2021-04-13 15:57:22 +02:00
resources :super_admins, only: [:index, :show, :destroy]
2021-04-13 15:54:42 +02:00
2018-03-21 10:28:17 +01:00
post 'demandes/create_administrateur'
2018-03-27 13:32:14 +02:00
post 'demandes/refuse_administrateur'
authenticate :super_admin do
2019-07-04 12:36:17 +02:00
mount Flipper::UI.app(-> { Flipper.instance }) => "/features", as: :flipper
2018-01-16 16:58:52 +01:00
match "/delayed_job" => DelayedJobWeb, :anchor => false, :via => [:get, :post]
end
2018-01-16 18:09:01 +01:00
root to: "administrateurs#index"
2017-12-28 19:44:11 +01:00
end
2018-09-25 11:54:15 +02:00
#
# Letter Opener
#
if Rails.env.development?
mount LetterOpenerWeb::Engine, at: "/letter_opener"
end
2018-07-31 11:48:58 +02:00
#
# Monitoring
#
2020-06-22 15:28:36 +02:00
get "/ping" => "ping#index"
2016-06-01 15:07:27 +02:00
2018-07-31 11:48:58 +02:00
#
# Authentication
#
devise_for :super_admins, skip: [:registrations], controllers: {
sessions: 'super_admins/sessions',
passwords: 'super_admins/passwords'
}
get 'super_admins/edit_otp', to: 'super_admins#edit_otp', as: 'edit_super_admin_otp'
put 'super_admins/enable_otp', to: 'super_admins#enable_otp', as: 'enable_super_admin_otp'
2016-02-23 16:51:24 +01:00
devise_for :users, controllers: {
2018-01-15 19:02:12 +01:00
sessions: 'users/sessions',
registrations: 'users/registrations',
confirmations: 'users/confirmations',
passwords: 'users/passwords'
2018-01-15 19:02:12 +01:00
}
devise_scope :user do
get '/users/no_procedure' => 'users/sessions#no_procedure'
get 'connexion-par-jeton/:id' => 'users/sessions#sign_in_by_link', as: 'sign_in_by_link'
get 'lien-envoye' => 'users/sessions#link_sent', as: 'link_sent'
get 'lien-envoye/:email' => 'users/sessions#link_sent', constraints: { email: /.*/ }, as: 'link_sent_legacy' # legacy, can be removed as soon as the previous line is deployed to production servers
get '/users/password/reset-link-sent' => 'users/passwords#reset_link_sent'
end
get 'password_complexity' => 'password_complexity#show', as: 'show_password_complexity'
2018-07-31 11:48:58 +02:00
#
# Main routes
#
root 'root#index'
get '/administration' => 'root#administration'
2015-10-05 16:42:29 +02:00
get 'users' => 'users#index'
get 'admin' => 'admin#index'
get '/stats' => 'stats#index'
get '/stats/download' => 'stats#download'
2017-03-24 18:04:37 +01:00
namespace :france_connect do
get 'particulier' => 'particulier#login'
get 'particulier/callback' => 'particulier#callback'
end
2015-08-10 11:05:06 +02:00
2018-04-03 17:53:14 +02:00
namespace :champs do
2018-09-06 19:23:27 +02:00
get ':position/siret', to: 'siret#show', as: :siret
get ':position/dossier_link', to: 'dossier_link#show', as: :dossier_link
2018-10-17 12:02:34 +02:00
post ':position/carte', to: 'carte#show', as: :carte
get ':champ_id/carte/features', to: 'carte#index', as: :carte_features
post ':champ_id/carte/features', to: 'carte#create'
post ':champ_id/carte/features/import', to: 'carte#import'
patch ':champ_id/carte/features/:id', to: 'carte#update'
delete ':champ_id/carte/features/:id', to: 'carte#destroy'
2019-01-30 16:14:15 +01:00
post ':position/repetition', to: 'repetition#show', as: :repetition
put 'piece_justificative/:champ_id', to: 'piece_justificative#update', as: :piece_justificative
2018-04-03 17:53:14 +02:00
end
resources :attachments, only: [:show, :destroy]
2021-04-29 09:32:25 +02:00
resources :recherche, only: [:index]
2018-07-31 11:48:58 +02:00
get "patron" => "root#patron"
2018-11-07 16:54:18 +01:00
get "suivi" => "root#suivi"
post "dismiss_outdated_browser" => "root#dismiss_outdated_browser"
2021-05-12 16:30:35 +02:00
post "save_locale" => "root#save_locale"
2018-07-31 11:48:58 +02:00
2018-08-29 21:26:22 +02:00
get "contact", to: "support#index"
post "contact", to: "support#create"
2018-11-28 15:19:12 +01:00
get "contact-admin", to: "support#admin"
2018-08-29 21:26:22 +02:00
post "webhooks/helpscout", to: "webhook#helpscout"
match "webhooks/helpscout", to: lambda { |_| [204, {}, nil] }, via: :head
2018-08-29 11:44:12 +02:00
2018-07-31 11:48:58 +02:00
#
# Deprecated UI
#
2015-09-23 19:20:03 +02:00
namespace :users do
2018-11-01 13:00:35 +01:00
resources :dossiers, only: [] do
post '/carte/zones' => 'carte#zones'
get '/carte' => 'carte#show'
post '/carte' => 'carte#save'
post '/repousser-expiration' => 'dossiers#extend_conservation'
2015-09-23 19:20:03 +02:00
end
# Redirection of legacy "/users/dossiers" route to "/dossiers"
get 'dossiers', to: redirect('/dossiers')
get 'dossiers/:id/recapitulatif', to: redirect('/dossiers/%{id}')
get 'dossiers/invites/:id', to: redirect(path: '/invites/%{id}')
2015-08-10 11:05:06 +02:00
2019-08-07 15:52:38 +02:00
get 'activate' => '/users/activate#new'
patch 'activate' => '/users/activate#create'
end
2019-09-24 16:38:58 +02:00
# order matters: we don't want those routes to match /admin/procedures/:id
get 'admin/procedures/new' => 'new_administrateur/procedures#new', as: :new_admin_procedure
namespace :admin do
get 'activate' => '/administrateurs/activate#new'
patch 'activate' => '/administrateurs/activate#create'
2020-09-17 13:53:48 +02:00
get 'procedures/archived', to: redirect('/admin/procedures?statut=archivees')
get 'procedures/draft', to: redirect('/admin/procedures?statut=brouillons')
namespace :assigns do
2018-08-29 22:11:38 +02:00
get 'show' # delete after fixed tests admin/instructeurs/show_spec without this line
end
end
2015-09-22 10:15:12 +02:00
resources :invites, only: [:show, :destroy] do
collection do
post 'dossier/:dossier_id', to: 'invites#create', as: :dossier
end
2016-09-13 12:17:56 +02:00
end
2018-07-31 11:48:58 +02:00
#
# API
#
2020-09-15 10:38:42 +02:00
authenticated :user, lambda { |user| user.administrateur_id } do
mount GraphqlPlayground::Rails::Engine, at: "/graphql", graphql_path: "/api/v2/graphql"
2018-11-19 21:18:39 +01:00
end
2015-12-21 17:50:34 +01:00
namespace :api do
namespace :v1 do
2016-01-20 15:48:46 +01:00
resources :procedures, only: [:index, :show] do
resources :dossiers, only: [:index, :show]
2016-01-20 15:48:46 +01:00
end
2015-12-21 17:50:34 +01:00
end
2018-11-19 21:18:17 +01:00
namespace :v2 do
post :graphql, to: "graphql#execute"
get 'dossiers/pdf/:id', format: :pdf, to: "dossiers#pdf", as: :dossier_pdf
get 'dossiers/geojson/:id', to: "dossiers#geojson", as: :dossier_geojson
2018-11-19 21:18:17 +01:00
end
resources :pays, only: :index
2015-12-21 17:50:34 +01:00
end
2018-07-31 11:48:58 +02:00
#
# User
#
2017-06-14 14:42:09 +02:00
2019-03-25 10:53:45 +01:00
scope module: 'users' do
2021-06-02 12:48:24 +02:00
namespace :statistiques do
get '/:path', action: 'statistiques'
end
2018-11-01 13:00:35 +01:00
namespace :commencer do
get '/test/:path/dossier_vide', action: 'dossier_vide_pdf_test', as: :dossier_vide_test
2018-11-01 13:00:35 +01:00
get '/test/:path', action: 'commencer_test', as: :test
get '/:path', action: 'commencer'
get '/:path/dossier_vide', action: 'dossier_vide_pdf', as: :dossier_vide
2019-01-16 11:57:58 +01:00
get '/:path/sign_in', action: 'sign_in', as: :sign_in
get '/:path/sign_up', action: 'sign_up', as: :sign_up
get '/:path/france_connect', action: 'france_connect', as: :france_connect
2018-11-01 13:00:35 +01:00
end
resources :dossiers, only: [:index, :show, :new] do
member do
get 'identite'
2018-02-08 17:13:15 +01:00
patch 'update_identite'
get 'siret'
post 'siret', to: 'dossiers#update_siret'
2018-10-15 12:25:25 +02:00
get 'etablissement'
get 'brouillon'
patch 'brouillon', to: 'dossiers#update_brouillon'
2018-09-05 18:23:10 +02:00
get 'modifier', to: 'dossiers#modifier'
patch 'modifier', to: 'dossiers#update'
2018-02-27 09:49:58 +01:00
get 'merci'
get 'demande'
2018-09-05 13:56:12 +02:00
get 'messagerie'
post 'commentaire' => 'dossiers#create_commentaire'
post 'ask_deletion'
get 'attestation'
get 'transferer', to: 'dossiers#transferer'
end
2018-07-17 11:27:10 +02:00
collection do
get 'transferer', to: 'dossiers#transferer_all'
get 'recherche'
resources :transfers, only: [:create, :update, :destroy]
2018-07-17 11:27:10 +02:00
end
end
2018-08-08 17:37:41 +02:00
resource :feedback, only: [:create]
get 'demarches' => 'demarches#index'
2019-07-02 18:15:03 +02:00
get 'profil' => 'profil#show'
post 'renew-api-token' => 'profil#renew_api_token'
# allow refresh 'renew api token' page
get 'renew-api-token' => redirect('/profil')
patch 'update_email' => 'profil#update_email'
2021-09-20 13:14:03 +02:00
post 'transfer_all_dossiers' => 'profil#transfer_all_dossiers'
end
2021-02-09 10:24:13 +01:00
#
# Expert
#
scope module: 'experts', as: 'expert' do
get 'avis', to: 'avis#index', as: 'all_avis'
2021-02-25 10:10:42 +01:00
resources :procedures, only: [], param: :procedure_id do
2021-02-09 10:24:13 +01:00
member do
resources :avis, only: [:show, :update] do
get '', action: 'procedure', on: :collection, as: :procedure
member do
get 'instruction'
get 'messagerie'
post 'commentaire' => 'avis#create_commentaire'
post 'avis' => 'avis#create_avis'
get 'bilans_bdf'
get 'sign_up' => 'avis#sign_up'
post 'sign_up' => 'avis#update_expert'
# This redirections are ephemeral, to ensure that emails sent to experts before are still valid
# TODO : remove these lines after September, 2021
get 'sign_up/email/:email' => 'avis#sign_up', constraints: { email: /.*/ }, as: 'sign_up_legacy'
post 'sign_up/email/:email' => 'avis#update_expert', constraints: { email: /.*/ }, as: 'update_expert_legacy'
2021-02-09 10:24:13 +01:00
end
end
end
end
end
2018-07-31 11:48:58 +02:00
#
# Instructeur
2018-07-31 11:48:58 +02:00
#
scope module: 'instructeurs', as: 'instructeur' do
2017-07-11 16:09:03 +02:00
resources :procedures, only: [:index, :show], param: :procedure_id do
member do
2019-10-25 09:26:31 +02:00
resources :groupes, only: [:index, :show], controller: 'groupe_instructeurs' do
member do
post 'add_instructeur'
2019-10-25 10:17:39 +02:00
delete 'remove_instructeur'
2019-10-25 09:26:31 +02:00
end
end
2019-10-24 21:52:05 +02:00
2020-06-26 19:28:28 +02:00
resources :avis, only: [:show, :update] do
get '', action: 'procedure', on: :collection, as: :procedure
member do
2020-07-16 11:14:37 +02:00
patch 'revoquer'
2020-07-20 16:26:16 +02:00
get 'revive'
end
end
patch 'update_displayed_fields'
2017-09-27 15:16:07 +02:00
get 'update_sort/:table/:column' => 'procedures#update_sort', as: 'update_sort'
2017-09-28 11:04:18 +02:00
post 'add_filter'
get 'remove_filter' => 'procedures#remove_filter', as: 'remove_filter'
get 'download_export'
get 'stats'
2019-03-13 17:37:07 +01:00
get 'email_notifications'
patch 'update_email_notifications'
get 'deleted_dossiers'
2021-07-22 14:33:02 +02:00
get 'email_usagers'
post 'create_multiple_commentaire'
resources :dossiers, only: [:show], param: :dossier_id do
member do
get 'attestation'
get 'geo_data'
get 'apercu_attestation'
2020-04-30 11:25:22 +02:00
get 'bilans_bdf'
2017-07-19 11:08:53 +02:00
get 'messagerie'
get 'annotations-privees' => 'dossiers#annotations_privees'
2017-09-26 14:38:16 +02:00
get 'avis'
get 'personnes-impliquees' => 'dossiers#personnes_impliquees'
patch 'follow'
patch 'unfollow'
patch 'archive'
patch 'unarchive'
patch 'supprimer-dossier' => 'dossiers#delete_dossier'
2017-08-02 15:33:23 +02:00
patch 'annotations' => 'dossiers#update_annotations'
post 'commentaire' => 'dossiers#create_commentaire'
post 'passer-en-instruction' => 'dossiers#passer_en_instruction'
post 'repasser-en-construction' => 'dossiers#repasser_en_construction'
2019-07-01 16:16:40 +02:00
post 'repasser-en-instruction' => 'dossiers#repasser_en_instruction'
2017-12-01 12:57:01 +01:00
post 'terminer'
post 'send-to-instructeurs' => 'dossiers#send_to_instructeurs'
2017-08-28 14:16:13 +02:00
post 'avis' => 'dossiers#create_avis'
get 'print' => 'dossiers#print'
get 'telecharger_pjs' => 'dossiers#telecharger_pjs'
end
2017-07-11 16:09:03 +02:00
end
resources :archives, only: [:index, :create, :show], controller: 'archives'
end
end
end
2018-07-31 11:48:58 +02:00
#
# Administrateur
#
namespace :admin, module: 'new_administrateur' do
resources :procedures do
collection do
get 'new_from_existing'
end
2018-04-13 16:56:00 +02:00
member do
get 'apercu'
2018-11-14 16:28:02 +01:00
get 'champs'
get 'annotations'
get 'monavis'
patch 'update_monavis'
get 'jeton'
patch 'update_jeton'
put :allow_expert_review
2021-04-16 11:11:50 +02:00
put :experts_require_administrateur_invitation
2018-04-13 16:56:00 +02:00
end
get :api_particulier, controller: 'jeton_particulier'
resource 'api_particulier', only: [] do
resource 'jeton', only: [:show, :update], controller: 'jeton_particulier'
2021-09-13 15:59:58 +02:00
resource 'sources', only: [:show, :update], controller: 'sources_particulier'
end
put 'clone'
put 'archive'
get 'publication' => 'procedures#publication', as: :publication
put 'publish' => 'procedures#publish', as: :publish
2020-09-29 10:52:13 +02:00
get 'transfert' => 'procedures#transfert', as: :transfert
post 'transfer' => 'procedures#transfer', as: :transfer
resources :mail_templates, only: [:edit, :update]
resources :groupe_instructeurs, only: [:index, :show, :create, :update, :destroy] do
2019-10-10 19:36:56 +02:00
member do
post 'add_instructeur'
2019-10-09 18:23:29 +02:00
delete 'remove_instructeur'
get 'reaffecter_dossiers'
post 'reaffecter'
2019-10-10 19:36:56 +02:00
end
2019-10-17 10:57:58 +02:00
collection do
patch 'update_routing_criteria_name'
patch 'update_routing_enabled'
patch 'update_instructeurs_self_management_enabled'
2021-06-09 17:51:49 +02:00
post 'import'
2019-10-17 10:57:58 +02:00
end
2019-10-10 19:36:56 +02:00
end
2019-10-17 15:13:50 +02:00
2019-04-12 10:43:51 +02:00
resources :administrateurs, controller: 'procedure_administrateurs', only: [:index, :create, :destroy]
resources :experts, controller: 'experts_procedures', only: [:index, :create, :update, :destroy]
2019-03-20 14:27:30 +01:00
resources :types_de_champ, only: [:create, :update, :destroy] do
member do
patch :move
end
end
resources :mail_templates, only: [:index] do
get 'preview', on: :member
end
resource :attestation_template, only: [:edit, :update, :create] do
get 'preview', on: :member
end
# ADDED TO ACCESS IT FROM THE IFRAME
get 'attestation_template/preview' => 'attestation_templates#preview'
2018-04-13 16:56:00 +02:00
end
2018-04-19 16:15:44 +02:00
2018-04-23 15:32:27 +02:00
resources :services, except: [:show] do
2018-04-20 12:03:02 +02:00
collection do
patch 'add_to_procedure'
end
end
2018-04-13 16:56:00 +02:00
end
if Rails.env.test?
scope 'test/api_geo' do
get 'regions' => 'api_geo_test#regions'
get 'communes' => 'api_geo_test#communes'
get 'departements' => 'api_geo_test#departements'
end
end
2018-07-31 11:48:58 +02:00
#
# Legacy routes
2018-07-31 11:48:58 +02:00
#
get 'demandes/new' => redirect(DEMANDE_INSCRIPTION_ADMIN_PAGE_URL)
2018-07-31 11:48:58 +02:00
get 'backoffice' => redirect('/procedures')
get 'backoffice/sign_in' => redirect('/users/sign_in')
get 'backoffice/dossiers/procedure/:procedure_id' => redirect('/procedures/%{procedure_id}')
2015-08-10 11:05:06 +02:00
end