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 .jsv suffix or ?format=jsv
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/jsv
Content-Type: text/jsv
Content-Length: length
{
id: 0,
name: String,
roomType: Single,
roomNumber: 0,
cost: 0,
bookingStartDate: 0001-01-01,
bookingEndDate: 0001-01-01,
notes: String,
couponId: String,
cancelled: False
}
HTTP/1.1 200 OK Content-Type: text/jsv 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 } } }