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 .csv suffix or ?format=csv

HTTP + CSV

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/csv
Content-Type: text/csv
Content-Length: length

{"firstName":"String","lastName":"String","email":"String","password":"String","timezone":"String","termsAndConditionsAccepted":false}
HTTP/1.1 200 OK
Content-Type: text/csv
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"}