Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

API Updates #1046

Merged
merged 4 commits into from
Apr 15, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions lib/stripe/object_types.rb
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ def self.object_names_to_classes
File::OBJECT_NAME => File,
File::OBJECT_NAME_ALT => File,
FileLink::OBJECT_NAME => FileLink,
FundingInstructions::OBJECT_NAME => FundingInstructions,
Identity::VerificationReport::OBJECT_NAME => Identity::VerificationReport,
Identity::VerificationSession::OBJECT_NAME => Identity::VerificationSession,
Invoice::OBJECT_NAME => Invoice,
Expand Down Expand Up @@ -92,6 +93,7 @@ def self.object_names_to_classes
TaxCode::OBJECT_NAME => TaxCode,
TaxId::OBJECT_NAME => TaxId,
TaxRate::OBJECT_NAME => TaxRate,
Terminal::Configuration::OBJECT_NAME => Terminal::Configuration,
Terminal::ConnectionToken::OBJECT_NAME => Terminal::ConnectionToken,
Terminal::Location::OBJECT_NAME => Terminal::Location,
Terminal::Reader::OBJECT_NAME => Terminal::Reader,
Expand Down
2 changes: 2 additions & 0 deletions lib/stripe/resources.rb
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
require "stripe/resources/exchange_rate"
require "stripe/resources/file"
require "stripe/resources/file_link"
require "stripe/resources/funding_instructions"
require "stripe/resources/identity/verification_report"
require "stripe/resources/identity/verification_session"
require "stripe/resources/invoice"
Expand Down Expand Up @@ -80,6 +81,7 @@
require "stripe/resources/tax_code"
require "stripe/resources/tax_id"
require "stripe/resources/tax_rate"
require "stripe/resources/terminal/configuration"
require "stripe/resources/terminal/connection_token"
require "stripe/resources/terminal/location"
require "stripe/resources/terminal/reader"
Expand Down
2 changes: 2 additions & 0 deletions lib/stripe/resources/customer.rb
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ class Customer < APIResource

nested_resource_class_methods :balance_transaction,
operations: %i[create retrieve update list]
nested_resource_class_methods :funding_instruction,
operations: %i[create list]
nested_resource_class_methods :tax_id,
operations: %i[create retrieve delete list]

Expand Down
20 changes: 20 additions & 0 deletions lib/stripe/resources/funding_instructions.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# File generated from our OpenAPI spec
# frozen_string_literal: true

module Stripe
class FundingInstructions < APIResource
extend Stripe::APIOperations::Create
extend Stripe::APIOperations::List

OBJECT_NAME = "funding_instructions"

def resource_url
if !respond_to?(:customer) || customer.nil?
raise NotImplementedError,
"FundingInstructions cannot be accessed without a customer ID."
end
"#{Customer.resource_url}/#{CGI.escape(customer)}/funding_instructions" \
"/#{CGI.escape(id)}"
end
end
end
15 changes: 15 additions & 0 deletions lib/stripe/resources/terminal/configuration.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# File generated from our OpenAPI spec
# frozen_string_literal: true

module Stripe
module Terminal
class Configuration < APIResource
extend Stripe::APIOperations::Create
include Stripe::APIOperations::Delete
extend Stripe::APIOperations::List
include Stripe::APIOperations::Save

OBJECT_NAME = "terminal.configuration"
end
end
end
44 changes: 44 additions & 0 deletions test/stripe/generated_examples_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -270,18 +270,36 @@ class CodegennedExampleTest < Test::Unit::TestCase
)
assert_requested :post, "#{Stripe.api_base}/v1/billing_portal/configurations"
end
should "work" do
Stripe::Terminal::Configuration.create
assert_requested :post, "#{Stripe.api_base}/v1/terminal/configurations?"
end
end
context "Configuration.delete" do
should "support requests with args: configuration" do
Stripe::Terminal::Configuration.delete("uc_123")
assert_requested :delete, "#{Stripe.api_base}/v1/terminal/configurations/uc_123?"
end
end
context "Configuration.list" do
should "support requests with args: limit" do
Stripe::BillingPortal::Configuration.list(limit: 3)
assert_requested :get, "#{Stripe.api_base}/v1/billing_portal/configurations?limit=3"
end
should "work" do
Stripe::Terminal::Configuration.list
assert_requested :get, "#{Stripe.api_base}/v1/terminal/configurations?"
end
end
context "Configuration.retrieve" do
should "support requests with args: id" do
Stripe::BillingPortal::Configuration.retrieve("bpc_xxxxxxxxxxxxx")
assert_requested :get, "#{Stripe.api_base}/v1/billing_portal/configurations/bpc_xxxxxxxxxxxxx?"
end
should "support requests with args: configuration" do
Stripe::Terminal::Configuration.retrieve("uc_123")
assert_requested :get, "#{Stripe.api_base}/v1/terminal/configurations/uc_123?"
end
end
context "Configuration.update" do
should "support requests with args: business_profile, id" do
Expand All @@ -296,6 +314,10 @@ class CodegennedExampleTest < Test::Unit::TestCase
)
assert_requested :post, "#{Stripe.api_base}/v1/billing_portal/configurations/bpc_xxxxxxxxxxxxx"
end
should "support requests with args: configuration" do
Stripe::Terminal::Configuration.update("uc_123")
assert_requested :post, "#{Stripe.api_base}/v1/terminal/configurations/uc_123?"
end
end
context "ConnectionToken.create" do
should "work" do
Expand Down Expand Up @@ -625,6 +647,28 @@ class CodegennedExampleTest < Test::Unit::TestCase
assert_requested :post, "#{Stripe.api_base}/v1/file_links/link_xxxxxxxxxxxxx"
end
end
context "FundingInstructions.create" do
should "support requests with args: customer, bank_transfer, currency, funding_type" do
Stripe::Customer.create_funding_instruction(
"cus_123",
{
bank_transfer: {
requested_address_types: ["zengin"],
type: "jp_bank_transfer",
},
currency: "usd",
funding_type: "bank_transfer",
}
)
assert_requested :post, "#{Stripe.api_base}/v1/customers/cus_123/funding_instructions"
end
end
context "FundingInstructions.list" do
should "support requests with args: customer" do
Stripe::Customer.list_funding_instructions("cus_123")
assert_requested :get, "#{Stripe.api_base}/v1/customers/cus_123/funding_instructions?"
end
end
context "Invoice.create" do
should "support requests with args: customer" do
Stripe::Invoice.create(customer: "cus_xxxxxxxxxxxxx")
Expand Down