Required role: | Employee |
POST | /coupons |
---|
import 'package:servicestack/servicestack.dart';
import 'dart:typed_data';
// @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? description;
// @Validate(Validator="GreaterThan(0)")
int? discount;
// @required()
DateTime? expiryDate;
CreateCoupon({this.description,this.discount,this.expiryDate});
CreateCoupon.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
description = json['description'];
discount = json['discount'];
expiryDate = JsonConverters.fromJson(json['expiryDate'],'DateTime',context!);
return this;
}
Map<String, dynamic> toJson() => {
'description': description,
'discount': discount,
'expiryDate': JsonConverters.toJson(expiryDate,'DateTime',context!)
};
getTypeName() => "CreateCoupon";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'blazor_gallery.servicestack.net', types: <String, TypeInfo> {
'CreateCoupon': TypeInfo(TypeOf.Class, create:() => CreateCoupon()),
});
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.
POST /coupons HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"description":"String","discount":0,"expiryDate":"0001-01-01T00:00:00"}
HTTP/1.1 200 OK Content-Type: text/csv 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"}}}