mirror of
https://github.com/internetee/registry.git
synced 2025-06-06 04:37:30 +02:00
60 lines
2 KiB
Ruby
60 lines
2 KiB
Ruby
namespace :invoices do
|
|
task process_payments: :environment do
|
|
registry_bank_account_iban = Setting.registry_iban
|
|
|
|
keystore = OpenSSL::PKCS12.new(File.read(ENV['lhv_p12_keystore']), ENV['lhv_keystore_password'])
|
|
key = keystore.key
|
|
cert = keystore.certificate
|
|
|
|
api = Lhv::ConnectApi.new
|
|
api.cert = cert
|
|
api.key = key
|
|
api.ca_file = ENV['lhv_ca_file']
|
|
api.dev_mode = ENV['lhv_dev_mode'] == 'true'
|
|
|
|
incoming_transactions = []
|
|
|
|
api.credit_debit_notification_messages.each do |message|
|
|
next unless message.bank_account_iban == registry_bank_account_iban
|
|
|
|
message.credit_transactions.each do |credit_transaction|
|
|
incoming_transactions << credit_transaction
|
|
end
|
|
end
|
|
|
|
if incoming_transactions.any?
|
|
log 'Got incoming transactions'
|
|
log incoming_transactions
|
|
|
|
bank_statement = BankStatement.new(bank_code: Setting.registry_bank_code,
|
|
iban: Setting.registry_iban)
|
|
|
|
ActiveRecord::Base.transaction do
|
|
bank_statement.save!
|
|
|
|
incoming_transactions.each do |incoming_transaction|
|
|
transaction_attributes = { sum: incoming_transaction.amount,
|
|
currency: incoming_transaction.currency,
|
|
paid_at: incoming_transaction.date,
|
|
reference_no: incoming_transaction.payment_reference_number,
|
|
description: incoming_transaction.payment_description }
|
|
transaction = bank_statement.bank_transactions.create!(transaction_attributes)
|
|
|
|
unless transaction.non_canceled?
|
|
Invoice.create_from_transaction!(transaction) unless transaction.autobindable?
|
|
transaction.autobind_invoice
|
|
end
|
|
end
|
|
end
|
|
else
|
|
log 'Got no incoming transactions parsed, aborting'
|
|
end
|
|
|
|
puts "Transactions processed: #{incoming_transactions.size}"
|
|
end
|
|
|
|
def log(msg)
|
|
@log ||= Logger.new(STDOUT)
|
|
@log.info(msg)
|
|
end
|
|
end
|