Add afterparty task to create experts from instructeurs after deploy
This commit is contained in:
parent
2987139dd6
commit
b39d9d41f0
2 changed files with 29 additions and 1 deletions
|
@ -10,7 +10,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(version: 2021_01_13_084256) do
|
ActiveRecord::Schema.define(version: 2021_01_20_084256) do
|
||||||
|
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "plpgsql"
|
enable_extension "plpgsql"
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
namespace :after_party do
|
||||||
|
desc 'Deployment task: backfill_expert_id_on_avis_table'
|
||||||
|
task backfill_experts_procedure_id_on_avis_table: :environment do
|
||||||
|
puts "Running deploy task 'backfill_expert_id_on_avis_table'"
|
||||||
|
# rubocop:disable DS/Unscoped
|
||||||
|
# rubocop:disable Rails/PluckInWhere
|
||||||
|
|
||||||
|
Instructeur.includes(:user)
|
||||||
|
.where(id: Avis.unscoped.pluck(:instructeur_id))
|
||||||
|
.where.not(users: { instructeur_id: nil })
|
||||||
|
.find_each do |instructeur|
|
||||||
|
user = instructeur.user
|
||||||
|
User.create_or_promote_to_expert(user.email, SecureRandom.hex)
|
||||||
|
user.reload
|
||||||
|
# rubocop:enable DS/Unscoped
|
||||||
|
# rubocop:enable Rails/PluckInWhere
|
||||||
|
instructeur.avis.each do |avis|
|
||||||
|
experts_procedure = ExpertsProcedure.find_or_create_by(expert: user.expert, procedure: avis.procedure)
|
||||||
|
avis.update_column(:experts_procedure_id, experts_procedure.id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Update task as completed. If you remove the line below, the task will
|
||||||
|
# run with every deploy (or every time you call after_party:run).
|
||||||
|
AfterParty::TaskRecord
|
||||||
|
.create version: AfterParty::TaskRecorder.new(__FILE__).timestamp
|
||||||
|
end
|
||||||
|
end
|
Loading…
Add table
Reference in a new issue