GET | /invoices | ||
---|---|---|---|
GET | /invoices/{InvoiceId} |
import 'package:servicestack/servicestack.dart';
import 'dart:typed_data';
// @DataContract
abstract class QueryBase
{
// @DataMember(Order=1)
int? skip;
// @DataMember(Order=2)
int? take;
// @DataMember(Order=3)
String? orderBy;
// @DataMember(Order=4)
String? orderByDesc;
// @DataMember(Order=5)
String? include;
// @DataMember(Order=6)
String? fields;
// @DataMember(Order=7)
Map<String,String?>? meta;
QueryBase({this.skip,this.take,this.orderBy,this.orderByDesc,this.include,this.fields,this.meta});
QueryBase.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
skip = json['skip'];
take = json['take'];
orderBy = json['orderBy'];
orderByDesc = json['orderByDesc'];
include = json['include'];
fields = json['fields'];
meta = JsonConverters.toStringMap(json['meta']);
return this;
}
Map<String, dynamic> toJson() => {
'skip': skip,
'take': take,
'orderBy': orderBy,
'orderByDesc': orderByDesc,
'include': include,
'fields': fields,
'meta': meta
};
getTypeName() => "QueryBase";
TypeContext? context = _ctx;
}
abstract class QueryDb<T> extends QueryBase
{
QueryDb();
QueryDb.fromJson(Map<String, dynamic> json) : super.fromJson(json);
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
return this;
}
Map<String, dynamic> toJson() => super.toJson();
getTypeName() => "QueryDb<$T>";
TypeContext? context = _ctx;
}
class Invoices implements IConvertible
{
int? invoiceId;
int? customerId;
DateTime? invoiceDate;
String? billingAddress;
String? billingCity;
String? billingState;
String? billingCountry;
String? billingPostalCode;
double? total;
Invoices({this.invoiceId,this.customerId,this.invoiceDate,this.billingAddress,this.billingCity,this.billingState,this.billingCountry,this.billingPostalCode,this.total});
Invoices.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
invoiceId = json['invoiceId'];
customerId = json['customerId'];
invoiceDate = JsonConverters.fromJson(json['invoiceDate'],'DateTime',context!);
billingAddress = json['billingAddress'];
billingCity = json['billingCity'];
billingState = json['billingState'];
billingCountry = json['billingCountry'];
billingPostalCode = json['billingPostalCode'];
total = JsonConverters.toDouble(json['total']);
return this;
}
Map<String, dynamic> toJson() => {
'invoiceId': invoiceId,
'customerId': customerId,
'invoiceDate': JsonConverters.toJson(invoiceDate,'DateTime',context!),
'billingAddress': billingAddress,
'billingCity': billingCity,
'billingState': billingState,
'billingCountry': billingCountry,
'billingPostalCode': billingPostalCode,
'total': total
};
getTypeName() => "Invoices";
TypeContext? context = _ctx;
}
class QueryInvoices extends QueryDb<Invoices> implements IGet, IConvertible
{
int? invoiceId;
QueryInvoices({this.invoiceId});
QueryInvoices.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
invoiceId = json['invoiceId'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'invoiceId': invoiceId
});
getTypeName() => "QueryInvoices";
TypeContext? context = _ctx;
}
class Todo implements IConvertible
{
int? id;
String? text;
bool? isFinished;
Todo({this.id,this.text,this.isFinished});
Todo.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
id = json['id'];
text = json['text'];
isFinished = json['isFinished'];
return this;
}
Map<String, dynamic> toJson() => {
'id': id,
'text': text,
'isFinished': isFinished
};
getTypeName() => "Todo";
TypeContext? context = _ctx;
}
// @DataContract
class QueryResponse<T> implements IConvertible
{
// @DataMember(Order=1)
int? offset;
// @DataMember(Order=2)
int? total;
// @DataMember(Order=3)
List<Todo>? results;
// @DataMember(Order=4)
Map<String,String?>? meta;
// @DataMember(Order=5)
ResponseStatus? responseStatus;
QueryResponse({this.offset,this.total,this.results,this.meta,this.responseStatus});
QueryResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
offset = json['offset'];
total = json['total'];
results = JsonConverters.fromJson(json['results'],'List<Todo>',context!);
meta = JsonConverters.toStringMap(json['meta']);
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
return this;
}
Map<String, dynamic> toJson() => {
'offset': offset,
'total': total,
'results': JsonConverters.toJson(results,'List<Todo>',context!),
'meta': meta,
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
};
getTypeName() => "QueryResponse<$T>";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'blazor_gallery.servicestack.net', types: <String, TypeInfo> {
'Invoices': TypeInfo(TypeOf.Class, create:() => Invoices()),
'QueryInvoices': TypeInfo(TypeOf.Class, create:() => QueryInvoices()),
'List<Invoices>': TypeInfo(TypeOf.Class, create:() => <Invoices>[]),
'Todo': TypeInfo(TypeOf.Class, create:() => Todo()),
'List<Todo>': TypeInfo(TypeOf.Class, create:() => <Todo>[]),
});
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.
GET /invoices HTTP/1.1 Host: blazor-gallery.servicestack.net Accept: text/jsv
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { offset: 0, total: 0, results: [ { invoiceId: 0, customerId: 0, invoiceDate: 0001-01-01, billingAddress: String, billingCity: String, billingState: String, billingCountry: String, billingPostalCode: String, total: 0 } ], meta: { String: String }, responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } } }