Class: Stripe::Forwarding::Request

Inherits:
APIResource show all
Extended by:
APIOperations::Create, APIOperations::List
Defined in:
lib/stripe/resources/forwarding/request.rb

Overview

Instructs Stripe to make a request on your behalf using the destination URL. The destination URL is activated by Stripe at the time of onboarding. Stripe verifies requests with your credentials provided during onboarding, and injects card details from the payment_method into the request.

Stripe redacts all sensitive fields and headers, including authentication credentials and card numbers, before storing the request and response data in the forwarding Request object, which are subject to a 30-day retention period.

You can provide a Stripe idempotency key to make sure that requests with the same key result in only one outbound request. The Stripe idempotency key provided should be unique and different from any idempotency keys provided on the underlying third-party request.

Forwarding Requests are synchronous requests that return a response or time out according to Stripe’s limits.

Related guide: [Forward card details to third-party API endpoints](docs.stripe.com/payments/forwarding).

Defined Under Namespace

Classes: CreateParams, ListParams, RequestContext, RequestDetails, ResponseDetails

Constant Summary collapse

OBJECT_NAME =
"forwarding.request"

Constants inherited from StripeObject

StripeObject::RESERVED_FIELD_NAMES

Instance Attribute Summary collapse

Attributes inherited from APIResource

#save_with_parent

Attributes inherited from StripeObject

#last_response

Class Method Summary collapse

Methods included from APIOperations::Create

create

Methods included from APIOperations::List

list

Methods inherited from APIResource

class_name, custom_method, #refresh, #request_stripe_object, resource_url, #resource_url, retrieve, save_nested_resource

Methods included from APIOperations::Request

included

Methods inherited from StripeObject

#==, #[], #[]=, additive_object_param, additive_object_param?, #as_json, construct_from, #deleted?, #dirty!, #each, #eql?, #hash, #initialize, #inspect, #keys, #marshal_dump, #marshal_load, protected_fields, #serialize_params, #to_hash, #to_json, #to_s, #update_attributes, #values

Constructor Details

This class inherits a constructor from Stripe::StripeObject

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class Stripe::StripeObject

Instance Attribute Details

#createdObject (readonly)

Time at which the object was created. Measured in seconds since the Unix epoch.



165
166
167
# File 'lib/stripe/resources/forwarding/request.rb', line 165

def created
  @created
end

#idObject (readonly)

Unique identifier for the object.



167
168
169
# File 'lib/stripe/resources/forwarding/request.rb', line 167

def id
  @id
end

#livemodeObject (readonly)

Has the value ‘true` if the object exists in live mode or the value `false` if the object exists in test mode.



169
170
171
# File 'lib/stripe/resources/forwarding/request.rb', line 169

def livemode
  @livemode
end

#metadataObject (readonly)

Set of [key-value pairs](stripe.com/docs/api/metadata) that you can attach to an object. This can be useful for storing additional information about the object in a structured format.



171
172
173
# File 'lib/stripe/resources/forwarding/request.rb', line 171

def 
  @metadata
end

#objectObject (readonly)

String representing the object’s type. Objects of the same type share the same value.



173
174
175
# File 'lib/stripe/resources/forwarding/request.rb', line 173

def object
  @object
end

#payment_methodObject (readonly)

The PaymentMethod to insert into the forwarded request. Forwarding previously consumed PaymentMethods is allowed.



175
176
177
# File 'lib/stripe/resources/forwarding/request.rb', line 175

def payment_method
  @payment_method
end

#replacementsObject (readonly)

The field kinds to be replaced in the forwarded request.



177
178
179
# File 'lib/stripe/resources/forwarding/request.rb', line 177

def replacements
  @replacements
end

#request_contextObject (readonly)

Context about the request from Stripe’s servers to the destination endpoint.



179
180
181
# File 'lib/stripe/resources/forwarding/request.rb', line 179

def request_context
  @request_context
end

#request_detailsObject (readonly)

The request that was sent to the destination endpoint. We redact any sensitive fields.



181
182
183
# File 'lib/stripe/resources/forwarding/request.rb', line 181

def request_details
  @request_details
end

#response_detailsObject (readonly)

The response that the destination endpoint returned to us. We redact any sensitive fields.



183
184
185
# File 'lib/stripe/resources/forwarding/request.rb', line 183

def response_details
  @response_details
end

#urlObject (readonly)

The destination URL for the forwarded request. Must be supported by the config.



185
186
187
# File 'lib/stripe/resources/forwarding/request.rb', line 185

def url
  @url
end

Class Method Details

.create(params = {}, opts = {}) ⇒ Object

Creates a ForwardingRequest object.



188
189
190
191
192
193
194
195
# File 'lib/stripe/resources/forwarding/request.rb', line 188

def self.create(params = {}, opts = {})
  request_stripe_object(
    method: :post,
    path: "/v1/forwarding/requests",
    params: params,
    opts: opts
  )
end

.list(params = {}, opts = {}) ⇒ Object

Lists all ForwardingRequest objects.



198
199
200
201
202
203
204
205
# File 'lib/stripe/resources/forwarding/request.rb', line 198

def self.list(params = {}, opts = {})
  request_stripe_object(
    method: :get,
    path: "/v1/forwarding/requests",
    params: params,
    opts: opts
  )
end

.object_nameObject



27
28
29
# File 'lib/stripe/resources/forwarding/request.rb', line 27

def self.object_name
  "forwarding.request"
end