Как сохранить json из API webhook (Shopify webhook)? - PullRequest
0 голосов
/ 17 мая 2019

У меня проблемы с сохранением запроса веб-крюка, который я получаю при создании заказов.

Я хочу сохранить эту информацию в моей БД

У меня есть этот контроллер:

class WebhooksController < ShopifyApp::WebhooksController
  include ShopifyApp::WebhookVerification
  skip_before_action :verify_authenticity_token, raise: false

  def orders_create
    params.permit!
    OrdersCreateJob.perform_later(shop_domain: shop_domain, webhook: webhook_params.to_h)
    head :no_content
  end

  def orders_create_save
    @order = Order.new(shopify_order_id: webhook_params[:webhook][:id])
    @order.save

  end

  private

  def webhook_params
    params.except(:controller, :action, :type)
  end
end

Это задание:

class OrdersCreateJob < ActiveJob::Base
  def perform(shop_domain:, webhook:)
    shop = Shop.find_by(shopify_domain: shop_domain)
    shop.with_shopify_session do
      line_items = webhook[:line_items]
      line_items.each do |item|
        variant_id = item[:variant_id]
        product_id = item[:product_id]
      end
    end
  end
end

Маршруты:

post '/webhooks/orders_create', to: 'webhooks#orders_create'
get '/webhooks/orders_create', to: 'webhooks#orders_create_save'
resources :orders
mount ShopifyApp::Engine, at: '/'
...

Моя конфигурация настроена правильно:

config.webhooks = [
    {topic: 'orders/create', address: 'https://i-shelf-74894.herokuapp.com/webhooks/orders_create', format: 'json'},
    # {topic: 'orders/update', address: 'https://example.herokuapp.com/webhooks/orders_update', format: 'json'}
  ]

Затем я получаю этосоздание заказа:

2019-05-17T07:06:31.036912+00:00 app[web.1]: I, [2019-05-17T07:06:31.036742 #4]  INFO -- : [213ed49f-d14c-4118-bb07-021a34614db7] Started POST "/webhooks/orders_create" for 35.231.147.210 at 2019-05-17 07:06:31 +0000

2019-05-17T07:06:31.049488+00:00 app[web.1]: I, [2019-05-17T07:06:31.049364 #4]  INFO -- : [213ed49f-d14c-4118-bb07-021a34614db7] Processing by WebhooksController#orders_create as */*

2019-05-17T07:06:31.050418+00:00 app[web.1]: I, [2019-05-17T07:06:31.050279 #4]  INFO -- : [213ed49f-d14c-4118-bb07-021a34614db7]   Parameters: {"id"=>922193756209, "email"=>"", "closed_at"=>nil, "created_at"=>"2019-05-17T02:58:25-04:00", "updated_at"=>"2019-05-17T02:58:26-04:00", "number"=>38, "note"=>"", "token"=>"f506480412c5128d64301346c42a0734", "gateway"=>"manual", "test"=>false, "total_price"=>"15.99", "subtotal_price"=>"15.00", "total_weight"=>198, "total_tax"=>"0.99", "taxes_included"=>false,
.........

Следующая строка:

2019-05-17T07:27:59.308685+00:00 app[web.1]: I, [2019-05-17T07:27:59.308487 #4]  INFO -- : [e65ceb94-bf08-4875-89a9-b1353e03b8d8] [ActiveJob] Enqueued OrdersCreateJob (Job ID: 1a8a3f9b-87d5-47fb-8e02-6d32df51234f861) to Async(default) with arguments: {:shop_domain=>"shopifey-store-2123445345.myshopify.com", :webhook=>{"id"=>922

Следующая:

    2019-05-17T07:27:59.329687+00:00 app[web.1]: I, [2019-05-17T07:27:59.329531 #4]  INFO -- : [e65ceb94-bf08-4875-89a9-b1353e03b8d8] Completed 204 No Content in 40ms

2019-05-17T07:27:59.330964+00:00 app[web.1]: I, [2019-05-17T07:27:59.329116 #4]  INFO -- : [ActiveJob] [OrdersCreateJob] [1a8a3f9b-87d5-47fb-8e02-6d32df5ff861] Performing OrdersCreateJob (Job ID: 1a8a3f9b-87d5-47fb-8e02-6d32df5ff861) from Async(default) with arguments: {:shop_domain=>"shopifey-store-
....

Конец:

2019-05-17T07:27:59.370131+00:00 app[web.1]: D, [2019-05-17T07:27:59.369968 #4] DEBUG -- : [ActiveJob] [OrdersCreateJob] [1a8a3f9b-87d5-47fb-8e02-6d32df5ff861]   [1m[36mShop Load (2.0ms)[0m  [1m[34mSELECT  "shops".* FROM "shops" WHERE "shops"."shopify_domain" = $1 LIMIT $2[0m  [["shopify_domain", "s1234re-2111234.myshopify.com"], ["LIMIT", 1]]

2019-05-17T07:27:59.371321+00:00 app[web.1]: I, [2019-05-17T07:27:59.371240 #4]  INFO -- : [ActiveJob] [OrdersCreateJob] [1a81234f5ff861] Performed OrdersCreateJob (Job ID: 17d5-47fb-8e02-6d3222234ff861) from Async(default) in 39.89ms

Я пытался использовать:

@ order = Order.new (shopify_order_id: webhook_params [: webhook] [: id]) @ order.save

Непосредственно в методе orders_create и в коде задания OrdersCreateJob.

Пробовал использовать "webhook" вместо "webhook_params".

Что я здесь не так делаю?

Модель заказа существует с shopify_order_id

...