diff --git a/lib/webhook.rb b/lib/webhook.rb index 51c505c..a2bc0e7 100644 --- a/lib/webhook.rb +++ b/lib/webhook.rb @@ -33,6 +33,14 @@ class Web < Sinatra::Base status 200 end + post %r{shopify/(?\w*)/(?\w*)/(?\w*)} do + webhook = Oj.load(request.body.read) + routing_key = ['shopify', params['topic'], params['action']].join('.') + webhook['wanelo_store_id'] = params['wanelo_store_id'] + Publisher::Shopify.new(webhook).publish(routing_key) + status 200 + end + post %r{shopify/(?\w*)/(?\w*)} do webhook = Oj.load(request.body.read) routing_key = ['shopify', params['topic'], params['action']].join('.') @@ -42,4 +50,3 @@ class Web < Sinatra::Base end end end - diff --git a/spec/functional/shopify/lapine_spec.rb b/spec/functional/shopify/lapine_spec.rb index 5128155..66cbb36 100644 --- a/spec/functional/shopify/lapine_spec.rb +++ b/spec/functional/shopify/lapine_spec.rb @@ -36,4 +36,12 @@ def rack_env(hmac) message = queue.messages.pop expect(message[1]).to eq({routing_key: 'shopify.orders.fulfilled'}) end + + context 'with store id in path' do + it 'includes the store id in the message' do + post '/shopify/1/orders/fulfilled', body, rack_env(body_hmac) + message = queue.messages.pop + expect(Oj.load(message[0])['wanelo_store_id'].to_i).to eq(1) + end + end end diff --git a/spec/functional/shopify/routing_spec.rb b/spec/functional/shopify/routing_spec.rb index edec6e7..83c8df0 100644 --- a/spec/functional/shopify/routing_spec.rb +++ b/spec/functional/shopify/routing_spec.rb @@ -18,6 +18,13 @@ def rack_env(hmac) } end + context 'with store id in path' do + it 'includes store id in payload' do + post '/shopify/1/orders/fulfilled', body, rack_env(body_hmac) + expect(last_response.status).to eq(200) + end + end + context 'with HTTP_X_SHOPIFY_HMAC_SHA256 header' do context 'when submitted hmac and calculated hmac are the same' do it 'continues' do