| PUT | /subscription/{EventType} | Update your subscription to an event with a url we should post to | |
|---|---|---|---|
| PUT | /subscription | Update your subscription to an event with a url we should post to |
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
{
String? Description;
String? Heading;
bool? WasSuccessful;
dynamic? ModelState;
ApiServiceResponse({this.Description,this.Heading,this.WasSuccessful,this.ModelState});
ApiServiceResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
Description = json['Description'];
Heading = json['Heading'];
WasSuccessful = json['WasSuccessful'];
ModelState = JsonConverters.fromJson(json['ModelState'],'dynamic',context!);
return this;
}
Map<String, dynamic> toJson() => {
'Description': Description,
'Heading': Heading,
'WasSuccessful': WasSuccessful,
'ModelState': JsonConverters.toJson(ModelState,'dynamic',context!)
};
getTypeName() => "ApiServiceResponse";
TypeContext? context = _ctx;
}
class WebhookSubscriptionEventType
{
static const WebhookSubscriptionEventType MessageReceived = const WebhookSubscriptionEventType._(1);
final int _value;
const WebhookSubscriptionEventType._(this._value);
int get value => _value;
static List<WebhookSubscriptionEventType> get values => const [MessageReceived];
}
class UpdateSubscription extends ApiServiceRequest implements ILogRequest, IConvertible
{
/**
* The event type being subscribed to
*/
// @ApiMember(Description="The event type being subscribed to", IsRequired=true)
WebhookSubscriptionEventType? EventType;
/**
* The URL we should post the event data to
*/
// @ApiMember(Description="The URL we should post the event data to", IsRequired=true)
String? SubscriptionUrl;
UpdateSubscription({this.EventType,this.SubscriptionUrl});
UpdateSubscription.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
EventType = JsonConverters.fromJson(json['EventType'],'WebhookSubscriptionEventType',context!);
SubscriptionUrl = json['SubscriptionUrl'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'EventType': JsonConverters.toJson(EventType,'WebhookSubscriptionEventType',context!),
'SubscriptionUrl': SubscriptionUrl
});
getTypeName() => "UpdateSubscription";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'galaxymobile.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),
'UpdateSubscription': TypeInfo(TypeOf.Class, create:() => UpdateSubscription()),
});
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
PUT /subscription/{EventType} HTTP/1.1
Host: galaxymobile.api.client.prod.86degrees.com
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"EventType":1,"SubscriptionUrl":"String","ApiKey":"String"}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length
{"Description":"String","Heading":"String","WasSuccessful":false,"ModelState":{}}