Skip to content

Commit

Permalink
refactor where mandatory webhooks are skipped (Shopify#1249)
Browse files Browse the repository at this point in the history
* refactor where mandatory webhooks are skipped

* changelog

* more explicit mandatory registration result

* lint
  • Loading branch information
nelsonwittwer authored and garethson committed Dec 1, 2023
1 parent dfd13ba commit de019cc
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 10 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand Down
15 changes: 13 additions & 2 deletions lib/shopify_api/webhooks/registry.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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,
Expand Down
11 changes: 3 additions & 8 deletions test/webhooks/registry_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down

0 comments on commit de019cc

Please sign in to comment.