GET | /employees | ||
---|---|---|---|
GET | /employees/{EmployeeId} |
import 'package:servicestack/servicestack.dart';
// @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 Employees implements IConvertible
{
int? employeeId;
// @required()
String? lastName;
// @required()
String? firstName;
String? title;
int? reportsTo;
DateTime? birthDate;
DateTime? hireDate;
String? address;
String? city;
String? state;
String? country;
String? postalCode;
String? phone;
String? fax;
String? email;
Employees({this.employeeId,this.lastName,this.firstName,this.title,this.reportsTo,this.birthDate,this.hireDate,this.address,this.city,this.state,this.country,this.postalCode,this.phone,this.fax,this.email});
Employees.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
employeeId = json['employeeId'];
lastName = json['lastName'];
firstName = json['firstName'];
title = json['title'];
reportsTo = json['reportsTo'];
birthDate = JsonConverters.fromJson(json['birthDate'],'DateTime',context!);
hireDate = JsonConverters.fromJson(json['hireDate'],'DateTime',context!);
address = json['address'];
city = json['city'];
state = json['state'];
country = json['country'];
postalCode = json['postalCode'];
phone = json['phone'];
fax = json['fax'];
email = json['email'];
return this;
}
Map<String, dynamic> toJson() => {
'employeeId': employeeId,
'lastName': lastName,
'firstName': firstName,
'title': title,
'reportsTo': reportsTo,
'birthDate': JsonConverters.toJson(birthDate,'DateTime',context!),
'hireDate': JsonConverters.toJson(hireDate,'DateTime',context!),
'address': address,
'city': city,
'state': state,
'country': country,
'postalCode': postalCode,
'phone': phone,
'fax': fax,
'email': email
};
getTypeName() => "Employees";
TypeContext? context = _ctx;
}
class QueryEmployees extends QueryDb<Employees> implements IGet, IConvertible
{
int? employeeId;
QueryEmployees({this.employeeId});
QueryEmployees.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
employeeId = json['employeeId'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'employeeId': employeeId
});
getTypeName() => "QueryEmployees";
TypeContext? context = _ctx;
}
class Albums implements IConvertible
{
int? albumId;
// @required()
String? title;
int? artistId;
Albums({this.albumId,this.title,this.artistId});
Albums.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
albumId = json['albumId'];
title = json['title'];
artistId = json['artistId'];
return this;
}
Map<String, dynamic> toJson() => {
'albumId': albumId,
'title': title,
'artistId': artistId
};
getTypeName() => "Albums";
TypeContext? context = _ctx;
}
// @DataContract
class QueryResponse<T> implements IConvertible
{
// @DataMember(Order=1)
int? offset;
// @DataMember(Order=2)
int? total;
// @DataMember(Order=3)
List<Albums>? 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<Albums>',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<Albums>',context!),
'meta': meta,
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
};
getTypeName() => "QueryResponse<$T>";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'chinook.netcore.io', types: <String, TypeInfo> {
'Employees': TypeInfo(TypeOf.Class, create:() => Employees()),
'QueryEmployees': TypeInfo(TypeOf.Class, create:() => QueryEmployees()),
'List<Employees>': TypeInfo(TypeOf.Class, create:() => <Employees>[]),
'Albums': TypeInfo(TypeOf.Class, create:() => Albums()),
'List<Albums>': TypeInfo(TypeOf.Class, create:() => <Albums>[]),
});
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 /employees HTTP/1.1 Host: chinook.netcore.io Accept: text/jsv
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { offset: 0, total: 0, results: [ { employeeId: 0, lastName: String, firstName: String, title: String, reportsTo: 0, birthDate: 0001-01-01, hireDate: 0001-01-01, address: String, city: String, state: String, country: String, postalCode: String, phone: String, fax: String, email: String } ], meta: { String: String }, responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } } }