GET | /clients | Get all clients |
---|
using System;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using SanctionsSearch.Api2.ServiceModel.Operations.Clients;
using SanctionsSearch.Api2.ServiceModel.Operations.Base;
using SanctionsSearch.Api2.ServiceModel.Types;
namespace SanctionsSearch.Api2.ServiceModel.Operations.Base
{
public partial class ArrayOfResponseError
: List<ResponseError>
{
}
[DataContract]
public partial class BaseRequest
: IBaseRequest
{
///<summary>
///The authentication credentials
///</summary>
[DataMember]
[ApiMember(Description="The authentication credentials", IsRequired=true, ParameterType="header, body")]
public virtual Authentication Authentication { get; set; }
}
public partial class BaseResponse
: IBaseDataResponse, IHasResponseStatus
{
///<summary>
///The status of the response
///</summary>
[ApiMember(Description="The status of the response")]
public virtual ResponseStatus ResponseStatus { get; set; }
}
[DataContract]
public partial class PagedRequest
: BaseRequest
{
///<summary>
///The maximum number of records to be returned in one page
///</summary>
[DataMember(Name="page[limit]")]
[ApiMember(Description="The maximum number of records to be returned in one page", ParameterType="query")]
public virtual int PageLimit { get; set; }
///<summary>
///The starting point in the list of records from where the data should be fetched. Zero based index.
///</summary>
[DataMember(Name="page[offset]")]
[ApiMember(Description="The starting point in the list of records from where the data should be fetched. Zero based index.", ParameterType="query")]
public virtual int PageOffset { get; set; }
///<summary>
///The term to determine the order in which the data is returned
///</summary>
[DataMember]
[ApiMember(Description="The term to determine the order in which the data is returned", ParameterType="query")]
public virtual string Sort { get; set; }
}
public partial class PagedResponse<T>
: BaseResponse
{
///<summary>
///The response Metadata
///</summary>
[ApiMember(Description="The response Metadata")]
public virtual Meta<T> Meta { get; set; }
}
[DataContract]
public partial class ResponseError
{
public ResponseError()
{
Meta = new Dictionary<string, string>{};
}
[DataMember(Order=1)]
public virtual string ErrorCode { get; set; }
[DataMember(Order=2)]
public virtual string FieldName { get; set; }
[DataMember(Order=3)]
public virtual string Message { get; set; }
[DataMember(Order=4)]
public virtual Dictionary<string, string> Meta { get; set; }
}
[DataContract]
public partial class ResponseStatus
{
public ResponseStatus()
{
Meta = new Dictionary<string, string>{};
}
[DataMember(Order=1)]
public virtual string ErrorCode { get; set; }
[DataMember(Order=2)]
public virtual string Message { get; set; }
[DataMember(Order=3)]
public virtual string StackTrace { get; set; }
[DataMember(Order=4)]
public virtual ArrayOfResponseError Errors { get; set; }
[DataMember(Order=5)]
public virtual Dictionary<string, string> Meta { get; set; }
}
}
namespace SanctionsSearch.Api2.ServiceModel.Operations.Clients
{
[DataContract]
public partial class GetClients
: PagedRequest
{
///<summary>
///Filter the results to those that have a State matching the state specified
///</summary>
[DataMember]
[ApiMember(Description="Filter the results to those that have a State matching the state specified", ParameterType="query")]
public virtual ClientState State { get; set; }
///<summary>
///Filter the results to those that have a IsValidateMe flag matching the specified value
///</summary>
[DataMember]
[ApiMember(Description="Filter the results to those that have a IsValidateMe flag matching the specified value", ParameterType="query")]
public virtual bool? IsValidateMe { get; set; }
///<summary>
///Filter the results to those that have a Name including the specified value
///</summary>
[DataMember]
[ApiMember(Description="Filter the results to those that have a Name including the specified value", ParameterType="query")]
public virtual string Name { get; set; }
///<summary>
///Filter the results to those that were created after (or on) this date
///</summary>
[DataMember]
[ApiMember(Description="Filter the results to those that were created after (or on) this date", ParameterType="query")]
public virtual DateTime DateFrom { get; set; }
///<summary>
///Filter the results to those that were created before this date
///</summary>
[DataMember]
[ApiMember(Description="Filter the results to those that were created before this date", ParameterType="query")]
public virtual DateTime DateTo { get; set; }
///<summary>
///If the searches are being accessed by a sub user, specify their username here to only return searches they have permissions to view
///</summary>
[DataMember]
[ApiMember(Description="If the searches are being accessed by a sub user, specify their username here to only return searches they have permissions to view", ParameterType="query")]
public virtual string SubUserName { get; set; }
}
public partial class GetClientsData
: PagedResponse<GetClients>
{
public virtual ArrayOfClientShort Clients { get; set; }
}
[DataContract]
public partial class GetClientsResponse
{
[DataMember]
public virtual GetClientsData Data { get; set; }
}
}
namespace SanctionsSearch.Api2.ServiceModel.Types
{
public partial class ArrayOfClientShort
: List<ClientShort>
{
}
[DataContract]
public partial class Authentication
{
///<summary>
///The API User ID provided by us when you signed up to use our API
///</summary>
[DataMember]
[ApiMember(Description="The API User ID provided by us when you signed up to use our API", IsRequired=true, ParameterType="header, body")]
public virtual string ApiUserId { get; set; }
///<summary>
///The API User Key provided by us when you signed up to use our API
///</summary>
[DataMember]
[ApiMember(Description="The API User Key provided by us when you signed up to use our API", IsRequired=true, ParameterType="header, body")]
public virtual string ApiUserKey { get; set; }
}
public partial class ClientShort
{
public virtual int Id { get; set; }
public virtual DateTime DateCreated { get; set; }
public virtual string Name { get; set; }
public virtual string Reference { get; set; }
public virtual bool IsValidateMe { get; set; }
public virtual ClientState State { get; set; }
public virtual Links Links { get; set; }
public virtual int NumOfDocuments { get; set; }
public virtual Image Photo { get; set; }
}
[DataContract(Name="ClientState", Namespace="http://schemas.servicestack.net/types")]
public enum ClientState
{
Undefined,
PendingCompletion,
PendingOcr,
PendingVerification,
Verified,
}
public partial class Image
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual int? OcrId { get; set; }
public virtual string Url { get; set; }
}
public partial class Links
{
[ApiMember]
public virtual string Self { get; set; }
}
public partial class Meta<T>
{
///<summary>
///Pagination links
///</summary>
[ApiMember(Description="Pagination links")]
public virtual MetaLinks Links { get; set; }
///<summary>
///The total number of records for the query
///</summary>
[ApiMember(Description="The total number of records for the query")]
public virtual int? TotalCount { get; set; }
///<summary>
///The maximum number of records to be returned in one page
///</summary>
[ApiMember(Description="The maximum number of records to be returned in one page")]
public virtual int? PageLimit { get; set; }
///<summary>
///The starting point in the list of records from where the data should be fetched. Zero based index.
///</summary>
[ApiMember(Description="The starting point in the list of records from where the data should be fetched. Zero based index.")]
public virtual int? PageOffset { get; set; }
}
public partial class MetaLinks
: Links
{
///<summary>
///The link to the first page of records
///</summary>
[ApiMember(Description="The link to the first page of records")]
public virtual string First { get; set; }
///<summary>
///The link to the last page of records
///</summary>
[ApiMember(Description="The link to the last page of records")]
public virtual string Last { get; set; }
///<summary>
///The link to the next page of records, if applicable
///</summary>
[ApiMember(Description="The link to the next page of records, if applicable")]
public virtual string Next { get; set; }
///<summary>
///The link to the last page of records, if applicable
///</summary>
[ApiMember(Description="The link to the last page of records, if applicable")]
public virtual string Prev { get; set; }
}
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .json suffix or ?format=json
To embed the response in a jsonp callback, append ?callback=myCallback
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /clients HTTP/1.1 Host: api.sanctionssearch.com Accept: application/json
HTTP/1.1 200 OK Content-Type: application/json Content-Length: length {"data":{"clients":[{"id":0,"dateCreated":"\/Date(-62135596800000-0000)\/","name":"String","reference":"String","isValidateMe":false,"state":"Undefined","links":{"self":"String"},"numOfDocuments":0,"photo":{"id":0,"name":"String","ocrId":0,"url":"String"}}],"meta":{"links":{"first":"String","last":"String","next":"String","prev":"String","self":"String"},"totalCount":0,"pageLimit":0,"pageOffset":0},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}}