2017-01-22 13 views
2

Я пытаюсь установить Mollie API, но я не получаю работу webhook. Я работаю в Ruby on Rails 4. Он продолжает говорить Невозможно проверить аутентификацию токена CSRF. Я попробовал несколько ответов из stackoverflow, но они не работают. Например.Не удается проверить аутентификацию токена CSRF

  • skip_before_filter: verify_authenticity_token
  • protect_from_forgery за исключением: [: уведомит]
  • protect_from_forgery с:: null_session, если: -> {?} Request.format.json

Моя уведомит-контроллер выглядит следующим образом:

class ReservationsController < ApplicationController 
    before_action :authenticate_user!, except: [:notify] 

    skip_before_filter :verify_authenticity_token 

    def preload 
     training = Training.find(params[:training_id]) 
     today = Date.today 
     reservations = training.reservations.where("date >= ?", today) 

     render json: reservations 
    end 

    def create 



     @thrill = Thrill.find(params[:thrill_id]) 
     if @thrill.reservations.length < @thrill.training.tr_max_attendants 
      @reservation = current_user.reservations.create(reservation_params) 

      if @reservation 

       require 'Mollie/API/Client' 

       mollie = Mollie::API::Client.new('test_gUejkz43UkdeCauC22J6UNqqVRdpwW') 

       payment = mollie.payments.create(
        amount: 10.00, 
        description: 'My first API payment', 
        redirect_Url: 'http://d7459af1.ngrok.io/your_trips', 
        webhookUrl: 'http://d7459af1.ngrok.io/notify', 
        metadata: { 
         reservationid: @reservation.id 
        } 
       ) 



       @reservation.update_attributes payid:payment.id 

       redirect_to payment.payment_url 


      else 
       redirect_to @thrill.training, notice: "Helaas, de training is vol" 
      end 
     end 
    end 

    protect_from_forgery except: [:notify] 
# protect_from_forgery with: :null_session, if: -> {request.format.json?} 

    def notify 

     require 'Mollie/API/Client' 

     mollie = Mollie::API::Client.new('test_gUejkz43UkdeCauC22J6UNqqVRdpwW') 

     payment = mollie.payments.get(payment.id) 

     params.permit! 
     status = params[:payment_status] 

     if payment.paid? 

      reservation = Reservation.find(params[:payid]) 
      reservation.update_attributes status:true 
     else 
      reservation.destroy 
     end 

     render nothing: true 

    end 

    protect_from_forgery except: [:your_trips] 
    def your_trips 
     @reservations = current_user.reservations.joins(:thrill).order('thrills.thrilldate asc').where('? <= thrills.thrilldate', Date.today) 
    end 

    def your_reservations 
     @trainings = current_user.trainings 
    end 

    private 
     def reservation_params 

      params.permit(:thrill_id, :user_id) 
     end 


    end 

Если у кого-то есть подсказка или подсказка, мы будем очень признательны! Спасибо!

+0

Hi Chris. Если вы новичок в Rails: код, который вы публикуете здесь, не похож на обычный контроллер Rails. Можете ли вы опубликовать весь код в своем уведомляющем контроллере, пожалуйста? Я бы ожидал, что он начнется с 'class NotifyController Mauddev

+0

Привет, Mauddev, спасибо за ваш комментарий. Я действительно очень новичок в этом, я добавил полный контроллер. Надеюсь, вы можете что-то сделать. –

ответ

3

Вам необходимо позвонить по телефону protect_from_forgery на самый верх вашего контроллера или вы можете удалить звонок protect_from_forgery в ApplicationController.

Пример:

class ReservationsController < ApplicationController 
    before_action :authenticate_user!, except: [:notify] 

    skip_before_filter :verify_authenticity_token 

    protect_from_forgery except: [:notify, :your_trips] 

    # actions go below here 

Обратите внимание, что вы можете передать несколько действий по параметру :except

Side Примечание: если вы работаете на JSON API только приложения, я предлагаю вам посмотреть в Rails API : https://github.com/rails-api/rails-api