BokaMera.API.Host

<back to all web services

CreateStripeWebhook

Requires Authentication
Requires any of the roles:bookingsupplier-administrator-write, bookingsupplier-administrator-read, superadmin
The following routes are available for this service:
POST/payment/stripe/v1/webhookCreate stripe webhook with all events: By default it will create webhook set in settings with all events covered in bokameraCreate stripe webhook with all events
using System;
using System.IO;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using BokaMera.API.ServiceModel.Dtos;

namespace BokaMera.API.ServiceModel.Dtos
{
    public partial class CreateStripeWebhook
        : ICompany
    {
        ///<summary>
        ///The company id, if empty will use the company id for the user you are logged in with.
        ///</summary>
        [ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.")]
        public virtual Guid? CompanyId { get; set; }

        ///<summary>
        ///Events (webhooks) that are accepted by stripe.
        ///</summary>
        [ApiMember(Description="Events (webhooks) that are accepted by stripe.")]
        public virtual List<string> Events { get; set; } = [];

        ///<summary>
        ///Should webhook listen to customer events's
        ///</summary>
        [ApiMember(Description="Should webhook listen to customer events's")]
        public virtual bool Connect { get; set; }

        ///<summary>
        ///Url that stripe should send hook to.
        ///</summary>
        [ApiMember(Description="Url that stripe should send hook to.")]
        public virtual string Url { get; set; }
    }

    public partial class StripeWebhookResponse
    {
        public virtual string Id { get; set; }
        public virtual List<string> Events { get; set; } = [];
        public virtual string Url { get; set; }
    }

}

C# CreateStripeWebhook DTOs

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

HTTP + JSV

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

POST /payment/stripe/v1/webhook HTTP/1.1 
Host: api.bokamera.se 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	CompanyId: 00000000-0000-0000-0000-000000000000,
	Events: 
	[
		String
	],
	Connect: False,
	Url: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	Id: String,
	Events: 
	[
		String
	],
	Url: String
}