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 java.math.*
import java.util.*
import net.servicestack.client.*
import com.google.gson.annotations.*
import com.google.gson.reflect.*


open class SearchAllEmployersRequest : SearchOperationTenanted<SearchAllEmployersResponse>()
{
}

open class SearchOperationTenanted<TResponse> : SearchOperationUnTenanted<TResponse>(), ITenantedRequest
{
    var organisationId:String? = null
}

open class SearchOperationUnTenanted<TResponse> : GetOperationUnTenanted<TResponse>(), IHasSearchOptions
{
    var distinct:String? = null
    var limit:Int? = null
    var offset:Int? = null
    var sort:String? = null
    var filter:String? = null
    var search:String? = null
}

open class GetOperationUnTenanted<TResponse> : IHasGetOptions, IGet
{
    var embed:String? = null
}

open class SearchAllEmployersResponse
{
    var responseStatus:ResponseStatus? = null
    var employers:ArrayList<Employer> = ArrayList<Employer>()
    var metadata:SearchMetadata? = null
}

open class Employer : IIdentifiableResource
{
    var name:String? = null
    var businessDetails:BusinessDetails? = null
    var contact:Contact? = null
    var postalAddress:Address? = null
    var physicalAddress:Address? = null
    var id:String? = null
}

open class BusinessDetails
{
    var tradingName:String? = null
    var australianBusinessNumber:String? = null
    var australianCompanyNumber:String? = null
}

open class Contact
{
    var contactName:String? = null
    var email:String? = null
    var phoneNumber:String? = null
    var preferredContactMethod:String? = null
}

open class Address
{
    var addressLine1:String? = null
    var addressLine2:String? = null
    var suburb:String? = null
    var stateTerritory:String? = null
    var postcode:String? = null
}

open class SearchMetadata
{
    var total:Int? = null
    var limit:Int? = null
    var offset:Int? = null
    var sort:Sorting? = null
    var filter:Filtering? = null
}

open class Sorting
{
    @SerializedName("by") var By:String? = null
    var direction:SortDirection? = null
}

enum class SortDirection
{
    Ascending,
    Descending,
}

open class Filtering
{
    var fields:ArrayList<String> = ArrayList<String>()
    var search:String? = null
}

Kotlin 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
		}
	}
}