Class: Dodopayments::Resources::Webhooks

Inherits:
Object
  • Object
show all
Defined in:
lib/dodopayments/resources/webhooks.rb,
lib/dodopayments/resources/webhooks/headers.rb

Defined Under Namespace

Classes: Headers

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client:) ⇒ Webhooks

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of Webhooks.

Parameters:



186
187
188
189
# File 'lib/dodopayments/resources/webhooks.rb', line 186

def initialize(client:)
  @client = client
  @headers = Dodopayments::Resources::Webhooks::Headers.new(client: client)
end

Instance Attribute Details

#headersDodopayments::Resources::Webhooks::Headers (readonly)



7
8
9
# File 'lib/dodopayments/resources/webhooks.rb', line 7

def headers
  @headers
end

Instance Method Details

#create(url: , description: nil, disabled: nil, filter_types: nil, headers: nil, idempotency_key: nil, metadata: nil, rate_limit: nil, request_options: {}) ⇒ Dodopayments::Models::WebhookDetails

Some parameter documentations has been truncated, see Models::WebhookCreateParams for more details.

Create a new webhook

Parameters:

  • url (String)

    Url of the webhook

  • description (String, nil)
  • disabled (Boolean, nil)

    Create the webhook in a disabled state.

  • filter_types (Array<Symbol, Dodopayments::Models::WebhookEventType>)

    Filter events to the webhook.

  • headers (Hash{Symbol=>String}, nil)

    Custom headers to be passed

  • idempotency_key (String, nil)

    The request’s idempotency key

  • metadata (Hash{Symbol=>String}, nil)

    Metadata to be passed to the webhook

  • rate_limit (Integer, nil)
  • request_options (Dodopayments::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



37
38
39
40
41
42
43
44
45
46
# File 'lib/dodopayments/resources/webhooks.rb', line 37

def create(params)
  parsed, options = Dodopayments::WebhookCreateParams.dump_request(params)
  @client.request(
    method: :post,
    path: "webhooks",
    body: parsed,
    model: Dodopayments::WebhookDetails,
    options: options
  )
end

#delete(webhook_id, request_options: {}) ⇒ nil

Delete a webhook by id

Parameters:

Returns:

  • (nil)

See Also:



139
140
141
142
143
144
145
146
# File 'lib/dodopayments/resources/webhooks.rb', line 139

def delete(webhook_id, params = {})
  @client.request(
    method: :delete,
    path: ["webhooks/%1$s", webhook_id],
    model: NilClass,
    options: params[:request_options]
  )
end

#list(iterator: nil, limit: nil, request_options: {}) ⇒ Dodopayments::Internal::CursorPagePagination<Dodopayments::Models::WebhookDetails>

List all webhooks

Parameters:

  • iterator (String, nil)

    The iterator returned from a prior invocation

  • limit (Integer, nil)

    Limit the number of returned items

  • request_options (Dodopayments::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



117
118
119
120
121
122
123
124
125
126
127
# File 'lib/dodopayments/resources/webhooks.rb', line 117

def list(params = {})
  parsed, options = Dodopayments::WebhookListParams.dump_request(params)
  @client.request(
    method: :get,
    path: "webhooks",
    query: parsed,
    page: Dodopayments::Internal::CursorPagePagination,
    model: Dodopayments::WebhookDetails,
    options: options
  )
end

#retrieve(webhook_id, request_options: {}) ⇒ Dodopayments::Models::WebhookDetails

Get a webhook by id

Parameters:

Returns:

See Also:



58
59
60
61
62
63
64
65
# File 'lib/dodopayments/resources/webhooks.rb', line 58

def retrieve(webhook_id, params = {})
  @client.request(
    method: :get,
    path: ["webhooks/%1$s", webhook_id],
    model: Dodopayments::WebhookDetails,
    options: params[:request_options]
  )
end

#retrieve_secret(webhook_id, request_options: {}) ⇒ Dodopayments::Models::WebhookRetrieveSecretResponse

Get webhook secret by id

Parameters:

Returns:

See Also:



158
159
160
161
162
163
164
165
# File 'lib/dodopayments/resources/webhooks.rb', line 158

def retrieve_secret(webhook_id, params = {})
  @client.request(
    method: :get,
    path: ["webhooks/%1$s/secret", webhook_id],
    model: Dodopayments::Models::WebhookRetrieveSecretResponse,
    options: params[:request_options]
  )
end

#unsafe_unwrap(payload) ⇒ Dodopayments::Models::DisputeAcceptedWebhookEvent, ...



170
171
172
173
# File 'lib/dodopayments/resources/webhooks.rb', line 170

def unsafe_unwrap(payload)
  parsed = JSON.parse(payload, symbolize_names: true)
  Dodopayments::Internal::Type::Converter.coerce(Dodopayments::Models::UnsafeUnwrapWebhookEvent, parsed)
end

#unwrap(payload) ⇒ Dodopayments::Models::DisputeAcceptedWebhookEvent, ...



178
179
180
181
# File 'lib/dodopayments/resources/webhooks.rb', line 178

def unwrap(payload)
  parsed = JSON.parse(payload, symbolize_names: true)
  Dodopayments::Internal::Type::Converter.coerce(Dodopayments::Models::UnwrapWebhookEvent, parsed)
end

#update(webhook_id, description: nil, disabled: nil, filter_types: nil, metadata: nil, rate_limit: nil, url: nil, request_options: {}) ⇒ Dodopayments::Models::WebhookDetails

Some parameter documentations has been truncated, see Models::WebhookUpdateParams for more details.

Patch a webhook by id

Parameters:

  • webhook_id (String)
  • description (String, nil)

    Description of the webhook

  • disabled (Boolean, nil)

    To Disable the endpoint, set it to true.

  • filter_types (Array<Symbol, Dodopayments::Models::WebhookEventType>, nil)

    Filter events to the endpoint.

  • metadata (Hash{Symbol=>String}, nil)

    Metadata

  • rate_limit (Integer, nil)

    Rate limit

  • url (String, nil)

    Url endpoint

  • request_options (Dodopayments::RequestOptions, Hash{Symbol=>Object}, nil)

Returns:

See Also:



93
94
95
96
97
98
99
100
101
102
# File 'lib/dodopayments/resources/webhooks.rb', line 93

def update(webhook_id, params = {})
  parsed, options = Dodopayments::WebhookUpdateParams.dump_request(params)
  @client.request(
    method: :patch,
    path: ["webhooks/%1$s", webhook_id],
    body: parsed,
    model: Dodopayments::WebhookDetails,
    options: options
  )
end