1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-18 07:52:23 +01:00

extend subscription and offer free days will keep track of previous subscription

This commit is contained in:
Sylvain 2018-12-10 13:24:00 +01:00
parent bef3118649
commit 8e60545753
9 changed files with 78 additions and 42 deletions

View File

@ -34,6 +34,8 @@ group :development, :test do
gem 'spring'
gem 'railroady'
gem 'rubocop', '~> 0.61.1', require: false
end
group :development do

View File

@ -59,6 +59,7 @@ GEM
apipie-rails (0.3.6)
json
arel (6.0.4)
ast (2.4.0)
autoprefixer-rails (5.1.8)
execjs
json
@ -211,6 +212,7 @@ GEM
i18n (0.9.1)
concurrent-ruby (~> 1.0)
ice_nine (0.11.2)
jaro_winkler (1.5.1)
jbuilder (2.5.0)
activesupport (>= 3.0.0, < 5.1)
multi_json (~> 1.2)
@ -289,6 +291,9 @@ GEM
openlab_ruby (0.0.4)
httparty (~> 0.13)
orm_adapter (0.5.0)
parallel (1.12.1)
parser (2.5.3.0)
ast (~> 2.4.0)
pdf-core (0.5.1)
pdf-reader (1.4.0)
Ascii85 (~> 1.0.0)
@ -297,6 +302,7 @@ GEM
ruby-rc4
ttfunk
pg (0.18.1)
powerpack (0.1.2)
prawn (2.0.1)
pdf-core (~> 0.5.1)
ttfunk (~> 1.4.0)
@ -344,6 +350,7 @@ GEM
activesupport (= 4.2.10)
rake (>= 0.8.7)
thor (>= 0.18.1, < 2.0)
rainbow (3.0.0)
raindrops (0.13.0)
rake (12.2.1)
rb-fsevent (0.9.4)
@ -364,6 +371,14 @@ GEM
mime-types (>= 1.16, < 3.0)
netrc (~> 0.7)
rolify (4.0.0)
rubocop (0.61.1)
jaro_winkler (~> 1.5.1)
parallel (~> 1.10)
parser (>= 2.5, != 2.5.1.1)
powerpack (~> 0.1)
rainbow (>= 2.2.2, < 4.0)
ruby-progressbar (~> 1.7)
unicode-display_width (~> 1.4.0)
ruby-progressbar (1.7.5)
ruby-rc4 (0.1.5)
rubyzip (1.2.2)
@ -465,6 +480,7 @@ GEM
unf (0.1.4)
unf_ext
unf_ext (0.0.6)
unicode-display_width (1.4.0)
unicorn (4.8.3)
kgio (~> 2.6)
rack
@ -549,6 +565,7 @@ DEPENDENCIES
recurrence
responders (~> 2.0)
rolify
rubocop (~> 0.61.1)
rubyzip (>= 1.2.2)
rvm-capistrano
sass-rails (= 5.0.1)

View File

@ -48,7 +48,7 @@ class API::MembersController < API::ApiController
end
if @member.save
@member.generate_admin_invoice
@member.generate_subscription_invoice
@member.send_confirmation_instructions
if !user_params[:password] and !user_params[:password_confirmation]
UsersMailer.delay.notify_user_account_created(@member, generated_password)

View File

@ -16,7 +16,7 @@ class API::SubscriptionsController < API::ApiController
user_id = current_user.is_admin? ? subscription_params[:user_id] : current_user.id
@subscription = Subscription.new(subscription_params)
is_subscribe = Subscribe.new(method, user_id).pay_and_save(@subscription, coupon_params[:coupon_code], true)
is_subscribe = Subscribe.new(user_id).pay_and_save(@subscription, method, coupon_params[:coupon_code], true)
if is_subscribe
render :show, status: :created, location: @subscription
@ -29,11 +29,10 @@ class API::SubscriptionsController < API::ApiController
def update
authorize @subscription
free_days = params[:subscription][:free] == true
free_days = params[:subscription][:free] || false
if @subscription.extend_expired_date(subscription_update_params[:expired_at], free_days)
ex_expired_at = @subscription.previous_changes[:expired_at].first
@subscription.user.generate_admin_invoice(free_days, ex_expired_at)
if Subscribe.new(@subscription.user_id)
.extend_subscription(@subscription, subscription_update_params[:expired_at], free_days)
render status: :ok
else
render status: :unprocessable_entity

View File

@ -35,7 +35,7 @@ class Subscription < ActiveRecord::Base
discount = 0
if @coupon.type == 'percent_off'
discount = (total * @coupon.percent_off / 100).to_i
discount = (total * @coupon.percent_off / 100).to_i
elsif @coupon.type == 'amount_off'
discount = @coupon.amount_off
else
@ -65,28 +65,24 @@ class Subscription < ActiveRecord::Base
end
new_subscription = customer.subscriptions.create(plan: plan.stp_plan_id, source: card_token)
# very important to set expired_at to nil that can allow method is_new? to return true
# for send the notification
# TODO: Refactoring
update_column(:expired_at, nil) unless new_record?
self.stp_subscription_id = new_subscription.id
self.canceled_at = nil
self.expired_at = Time.at(new_subscription.current_period_end)
save!
UsersCredits::Manager.new(user: self.user).reset_credits if expired_date_changed
UsersCredits::Manager.new(user: user).reset_credits if expired_date_changed
# generate invoice
stp_invoice = Stripe::Invoice.all(customer: user.stp_customer_id, limit: 1).data.first
if invoice
invoc = generate_invoice(stp_invoice.id, coupon_code)
db_invoice = generate_invoice(stp_invoice.id, coupon_code)
# debit wallet
wallet_transaction = debit_user_wallet
if wallet_transaction
invoc.wallet_amount = @wallet_amount_debit
invoc.wallet_transaction_id = wallet_transaction.id
db_invoice.wallet_amount = @wallet_amount_debit
db_invoice.wallet_transaction_id = wallet_transaction.id
end
invoc.save
db_invoice.save
end
# cancel subscription after create
cancel
@ -122,7 +118,7 @@ class Subscription < ActiveRecord::Base
logger.error e
errors[:payment] << e.message
return false
rescue => e
rescue StandardError => e
clear_wallet_and_goupon_invoice_items(invoice_items)
# Something else happened, completely unrelated to Stripe
logger.error e
@ -179,13 +175,6 @@ class Subscription < ActiveRecord::Base
generate_invoice(stp_invoice_id).save
end
def generate_and_save_offer_day_invoice(offer_day_start_at)
od = offer_days.create(start_at: offer_day_start_at, end_at: expired_at)
invoice = Invoice.new(invoiced_id: od.id, invoiced_type: 'OfferDay', user: user, total: 0)
invoice.invoice_items.push InvoiceItem.new(amount: 0, description: plan.name, subscription_id: self.id)
invoice.save
end
def cancel
return unless stp_subscription_id.present?
@ -213,13 +202,23 @@ class Subscription < ActiveRecord::Base
expired_at <= Time.now
end
def extend_expired_date(expired_at, free_days = false)
return false if expired_at <= self.expired_at
def expired_at
last_offered = offer_days.order(:end_at).last
return last_offered.end_at if last_offered
expiration_date
end
def free_extend(expiration)
return false if expiration <= expired_at
od = offer_days.create(start_at: expired_at, end_at: expiration)
invoice = Invoice.new(invoiced_id: od.id, invoiced_type: 'OfferDay', user: user, total: 0)
invoice.invoice_items.push InvoiceItem.new(amount: 0, description: plan.name, subscription_id: id)
invoice.save
self.expired_at = expired_at
if save
UsersCredits::Manager.new(user: user).reset_credits unless free_days
notify_subscription_extended(free_days)
notify_subscription_extended(true)
return true
end
false

View File

@ -104,7 +104,7 @@ class User < ActiveRecord::Base
end
def subscription
subscriptions.last
subscriptions.order(:created_at).last
end
def is_admin?
@ -119,14 +119,10 @@ class User < ActiveRecord::Base
my_projects.to_a.concat projects
end
def generate_admin_invoice(offer_day = false, offer_day_start_at = nil)
def generate_subscription_invoice
return unless subscription
if offer_day
subscription.generate_and_save_offer_day_invoice(offer_day_start_at) unless invoicing_disabled?
else
subscription.generate_and_save_invoice unless invoicing_disabled?
end
subscription.generate_and_save_invoice unless invoicing_disabled?
end
def stripe_customer

View File

@ -1,12 +1,11 @@
class Subscribe
attr_accessor :payment_method, :user_id
attr_accessor :user_id
def initialize(payment_method, user_id)
@payment_method = payment_method
def initialize(user_id)
@user_id = user_id
end
def pay_and_save(subscription, coupon, invoice)
def pay_and_save(subscription, payment_method, coupon, invoice)
subscription.user_id = user_id
if payment_method == :local
subscription.save_with_local_payment(invoice, coupon)
@ -14,4 +13,19 @@ class Subscribe
subscription.save_with_payment(invoice, coupon)
end
end
def extend_subscription(subscription, new_expiration_date, free_days)
return subscription.free_extend(new_expiration_date) if free_days
new_sub = Subscription.create(
plan_id: subscription.plan_id,
user_id: subscription.user_id,
expiration_date: new_expiration_date
)
if new_sub.save
new_sub.user.generate_subscription_invoice
return true
end
false
end
end

View File

@ -0,0 +1,9 @@
class RenameExpiredAtToExpirationDateFromSubscription < ActiveRecord::Migration
def up
rename_column :subscriptions, :expired_at, :expiration_date
end
def down
rename_column :subscriptions, :expiration_date, :expired_at
end
end

View File

@ -11,7 +11,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 20171011125217) do
ActiveRecord::Schema.define(version: 20181210105917) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@ -667,7 +667,7 @@ ActiveRecord::Schema.define(version: 20171011125217) do
t.string "stp_subscription_id"
t.datetime "created_at"
t.datetime "updated_at"
t.datetime "expired_at"
t.datetime "expiration_date"
t.datetime "canceled_at"
end