1Fetch Client API

<back to all web services

TestSubscription

The following routes are available for this service:
GET,POST/subscription/testFire a test to one of your webhooks
GET,POST/subscription/test/{EventType}Fire a test to one of your webhooks
import 'package:servicestack/servicestack.dart';

class ApiServiceRequest implements IServiceRequest, IHasApiKey, IConvertible
{
    /**
    * The API Key required for authentication
    */
    // @ApiMember(DataType="string", Description="The API Key required for authentication", IsRequired=true)
    String? ApiKey;

    ApiServiceRequest({this.ApiKey});
    ApiServiceRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        ApiKey = json['ApiKey'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'ApiKey': ApiKey
    };

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

class ApiServiceResponse implements IServiceResponse, IConvertible
{
    /**
    * Information about the response.
    */
    // @ApiMember(Description="Information about the response.", IsRequired=true)
    String? Description;

    /**
    * Heading or summary of the response.
    */
    // @ApiMember(Description="Heading or summary of the response.", IsRequired=true)
    String? Heading;

    /**
    * Did the intended operation for this response complete successfully?
    */
    // @ApiMember(DataType="boolean", Description="Did the intended operation for this response complete successfully?", IsRequired=true)
    bool? WasSuccessful;

    ApiServiceResponse({this.Description,this.Heading,this.WasSuccessful});
    ApiServiceResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        Description = json['Description'];
        Heading = json['Heading'];
        WasSuccessful = json['WasSuccessful'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'Description': Description,
        'Heading': Heading,
        'WasSuccessful': WasSuccessful
    };

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

class WebhookSubscriptionEventType
{
    static const WebhookSubscriptionEventType DriverOnTheWay = const WebhookSubscriptionEventType._(0);
    static const WebhookSubscriptionEventType ArrivedAtWaypoint = const WebhookSubscriptionEventType._(1);
    static const WebhookSubscriptionEventType DepartedWaypoint = const WebhookSubscriptionEventType._(2);
    static const WebhookSubscriptionEventType OrderCompleted = const WebhookSubscriptionEventType._(3);
    static const WebhookSubscriptionEventType OrderCancelled = const WebhookSubscriptionEventType._(4);

    final int _value;
    const WebhookSubscriptionEventType._(this._value);
    int get value => _value;
    static List<WebhookSubscriptionEventType> get values => const [DriverOnTheWay,ArrivedAtWaypoint,DepartedWaypoint,OrderCompleted,OrderCancelled];
}

class TestSubscription extends ApiServiceRequest implements ILogRequest, IConvertible
{
    /**
    * The event type being subscribed to
    */
    // @ApiMember(Description="The event type being subscribed to", IsRequired=true)
    WebhookSubscriptionEventType? EventType;

    TestSubscription({this.EventType});
    TestSubscription.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        EventType = JsonConverters.fromJson(json['EventType'],'WebhookSubscriptionEventType',context!);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'EventType': JsonConverters.toJson(EventType,'WebhookSubscriptionEventType',context!)
    });

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

TypeContext _ctx = TypeContext(library: '1fetch.api.client.prod.86degrees.com', types: <String, TypeInfo> {
    'ApiServiceRequest': TypeInfo(TypeOf.Class, create:() => ApiServiceRequest()),
    'ApiServiceResponse': TypeInfo(TypeOf.Class, create:() => ApiServiceResponse()),
    'WebhookSubscriptionEventType': TypeInfo(TypeOf.Enum, enumValues:WebhookSubscriptionEventType.values),
    'TestSubscription': TypeInfo(TypeOf.Class, create:() => TestSubscription()),
});

Dart TestSubscription DTOs

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

HTTP + XML

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

POST /subscription/test HTTP/1.1 
Host: 1fetch.api.client.prod.86degrees.com 
Accept: application/xml
Content-Type: application/xml
Content-Length: length

<TestSubscription xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel">
  <ApiKey xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel.Base">String</ApiKey>
  <EventType>DriverOnTheWay</EventType>
</TestSubscription>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<ApiServiceResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel.Base">
  <Description>String</Description>
  <Heading>String</Heading>
  <WasSuccessful>false</WasSuccessful>
</ApiServiceResponse>