Skip to content

Commit

Permalink
Add raw_request (#1431)
Browse files Browse the repository at this point in the history
* Add raw request

* Copy readme from beta

* fix readme
  • Loading branch information
helenye-stripe authored Jul 10, 2024
1 parent 9cbc463 commit 816fe0d
Show file tree
Hide file tree
Showing 6 changed files with 124 additions and 0 deletions.
4 changes: 4 additions & 0 deletions .rubocop.yml
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,10 @@ Metrics/MethodLength:
Metrics/ModuleLength:
Enabled: false

Metrics/ParameterLists:
# There's 2 methods in `StripeClient` that have long parameter lists.
Max: 8

Style/AccessModifierDeclarations:
EnforcedStyle: inline

Expand Down
17 changes: 17 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -338,6 +338,23 @@ If your beta feature requires a `Stripe-Version` header to be sent, set the `Str
Stripe.add_beta_version("feature_beta", "v3")
```

### Custom requests

If you:

- would like to send a request to an undocumented API (for example you are in a private beta)
- prefer to bypass the method definitions in the library and specify your request details directly,
- used the method `Stripe::APIResource.request(...)` to specify your own requests, which will soon be broken

you can now use the `raw_request` method on `Stripe`.

```ruby
resp = Stripe.raw_request(:post, "/v1/beta_endpoint", {param: 123}, {stripe_version: "2022-11-15; feature_beta=v3"})

# (Optional) resp is a StripeResponse. You can use `Stripe.deserialize` to get a StripeObject.
deserialized_resp = Stripe.deserialize(resp.http_body)
```

## Support

New features and bug fixes are released on the latest major version of the Stripe Ruby library. If you are on an older major version, we recommend that you upgrade to the latest in order to use the new features and bug fixes including those for security vulnerabilities. Older major versions of the package will continue to be available for use, but will not be receiving any updates.
Expand Down
25 changes: 25 additions & 0 deletions lib/stripe.rb
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,31 @@ def self.set_app_info(name, partner_id: nil, url: nil, version: nil)
version: version,
}
end

class RawRequest
include Stripe::APIOperations::Request

def initialize
@opts = {}
end

def execute(method, url, params = {}, opts = {})
resp, = execute_resource_request(method, url, params, opts)

resp
end
end

# Sends a request to Stripe REST API
def self.raw_request(method, url, params = {}, opts = {})
req = RawRequest.new
req.execute(method, url, params, opts)
end

def self.deserialize(data)
data = JSON.parse(data) if data.is_a?(String)
Util.convert_to_stripe_object(data, {})
end
end

Stripe.log_level = ENV["STRIPE_LOG"] unless ENV["STRIPE_LOG"].nil?
2 changes: 2 additions & 0 deletions lib/stripe/stripe_client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -462,6 +462,7 @@ def self.maybe_gc_connection_managers

headers = request_headers(api_key, method)
.update(Util.normalize_headers(headers))

url = api_url(path, api_base)

# Merge given query parameters with any already encoded in the path.
Expand Down Expand Up @@ -879,6 +880,7 @@ def self.maybe_gc_connection_managers
end

headers["Stripe-Version"] = config.api_version if config.api_version

headers["Stripe-Account"] = config.stripe_account if config.stripe_account

user_agent = @system_profiler.user_agent
Expand Down
38 changes: 38 additions & 0 deletions test/stripe/raw_request_test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
# frozen_string_literal: true

require File.expand_path("../test_helper", __dir__)

class RawRequestTest < Test::Unit::TestCase
context "raw_request" do
should "send get request and return a response" do
expected_body = "{\"id\": \"acc_123\"}"
req = nil

stub_request(:get, "#{Stripe.api_base}/v1/accounts/acc_123")
.with { |request| req = request }
.to_return(body: expected_body)

resp = Stripe.raw_request(:get, "/v1/accounts/acc_123")

assert_equal expected_body, resp.http_body
assert_equal "application/x-www-form-urlencoded", req.headers["Content-Type"]
assert_equal Stripe::ApiVersion::CURRENT, req.headers["Stripe-Version"]
end

should "send post request with body and return a response" do
expected_body = "{\"id\": \"acc_123\"}"
req = nil

stub_request(:post, "#{Stripe.api_base}/v1/accounts/acc_123")
.with(body: "p1=1&p2=string")
.with { |request| req = request }
.to_return(body: expected_body)

resp = Stripe.raw_request(:post, "/v1/accounts/acc_123", { p1: 1, p2: "string" })

assert_equal expected_body, resp.http_body
assert_equal "application/x-www-form-urlencoded", req.headers["Content-Type"]
assert_equal Stripe::ApiVersion::CURRENT, req.headers["Stripe-Version"]
end
end
end
38 changes: 38 additions & 0 deletions test/stripe_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -134,4 +134,42 @@ class StripeTest < Test::Unit::TestCase
assert_equal "client", Stripe.client_id
end
end

context "deserialize" do
should "deserializes string into known object" do
expected_body = "{\"id\": \"acc_123\", \"object\": \"account\"}"

obj = Stripe.deserialize(expected_body)

assert_equal obj.class, Stripe::Account
assert_equal obj.id, "acc_123"
end

should "deserializes string into unknown object" do
expected_body = "{\"id\": \"acc_123\", \"object\": \"unknown\"}"

obj = Stripe.deserialize(expected_body)

assert_equal obj.class, Stripe::StripeObject
assert_equal obj.id, "acc_123"
end

should "deserializes hash into known object" do
expected_body = { "id" => "acc_123", "object" => "account" }

obj = Stripe.deserialize(expected_body)

assert_equal obj.class, Stripe::Account
assert_equal obj.id, "acc_123"
end

should "deserializes hash into unknown object" do
expected_body = { "id" => "acc_123", "object" => "unknown" }

obj = Stripe.deserialize(expected_body)

assert_equal obj.class, Stripe::StripeObject
assert_equal obj.id, "acc_123"
end
end
end

0 comments on commit 816fe0d

Please sign in to comment.