2019-02-13 12:59:28 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# Stripe relative tasks
|
|
|
|
namespace :fablab do
|
|
|
|
namespace :stripe do
|
|
|
|
|
|
|
|
desc 'find any invoices with incoherent total between stripe and DB'
|
|
|
|
task :find_incoherent_invoices, [:start_date] => :environment do |_task, args|
|
2019-09-10 16:45:45 +02:00
|
|
|
puts 'DEPRECATION WARNING: Will not work for invoices created from version 4.1.0 and above'
|
2019-02-13 12:59:28 +01:00
|
|
|
date = Date.parse('2017-05-01')
|
|
|
|
if args.start_date
|
|
|
|
begin
|
|
|
|
date = Date.parse(args.start_date)
|
|
|
|
rescue ArgumentError => e
|
|
|
|
raise e
|
|
|
|
end
|
|
|
|
end
|
|
|
|
Invoice.where('created_at > ? AND stp_invoice_id IS NOT NULL', date).each do |invoice|
|
2020-08-26 11:35:27 +02:00
|
|
|
stp_invoice = Stripe::Invoice.retrieve(invoice.stp_invoice_id, api_key: Setting.get('stripe_secret_key'))
|
2019-02-13 12:59:28 +01:00
|
|
|
next if invoice.amount_paid == stp_invoice.total
|
|
|
|
|
|
|
|
puts "Id: #{invoice.id}, reference: #{invoice.reference}, stripe id: #{stp_invoice.id}, " \
|
|
|
|
"invoice total: #{invoice.amount_paid / 100.0}, stripe invoice total: #{stp_invoice.total / 100.0}, " \
|
|
|
|
"date: #{invoice.created_at}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
desc 'clean stripe secrets from VCR cassettes'
|
|
|
|
task clean_cassettes_secrets: :environment do
|
|
|
|
Dir['test/vcr_cassettes/*.yml'].each do |cassette_file|
|
|
|
|
cassette = File.read(cassette_file)
|
2020-06-10 11:33:03 +02:00
|
|
|
cassette = cassette.gsub(Setting.get('stripe_secret_key'), 'sk_test_testfaketestfaketestfake')
|
2020-06-10 11:02:30 +02:00
|
|
|
cassette = cassette.gsub(Setting.get('stripe_public_key'), 'pk_test_faketestfaketestfaketest')
|
2019-02-13 12:59:28 +01:00
|
|
|
puts cassette
|
|
|
|
File.write(cassette_file, cassette)
|
|
|
|
end
|
|
|
|
end
|
2019-12-03 16:32:59 +01:00
|
|
|
|
|
|
|
desc 'sync users to the stripe database'
|
|
|
|
task sync_members: :environment do
|
2020-04-29 10:57:32 +02:00
|
|
|
puts 'We create all non-existing customers on stripe. This may take a while, please wait...'
|
2020-07-01 16:26:59 +02:00
|
|
|
SyncMembersOnStripeWorker.new.perform
|
2020-04-29 10:57:32 +02:00
|
|
|
puts 'Done'
|
|
|
|
end
|
2021-02-23 14:42:48 +01:00
|
|
|
desc 'sync coupons to the stripe database'
|
|
|
|
task sync_coupons: :environment do
|
|
|
|
puts 'We create all non-existing coupons on stripe. This may take a while, please wait...'
|
|
|
|
Coupon.all.each do |c|
|
|
|
|
Stripe::Coupon.retrieve(c.code, api_key: Setting.get('stripe_secret_key'))
|
|
|
|
rescue Stripe::InvalidRequestError
|
|
|
|
StripeService.create_stripe_coupon(c.id)
|
|
|
|
end
|
|
|
|
puts 'Done'
|
|
|
|
end
|
2020-04-29 10:57:32 +02:00
|
|
|
|
2020-11-12 12:14:51 +01:00
|
|
|
desc 'set stp_product_id to all plans/machines/trainings/spaces'
|
|
|
|
task set_product_id: :environment do
|
2020-10-27 16:46:38 +01:00
|
|
|
w = StripeWorker.new
|
|
|
|
Plan.all.each do |p|
|
2020-11-12 12:14:51 +01:00
|
|
|
w.perform(:create_or_update_stp_product, Plan.name, p.id)
|
|
|
|
end
|
|
|
|
Machine.all.each do |m|
|
|
|
|
w.perform(:create_or_update_stp_product, Machine.name, m.id)
|
|
|
|
end
|
|
|
|
Training.all.each do |t|
|
|
|
|
w.perform(:create_or_update_stp_product, Training.name, t.id)
|
|
|
|
end
|
|
|
|
Space.all.each do |s|
|
|
|
|
w.perform(:create_or_update_stp_product, Space.name, s.id)
|
2020-10-27 16:46:38 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-03-03 15:28:56 +01:00
|
|
|
desc 'set stripe as the default payment gateway'
|
|
|
|
task set_gateway: :environment do
|
|
|
|
if Setting.find_by(name: 'stripe_public_key').try(:value) && Setting.find_by(name: 'stripe_secret_key').try(:value)
|
|
|
|
Setting.set('payment_gateway', 'stripe') unless Setting.find_by(name: 'payment_gateway').try(:value)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-29 10:57:32 +02:00
|
|
|
def print_on_line(str)
|
|
|
|
print "#{str}\r"
|
|
|
|
$stdout.flush
|
2019-12-03 16:32:59 +01:00
|
|
|
end
|
2019-02-13 12:59:28 +01:00
|
|
|
end
|
|
|
|
end
|