From 95746243d036f3529f63779e0746b2c57019fe89 Mon Sep 17 00:00:00 2001 From: Remi Jannel Date: Thu, 11 Apr 2019 17:27:01 -0700 Subject: [PATCH] Add support for `spending_limits` with Issuing Card and Cardholder --- issuing_card.go | 55 ++++++++++++++++++++++++++++++++++++------- issuing_cardholder.go | 40 ++++++++++++++++--------------- 2 files changed, 67 insertions(+), 28 deletions(-) diff --git a/issuing_card.go b/issuing_card.go index c740175fce..8a2740681b 100644 --- a/issuing_card.go +++ b/issuing_card.go @@ -45,12 +45,37 @@ const ( IssuingCardTypeVirtual IssuingCardType = "virtual" ) +// IssuingSpendingLimitInterval is the list of possible values for the interval of a given +// spending limit on an issuing card or cardholder. +type IssuingSpendingLimitInterval string + +// List of values that IssuingCardShippingStatus can take. +const ( + IssuingSpendingLimitIntervalAllTime IssuingSpendingLimitInterval = "all_time" + IssuingSpendingLimitIntervalDaily IssuingSpendingLimitInterval = "daily" + IssuingSpendingLimitIntervalMonthly IssuingSpendingLimitInterval = "monthly" + IssuingSpendingLimitIntervalPerAuthorization IssuingSpendingLimitInterval = "per_authorization" + IssuingSpendingLimitIntervalWeekly IssuingSpendingLimitInterval = "weekly" + IssuingSpendingLimitIntervalYearly IssuingSpendingLimitInterval = "yearly" +) + +// IssuingAuthorizationControlsSpendingLimitsParams is the set of parameters that can be used for +// the spending limits associated with a given issuing card or cardholder. +type IssuingAuthorizationControlsSpendingLimitsParams struct { + Amount *int64 `form:"amount"` + Categories []*string `form:"categories"` + Interval *string `form:"interval"` +} + // AuthorizationControlsParams is the set of parameters that can be used for the shipping parameter. type AuthorizationControlsParams struct { - AllowedCategories []*string `form:"allowed_categories"` - BlockedCategories []*string `form:"blocked_categories"` - MaxAmount *int64 `form:"max_amount"` - MaxApprovals *int64 `form:"max_approvals"` + AllowedCategories []*string `form:"allowed_categories"` + BlockedCategories []*string `form:"blocked_categories"` + SpendingLimits *IssuingAuthorizationControlsSpendingLimitsParams `form:"spending_limits"` + + // The following parameters are considered deprecated and only apply to issuing cards + MaxAmount *int64 `form:"max_amount"` + MaxApprovals *int64 `form:"max_approvals"` } // IssuingCardShippingParams is the set of parameters that can be used for the shipping parameter. @@ -98,13 +123,25 @@ type IssuingCardDetails struct { Object string `json:"object"` } +// IssuingAuthorizationControlsSpendingLimits is the resource representing spending limits +// associated with a card or cardholder. +type IssuingAuthorizationControlsSpendingLimits struct { + Amount int64 `json:"amount"` + Categories []string `json:"categories"` + Interval IssuingSpendingLimitInterval `json:"interval"` +} + // IssuingCardAuthorizationControls is the resource representing authorization controls on an issuing card. +// TODO: Rename to IssuingAuthorizationControls in the next major type IssuingCardAuthorizationControls struct { - AllowedCategories []string `json:"allowed_categories"` - BlockedCategories []string `json:"blocked_categories"` - Currency Currency `json:"currency"` - MaxAmount int64 `json:"max_amount"` - MaxApprovals int64 `json:"max_approvals"` + AllowedCategories []string `json:"allowed_categories"` + BlockedCategories []string `json:"blocked_categories"` + SpendingLimits *IssuingAuthorizationControlsSpendingLimits `json:"spending_limits"` + + // The properties below are considered deprecated and can only be used for an issuing card. + Currency Currency `json:"currency"` + MaxAmount int64 `json:"max_amount"` + MaxApprovals int64 `json:"max_approvals"` } // IssuingCardShipping is the resource representing shipping on an issuing card. diff --git a/issuing_cardholder.go b/issuing_cardholder.go index 175b16a966..c1dec90ad3 100644 --- a/issuing_cardholder.go +++ b/issuing_cardholder.go @@ -29,14 +29,15 @@ type IssuingBillingParams struct { // IssuingCardholderParams is the set of parameters that can be used when creating or updating an issuing cardholder. type IssuingCardholderParams struct { - Params `form:"*"` - Billing *IssuingBillingParams `form:"billing"` - Email *string `form:"email"` - IsDefault *bool `form:"is_default"` - Name *string `form:"name"` - PhoneNumber *string `form:"phone_number"` - Status *string `form:"status"` - Type *string `form:"type"` + Params `form:"*"` + AuthorizationControls *AuthorizationControlsParams `form:"authorization_controls"` + Billing *IssuingBillingParams `form:"billing"` + Email *string `form:"email"` + IsDefault *bool `form:"is_default"` + Name *string `form:"name"` + PhoneNumber *string `form:"phone_number"` + Status *string `form:"status"` + Type *string `form:"type"` } // IssuingCardholderListParams is the set of parameters that can be used when listing issuing cardholders. @@ -59,17 +60,18 @@ type IssuingBilling struct { // IssuingCardholder is the resource representing a Stripe issuing cardholder. type IssuingCardholder struct { - Billing *IssuingBilling `json:"billing"` - Created int64 `json:"created"` - Email string `json:"email"` - ID string `json:"id"` - Livemode bool `json:"livemode"` - Metadata map[string]string `json:"metadata"` - Name string `json:"name"` - Object string `json:"object"` - PhoneNumber string `json:"phone_number"` - Status IssuingCardholderStatus `json:"status"` - Type IssuingCardholderType `json:"type"` + AuthorizationControls *IssuingCardAuthorizationControls `json:"authorization_controls"` + Billing *IssuingBilling `json:"billing"` + Created int64 `json:"created"` + Email string `json:"email"` + ID string `json:"id"` + Livemode bool `json:"livemode"` + Metadata map[string]string `json:"metadata"` + Name string `json:"name"` + Object string `json:"object"` + PhoneNumber string `json:"phone_number"` + Status IssuingCardholderStatus `json:"status"` + Type IssuingCardholderType `json:"type"` } // IssuingCardholderList is a list of issuing cardholders as retrieved from a list endpoint.