Requires the role: | manager |
POST | /users/invite |
---|
import 'package:servicestack/servicestack.dart';
abstract class PostOperationUnTenanted<TResponse> implements IPost
{
PostOperationUnTenanted();
PostOperationUnTenanted.fromJson(Map<String, dynamic> json) : super();
fromMap(Map<String, dynamic> json) {
return this;
}
Map<String, dynamic> toJson() => {};
getTypeName() => "PostOperationUnTenanted<$TResponse>";
TypeContext? context = _ctx;
}
class Invitation implements IConvertible
{
String? firstName;
String? lastName;
String? email;
String? id;
Invitation({this.firstName,this.lastName,this.email,this.id});
Invitation.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
firstName = json['firstName'];
lastName = json['lastName'];
email = json['email'];
id = json['id'];
return this;
}
Map<String, dynamic> toJson() => {
'firstName': firstName,
'lastName': lastName,
'email': email,
'id': id
};
getTypeName() => "Invitation";
TypeContext? context = _ctx;
}
class InviteGuestResponse implements IConvertible
{
ResponseStatus? responseStatus;
Invitation? invitation;
InviteGuestResponse({this.responseStatus,this.invitation});
InviteGuestResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
invitation = JsonConverters.fromJson(json['invitation'],'Invitation',context!);
return this;
}
Map<String, dynamic> toJson() => {
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!),
'invitation': JsonConverters.toJson(invitation,'Invitation',context!)
};
getTypeName() => "InviteGuestResponse";
TypeContext? context = _ctx;
}
class InviteGuestRequest extends PostOperationUnTenanted<InviteGuestResponse> implements IConvertible
{
String? email;
InviteGuestRequest({this.email});
InviteGuestRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
email = json['email'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'email': email
});
getTypeName() => "InviteGuestRequest";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'staging_api.billiecart.com.au', types: <String, TypeInfo> {
'PostOperationUnTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
'Invitation': TypeInfo(TypeOf.Class, create:() => Invitation()),
'InviteGuestResponse': TypeInfo(TypeOf.Class, create:() => InviteGuestResponse()),
'InviteGuestRequest': TypeInfo(TypeOf.Class, create:() => InviteGuestRequest()),
});
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.
POST /users/invite HTTP/1.1
Host: staging-api.billiecart.com.au
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
email: String
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } }, invitation: { firstName: String, lastName: String, email: String, id: String } }