Sanctions Search API: v2

<back to all web services

GetPdfs

Account
The following routes are available for this service:
POST/pdfs/listGet all PDFs
import Foundation
import ServiceStack

// @DataContract
public class GetPdfs : BaseRequest
{
    /**
    * The request data
    */
    // @DataMember
    // @ApiMember(Description="The request data", ParameterType="body")
    public var request:GetPdfsRequest

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case request
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        request = try container.decodeIfPresent(GetPdfsRequest.self, forKey: .request)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if request != nil { try container.encode(request, forKey: .request) }
    }
}

// @DataContract
public class BaseRequest : IBaseRequest, Codable
{
    /**
    * The authentication credentials
    */
    // @DataMember
    // @ApiMember(Description="The authentication credentials", IsRequired=true, ParameterType="header, body")
    public var authentication:Authentication

    required public init(){}
}

// @DataContract
public class Authentication : Codable
{
    /**
    * The API User ID provided by us when you signed up to use our API
    */
    // @DataMember
    // @ApiMember(Description="The API User ID provided by us when you signed up to use our API", IsRequired=true, ParameterType="header, body")
    public var apiUserId:String

    /**
    * The API User Key provided by us when you signed up to use our API
    */
    // @DataMember
    // @ApiMember(Description="The API User Key provided by us when you signed up to use our API", IsRequired=true, ParameterType="header, body")
    public var apiUserKey:String

    required public init(){}
}

public class GetPdfsRequest : Codable
{
    /**
    * If the saved documents are kept within a single Sub User account, specify their username here
    */
    // @ApiMember(Description="If the saved documents are kept within a single Sub User account, specify their username here")
    public var subUserName:String

    required public init(){}
}

// @DataContract
public class GetPdfsResponse : Codable
{
    /**
    * The response data
    */
    // @DataMember
    // @ApiMember(Description="The response data")
    public var data:GetPdfsData

    required public init(){}
}

public class GetPdfsData : BaseResponse
{
    /**
    * List of Documents, but not including the file data
    */
    // @ApiMember(Description="List of Documents, but not including the file data")
    public var documents:ArrayOfPdfDocument

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case documents
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        documents = try container.decodeIfPresent(ArrayOfPdfDocument.self, forKey: .documents)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if documents != nil { try container.encode(documents, forKey: .documents) }
    }
}

public class BaseResponse : IBaseDataResponse, IHasResponseStatus, Codable
{
    /**
    * The status of the response
    */
    // @ApiMember(Description="The status of the response")
    public var responseStatus:ResponseStatus

    required public init(){}
}

public class ArrayOfResponseError : List<ResponseError>
{
    required public init(){ super.init() }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
    }
}

public class ArrayOfPdfDocument : List<PdfDocument>
{
    required public init(){ super.init() }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
    }
}

public class PdfDocument : Codable
{
    /**
    * The ID of the saved document
    */
    // @ApiMember(Description="The ID of the saved document")
    public var id:Int

    /**
    * Is the document ready to download
    */
    // @ApiMember(Description="Is the document ready to download")
    public var isReady:Bool

    /**
    * The name of the saved document
    */
    // @ApiMember(Description="The name of the saved document")
    public var name:String

    /**
    * The file name (including extension) of the saved document
    */
    // @ApiMember(Description="The file name (including extension) of the saved document")
    public var fileName:String

    /**
    * The type of saved document (Human readable, pep, sanctions, validid, companylookup, etc.)
    */
    // @ApiMember(Description="The type of saved document (Human readable, pep, sanctions, validid, companylookup, etc.)")
    public var type:String

    /**
    * If this document is a Saved Sanctions Search, the ID of the search it relates to
    */
    // @ApiMember(Description="If this document is a Saved Sanctions Search, the ID of the search it relates to")
    public var sanctionsSearchId:Int?

    /**
    * If this document is a Saved PEP Search, the ID of the search it relates to
    */
    // @ApiMember(Description="If this document is a Saved PEP Search, the ID of the search it relates to")
    public var pepSearchId:Int?

    /**
    * If this document is a Saved ValidID Search, the ID of the search it relates to
    */
    // @ApiMember(Description="If this document is a Saved ValidID Search, the ID of the search it relates to")
    public var validIdSearchId:Int?

    /**
    * If this document is a Saved CompanyLookup Search, the ID of the search it relates to
    */
    // @ApiMember(Description="If this document is a Saved CompanyLookup Search, the ID of the search it relates to")
    public var companyLookupSearchId:Int?

    /**
    * The date the saved document was created/requested
    */
    // @ApiMember(Description="The date the saved document was created/requested")
    public var dateCreated:Date

    /**
    * The date the saved document will be no longer available. You can request a new document using the SaveSearch, SavePepSearch, etc. methods
    */
    // @ApiMember(Description="The date the saved document will be no longer available. You can request a new document using the SaveSearch, SavePepSearch, etc. methods")
    public var dateExpires:Date

    required public init(){}
}


Swift GetPdfs DTOs

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

HTTP + JSON

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /pdfs/list HTTP/1.1 
Host: api.sanctionssearch.com 
Accept: application/json
Content-Type: application/json
Content-Length: length

{"request":{"subUserName":"String"},"authentication":{"apiUserId":"String","apiUserKey":"String"}}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"data":{"documents":[{"id":0,"isReady":false,"name":"String","fileName":"String","type":"String","sanctionsSearchId":0,"pepSearchId":0,"validIdSearchId":0,"companyLookupSearchId":0,"dateCreated":"\/Date(-62135596800000-0000)\/","dateExpires":"\/Date(-62135596800000-0000)\/"}],"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}}