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)
<?php namespace dtos;

use DateTime;
use Exception;
use DateInterval;
use JsonSerializable;
use ServiceStack\{IReturn,IReturnVoid,IGet,IPost,IPut,IDelete,IPatch,IMeta,IHasSessionId,IHasBearerToken,IHasVersion};
use ServiceStack\{ICrud,ICreateDb,IUpdateDb,IPatchDb,IDeleteDb,ISaveDb,AuditBase,QueryDb,QueryDb2,QueryData,QueryData2,QueryResponse};
use ServiceStack\{ResponseStatus,ResponseError,EmptyResponse,IdResponse,ArrayList,KeyValuePair2,StringResponse,StringsResponse,Tuple2,Tuple3,ByteArray};
use ServiceStack\{JsonConverters,Returns,TypeContext};


class StripeCheckoutQueryResponse implements JsonSerializable
{
    public function __construct(
        /** @description The checkout session id */
        // @ApiMember(Description="The checkout session id")
        /** @var string|null */
        public ?string $SessionId=null,

        /** @description The url for checkout module to be placed in a iframe */
        // @ApiMember(Description="The url for checkout module to be placed in a iframe")
        /** @var string|null */
        public ?string $Url=null,

        /** @description The checkout status */
        // @ApiMember(Description="The checkout status")
        /** @var string|null */
        public ?string $Status=null,

        /** @description Client secret to be used when initializing Stripe.js embedded checkout. */
        // @ApiMember(Description="Client secret to be used when initializing Stripe.js embedded checkout.")
        /** @var string|null */
        public ?string $ClientSecret=null,

        /** @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. */
        // @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.")
        /** @var string|null */
        public ?string $CustomerId=null,

        /** @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. */
        // @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.")
        /** @var string|null */
        public ?string $PaymentIntentClientSecret=null,

        /** @var string|null */
        public ?string $PaymentIntentId=null,
        /** @var string|null */
        public ?string $StripeAccount=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['SessionId'])) $this->SessionId = $o['SessionId'];
        if (isset($o['Url'])) $this->Url = $o['Url'];
        if (isset($o['Status'])) $this->Status = $o['Status'];
        if (isset($o['ClientSecret'])) $this->ClientSecret = $o['ClientSecret'];
        if (isset($o['CustomerId'])) $this->CustomerId = $o['CustomerId'];
        if (isset($o['PaymentIntentClientSecret'])) $this->PaymentIntentClientSecret = $o['PaymentIntentClientSecret'];
        if (isset($o['PaymentIntentId'])) $this->PaymentIntentId = $o['PaymentIntentId'];
        if (isset($o['StripeAccount'])) $this->StripeAccount = $o['StripeAccount'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->SessionId)) $o['SessionId'] = $this->SessionId;
        if (isset($this->Url)) $o['Url'] = $this->Url;
        if (isset($this->Status)) $o['Status'] = $this->Status;
        if (isset($this->ClientSecret)) $o['ClientSecret'] = $this->ClientSecret;
        if (isset($this->CustomerId)) $o['CustomerId'] = $this->CustomerId;
        if (isset($this->PaymentIntentClientSecret)) $o['PaymentIntentClientSecret'] = $this->PaymentIntentClientSecret;
        if (isset($this->PaymentIntentId)) $o['PaymentIntentId'] = $this->PaymentIntentId;
        if (isset($this->StripeAccount)) $o['StripeAccount'] = $this->StripeAccount;
        return empty($o) ? new class(){} : $o;
    }
}

class StripeV1CreateCheckout implements ICompany, JsonSerializable
{
    public function __construct(
        /** @description The company id. */
        // @ApiMember(Description="The company id.", IsRequired=true)
        /** @var string */
        public string $CompanyId='',

        /** @description Country code for checkout */
        // @ApiMember(Description="Country code for checkout", IsRequired=true)
        /** @var string */
        public string $CountryCode='',

        /** @description Articles (Could be Service, rebate code types, etc.. */
        // @ApiMember(Description="Articles (Could be Service, rebate code types, etc..", IsRequired=true)
        /** @var ArticleToCreate[] */
        public array $Articles=[],

        /** @description An internal reference id (Could be booking, rebate code etc.) */
        // @ApiMember(Description="An internal reference id (Could be booking, rebate code etc.)", IsRequired=true)
        /** @var string */
        public string $InternalReferenceId='',

        /** @description Optional to set your own confirmation url after payment completed. */
        // @ApiMember(Description="Optional to set your own confirmation url after payment completed.")
        /** @var string|null */
        public ?string $ConfirmationUrl=null,

        /** @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>. */
        // @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>.")
        /** @var string|null */
        public ?string $CancelUrl=null,

        /** @description 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)
        /** @var string */
        public string $UiMode=''
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['CompanyId'])) $this->CompanyId = $o['CompanyId'];
        if (isset($o['CountryCode'])) $this->CountryCode = $o['CountryCode'];
        if (isset($o['Articles'])) $this->Articles = JsonConverters::fromArray('ArticleToCreate', $o['Articles']);
        if (isset($o['InternalReferenceId'])) $this->InternalReferenceId = $o['InternalReferenceId'];
        if (isset($o['ConfirmationUrl'])) $this->ConfirmationUrl = $o['ConfirmationUrl'];
        if (isset($o['CancelUrl'])) $this->CancelUrl = $o['CancelUrl'];
        if (isset($o['UiMode'])) $this->UiMode = $o['UiMode'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->CompanyId)) $o['CompanyId'] = $this->CompanyId;
        if (isset($this->CountryCode)) $o['CountryCode'] = $this->CountryCode;
        if (isset($this->Articles)) $o['Articles'] = JsonConverters::toArray('ArticleToCreate', $this->Articles);
        if (isset($this->InternalReferenceId)) $o['InternalReferenceId'] = $this->InternalReferenceId;
        if (isset($this->ConfirmationUrl)) $o['ConfirmationUrl'] = $this->ConfirmationUrl;
        if (isset($this->CancelUrl)) $o['CancelUrl'] = $this->CancelUrl;
        if (isset($this->UiMode)) $o['UiMode'] = $this->UiMode;
        return empty($o) ? new class(){} : $o;
    }
}

class ArticleToCreate implements JsonSerializable
{
    public function __construct(
        /** @var int */
        public int $ArticleId=0,
        /** @var int */
        public int $ArticleTypeId=0,
        /** @var int */
        public int $Quantity=0
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['ArticleId'])) $this->ArticleId = $o['ArticleId'];
        if (isset($o['ArticleTypeId'])) $this->ArticleTypeId = $o['ArticleTypeId'];
        if (isset($o['Quantity'])) $this->Quantity = $o['Quantity'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->ArticleId)) $o['ArticleId'] = $this->ArticleId;
        if (isset($this->ArticleTypeId)) $o['ArticleTypeId'] = $this->ArticleTypeId;
        if (isset($this->Quantity)) $o['Quantity'] = $this->Quantity;
        return empty($o) ? new class(){} : $o;
    }
}

PHP 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"}