Task to migrate carto to champ carte
This commit is contained in:
parent
e63fd9d573
commit
44ca6a2d02
1 changed files with 80 additions and 0 deletions
|
@ -0,0 +1,80 @@
|
|||
namespace :after_party do
|
||||
desc 'Deployment task: migrate_carto_to_carte'
|
||||
task migrate_carto_to_carte: :environment do
|
||||
def add_champ_carte_if_needed(procedure)
|
||||
champ_carte = procedure.types_de_champ_ordered.to_a.find do |type_de_champ|
|
||||
type_de_champ.type_champ == TypeDeChamp.type_champs.fetch(:carte)
|
||||
end
|
||||
|
||||
if champ_carte
|
||||
puts "Procedure##{procedure.id} already migrated to use champ carte"
|
||||
else
|
||||
add_champ_carte(procedure)
|
||||
end
|
||||
end
|
||||
|
||||
def add_champ_carte(procedure)
|
||||
qp = !!procedure.module_api_carto.quartiers_prioritaires
|
||||
ca = !!procedure.module_api_carto.cadastre
|
||||
|
||||
puts "Creating champ carte on Procedure##{procedure.id} with qp:#{qp} and ca:#{ca}..."
|
||||
|
||||
procedure.types_de_champ.update_all('order_place = order_place + 1')
|
||||
type_de_champ = procedure.types_de_champ.create(
|
||||
order_place: 0,
|
||||
libelle: 'Cartographie',
|
||||
type_champ: TypeDeChamp.type_champs.fetch(:carte),
|
||||
quartiers_prioritaires: qp,
|
||||
cadastres: ca,
|
||||
mandatory: true
|
||||
)
|
||||
|
||||
procedure.dossiers.each do |dossier|
|
||||
champ = type_de_champ.champ.create(dossier: dossier, value: dossier.json_latlngs)
|
||||
|
||||
if ca && !dossier.cadastres.empty?
|
||||
puts "Creating Cadastres on Dossier##{dossier.id}..."
|
||||
dossier.cadastres.each do |cadastre|
|
||||
champ.geo_areas.create(
|
||||
source: GeoArea.sources.fetch(:cadastre),
|
||||
geometry: cadastre.geometry,
|
||||
surface_intersection: cadastre.surface_intersection,
|
||||
surface_parcelle: cadastre.surface_parcelle,
|
||||
numero: cadastre.numero,
|
||||
feuille: cadastre.feuille,
|
||||
section: cadastre.section,
|
||||
code_dep: cadastre.code_dep,
|
||||
nom_com: cadastre.nom_com,
|
||||
code_com: cadastre.code_com,
|
||||
code_arr: cadastre.code_arr
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
if qp && !dossier.quartier_prioritaires.empty?
|
||||
puts "Creating Quartiers Prioritaires on Dossier##{dossier.id}..."
|
||||
dossier.quartier_prioritaires.each do |qp|
|
||||
champ.geo_areas.create(
|
||||
source: GeoArea.sources.fetch(:quartier_prioritaire),
|
||||
geometry: qp.geometry,
|
||||
code: qp.code,
|
||||
nom: qp.nom,
|
||||
commune: qp.commune
|
||||
)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
procedure.module_api_carto.update(migrated: true)
|
||||
end
|
||||
|
||||
Procedure.includes(:types_de_champ, dossiers: [:cadastres, :quartier_prioritaires])
|
||||
.joins(:module_api_carto)
|
||||
.where(module_api_cartos: { use_api_carto: true, migrated: nil })
|
||||
.find_each do |procedure|
|
||||
add_champ_carte_if_needed(procedure)
|
||||
end
|
||||
|
||||
AfterParty::TaskRecord.create version: '20181030155307'
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue