Billiecart API

<back to all web services

AssociateUserAccountToCustomerRequest

Requires Authentication
Requires the role:manager
The following routes are available for this service:
PUT/customers/{Id}/associate-to-user-account
import 'package:servicestack/servicestack.dart';

abstract class PutOperationUnTenanted<TResponse> implements IPut
{
    PutOperationUnTenanted();
    PutOperationUnTenanted.fromJson(Map<String, dynamic> json) : super();
    fromMap(Map<String, dynamic> json) {
        return this;
    }

    Map<String, dynamic> toJson() => {};
    getTypeName() => "PutOperationUnTenanted<$TResponse>";
    TypeContext? context = _ctx;
}

abstract class PutOperationTenanted<TResponse> extends PutOperationUnTenanted<TResponse> implements ITenantedRequest
{
    String? organisationId;

    PutOperationTenanted({this.organisationId});
    PutOperationTenanted.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        organisationId = json['organisationId'];
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'organisationId': organisationId
    });

    getTypeName() => "PutOperationTenanted<$TResponse>";
    TypeContext? context = _ctx;
}

class BankAccount implements IConvertible
{
    String? bsbNumber;
    String? accountNumber;

    BankAccount({this.bsbNumber,this.accountNumber});
    BankAccount.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        bsbNumber = json['bsbNumber'];
        accountNumber = json['accountNumber'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'bsbNumber': bsbNumber,
        'accountNumber': accountNumber
    };

    getTypeName() => "BankAccount";
    TypeContext? context = _ctx;
}

class Customer implements IIdentifiableResource, IConvertible
{
    String? id;
    String? firstName;
    String? lastName;
    DateTime? dateOfBirth;
    String? driversLicenceNo;
    String? email;
    String? phone;
    String? preferredContactMethod;
    String? addressLine1;
    String? addressLine2;
    String? suburb;
    String? stateTerritory;
    String? postcode;
    BankAccount? bankAccount;
    String? userAccountId;

    Customer({this.id,this.firstName,this.lastName,this.dateOfBirth,this.driversLicenceNo,this.email,this.phone,this.preferredContactMethod,this.addressLine1,this.addressLine2,this.suburb,this.stateTerritory,this.postcode,this.bankAccount,this.userAccountId});
    Customer.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        id = json['id'];
        firstName = json['firstName'];
        lastName = json['lastName'];
        dateOfBirth = JsonConverters.fromJson(json['dateOfBirth'],'DateTime',context!);
        driversLicenceNo = json['driversLicenceNo'];
        email = json['email'];
        phone = json['phone'];
        preferredContactMethod = json['preferredContactMethod'];
        addressLine1 = json['addressLine1'];
        addressLine2 = json['addressLine2'];
        suburb = json['suburb'];
        stateTerritory = json['stateTerritory'];
        postcode = json['postcode'];
        bankAccount = JsonConverters.fromJson(json['bankAccount'],'BankAccount',context!);
        userAccountId = json['userAccountId'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'id': id,
        'firstName': firstName,
        'lastName': lastName,
        'dateOfBirth': JsonConverters.toJson(dateOfBirth,'DateTime',context!),
        'driversLicenceNo': driversLicenceNo,
        'email': email,
        'phone': phone,
        'preferredContactMethod': preferredContactMethod,
        'addressLine1': addressLine1,
        'addressLine2': addressLine2,
        'suburb': suburb,
        'stateTerritory': stateTerritory,
        'postcode': postcode,
        'bankAccount': JsonConverters.toJson(bankAccount,'BankAccount',context!),
        'userAccountId': userAccountId
    };

    getTypeName() => "Customer";
    TypeContext? context = _ctx;
}

class AssociateUserAccountToCustomerResponse implements IConvertible
{
    ResponseStatus? responseStatus;
    Customer? customer;

    AssociateUserAccountToCustomerResponse({this.responseStatus,this.customer});
    AssociateUserAccountToCustomerResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
        customer = JsonConverters.fromJson(json['customer'],'Customer',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!),
        'customer': JsonConverters.toJson(customer,'Customer',context!)
    };

    getTypeName() => "AssociateUserAccountToCustomerResponse";
    TypeContext? context = _ctx;
}

class AssociateUserAccountToCustomerRequest extends PutOperationTenanted<AssociateUserAccountToCustomerResponse> implements IConvertible
{
    String? id;
    String? userAccountId;

    AssociateUserAccountToCustomerRequest({this.id,this.userAccountId});
    AssociateUserAccountToCustomerRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        id = json['id'];
        userAccountId = json['userAccountId'];
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'id': id,
        'userAccountId': userAccountId
    });

    getTypeName() => "AssociateUserAccountToCustomerRequest";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'staging_api.billiecart.com.au', types: <String, TypeInfo> {
    'PutOperationUnTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
    'PutOperationTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
    'BankAccount': TypeInfo(TypeOf.Class, create:() => BankAccount()),
    'Customer': TypeInfo(TypeOf.Class, create:() => Customer()),
    'AssociateUserAccountToCustomerResponse': TypeInfo(TypeOf.Class, create:() => AssociateUserAccountToCustomerResponse()),
    'AssociateUserAccountToCustomerRequest': TypeInfo(TypeOf.Class, create:() => AssociateUserAccountToCustomerRequest()),
});

Dart AssociateUserAccountToCustomerRequest 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.

PUT /customers/{Id}/associate-to-user-account HTTP/1.1 
Host: staging-api.billiecart.com.au 
Accept: text/csv
Content-Type: text/csv
Content-Length: length

{"id":"String","userAccountId":"String","organisationId":"String"}
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"}},"customer":{"id":"String","firstName":"String","lastName":"String","driversLicenceNo":"String","email":"String","phone":"String","preferredContactMethod":"String","addressLine1":"String","addressLine2":"String","suburb":"String","stateTerritory":"String","postcode":"String","bankAccount":{"bsbNumber":"String","accountNumber":"String"},"userAccountId":"String"}}