All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.stripe.model.issuing.Transaction Maven / Gradle / Ivy

There is a newer version: 28.2.0
Show newest version
// File generated from our OpenAPI spec
package com.stripe.model.issuing;

import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.model.BalanceTransaction;
import com.stripe.model.BalanceTransactionSource;
import com.stripe.model.ExpandableField;
import com.stripe.model.MetadataStore;
import com.stripe.model.StripeObject;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.issuing.TransactionCreateForceCaptureParams;
import com.stripe.param.issuing.TransactionCreateUnlinkedRefundParams;
import com.stripe.param.issuing.TransactionListParams;
import com.stripe.param.issuing.TransactionRefundParams;
import com.stripe.param.issuing.TransactionRetrieveParams;
import com.stripe.param.issuing.TransactionUpdateParams;
import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;

/**
 * Any use of an issued card that results in funds
 * entering or leaving your Stripe account, such as a completed purchase or refund, is represented
 * by an Issuing {@code Transaction} object.
 *
 * 

Related guide: Issued card * transactions */ @Getter @Setter @EqualsAndHashCode(callSuper = false) public class Transaction extends ApiResource implements MetadataStore, BalanceTransactionSource { /** * The transaction amount, which will be reflected in your balance. This amount is in your * currency and in the smallest currency * unit. */ @SerializedName("amount") Long amount; /** * Detailed breakdown of amount components. These amounts are denominated in {@code currency} and * in the smallest currency unit. */ @SerializedName("amount_details") AmountDetails amountDetails; /** The {@code Authorization} object that led to this transaction. */ @SerializedName("authorization") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField authorization; /** * ID of the balance transaction * associated with this transaction. */ @SerializedName("balance_transaction") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField balanceTransaction; /** The card used to make this transaction. */ @SerializedName("card") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField card; /** The cardholder to whom this transaction belongs. */ @SerializedName("cardholder") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField cardholder; /** Time at which the object was created. Measured in seconds since the Unix epoch. */ @SerializedName("created") Long created; /** * Three-letter ISO currency code, * in lowercase. Must be a supported currency. */ @SerializedName("currency") String currency; /** If you've disputed the transaction, the ID of the dispute. */ @SerializedName("dispute") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField dispute; /** Unique identifier for the object. */ @Getter(onMethod_ = {@Override}) @SerializedName("id") String id; /** * Has the value {@code true} if the object exists in live mode or the value {@code false} if the * object exists in test mode. */ @SerializedName("livemode") Boolean livemode; /** * The amount that the merchant will receive, denominated in {@code merchant_currency} and in the * smallest currency unit. It will * be different from {@code amount} if the merchant is taking payment in a different currency. */ @SerializedName("merchant_amount") Long merchantAmount; /** The currency with which the merchant is taking payment. */ @SerializedName("merchant_currency") String merchantCurrency; @SerializedName("merchant_data") MerchantData merchantData; /** * Set of key-value pairs that you can attach * to an object. This can be useful for storing additional information about the object in a * structured format. */ @Getter(onMethod_ = {@Override}) @SerializedName("metadata") Map metadata; /** Details about the transaction, such as processing dates, set by the card network. */ @SerializedName("network_data") NetworkData networkData; /** * String representing the object's type. Objects of the same type share the same value. * *

Equal to {@code issuing.transaction}. */ @SerializedName("object") String object; /** Additional purchase information that is optionally provided by the merchant. */ @SerializedName("purchase_details") PurchaseDetails purchaseDetails; @SerializedName("settlement") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField settlement; /** * Token object used for this * transaction. If a network token was not used for this transaction, this field will be null. */ @SerializedName("token") @Getter(lombok.AccessLevel.NONE) @Setter(lombok.AccessLevel.NONE) ExpandableField token; /** * Treasury details related to this transaction * if it was created on a [FinancialAccount](/docs/api/treasury/financial_accounts */ @SerializedName("treasury") Treasury treasury; /** * The nature of the transaction. * *

One of {@code capture}, or {@code refund}. */ @SerializedName("type") String type; /** * The digital wallet used for this transaction. One of {@code apple_pay}, {@code google_pay}, or * {@code samsung_pay}. */ @SerializedName("wallet") String wallet; /** Get ID of expandable {@code authorization} object. */ public String getAuthorization() { return (this.authorization != null) ? this.authorization.getId() : null; } public void setAuthorization(String id) { this.authorization = ApiResource.setExpandableFieldId(id, this.authorization); } /** Get expanded {@code authorization}. */ public Authorization getAuthorizationObject() { return (this.authorization != null) ? this.authorization.getExpanded() : null; } public void setAuthorizationObject(Authorization expandableObject) { this.authorization = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code balanceTransaction} object. */ public String getBalanceTransaction() { return (this.balanceTransaction != null) ? this.balanceTransaction.getId() : null; } public void setBalanceTransaction(String id) { this.balanceTransaction = ApiResource.setExpandableFieldId(id, this.balanceTransaction); } /** Get expanded {@code balanceTransaction}. */ public BalanceTransaction getBalanceTransactionObject() { return (this.balanceTransaction != null) ? this.balanceTransaction.getExpanded() : null; } public void setBalanceTransactionObject(BalanceTransaction expandableObject) { this.balanceTransaction = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code card} object. */ public String getCard() { return (this.card != null) ? this.card.getId() : null; } public void setCard(String id) { this.card = ApiResource.setExpandableFieldId(id, this.card); } /** Get expanded {@code card}. */ public Card getCardObject() { return (this.card != null) ? this.card.getExpanded() : null; } public void setCardObject(Card expandableObject) { this.card = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code cardholder} object. */ public String getCardholder() { return (this.cardholder != null) ? this.cardholder.getId() : null; } public void setCardholder(String id) { this.cardholder = ApiResource.setExpandableFieldId(id, this.cardholder); } /** Get expanded {@code cardholder}. */ public Cardholder getCardholderObject() { return (this.cardholder != null) ? this.cardholder.getExpanded() : null; } public void setCardholderObject(Cardholder expandableObject) { this.cardholder = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code dispute} object. */ public String getDispute() { return (this.dispute != null) ? this.dispute.getId() : null; } public void setDispute(String id) { this.dispute = ApiResource.setExpandableFieldId(id, this.dispute); } /** Get expanded {@code dispute}. */ public Dispute getDisputeObject() { return (this.dispute != null) ? this.dispute.getExpanded() : null; } public void setDisputeObject(Dispute expandableObject) { this.dispute = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code settlement} object. */ public String getSettlement() { return (this.settlement != null) ? this.settlement.getId() : null; } public void setSettlement(String id) { this.settlement = ApiResource.setExpandableFieldId(id, this.settlement); } /** Get expanded {@code settlement}. */ public Settlement getSettlementObject() { return (this.settlement != null) ? this.settlement.getExpanded() : null; } public void setSettlementObject(Settlement expandableObject) { this.settlement = new ExpandableField(expandableObject.getId(), expandableObject); } /** Get ID of expandable {@code token} object. */ public String getToken() { return (this.token != null) ? this.token.getId() : null; } public void setToken(String id) { this.token = ApiResource.setExpandableFieldId(id, this.token); } /** Get expanded {@code token}. */ public Token getTokenObject() { return (this.token != null) ? this.token.getExpanded() : null; } public void setTokenObject(Token expandableObject) { this.token = new ExpandableField(expandableObject.getId(), expandableObject); } /** * Returns a list of Issuing {@code Transaction} objects. The objects are sorted in descending * order by creation date, with the most recently created object appearing first. */ public static TransactionCollection list(Map params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of Issuing {@code Transaction} objects. The objects are sorted in descending * order by creation date, with the most recently created object appearing first. */ public static TransactionCollection list(Map params, RequestOptions options) throws StripeException { String path = "/v1/issuing/transactions"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, TransactionCollection.class); } /** * Returns a list of Issuing {@code Transaction} objects. The objects are sorted in descending * order by creation date, with the most recently created object appearing first. */ public static TransactionCollection list(TransactionListParams params) throws StripeException { return list(params, (RequestOptions) null); } /** * Returns a list of Issuing {@code Transaction} objects. The objects are sorted in descending * order by creation date, with the most recently created object appearing first. */ public static TransactionCollection list(TransactionListParams params, RequestOptions options) throws StripeException { String path = "/v1/issuing/transactions"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, TransactionCollection.class); } /** Retrieves an Issuing {@code Transaction} object. */ public static Transaction retrieve(String transaction) throws StripeException { return retrieve(transaction, (Map) null, (RequestOptions) null); } /** Retrieves an Issuing {@code Transaction} object. */ public static Transaction retrieve(String transaction, RequestOptions options) throws StripeException { return retrieve(transaction, (Map) null, options); } /** Retrieves an Issuing {@code Transaction} object. */ public static Transaction retrieve( String transaction, Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/issuing/transactions/%s", ApiResource.urlEncodeId(transaction)); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options); return getGlobalResponseGetter().request(request, Transaction.class); } /** Retrieves an Issuing {@code Transaction} object. */ public static Transaction retrieve( String transaction, TransactionRetrieveParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/issuing/transactions/%s", ApiResource.urlEncodeId(transaction)); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.GET, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Transaction.class); } /** * Updates the specified Issuing {@code Transaction} object by setting the values of the * parameters passed. Any parameters not provided will be left unchanged. */ @Override public Transaction update(Map params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified Issuing {@code Transaction} object by setting the values of the * parameters passed. Any parameters not provided will be left unchanged. */ @Override public Transaction update(Map params, RequestOptions options) throws StripeException { String path = String.format("/v1/issuing/transactions/%s", ApiResource.urlEncodeId(this.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getResponseGetter().request(request, Transaction.class); } /** * Updates the specified Issuing {@code Transaction} object by setting the values of the * parameters passed. Any parameters not provided will be left unchanged. */ public Transaction update(TransactionUpdateParams params) throws StripeException { return update(params, (RequestOptions) null); } /** * Updates the specified Issuing {@code Transaction} object by setting the values of the * parameters passed. Any parameters not provided will be left unchanged. */ public Transaction update(TransactionUpdateParams params, RequestOptions options) throws StripeException { String path = String.format("/v1/issuing/transactions/%s", ApiResource.urlEncodeId(this.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getResponseGetter().request(request, Transaction.class); } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class AmountDetails extends StripeObject { /** The fee charged by the ATM for the cash withdrawal. */ @SerializedName("atm_fee") Long atmFee; /** The amount of cash requested by the cardholder. */ @SerializedName("cashback_amount") Long cashbackAmount; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class MerchantData extends StripeObject { /** * A categorization of the seller's type of business. See our merchant categories guide for * a list of possible values. */ @SerializedName("category") String category; /** The merchant category code for the seller’s business. */ @SerializedName("category_code") String categoryCode; /** City where the seller is located. */ @SerializedName("city") String city; /** Country where the seller is located. */ @SerializedName("country") String country; /** Name of the seller. */ @SerializedName("name") String name; /** * Identifier assigned to the seller by the card network. Different card networks may assign * different network_id fields to the same merchant. */ @SerializedName("network_id") String networkId; /** Postal code where the seller is located. */ @SerializedName("postal_code") String postalCode; /** State where the seller is located. */ @SerializedName("state") String state; /** An ID assigned by the seller to the location of the sale. */ @SerializedName("terminal_id") String terminalId; /** URL provided by the merchant on a 3DS request. */ @SerializedName("url") String url; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class NetworkData extends StripeObject { /** * A code created by Stripe which is shared with the merchant to validate the authorization. * This field will be populated if the authorization message was approved. The code typically * starts with the letter "S", followed by a six-digit number. For example, * "S498162". Please note that the code is not guaranteed to be unique across * authorizations. */ @SerializedName("authorization_code") String authorizationCode; /** * The date the transaction was processed by the card network. This can be different from the * date the seller recorded the transaction depending on when the acquirer submits the * transaction to the network. */ @SerializedName("processing_date") String processingDate; /** * Unique identifier for the authorization assigned by the card network used to match subsequent * messages, disputes, and transactions. */ @SerializedName("transaction_id") String transactionId; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class PurchaseDetails extends StripeObject { /** Fleet-specific information for transactions using Fleet cards. */ @SerializedName("fleet") Fleet fleet; /** Information about the flight that was purchased with this transaction. */ @SerializedName("flight") Flight flight; /** Information about fuel that was purchased with this transaction. */ @SerializedName("fuel") Fuel fuel; /** Information about lodging that was purchased with this transaction. */ @SerializedName("lodging") Lodging lodging; /** The line items in the purchase. */ @SerializedName("receipt") List receipt; /** A merchant-specific order number. */ @SerializedName("reference") String reference; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Fleet extends StripeObject { /** Answers to prompts presented to cardholder at point of sale. */ @SerializedName("cardholder_prompt_data") CardholderPromptData cardholderPromptData; /** * The type of purchase. One of {@code fuel_purchase}, {@code non_fuel_purchase}, or {@code * fuel_and_non_fuel_purchase}. */ @SerializedName("purchase_type") String purchaseType; /** * More information about the total amount. This information is not guaranteed to be accurate * as some merchants may provide unreliable data. */ @SerializedName("reported_breakdown") ReportedBreakdown reportedBreakdown; /** * The type of fuel service. One of {@code non_fuel_transaction}, {@code full_service}, or * {@code self_service}. */ @SerializedName("service_type") String serviceType; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class CardholderPromptData extends StripeObject { /** Driver ID. */ @SerializedName("driver_id") String driverId; /** Odometer reading. */ @SerializedName("odometer") Long odometer; /** * An alphanumeric ID. This field is used when a vehicle ID, driver ID, or generic ID is * entered by the cardholder, but the merchant or card network did not specify the prompt * type. */ @SerializedName("unspecified_id") String unspecifiedId; /** User ID. */ @SerializedName("user_id") String userId; /** Vehicle number. */ @SerializedName("vehicle_number") String vehicleNumber; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class ReportedBreakdown extends StripeObject { /** Breakdown of fuel portion of the purchase. */ @SerializedName("fuel") Fuel fuel; /** Breakdown of non-fuel portion of the purchase. */ @SerializedName("non_fuel") NonFuel nonFuel; /** Information about tax included in this transaction. */ @SerializedName("tax") Tax tax; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Fuel extends StripeObject { /** * Gross fuel amount that should equal Fuel Volume multipled by Fuel Unit Cost, inclusive * of taxes. */ @SerializedName("gross_amount_decimal") BigDecimal grossAmountDecimal; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class NonFuel extends StripeObject { /** * Gross non-fuel amount that should equal the sum of the line items, inclusive of taxes. */ @SerializedName("gross_amount_decimal") BigDecimal grossAmountDecimal; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Tax extends StripeObject { /** * Amount of state or provincial Sales Tax included in the transaction amount. Null if not * reported by merchant or not subject to tax. */ @SerializedName("local_amount_decimal") BigDecimal localAmountDecimal; /** * Amount of national Sales Tax or VAT included in the transaction amount. Null if not * reported by merchant or not subject to tax. */ @SerializedName("national_amount_decimal") BigDecimal nationalAmountDecimal; } } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Flight extends StripeObject { /** The time that the flight departed. */ @SerializedName("departure_at") Long departureAt; /** The name of the passenger. */ @SerializedName("passenger_name") String passengerName; /** Whether the ticket is refundable. */ @SerializedName("refundable") Boolean refundable; /** The legs of the trip. */ @SerializedName("segments") List segments; /** The travel agency that issued the ticket. */ @SerializedName("travel_agency") String travelAgency; @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Segment extends StripeObject { /** The three-letter IATA airport code of the flight's destination. */ @SerializedName("arrival_airport_code") String arrivalAirportCode; /** The airline carrier code. */ @SerializedName("carrier") String carrier; /** The three-letter IATA airport code that the flight departed from. */ @SerializedName("departure_airport_code") String departureAirportCode; /** The flight number. */ @SerializedName("flight_number") String flightNumber; /** The flight's service class. */ @SerializedName("service_class") String serviceClass; /** Whether a stopover is allowed on this flight. */ @SerializedName("stopover_allowed") Boolean stopoverAllowed; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Fuel extends StripeObject { /** * Conexxus Payment * System Product Code identifying the primary fuel product purchased. */ @SerializedName("industry_product_code") String industryProductCode; /** * The quantity of {@code unit}s of fuel that was dispensed, represented as a decimal string * with at most 12 decimal places. */ @SerializedName("quantity_decimal") BigDecimal quantityDecimal; /** * The type of fuel that was purchased. One of {@code diesel}, {@code unleaded_plus}, {@code * unleaded_regular}, {@code unleaded_super}, or {@code other}. */ @SerializedName("type") String type; /** * The units for {@code quantity_decimal}. One of {@code charging_minute}, {@code * imperial_gallon}, {@code kilogram}, {@code kilowatt_hour}, {@code liter}, {@code pound}, * {@code us_gallon}, or {@code other}. */ @SerializedName("unit") String unit; /** * The cost in cents per each unit of fuel, represented as a decimal string with at most 12 * decimal places. */ @SerializedName("unit_cost_decimal") BigDecimal unitCostDecimal; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Lodging extends StripeObject { /** The time of checking into the lodging. */ @SerializedName("check_in_at") Long checkInAt; /** The number of nights stayed at the lodging. */ @SerializedName("nights") Long nights; } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Receipt extends StripeObject { /** The description of the item. The maximum length of this field is 26 characters. */ @SerializedName("description") String description; /** The quantity of the item. */ @SerializedName("quantity") BigDecimal quantity; /** The total for this line item in cents. */ @SerializedName("total") Long total; /** The unit cost of the item in cents. */ @SerializedName("unit_cost") Long unitCost; } } @Getter @Setter @EqualsAndHashCode(callSuper = false) public static class Treasury extends StripeObject { /** * The Treasury ReceivedCredit representing * this Issuing transaction if it is a refund */ @SerializedName("received_credit") String receivedCredit; /** * The Treasury ReceivedDebit * representing this Issuing transaction if it is a capture */ @SerializedName("received_debit") String receivedDebit; } public TestHelpers getTestHelpers() { return new TestHelpers(this); } public static class TestHelpers { private final Transaction resource; private TestHelpers(Transaction resource) { this.resource = resource; } /** Refund a test-mode Transaction. */ public Transaction refund() throws StripeException { return refund((Map) null, (RequestOptions) null); } /** Refund a test-mode Transaction. */ public Transaction refund(RequestOptions options) throws StripeException { return refund((Map) null, options); } /** Refund a test-mode Transaction. */ public Transaction refund(Map params) throws StripeException { return refund(params, (RequestOptions) null); } /** Refund a test-mode Transaction. */ public Transaction refund(Map params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/issuing/transactions/%s/refund", ApiResource.urlEncodeId(this.resource.getId())); ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return resource.getResponseGetter().request(request, Transaction.class); } /** Refund a test-mode Transaction. */ public Transaction refund(TransactionRefundParams params) throws StripeException { return refund(params, (RequestOptions) null); } /** Refund a test-mode Transaction. */ public Transaction refund(TransactionRefundParams params, RequestOptions options) throws StripeException { String path = String.format( "/v1/test_helpers/issuing/transactions/%s/refund", ApiResource.urlEncodeId(this.resource.getId())); ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return resource.getResponseGetter().request(request, Transaction.class); } /** Allows the user to capture an arbitrary amount, also known as a forced capture. */ public static Transaction createForceCapture(Map params) throws StripeException { return createForceCapture(params, (RequestOptions) null); } /** Allows the user to capture an arbitrary amount, also known as a forced capture. */ public static Transaction createForceCapture(Map params, RequestOptions options) throws StripeException { String path = "/v1/test_helpers/issuing/transactions/create_force_capture"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Transaction.class); } /** Allows the user to capture an arbitrary amount, also known as a forced capture. */ public static Transaction createForceCapture(TransactionCreateForceCaptureParams params) throws StripeException { return createForceCapture(params, (RequestOptions) null); } /** Allows the user to capture an arbitrary amount, also known as a forced capture. */ public static Transaction createForceCapture( TransactionCreateForceCaptureParams params, RequestOptions options) throws StripeException { String path = "/v1/test_helpers/issuing/transactions/create_force_capture"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Transaction.class); } /** Allows the user to refund an arbitrary amount, also known as a unlinked refund. */ public static Transaction createUnlinkedRefund(Map params) throws StripeException { return createUnlinkedRefund(params, (RequestOptions) null); } /** Allows the user to refund an arbitrary amount, also known as a unlinked refund. */ public static Transaction createUnlinkedRefund( Map params, RequestOptions options) throws StripeException { String path = "/v1/test_helpers/issuing/transactions/create_unlinked_refund"; ApiRequest request = new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options); return getGlobalResponseGetter().request(request, Transaction.class); } /** Allows the user to refund an arbitrary amount, also known as a unlinked refund. */ public static Transaction createUnlinkedRefund(TransactionCreateUnlinkedRefundParams params) throws StripeException { return createUnlinkedRefund(params, (RequestOptions) null); } /** Allows the user to refund an arbitrary amount, also known as a unlinked refund. */ public static Transaction createUnlinkedRefund( TransactionCreateUnlinkedRefundParams params, RequestOptions options) throws StripeException { String path = "/v1/test_helpers/issuing/transactions/create_unlinked_refund"; ApiResource.checkNullTypedParams(path, params); ApiRequest request = new ApiRequest( BaseAddress.API, ApiResource.RequestMethod.POST, path, ApiRequestParams.paramsToMap(params), options); return getGlobalResponseGetter().request(request, Transaction.class); } } @Override public void setResponseGetter(StripeResponseGetter responseGetter) { super.setResponseGetter(responseGetter); trySetResponseGetter(amountDetails, responseGetter); trySetResponseGetter(authorization, responseGetter); trySetResponseGetter(balanceTransaction, responseGetter); trySetResponseGetter(card, responseGetter); trySetResponseGetter(cardholder, responseGetter); trySetResponseGetter(dispute, responseGetter); trySetResponseGetter(merchantData, responseGetter); trySetResponseGetter(networkData, responseGetter); trySetResponseGetter(purchaseDetails, responseGetter); trySetResponseGetter(settlement, responseGetter); trySetResponseGetter(token, responseGetter); trySetResponseGetter(treasury, responseGetter); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy