调用操作后将列更新为NULL

时间:2014-03-14 19:19:50

标签: ruby-on-rails

我的应用程序上设置了Stripe,用户可以取消或升级他们的订阅。它与Stripe完美通信。我需要帮助弄清楚如何让更改与我的数据库进行通信。

如果用户取消订阅,则应在cancelled列下的订阅表中进行标记。如果在数据库中显示其订阅被取消,则用户将被限制访问网站。

我不知道如何将其添加到我设置的取消订阅操作中。

非常感谢您的帮助!

订阅控制器:

  def new
    plan = Plan.find(params[:plan_id])
    @subscription = plan.subscriptions.build
    if params[:PayerID]
      @subscription.paypal_customer_token = params[:PayerID]
      @subscription.paypal_payment_token = params[:token]
      @subscription.email = @subscription.paypal.checkout_details.email
    end
  end

  def create
    @subscription = Subscription.new(params[:subscription])
    if @subscription.save_with_payment
      redirect_to @subscription, :notice => "Thank you for subscribing!"
    else
      render :new
    end
  end

  def show
    @subscription = Subscription.find(params[:id])
  end

    def updatesubscription
      @user = current_user
      @customer = Stripe::Customer.retrieve(@user.subscription.stripe_customer_token)
      @customer.update_subscription(:plan => "1", :prorate => true)
     current_user.save!
      flash.alert = 'Your subscription has been updated!'
      redirect_to root_url
     end

     def cancelsubscription
       @user = current_user
         @customer = Stripe::Customer.retrieve(@user.subscription.stripe_customer_token)
         @customer.cancel_subscription()
         current_user.save!
         flash.alert = 'Your subscription has been cancelled successfully!'
         redirect_to root_url
       end

       def showcard
         @user = current_user
         Stripe::Customer.retrieve(@user.subscription.stripe_customer_token).cards.all()
       end

       def changecard
           @user = current_user       
           @customer = Stripe::Customer.retrieve(@user.subscription.stripe_customer_token)

             card = @customer.cards.create({
               :card => @user.subscription.stripe_customer_token
             })

             @customer.default_card = card
             @customer.save
           end
end

订阅模式:

  belongs_to :plan
  belongs_to :subscription
  belongs_to :user

  validates_presence_of :plan_id
  validates_presence_of :email

  attr_accessor :stripe_card_token, :paypal_payment_token

  def save_with_payment
    if valid?
      if paypal_payment_token.present?
        save_with_paypal_payment
      else
        save_with_stripe_payment
      end
    end
  end

  def paypal
    PaypalPayment.new(self)
  end

  def save_with_paypal_payment
    response = paypal.make_recurring
    self.paypal_recurring_profile_token = response.profile_id
    save!
  end

  def save_with_stripe_payment
    customer = Stripe::Customer.create(description: email, plan: plan_id, card: stripe_card_token)
    self.stripe_customer_token = customer.id
    save!
  rescue Stripe::InvalidRequestError => e
    logger.error "Stripe error while creating customer: #{e.message}"
    errors.add :base, "There was a problem with your credit card."
    false
  end

  def payment_provided?
    stripe_card_token.present? || paypal_payment_token.present?
  end

  def suspend_paypal
    paypal.suspend
    save
  end


  def reactivate_paypal
    paypal.reactivate
    save
  end
end

2 个答案:

答案 0 :(得分:2)

最简单的方法是添加额外的行来更新所需的列。

def cancelsubscription
  @user = current_user
  @customer = Stripe::Customer.retrieve(@user.subscription.stripe_customer_token)
  @customer.cancel_subscription()
  current_user.subscription.update_attributes(:cancelled => 1)
  current_user.save!
  flash.alert = 'Your subscription has been cancelled successfully!'
  redirect_to root_url
end

然而,理想情况下,所有这些都应该在模型中发生。从控制器中你应该告诉模型取消订阅。

所以,这种方法可能会变成:

#subscriptions_controller.rb
def cancelsubscription
  current_user.subscription.cancel_stripe_subscription
  flash.alert = 'Your subscription has been cancelled successfully!'
  redirect_to root_url
end

#subscription.rb model
def cancel_stripe_subscription
  customer = Stripe::Customer.retrieve(self.stripe_customer_token)
  customer.cancel_subscription()
  self.cancelled = 1
  self.save!
end

答案 1 :(得分:1)

您是否可以通过active_record查询更新Subscription表?像这样:

updateQuery = ActiveRecord::Base.connection.execute("UPDATE Subscription SET cancelled = 'Cancelled' WHERE user_id = #{@user.id}")

这会更新您的订阅表并将目标字段值更改为“已取消”。不清楚这是否是一个布尔值。如果是,则该值应为“TRUE”而不是我放入的“已取消”字符串。

如果订阅成功保存,则执行查询。但是你必须确保将查询置于一个条件之间,以便它只在用户取消订阅时执行它,而不是每次更新时都执行。

respond_to do |format|
  if @subscription.save
    if (something to tell the controller you are cancelling the subscription)
       EXECUTE QUERY HERE
    end
  end
end