2023-03-23 09:33:43 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
namespace :fablab do
|
2023-03-24 17:21:44 +01:00
|
|
|
desc 'Fill the holes in the logical sequence of invoices references'
|
2023-03-23 09:33:43 +01:00
|
|
|
task fix_references: :environment do |_task, _args|
|
|
|
|
include ActionView::Helpers::NumberHelper
|
2023-03-27 17:18:44 +02:00
|
|
|
include DbHelper
|
2023-03-23 09:33:43 +01:00
|
|
|
|
|
|
|
user = User.adminsys || User.admins.first
|
|
|
|
|
|
|
|
ActiveRecord::Base.transaction do
|
|
|
|
missing_references = {}
|
|
|
|
|
|
|
|
# browse invoices to list missing reference
|
2023-03-27 17:18:44 +02:00
|
|
|
puts 'Computing missing references...'
|
2023-03-23 09:33:43 +01:00
|
|
|
not_closed(Invoice).order(created_at: :desc).each do |invoice|
|
|
|
|
number = Invoices::NumberService.number(invoice)
|
|
|
|
next if number == 1
|
|
|
|
|
2023-03-27 17:18:44 +02:00
|
|
|
previous = Invoice.where('created_at < :date', date: db_time(invoice.created_at))
|
|
|
|
.order(created_at: :desc)
|
|
|
|
.limit(1)
|
|
|
|
.first
|
|
|
|
previous_number = Invoices::NumberService.number(previous)
|
|
|
|
next if previous_number.nil? || previous_number == number - 1
|
2023-03-23 09:33:43 +01:00
|
|
|
|
|
|
|
missing_references[invoice.created_at] ||= []
|
2023-03-27 17:18:44 +02:00
|
|
|
|
|
|
|
# ignore numbers of already existing invoices
|
|
|
|
(previous_number + 1...number).to_a.each do |num|
|
|
|
|
next unless Invoices::NumberService.find_by_number(num, date: invoice.created_at).nil?
|
|
|
|
|
|
|
|
missing_references[invoice.created_at].push(num)
|
|
|
|
end
|
2023-03-23 09:33:43 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
# create placeholder invoices for found missing references
|
2023-03-27 17:18:44 +02:00
|
|
|
puts 'Creating missing invoices...'
|
|
|
|
total = missing_references.values.filter(&:present?).flatten.count
|
|
|
|
counter = 1
|
|
|
|
missing_references.each_pair do |date, numbers|
|
|
|
|
numbers.reverse_each.with_index do |number, index|
|
|
|
|
puts "#{counter} / #{total}"
|
|
|
|
invoice = Invoice.new(
|
2023-03-23 09:33:43 +01:00
|
|
|
total: 0,
|
|
|
|
invoicing_profile: user.invoicing_profile,
|
|
|
|
statistic_profile: user.statistic_profile,
|
|
|
|
operator_profile: user.invoicing_profile,
|
|
|
|
payment_method: '',
|
|
|
|
created_at: date - (index + 1).seconds,
|
|
|
|
invoice_items_attributes: [{
|
|
|
|
amount: 0,
|
2023-03-27 17:18:44 +02:00
|
|
|
description: I18n.t('invoices.null_invoice'),
|
2023-03-23 09:33:43 +01:00
|
|
|
object_type: 'Error',
|
|
|
|
object_id: 1,
|
|
|
|
main: true
|
|
|
|
}]
|
|
|
|
)
|
2023-03-27 17:18:44 +02:00
|
|
|
invoice.reference = PaymentDocumentService.generate_numbered_reference(number, invoice)
|
|
|
|
invoice.save!
|
|
|
|
counter += 1
|
2023-03-23 09:33:43 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# @param klass [Class]
|
|
|
|
# @return [ActiveRecord::Relation<klass>,Class]
|
|
|
|
def not_closed(klass)
|
|
|
|
if AccountingPeriod.count.positive?
|
|
|
|
last_period = AccountingPeriod.order(start_at: :desc).first
|
|
|
|
klass.where('created_at > ?', last_period.end_at)
|
|
|
|
else
|
|
|
|
klass
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|