POST | /users/register |
---|
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 RegisterUserResponse implements IConvertible
{
ResponseStatus? responseStatus;
String? userId;
String? referrerUrl;
RegisterUserResponse({this.responseStatus,this.userId,this.referrerUrl});
RegisterUserResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
userId = json['userId'];
referrerUrl = json['referrerUrl'];
return this;
}
Map<String, dynamic> toJson() => {
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!),
'userId': userId,
'referrerUrl': referrerUrl
};
getTypeName() => "RegisterUserResponse";
TypeContext? context = _ctx;
}
class RegisterUserRequest extends PostOperationUnTenanted<RegisterUserResponse> implements IConvertible
{
String? firstName;
String? lastName;
String? email;
String? password;
String? timezone;
bool? termsAndConditionsAccepted;
RegisterUserRequest({this.firstName,this.lastName,this.email,this.password,this.timezone,this.termsAndConditionsAccepted});
RegisterUserRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
firstName = json['firstName'];
lastName = json['lastName'];
email = json['email'];
password = json['password'];
timezone = json['timezone'];
termsAndConditionsAccepted = json['termsAndConditionsAccepted'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'firstName': firstName,
'lastName': lastName,
'email': email,
'password': password,
'timezone': timezone,
'termsAndConditionsAccepted': termsAndConditionsAccepted
});
getTypeName() => "RegisterUserRequest";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'staging_api.billiecart.com.au', types: <String, TypeInfo> {
'PostOperationUnTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
'RegisterUserResponse': TypeInfo(TypeOf.Class, create:() => RegisterUserResponse()),
'RegisterUserRequest': TypeInfo(TypeOf.Class, create:() => RegisterUserRequest()),
});
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/register HTTP/1.1
Host: staging-api.billiecart.com.au
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
firstName: String,
lastName: String,
email: String,
password: String,
timezone: String,
termsAndConditionsAccepted: False
}
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 } }, userId: String, referrerUrl: String }