Skip to content

Commit

Permalink
feat: Bump awesome and add rake task for migration
Browse files Browse the repository at this point in the history
  • Loading branch information
Quentinchampenois committed Mar 21, 2024
1 parent d2923c0 commit 99310f9
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 1 deletion.
2 changes: 1 addition & 1 deletion Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ GIT

GIT
remote: https://github.com/octree-gva/decidim-module-decidim_awesome.git
revision: 21ce064a26837ba43835621ddb6f6773b14c59e8
revision: afa824a79faa42f99eee5c0dcb4944e3a78b4a1d
branch: feat/awesome_decidim_private_fields
specs:
decidim-decidim_awesome (0.9.2)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# frozen_string_literal: true
# This migration comes from decidim_decidim_awesome (originally 20230309124413)

class CreatePrivateProposalFields < ActiveRecord::Migration[5.2]
def up
create_table :decidim_awesome_private_proposal_fields do |t|
t.text :private_body, default: '<xml></xml>'

t.references :proposal, null: false, foreign_key: { to_table: :decidim_proposals_proposals }, index: { name: "decidim_awesome_private_proposal_fields_idx" }
t.timestamps
end
end
end
31 changes: 31 additions & 0 deletions lib/tasks/repair_data.rake
Original file line number Diff line number Diff line change
Expand Up @@ -51,4 +51,35 @@ namespace :decidim do
end
end
end

namespace :awesome do
desc "Migrate private fields from old proposals to new ones"
task private_fields: :environment do
Rails.logger.info("Migrating private fields from old proposals to new ones")

proposals = Decidim::Proposals::Proposal.where(
"private_body != ? AND private_body != ?",
"<xml></xml>", "{}"
).pluck(:id, :private_body)

Rails.logger.info("Preparing to migrate #{proposals.count} proposals")
creations = proposals.map do |proposal_id, private_body|
creation = Decidim::DecidimAwesome::PrivateProposalField.create(
proposal_id: proposal_id,
private_body: private_body
)

[proposal_id, creation]
end

if creations.any? { |_, creation| creation.invalid? }
proposal_ids = creations.select { |ary| ary.last.invalid? }.map(&:first)
Rails.logger.error("Failed to migrate #{proposal_ids.count} proposals")
Rails.logger.error("Failed proposals ID : #{proposal_ids.join(", ")}")
return
end

Rails.logger.info("Migrated #{creations.count} proposals")
end
end
end

0 comments on commit 99310f9

Please sign in to comment.