BokaMera.API.Host

<back to all web services

UpdateWebhookEndpoint

Requires Authentication
Requires any of the roles:bookingsupplier-administrator-write, superadmin
The following routes are available for this service:
PUT/webhook/endpoints/{id}Update webhook endpoint
import 'package:servicestack/servicestack.dart';

class WebhookEndpoint implements IConvertible
{
    String? Description;
    String? Url;
    String? Id;
    bool? Disabled;
    List<String>? EventTypes;

    WebhookEndpoint({this.Description,this.Url,this.Id,this.Disabled,this.EventTypes});
    WebhookEndpoint.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        Description = json['Description'];
        Url = json['Url'];
        Id = json['Id'];
        Disabled = json['Disabled'];
        EventTypes = JsonConverters.fromJson(json['EventTypes'],'List<String>',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'Description': Description,
        'Url': Url,
        'Id': Id,
        'Disabled': Disabled,
        'EventTypes': JsonConverters.toJson(EventTypes,'List<String>',context!)
    };

    getTypeName() => "WebhookEndpoint";
    TypeContext? context = _ctx;
}

// @ApiResponse(Description="You were unauthorized to call this service", StatusCode=401)
// @ValidateRequest(Validator="IsAuthenticated")
class UpdateWebhookEndpoint implements ICompany, IConvertible
{
    /**
    * The company id, if empty will use the company id for the user you are logged in with.
    */
    // @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.", IsRequired=true, ParameterType="query")
    String? CompanyId;

    /**
    * The webhook endpoint URL.
    */
    // @ApiMember(Description="The webhook endpoint URL.", IsRequired=true)
    String? Url;

    /**
    * The ID of the webhook endpoint.
    */
    // @ApiMember(Description="The ID of the webhook endpoint.", IsRequired=true, ParameterType="path")
    String? Id;

    /**
    * List of event types. At least one event type is required.
    */
    // @ApiMember(Description="List of event types. At least one event type is required.", IsRequired=true)
    // @Validate(Validator="NotEmpty", ErrorCode="At least one event type is required.")
    List<String>? EventTypes;

    String? Description;
    bool? Disabled;

    UpdateWebhookEndpoint({this.CompanyId,this.Url,this.Id,this.EventTypes,this.Description,this.Disabled});
    UpdateWebhookEndpoint.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        CompanyId = json['CompanyId'];
        Url = json['Url'];
        Id = json['Id'];
        EventTypes = JsonConverters.fromJson(json['EventTypes'],'List<String>',context!);
        Description = json['Description'];
        Disabled = json['Disabled'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'CompanyId': CompanyId,
        'Url': Url,
        'Id': Id,
        'EventTypes': JsonConverters.toJson(EventTypes,'List<String>',context!),
        'Description': Description,
        'Disabled': Disabled
    };

    getTypeName() => "UpdateWebhookEndpoint";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'testapi.bokamera.se', types: <String, TypeInfo> {
    'WebhookEndpoint': TypeInfo(TypeOf.Class, create:() => WebhookEndpoint()),
    'UpdateWebhookEndpoint': TypeInfo(TypeOf.Class, create:() => UpdateWebhookEndpoint()),
});

Dart UpdateWebhookEndpoint 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.

PUT /webhook/endpoints/{id} HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

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

{
	Description: String,
	Url: String,
	Id: String,
	Disabled: False,
	EventTypes: 
	[
		String
	]
}