BokaMera.API.Host

<back to all web services

StripeV1CreateCheckout

The following routes are available for this service:
POST/payment/stripe/v1/checkoutCreate an checkout for Payble entity. Note if existing checkouts already exists, it will invalidate those.Create Stripe checkout (requires settings for Stripe Checkout 1.0)
import java.math.*;
import java.util.*;
import net.servicestack.client.*;

public class dtos
{

    public static class StripeV1CreateCheckout implements ICompany
    {
        /**
        * The company id.
        */
        @ApiMember(Description="The company id.", IsRequired=true)
        public UUID CompanyId = null;

        /**
        * Country code for checkout
        */
        @ApiMember(Description="Country code for checkout", IsRequired=true)
        public String CountryCode = null;

        /**
        * Articles (Could be Service, rebate code types, etc..
        */
        @ApiMember(Description="Articles (Could be Service, rebate code types, etc..", IsRequired=true)
        public ArrayList<ArticleToCreate> Articles = null;

        /**
        * An internal reference id (Could be booking, rebate code etc.)
        */
        @ApiMember(Description="An internal reference id (Could be booking, rebate code etc.)", IsRequired=true)
        public String InternalReferenceId = null;

        /**
        * Optional to set your own confirmation url after payment completed.
        */
        @ApiMember(Description="Optional to set your own confirmation url after payment completed.")
        public String ConfirmationUrl = null;

        /**
        * If set, Checkout displays a back button and customers will be directed to this URL if they decide to cancel payment and return to your website. This parameter is not allowed if ui_mode is <c>embedded</c>.
        */
        @ApiMember(Description="If set, Checkout displays a back button and customers will be directed to this URL if they decide to cancel payment and return to your website. This parameter is not allowed if ui_mode is <c>embedded</c>.")
        public String CancelUrl = null;

        /**
        * The UI mode of the Session. Defaults to <c>hosted</c>; One of: <c>embedded</c>, or <c>hosted</c>
        */
        @ApiMember(Description="The UI mode of the Session. Defaults to <c>hosted</c>; One of: <c>embedded</c>, or <c>hosted</c>", IsRequired=true)
        public String UiMode = null;
        
        public UUID getCompanyId() { return CompanyId; }
        public StripeV1CreateCheckout setCompanyId(UUID value) { this.CompanyId = value; return this; }
        public String getCountryCode() { return CountryCode; }
        public StripeV1CreateCheckout setCountryCode(String value) { this.CountryCode = value; return this; }
        public ArrayList<ArticleToCreate> getArticles() { return Articles; }
        public StripeV1CreateCheckout setArticles(ArrayList<ArticleToCreate> value) { this.Articles = value; return this; }
        public String getInternalReferenceId() { return InternalReferenceId; }
        public StripeV1CreateCheckout setInternalReferenceId(String value) { this.InternalReferenceId = value; return this; }
        public String getConfirmationUrl() { return ConfirmationUrl; }
        public StripeV1CreateCheckout setConfirmationUrl(String value) { this.ConfirmationUrl = value; return this; }
        public String getCancelUrl() { return CancelUrl; }
        public StripeV1CreateCheckout setCancelUrl(String value) { this.CancelUrl = value; return this; }
        public String getUiMode() { return UiMode; }
        public StripeV1CreateCheckout setUiMode(String value) { this.UiMode = value; return this; }
    }

    public static class ArticleToCreate
    {
        public Integer ArticleId = null;
        public Integer ArticleTypeId = null;
        public Integer Quantity = null;
        
        public Integer getArticleId() { return ArticleId; }
        public ArticleToCreate setArticleId(Integer value) { this.ArticleId = value; return this; }
        public Integer getArticleTypeId() { return ArticleTypeId; }
        public ArticleToCreate setArticleTypeId(Integer value) { this.ArticleTypeId = value; return this; }
        public Integer getQuantity() { return Quantity; }
        public ArticleToCreate setQuantity(Integer value) { this.Quantity = value; return this; }
    }

    public static class StripeCheckoutQueryResponse
    {
        /**
        * The checkout session id
        */
        @ApiMember(Description="The checkout session id")
        public String SessionId = null;

        /**
        * The url for checkout module to be placed in a iframe
        */
        @ApiMember(Description="The url for checkout module to be placed in a iframe")
        public String Url = null;

        /**
        * The checkout status
        */
        @ApiMember(Description="The checkout status")
        public String Status = null;

        /**
        * Client secret to be used when initializing Stripe.js embedded checkout.
        */
        @ApiMember(Description="Client secret to be used when initializing Stripe.js embedded checkout.")
        public String ClientSecret = null;

        /**
        * (ID of the Customer) The ID of the customer for this Session. For Checkout Sessions in subscription mode or Checkout Sessions with customer_creation set as always in payment mode, Checkout will create a new customer object based on information provided during the payment flow unless an existing customer was provided when the Session was created.
        */
        @ApiMember(Description="(ID of the Customer) The ID of the customer for this Session. For Checkout Sessions in subscription mode or Checkout Sessions with customer_creation set as always in payment mode, Checkout will create a new customer object based on information provided during the payment flow unless an existing customer was provided when the Session was created.")
        public String CustomerId = null;

        /**
        * The client secret of this PaymentIntent. Used for client-side retrieval using a publishable key. The client secret can be used to complete a payment from your frontend. It should not be stored, logged, or exposed to anyone other than the customer. Make sure that you have TLS enabled on any page that includes the client secret. Refer to our docs to accept a payment   and learn about how client_secret should be handled.
        */
        @ApiMember(Description="The client secret of this PaymentIntent. Used for client-side retrieval using a publishable key. The client secret can be used to complete a payment from your frontend. It should not be stored, logged, or exposed to anyone other than the customer. Make sure that you have TLS enabled on any page that includes the client secret. Refer to our docs to accept a payment   and learn about how client_secret should be handled.")
        public String PaymentIntentClientSecret = null;

        public String PaymentIntentId = null;
        public String StripeAccount = null;
        
        public String getSessionId() { return SessionId; }
        public StripeCheckoutQueryResponse setSessionId(String value) { this.SessionId = value; return this; }
        public String getUrl() { return Url; }
        public StripeCheckoutQueryResponse setUrl(String value) { this.Url = value; return this; }
        public String getStatus() { return Status; }
        public StripeCheckoutQueryResponse setStatus(String value) { this.Status = value; return this; }
        public String getClientSecret() { return ClientSecret; }
        public StripeCheckoutQueryResponse setClientSecret(String value) { this.ClientSecret = value; return this; }
        public String getCustomerId() { return CustomerId; }
        public StripeCheckoutQueryResponse setCustomerId(String value) { this.CustomerId = value; return this; }
        public String getPaymentIntentClientSecret() { return PaymentIntentClientSecret; }
        public StripeCheckoutQueryResponse setPaymentIntentClientSecret(String value) { this.PaymentIntentClientSecret = value; return this; }
        public String getPaymentIntentId() { return PaymentIntentId; }
        public StripeCheckoutQueryResponse setPaymentIntentId(String value) { this.PaymentIntentId = value; return this; }
        public String getStripeAccount() { return StripeAccount; }
        public StripeCheckoutQueryResponse setStripeAccount(String value) { this.StripeAccount = value; return this; }
    }

}

Java StripeV1CreateCheckout DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .other suffix or ?format=other

HTTP + OTHER

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /payment/stripe/v1/checkout HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/jsonl
Content-Type: text/jsonl
Content-Length: length

{"CompanyId":"00000000-0000-0000-0000-000000000000","CountryCode":"String","Articles":[{"ArticleId":0,"ArticleTypeId":0,"Quantity":0}],"InternalReferenceId":"String","ConfirmationUrl":"String","CancelUrl":"String","UiMode":"String"}
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length

{"SessionId":"String","Url":"String","Status":"String","ClientSecret":"String","CustomerId":"String","PaymentIntentClientSecret":"String","PaymentIntentId":"String","StripeAccount":"String"}