Starlite API

<back to all web services

AccountHistory

The following routes are available for this service:
POST/Accounts/AccountHistory
import Foundation
import ServiceStack

// @DataContract
public class AccountHistory : ServiceRequestBase
{
    /**
    * The property manager ID (or customer code ID) that can manage the account(s) requested
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="The property manager ID (or customer code ID) that can manage the account(s) requested")
    public var managementCompanyId:String?

    /**
    * The list of account numbers for which to receive transaction data
    */
    // @DataMember
    // @ApiMember(DataType="List<long>", Description="The list of account numbers for which to receive transaction data")
    public var accountNumbers:[Int] = []

    /**
    * The earliest date (in short DateTime format) for which to find transactions in the specified date range
    */
    // @DataMember
    // @ApiMember(DataType="DateTime", Description="The earliest date (in short DateTime format) for which to find transactions in the specified date range", IsRequired=true)
    public var fromDate:Date?

    /**
    * The most recent date (in short DateTime format) for which to find transactions in the specified date range
    */
    // @DataMember
    // @ApiMember(DataType="DateTime", Description="The most recent date (in short DateTime format) for which to find transactions in the specified date range", IsRequired=true)
    public var toDate:Date?

    /**
    * An array of external transaction codes for filtering the transactions in the response
    */
    // @DataMember
    // @ApiMember(DataType="List<string>", Description="An array of external transaction codes for filtering the transactions in the response")
    public var transactionCodes:[Int] = []

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

    private enum CodingKeys : String, CodingKey {
        case managementCompanyId
        case accountNumbers
        case fromDate
        case toDate
        case transactionCodes
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        managementCompanyId = try container.decodeIfPresent(String.self, forKey: .managementCompanyId)
        accountNumbers = try container.decodeIfPresent([Int].self, forKey: .accountNumbers) ?? []
        fromDate = try container.decodeIfPresent(Date.self, forKey: .fromDate)
        toDate = try container.decodeIfPresent(Date.self, forKey: .toDate)
        transactionCodes = try container.decodeIfPresent([Int].self, forKey: .transactionCodes) ?? []
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if managementCompanyId != nil { try container.encode(managementCompanyId, forKey: .managementCompanyId) }
        if accountNumbers.count > 0 { try container.encode(accountNumbers, forKey: .accountNumbers) }
        if fromDate != nil { try container.encode(fromDate, forKey: .fromDate) }
        if toDate != nil { try container.encode(toDate, forKey: .toDate) }
        if transactionCodes.count > 0 { try container.encode(transactionCodes, forKey: .transactionCodes) }
    }
}

// @DataContract
public class ServiceRequestBase : IHasVersion, Codable
{
    required public init(){}
}

// @DataContract
public class ServiceResponseBase : Codable
{
    /**
    * Identifies whether the request executed successfully, however does not indicated requested data was found
    */
    // @DataMember
    // @ApiMember(Description="Identifies whether the request executed successfully, however does not indicated requested data was found")
    public var isSuccessful:Bool?

    /**
    * The status code returned by the service
    */
    // @DataMember
    // @ApiMember(Description="The status code returned by the service")
    public var statusCode:Int?

    /**
    * The status message returned by the service
    */
    // @DataMember
    // @ApiMember(Description="The status message returned by the service")
    public var statusMessage:String?

    // @DataMember
    // @ApiMember(ExcludeInSchema=true)
    public var serviceDebugFields:[String:String] = [:]

    required public init(){}
}


Swift AccountHistory DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml

HTTP + XML

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

POST /Accounts/AccountHistory HTTP/1.1 
Host: services.allianceassociationbank.com 
Accept: application/xml
Content-Type: application/xml
Content-Length: length

<AccountHistory xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Babel.Framework.ApiPlugins.Starlite.AccountTransactions">
  <AccountNumbers xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
    <d2p1:long>0</d2p1:long>
  </AccountNumbers>
  <FromDate>0001-01-01T00:00:00</FromDate>
  <ManagementCompanyId>String</ManagementCompanyId>
  <ToDate>0001-01-01T00:00:00</ToDate>
  <TransactionCodes xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
    <d2p1:int>0</d2p1:int>
  </TransactionCodes>
</AccountHistory>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<ServiceResponseBase xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Babel.Framework.ApiContext">
  <IsSuccessful>false</IsSuccessful>
  <ServiceDebugFields xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
    <d2p1:KeyValueOfstringstring>
      <d2p1:Key>ApiServiceHost</d2p1:Key>
      <d2p1:Value>WAB-WEBPW02</d2p1:Value>
    </d2p1:KeyValueOfstringstring>
    <d2p1:KeyValueOfstringstring>
      <d2p1:Key>ApiServiceHostVersion</d2p1:Key>
      <d2p1:Value>1.0.0.0</d2p1:Value>
    </d2p1:KeyValueOfstringstring>
  </ServiceDebugFields>
  <StatusCode>0</StatusCode>
  <StatusMessage>String</StatusMessage>
</ServiceResponseBase>