Billiecart API

<back to all web services

RegisterUserRequest

The following routes are available for this service:
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()),
});

Dart RegisterUserRequest DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + 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
}