Billiecart API

<back to all web services

SearchAllEmployersRequest

Requires Authentication
Requires the role:manager
The following routes are available for this service:
GET/employers
import 'package:servicestack/servicestack.dart';

abstract class GetOperationUnTenanted<TResponse> implements IHasGetOptions, IGet
{
    String? embed;

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

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

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

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

abstract class SearchOperationUnTenanted<TResponse> extends GetOperationUnTenanted<TResponse> implements IHasSearchOptions
{
    String? distinct;
    int? limit;
    int? offset;
    String? sort;
    String? filter;
    String? search;

    SearchOperationUnTenanted({this.distinct,this.limit,this.offset,this.sort,this.filter,this.search});
    SearchOperationUnTenanted.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        distinct = json['distinct'];
        limit = json['limit'];
        offset = json['offset'];
        sort = json['sort'];
        filter = json['filter'];
        search = json['search'];
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson()..addAll({
        'distinct': distinct,
        'limit': limit,
        'offset': offset,
        'sort': sort,
        'filter': filter,
        'search': search
    });

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

abstract class SearchOperationTenanted<TResponse> extends SearchOperationUnTenanted<TResponse> implements ITenantedRequest
{
    String? organisationId;

    SearchOperationTenanted({this.organisationId});
    SearchOperationTenanted.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() => "SearchOperationTenanted<$TResponse>";
    TypeContext? context = _ctx;
}

class BusinessDetails implements IConvertible
{
    String? tradingName;
    String? australianBusinessNumber;
    String? australianCompanyNumber;

    BusinessDetails({this.tradingName,this.australianBusinessNumber,this.australianCompanyNumber});
    BusinessDetails.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        tradingName = json['tradingName'];
        australianBusinessNumber = json['australianBusinessNumber'];
        australianCompanyNumber = json['australianCompanyNumber'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'tradingName': tradingName,
        'australianBusinessNumber': australianBusinessNumber,
        'australianCompanyNumber': australianCompanyNumber
    };

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

class Contact implements IConvertible
{
    String? contactName;
    String? email;
    String? phoneNumber;
    String? preferredContactMethod;

    Contact({this.contactName,this.email,this.phoneNumber,this.preferredContactMethod});
    Contact.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        contactName = json['contactName'];
        email = json['email'];
        phoneNumber = json['phoneNumber'];
        preferredContactMethod = json['preferredContactMethod'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'contactName': contactName,
        'email': email,
        'phoneNumber': phoneNumber,
        'preferredContactMethod': preferredContactMethod
    };

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

class Address implements IConvertible
{
    String? addressLine1;
    String? addressLine2;
    String? suburb;
    String? stateTerritory;
    String? postcode;

    Address({this.addressLine1,this.addressLine2,this.suburb,this.stateTerritory,this.postcode});
    Address.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        addressLine1 = json['addressLine1'];
        addressLine2 = json['addressLine2'];
        suburb = json['suburb'];
        stateTerritory = json['stateTerritory'];
        postcode = json['postcode'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'addressLine1': addressLine1,
        'addressLine2': addressLine2,
        'suburb': suburb,
        'stateTerritory': stateTerritory,
        'postcode': postcode
    };

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

class Employer implements IIdentifiableResource, IConvertible
{
    String? name;
    BusinessDetails? businessDetails;
    Contact? contact;
    Address? postalAddress;
    Address? physicalAddress;
    String? id;

    Employer({this.name,this.businessDetails,this.contact,this.postalAddress,this.physicalAddress,this.id});
    Employer.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        name = json['name'];
        businessDetails = JsonConverters.fromJson(json['businessDetails'],'BusinessDetails',context!);
        contact = JsonConverters.fromJson(json['contact'],'Contact',context!);
        postalAddress = JsonConverters.fromJson(json['postalAddress'],'Address',context!);
        physicalAddress = JsonConverters.fromJson(json['physicalAddress'],'Address',context!);
        id = json['id'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'name': name,
        'businessDetails': JsonConverters.toJson(businessDetails,'BusinessDetails',context!),
        'contact': JsonConverters.toJson(contact,'Contact',context!),
        'postalAddress': JsonConverters.toJson(postalAddress,'Address',context!),
        'physicalAddress': JsonConverters.toJson(physicalAddress,'Address',context!),
        'id': id
    };

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

enum SortDirection
{
    Ascending,
    Descending,
}

class Sorting implements IConvertible
{
    String? by;
    SortDirection? direction;

    Sorting({this.by,this.direction});
    Sorting.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        by = json['by'];
        direction = JsonConverters.fromJson(json['direction'],'SortDirection',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'by': by,
        'direction': JsonConverters.toJson(direction,'SortDirection',context!)
    };

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

class Filtering implements IConvertible
{
    List<String>? fields;
    String? search;

    Filtering({this.fields,this.search});
    Filtering.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        fields = JsonConverters.fromJson(json['fields'],'List<String>',context!);
        search = json['search'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'fields': JsonConverters.toJson(fields,'List<String>',context!),
        'search': search
    };

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

class SearchMetadata implements IConvertible
{
    int? total;
    int? limit;
    int? offset;
    Sorting? sort;
    Filtering? filter;

    SearchMetadata({this.total,this.limit,this.offset,this.sort,this.filter});
    SearchMetadata.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        total = json['total'];
        limit = json['limit'];
        offset = json['offset'];
        sort = JsonConverters.fromJson(json['sort'],'Sorting',context!);
        filter = JsonConverters.fromJson(json['filter'],'Filtering',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'total': total,
        'limit': limit,
        'offset': offset,
        'sort': JsonConverters.toJson(sort,'Sorting',context!),
        'filter': JsonConverters.toJson(filter,'Filtering',context!)
    };

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

class SearchAllEmployersResponse implements IConvertible
{
    ResponseStatus? responseStatus;
    List<Employer>? employers;
    SearchMetadata? metadata;

    SearchAllEmployersResponse({this.responseStatus,this.employers,this.metadata});
    SearchAllEmployersResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
        employers = JsonConverters.fromJson(json['employers'],'List<Employer>',context!);
        metadata = JsonConverters.fromJson(json['metadata'],'SearchMetadata',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!),
        'employers': JsonConverters.toJson(employers,'List<Employer>',context!),
        'metadata': JsonConverters.toJson(metadata,'SearchMetadata',context!)
    };

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

class SearchAllEmployersRequest extends SearchOperationTenanted<SearchAllEmployersResponse> implements IConvertible
{
    SearchAllEmployersRequest();
    SearchAllEmployersRequest.fromJson(Map<String, dynamic> json) : super.fromJson(json);
    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson();
    getTypeName() => "SearchAllEmployersRequest";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'staging_api.billiecart.com.au', types: <String, TypeInfo> {
    'GetOperationUnTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
    'SearchOperationUnTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
    'SearchOperationTenanted<TResponse>': TypeInfo(TypeOf.AbstractClass),
    'BusinessDetails': TypeInfo(TypeOf.Class, create:() => BusinessDetails()),
    'Contact': TypeInfo(TypeOf.Class, create:() => Contact()),
    'Address': TypeInfo(TypeOf.Class, create:() => Address()),
    'Employer': TypeInfo(TypeOf.Class, create:() => Employer()),
    'SortDirection': TypeInfo(TypeOf.Enum, enumValues:SortDirection.values),
    'Sorting': TypeInfo(TypeOf.Class, create:() => Sorting()),
    'Filtering': TypeInfo(TypeOf.Class, create:() => Filtering()),
    'SearchMetadata': TypeInfo(TypeOf.Class, create:() => SearchMetadata()),
    'SearchAllEmployersResponse': TypeInfo(TypeOf.Class, create:() => SearchAllEmployersResponse()),
    'List<Employer>': TypeInfo(TypeOf.Class, create:() => <Employer>[]),
    'SearchAllEmployersRequest': TypeInfo(TypeOf.Class, create:() => SearchAllEmployersRequest()),
});

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

GET /employers HTTP/1.1 
Host: staging-api.billiecart.com.au 
Accept: text/jsv
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
		}
	},
	employers: 
	[
		{
			name: String,
			businessDetails: 
			{
				tradingName: String,
				australianBusinessNumber: String,
				australianCompanyNumber: String
			},
			contact: 
			{
				contactName: String,
				email: String,
				phoneNumber: String,
				preferredContactMethod: String
			},
			postalAddress: 
			{
				addressLine1: String,
				addressLine2: String,
				suburb: String,
				stateTerritory: String,
				postcode: String
			},
			physicalAddress: 
			{
				addressLine1: String,
				addressLine2: String,
				suburb: String,
				stateTerritory: String,
				postcode: String
			},
			id: String
		}
	],
	metadata: 
	{
		total: 0,
		limit: 0,
		offset: 0,
		sort: 
		{
			by: String,
			direction: Ascending
		},
		filter: 
		{
			fields: 
			[
				String
			],
			search: String
		}
	}
}