2021-05-31 12:53:28 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
namespace :fablab do
|
|
|
|
namespace :chain do
|
|
|
|
desc 'assign all footprints to existing records'
|
2021-06-28 08:38:48 +02:00
|
|
|
task :all, [:force] => :environment do |_task, args|
|
2023-09-29 14:33:50 +02:00
|
|
|
if args.force != 'force'
|
2021-05-31 12:53:28 +02:00
|
|
|
print 'All footprints will be regenerated. Are you sure? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_invoices
|
|
|
|
chain_invoice_items
|
|
|
|
chain_history_values
|
|
|
|
chain_payment_schedules
|
|
|
|
chain_payment_schedules_items
|
|
|
|
chain_payment_schedules_objects if ActiveRecord::Base.connection.table_exists? PaymentScheduleObject.arel_table
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'assign all footprints to existing Invoice records'
|
|
|
|
task invoices: :environment do
|
|
|
|
if Invoice.where.not(footprint: nil).count.positive?
|
|
|
|
print 'WARNING: Footprints were already generated. Regenerate? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_invoices
|
|
|
|
end
|
|
|
|
|
|
|
|
def chain_invoices
|
|
|
|
if AccountingPeriod.count.positive?
|
|
|
|
last_period = AccountingPeriod.order(start_at: :desc).first
|
|
|
|
puts "Regenerating from #{last_period.end_at}..."
|
2023-03-22 17:01:46 +01:00
|
|
|
Invoice.where('created_at > ?', last_period.end_at).order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
else
|
|
|
|
puts '(Re)generating all footprint...'
|
2023-03-22 17:01:46 +01:00
|
|
|
Invoice.order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'assign all footprints to existing InvoiceItem records'
|
|
|
|
task invoices_items: :environment do
|
|
|
|
if InvoiceItem.where.not(footprint: nil).count.positive?
|
|
|
|
print 'WARNING: Footprints were already generated. Regenerate? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_invoice_items
|
|
|
|
end
|
|
|
|
|
|
|
|
def chain_invoice_items
|
|
|
|
if AccountingPeriod.count.positive?
|
|
|
|
last_period = AccountingPeriod.order(start_at: :desc).first
|
|
|
|
puts "Regenerating from #{last_period.end_at}..."
|
2023-03-22 17:01:46 +01:00
|
|
|
InvoiceItem.where('created_at > ?', last_period.end_at).order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
else
|
|
|
|
puts '(Re)generating all footprint...'
|
2023-03-22 17:01:46 +01:00
|
|
|
InvoiceItem.order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'assign all footprints to existing HistoryValue records'
|
|
|
|
task history_values: :environment do
|
|
|
|
if HistoryValue.where.not(footprint: nil).count.positive?
|
|
|
|
print 'WARNING: Footprints were already generated. Regenerate? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_history_values
|
|
|
|
end
|
|
|
|
|
|
|
|
def chain_history_values
|
2023-03-22 17:01:46 +01:00
|
|
|
HistoryValue.order(:created_at).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'assign all footprints to existing PaymentSchedule records'
|
|
|
|
task payment_schedule: :environment do
|
|
|
|
if PaymentSchedule.where.not(footprint: nil).count.positive?
|
|
|
|
print 'WARNING: Footprints were already generated. Regenerate? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_payment_schedules
|
|
|
|
end
|
|
|
|
|
|
|
|
def chain_payment_schedules
|
|
|
|
if AccountingPeriod.count.positive?
|
|
|
|
last_period = AccountingPeriod.order(start_at: :desc).first
|
|
|
|
puts "Regenerating from #{last_period.end_at}..."
|
2023-03-22 17:01:46 +01:00
|
|
|
PaymentSchedule.where('created_at > ?', last_period.end_at).order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
else
|
|
|
|
puts '(Re)generating all footprint...'
|
2023-03-22 17:01:46 +01:00
|
|
|
PaymentSchedule.order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'assign all footprints to existing PaymentScheduleItem records'
|
|
|
|
task payment_schedule_item: :environment do
|
|
|
|
if PaymentScheduleItem.where.not(footprint: nil).count.positive?
|
|
|
|
print 'WARNING: Footprints were already generated. Regenerate? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_payment_schedules_items
|
|
|
|
end
|
|
|
|
|
|
|
|
def chain_payment_schedules_items
|
|
|
|
if AccountingPeriod.count.positive?
|
|
|
|
last_period = AccountingPeriod.order(start_at: :desc).first
|
|
|
|
puts "Regenerating from #{last_period.end_at}..."
|
2023-03-22 17:01:46 +01:00
|
|
|
PaymentScheduleItem.where('created_at > ?', last_period.end_at).order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
else
|
|
|
|
puts '(Re)generating all footprint...'
|
2023-03-22 17:01:46 +01:00
|
|
|
PaymentScheduleItem.order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'assign all footprints to existing PaymentScheduleObject records'
|
|
|
|
task payment_schedule_object: :environment do
|
|
|
|
if PaymentScheduleObject.where.not(footprint: nil).count.positive?
|
|
|
|
print 'WARNING: Footprints were already generated. Regenerate? (y/n) '
|
2023-03-22 17:01:46 +01:00
|
|
|
confirm = $stdin.gets.chomp
|
2021-05-31 12:53:28 +02:00
|
|
|
next unless confirm == 'y'
|
|
|
|
end
|
|
|
|
chain_payment_schedules_objects
|
|
|
|
end
|
|
|
|
|
|
|
|
def chain_payment_schedules_objects
|
|
|
|
if AccountingPeriod.count.positive?
|
|
|
|
last_period = AccountingPeriod.order(start_at: :desc).first
|
|
|
|
puts "Regenerating from #{last_period.end_at}..."
|
2023-03-22 17:01:46 +01:00
|
|
|
PaymentScheduleObject.where('created_at > ?', last_period.end_at).order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
else
|
|
|
|
puts '(Re)generating all footprint...'
|
2023-03-22 17:01:46 +01:00
|
|
|
PaymentScheduleObject.order(:id).find_each(&:chain_record)
|
2021-05-31 12:53:28 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|