2016-05-04 18:17:50 +02:00
|
|
|
namespace :fablab do
|
|
|
|
namespace :fix do
|
|
|
|
task reservations_not_existing_reservable: :environment do
|
|
|
|
ActiveRecord::Base.logger = Logger.new(STDOUT)
|
|
|
|
ActiveRecord::Base.connection.execute(
|
|
|
|
'UPDATE reservations SET reservable_type = NULL, reservable_id = NULL'\
|
|
|
|
' WHERE NOT EXISTS (SELECT 1 FROM events WHERE events.id = reservations.reservable_id)'\
|
|
|
|
' AND reservations.reservable_type = \'Event\''
|
|
|
|
)
|
|
|
|
end
|
2016-08-11 11:07:49 +02:00
|
|
|
|
|
|
|
task assign_category_to_uncategorized_events: :environment do
|
|
|
|
c = Category.find_or_create_by!({name: 'No category'})
|
|
|
|
Event.where(category: nil).each do |e|
|
|
|
|
e.category = c
|
|
|
|
e.save!
|
|
|
|
end
|
|
|
|
end
|
2017-03-15 12:50:19 +01:00
|
|
|
|
|
|
|
task rolling_plans: :environment do
|
|
|
|
Plan.where(is_rolling: nil).each do |p|
|
|
|
|
if p.is_rolling.nil? and p.is_rolling != false
|
|
|
|
p.is_rolling = true
|
|
|
|
p.save!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-03-21 15:47:25 +01:00
|
|
|
|
|
|
|
task new_plans_statistics: :environment do
|
|
|
|
StatisticSubType.where(key: nil).each do |sst|
|
|
|
|
p = Plan.find_by(name: sst.label)
|
|
|
|
if p
|
|
|
|
sst.key = p.slug
|
|
|
|
sst.save!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-05-15 15:25:27 +02:00
|
|
|
|
|
|
|
task new_group_space_prices: :environment do
|
|
|
|
Space.all.each do |space|
|
|
|
|
Group.all.each do |group|
|
|
|
|
begin
|
|
|
|
Price.find(priceable: space, group: group)
|
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
|
Price.create(priceable: space, group: group, amount: 0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-08-30 14:57:06 +02:00
|
|
|
|
|
|
|
task migrate_admins_group: :environment do
|
|
|
|
admins = Group.find_by(slug: 'admins')
|
|
|
|
User.all.each do |user|
|
|
|
|
if user.is_admin?
|
|
|
|
user.group = admins
|
|
|
|
user.save!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-05-04 18:17:50 +02:00
|
|
|
end
|
|
|
|
end
|