From de019cc8b5b2edf23605a398815043ae722b77d0 Mon Sep 17 00:00:00 2001 From: Nelson Date: Thu, 30 Nov 2023 13:22:53 -0500 Subject: [PATCH] refactor where mandatory webhooks are skipped (#1249) * refactor where mandatory webhooks are skipped * changelog * more explicit mandatory registration result * lint --- CHANGELOG.md | 1 + lib/shopify_api/webhooks/registry.rb | 15 +++++++++++++-- test/webhooks/registry_test.rb | 11 +++-------- 3 files changed, 17 insertions(+), 10 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 02eb78f7..34cf214b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ Note: For changes to the API, see https://shopify.dev/changelog?filter=api ## Unreleased - [#1244](https://github.com/Shopify/shopify-api-ruby/pull/1244) Add `expired?` to `ShopifyAPI::Auth::Session` to check if the session is expired (mainly for user sessions) +- [#1249](https://github.com/Shopify/shopify-api-ruby/pull/1249) Fix bug where mandatory webhooks could not be processed ## 13.3.0 diff --git a/lib/shopify_api/webhooks/registry.rb b/lib/shopify_api/webhooks/registry.rb index e52204cc..b357730e 100644 --- a/lib/shopify_api/webhooks/registry.rb +++ b/lib/shopify_api/webhooks/registry.rb @@ -22,8 +22,6 @@ class << self metafield_namespaces: T.nilable(T::Array[String])).void end def add_registration(topic:, delivery_method:, path:, handler: nil, fields: nil, metafield_namespaces: nil) - return if mandatory_webhook_topic?(topic) - @registry[topic] = case delivery_method when :pub_sub Registrations::PubSub.new(topic: topic, path: path, fields: fields, @@ -56,6 +54,8 @@ def clear ).returns(RegisterResult) end def register(topic:, session:) + return mandatory_registration_result(topic) if mandatory_webhook_topic?(topic) + registration = @registry[topic] unless registration @@ -83,6 +83,17 @@ def register(topic:, session:) RegisterResult.new(topic: topic, success: registered, body: register_body) end + sig do + params(topic: String).returns(RegisterResult) + end + def mandatory_registration_result(topic) + RegisterResult.new( + topic: topic, + success: false, + body: "Mandatory webhooks are to be registered in the partners dashboard", + ) + end + sig do params( session: Auth::Session, diff --git a/test/webhooks/registry_test.rb b/test/webhooks/registry_test.rb index 1d0ab478..147ff7f9 100644 --- a/test/webhooks/registry_test.rb +++ b/test/webhooks/registry_test.rb @@ -276,17 +276,12 @@ def test_get_webhook_id_with_graphql_errors def test_registrations_to_mandatory_topics_are_ignored ShopifyAPI::Webhooks::Registry.clear - ShopifyAPI::Webhooks::Registrations::Http.expects(:new).never + ShopifyAPI::Clients::Graphql::Admin.expects(:new).never ShopifyAPI::Webhooks::Registry::MANDATORY_TOPICS.each do |topic| - ShopifyAPI::Webhooks::Registry.add_registration( + ShopifyAPI::Webhooks::Registry.register( topic: topic, - delivery_method: :http, - path: "some_path_under_the_rainbow", - handler: TestHelpers::FakeWebhookHandler.new( - lambda do |topic, shop, body| - end, - ), + session: @session, ) end end