| Required role: | Employee |
| POST | /coupons |
|---|
import 'package:servicestack/servicestack.dart';
// @DataContract
class IdResponse implements IConvertible
{
// @DataMember(Order=1)
String id = "";
// @DataMember(Order=2)
ResponseStatus? responseStatus;
IdResponse({this.id,this.responseStatus});
IdResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
id = json['id'];
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
return this;
}
Map<String, dynamic> toJson() => {
'id': id,
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
};
getTypeName() => "IdResponse";
TypeContext? context = _ctx;
}
// @ValidateRequest(Validator="HasRole(`Employee`)")
class CreateCoupon implements ICreateDb<Coupon>, IConvertible
{
// @Validate(Validator="NotEmpty")
String id = "";
// @Validate(Validator="NotEmpty")
String description = "";
// @Validate(Validator="GreaterThan(0)")
int discount = 0;
// @Validate(Validator="NotNull")
DateTime expiryDate = DateTime(0);
CreateCoupon({this.id,this.description,this.discount,this.expiryDate});
CreateCoupon.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
id = json['id'];
description = json['description'];
discount = json['discount'];
expiryDate = JsonConverters.fromJson(json['expiryDate'],'DateTime',context!);
return this;
}
Map<String, dynamic> toJson() => {
'id': id,
'description': description,
'discount': discount,
'expiryDate': JsonConverters.toJson(expiryDate,'DateTime',context!)
};
getTypeName() => "CreateCoupon";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'blazor_vue.web_templates.io', types: <String, TypeInfo> {
'CreateCoupon': TypeInfo(TypeOf.Class, create:() => CreateCoupon()),
});
To override the Content-type in your clients, use the HTTP Accept Header, append the .json suffix or ?format=json
To embed the response in a jsonp callback, append ?callback=myCallback
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /coupons HTTP/1.1
Host: blazor-vue.web-templates.io
Accept: application/json
Content-Type: application/json
Content-Length: length
{"id":"String","description":"String","discount":0,"expiryDate":"0001-01-01T00:00:00"}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length
{"id":"String","responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}