Merge pull request #9613 from demarches-simplifiees/8742-effectifs

tech: utilise l'api entreprise v3 pour récupérer les effectifs mensuels et annuels
This commit is contained in:
krichtof 2023-10-19 14:46:10 +00:00 committed by GitHub
commit 7ae66d0360
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
12 changed files with 91 additions and 47 deletions

View file

@ -1,8 +1,7 @@
class APIEntreprise::EffectifsJob < APIEntreprise::Job
def perform(etablissement_id, procedure_id)
find_etablissement(etablissement_id)
# may 2020 is at the moment the most actual info for effectifs endpoint
etablissement_params = APIEntreprise::EffectifsAdapter.new(etablissement.siret, procedure_id, "2020", "05").to_params
etablissement = Etablissement.find(etablissement_id)
etablissement_params = APIEntreprise::EffectifsAdapter.new(etablissement.siret, procedure_id, *get_current_valid_month_for_effectif).to_params
etablissement.update!(etablissement_params)
end

View file

@ -5,8 +5,8 @@ class APIEntreprise::API
TVA_NAME = "v3/european_commission/unites_legales/%{id}/numero_tva"
EXERCICES_RESOURCE_NAME = "v3/dgfip/etablissements/%{id}/chiffres_affaires"
RNA_RESOURCE_NAME = "v4/djepva/api-association/associations/open_data/%{id}"
EFFECTIFS_RESOURCE_NAME = "v2/effectifs_mensuels_acoss_covid"
EFFECTIFS_ANNUELS_RESOURCE_NAME = "v2/effectifs_annuels_acoss_covid/%{id}"
EFFECTIFS_RESOURCE_NAME = "v3/gip_mds/etablissements/%{id}/effectifs_mensuels"
EFFECTIFS_ANNUELS_RESOURCE_NAME = "v3/gip_mds/unites_legales/%{id}/effectifs_annuels"
ATTESTATION_SOCIALE_RESOURCE_NAME = "v4/urssaf/unites_legales/%{id}/attestation_vigilance"
ATTESTATION_FISCALE_RESOURCE_NAME = "v4/dgfip/unites_legales/%{id}/attestation_fiscale"
BILANS_BDF_RESOURCE_NAME = "v3/banque_de_france/unites_legales/%{id}/bilans"
@ -50,13 +50,14 @@ class APIEntreprise::API
call_with_siret(RNA_RESOURCE_NAME, siret)
end
def effectifs(siren, annee, mois)
endpoint = [EFFECTIFS_RESOURCE_NAME, annee, mois, "entreprise", "%{id}"].join('/')
call_with_siret(endpoint, siren)
def effectifs(siret, annee, mois)
endpoint = [EFFECTIFS_RESOURCE_NAME, mois, "annee", annee].join('/')
call_with_siret(endpoint, siret)
end
def effectifs_annuels(siren)
call_with_siret(EFFECTIFS_ANNUELS_RESOURCE_NAME, siren)
def effectifs_annuels(siren, annee)
endpoint = [EFFECTIFS_ANNUELS_RESOURCE_NAME, annee].join('/')
call_with_siret(endpoint, siren)
end
def attestation_sociale(siren)

View file

@ -9,18 +9,24 @@ class APIEntreprise::EffectifsAdapter < APIEntreprise::Adapter
private
def get_resource
api(@procedure_id).effectifs(siren, @annee, @mois)
api(@procedure_id).effectifs(@siret, @annee, @mois)
end
def process_params
if data_source[:effectifs_mensuels].present?
data = data_source.fetch(:data, nil)
Sentry.with_scope do |scope|
scope.set_tags(siret: @siret)
scope.set_extras(source: data)
effectifs = data&.fetch(:effectifs_mensuels, nil)&.first
if effectifs.present?
{
entreprise_effectif_mensuel: data_source[:effectifs_mensuels],
entreprise_effectif_mois: data_source[:mois],
entreprise_effectif_annee: data_source[:annee]
entreprise_effectif_mensuel: effectifs[:value],
entreprise_effectif_mois: effectifs[:mois],
entreprise_effectif_annee: effectifs[:annee]
}
else
{}
end
end
end
end

View file

@ -1,23 +1,34 @@
class APIEntreprise::EffectifsAnnuelsAdapter < APIEntreprise::Adapter
def initialize(siret, procedure_id)
def initialize(siret, procedure_id, year = default_year)
@siret = siret
@procedure_id = procedure_id
@year = year
end
private
def default_year
Date.current.year - 1
end
def get_resource
api(@procedure_id).effectifs_annuels(siren)
api(@procedure_id).effectifs_annuels(siren, @year)
end
def process_params
if data_source[:effectifs_annuels].present?
data = data_source.fetch(:data, nil)
Sentry.with_scope do |scope|
scope.set_tags(siret: @siret)
scope.set_extras(source: data)
effectifs = data&.fetch(:effectifs_annuel, nil)&.first
if effectifs.present?
{
entreprise_effectif_annuel: data_source[:effectifs_annuels],
entreprise_effectif_annuel_annee: data_source[:annee]
entreprise_effectif_annuel: effectifs[:value],
entreprise_effectif_annuel_annee: effectifs[:annee]
}
else
{}
end
end
end
end

View file

@ -112,10 +112,10 @@ def add_identite_etablissement(pdf, etablissement)
if @include_infos_administration
if etablissement.entreprise_effectif_mensuel.present?
format_in_2_columns(pdf, "Effectif mensuel #{try_format_mois_effectif(etablissement)} (URSSAF) ", number_with_delimiter(etablissement.entreprise_effectif_mensuel.to_s))
format_in_2_columns(pdf, "Effectif mensuel #{try_format_mois_effectif(etablissement)} de l'établissement (URSSAF ou MSA) ", number_with_delimiter(etablissement.entreprise_effectif_mensuel.to_s))
end
if etablissement.entreprise_effectif_annuel_annee.present?
format_in_2_columns(pdf, "Effectif moyen annuel #{etablissement.entreprise_effectif_annuel_annee} (URSSAF) ", number_with_delimiter(etablissement.entreprise_effectif_annuel.to_s))
format_in_2_columns(pdf, "Effectif moyen annuel #{etablissement.entreprise_effectif_annuel_annee} de l'unité légale (URSSAF ou MSA) ", number_with_delimiter(etablissement.entreprise_effectif_annuel.to_s))
end
end

View file

@ -57,11 +57,11 @@
= humanized_entreprise_etat_administratif(etablissement)
- if profile == 'instructeur'
= render Dossiers::RowShowComponent.new(label: "Effectif mensuel #{try_format_mois_effectif(etablissement)} (URSSAF)") do |c|
= render Dossiers::RowShowComponent.new(label: "Effectif mensuel #{try_format_mois_effectif(etablissement)} de l'établissement (URSSAF ou MSA)") do |c|
- c.with_value do
%p= etablissement.entreprise_effectif_mensuel
= render Dossiers::RowShowComponent.new(label: "Effectif moyen annuel #{etablissement.entreprise_effectif_annuel_annee} (URSSAF)") do |c|
= render Dossiers::RowShowComponent.new(label: "Effectif moyen annuel #{etablissement.entreprise_effectif_annuel_annee} de l'unité légale (URSSAF ou MSA)") do |c|
- c.with_value do
%p= etablissement.entreprise_effectif_annuel

View file

@ -1,6 +1,17 @@
{
"siren": "418166096",
"data": {
"siret": "41816609600069",
"effectifs_mensuels": [
{
"regime": "regime_general",
"value": 12.34,
"nature": "effectif_moyen_mensuel",
"annee": "2020",
"mois": "02",
"effectifs_mensuels": 100.5
"date_derniere_mise_a_jour": "2018-01-01"
}
]
},
"links": {},
"meta": {}
}

View file

@ -1,5 +1,16 @@
{
"data": {
"siren": "418166096",
"annee": "2019",
"effectifs_annuels": 100.5
"annee": "2017",
"effectifs_annuel": [
{
"regime": "regime_general",
"value": 100.5,
"nature": "effectif_moyen_annuel",
"date_derniere_mise_a_jour": "2018-01-01"
}
]
},
"links": {},
"meta": {}
}

View file

@ -2,17 +2,21 @@ RSpec.describe APIEntreprise::EffectifsAnnuelsJob, type: :job do
let(:etablissement) { create(:etablissement, siret: siret) }
let(:siret) { '41816609600069' }
let(:siren) { '418166096' }
let(:now) { Date.parse("2021/02/13") }
let(:procedure) { create(:procedure) }
let(:procedure_id) { procedure.id }
let(:body) { File.read('spec/fixtures/files/api_entreprise/effectifs_annuels.json') }
let(:status) { 200 }
before do
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/effectifs_annuels_acoss_covid\/#{siren}/)
Timecop.freeze(now)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v3\/gip_mds\/unites_legales\/#{siren}\/effectifs_annuels\/2020/)
.to_return(body: body, status: status)
allow_any_instance_of(APIEntrepriseToken).to receive(:expired?).and_return(false)
end
after { Timecop.return }
subject { APIEntreprise::EffectifsAnnuelsJob.new.perform(etablissement.id, procedure_id) }
it 'updates etablissement' do

View file

@ -6,12 +6,12 @@ RSpec.describe APIEntreprise::EffectifsJob, type: :job do
let(:procedure_id) { procedure.id }
let(:now) { Time.zone.local(2020, 3, 12) }
let(:annee) { "2020" }
let(:mois) { "05" }
let(:mois) { "02" }
let(:body) { File.read('spec/fixtures/files/api_entreprise/effectifs.json') }
let(:status) { 200 }
before do
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/effectifs_mensuels_acoss_covid\/#{annee}\/#{mois}\/entreprise\/#{siren}/)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v3\/gip_mds\/etablissements\/#{siret}\/effectifs_mensuels\/#{mois}\/annee\/#{annee}/)
.to_return(body: body, status: status)
allow_any_instance_of(APIEntrepriseToken).to receive(:expired?).and_return(false)
end
@ -23,6 +23,6 @@ RSpec.describe APIEntreprise::EffectifsJob, type: :job do
it 'updates etablissement' do
subject
expect(Etablissement.find(etablissement.id).entreprise_effectif_mensuel).to eq(100.5)
expect(Etablissement.find(etablissement.id).entreprise_effectif_mensuel).to eq(12.34)
end
end

View file

@ -9,7 +9,7 @@ describe APIEntreprise::EffectifsAdapter do
subject { adapter.to_params }
before do
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/effectifs_mensuels_acoss_covid\/#{annee}\/#{mois}\/entreprise\/#{siren}/)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v3\/gip_mds\/etablissements\/#{siret}\/effectifs_mensuels\/#{mois}\/annee\/#{annee}/)
.to_return(body: body, status: status)
allow_any_instance_of(APIEntrepriseToken).to receive(:expired?).and_return(false)
end
@ -23,7 +23,7 @@ describe APIEntreprise::EffectifsAdapter do
end
it "renvoie les effectifs du mois demandé" do
expect(subject[:entreprise_effectif_mensuel]).to eq(100.5)
expect(subject[:entreprise_effectif_mensuel]).to eq(12.34)
end
end
end

View file

@ -1,13 +1,14 @@
describe APIEntreprise::EffectifsAnnuelsAdapter do
let(:siret) { '41816609600069' }
let(:siren) { '418166096' }
let(:annee) { 2017 }
let(:procedure) { create(:procedure) }
let(:procedure_id) { procedure.id }
let(:adapter) { described_class.new(siret, procedure_id) }
let(:adapter) { described_class.new(siret, procedure_id, annee) }
subject { adapter.to_params }
before do
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/effectifs_annuels_acoss_covid\/#{siren}/)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v3\/gip_mds\/unites_legales\/#{siren}\/effectifs_annuels\/#{annee}/)
.to_return(body: body, status: status)
allow_any_instance_of(APIEntrepriseToken).to receive(:expired?).and_return(false)
end