Required role: | Employee |
PATCH | /booking/{Id} |
---|
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;
}
enum RoomType
{
Single,
Double,
Queen,
Twin,
Suite,
}
/**
* Update an existing Booking
*/
// @ValidateRequest(Validator="HasRole(`Employee`)")
class UpdateBooking implements IPatchDb<Booking>, IConvertible
{
int? id;
String? name;
RoomType? roomType;
// @Validate(Validator="GreaterThan(0)")
int? roomNumber;
// @Validate(Validator="GreaterThan(0)")
double? cost;
DateTime? bookingStartDate;
DateTime? bookingEndDate;
String? notes;
String? couponId;
bool? cancelled;
UpdateBooking({this.id,this.name,this.roomType,this.roomNumber,this.cost,this.bookingStartDate,this.bookingEndDate,this.notes,this.couponId,this.cancelled});
UpdateBooking.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
id = json['id'];
name = json['name'];
roomType = JsonConverters.fromJson(json['roomType'],'RoomType',context!);
roomNumber = json['roomNumber'];
cost = JsonConverters.toDouble(json['cost']);
bookingStartDate = JsonConverters.fromJson(json['bookingStartDate'],'DateTime',context!);
bookingEndDate = JsonConverters.fromJson(json['bookingEndDate'],'DateTime',context!);
notes = json['notes'];
couponId = json['couponId'];
cancelled = json['cancelled'];
return this;
}
Map<String, dynamic> toJson() => {
'id': id,
'name': name,
'roomType': JsonConverters.toJson(roomType,'RoomType',context!),
'roomNumber': roomNumber,
'cost': cost,
'bookingStartDate': JsonConverters.toJson(bookingStartDate,'DateTime',context!),
'bookingEndDate': JsonConverters.toJson(bookingEndDate,'DateTime',context!),
'notes': notes,
'couponId': couponId,
'cancelled': cancelled
};
getTypeName() => "UpdateBooking";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'blazor_gallery.servicestack.net', types: <String, TypeInfo> {
'RoomType': TypeInfo(TypeOf.Enum, enumValues:RoomType.values),
'UpdateBooking': TypeInfo(TypeOf.Class, create:() => UpdateBooking()),
});
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.
PATCH /booking/{Id} HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"id":0,"name":"String","roomType":"Single","roomNumber":0,"cost":0,"bookingStartDate":"0001-01-01T00:00:00","bookingEndDate":"0001-01-01T00:00:00","notes":"String","couponId":"String","cancelled":false}
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"}}}