Starlite API

<back to all web services

DailyEndingBalance

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

// @DataContract
public class DailyEndingBalance : ServiceRequestBase
{
    /**
    * The account number which to retrieve the daily balance of
    */
    // @DataMember
    // @ApiMember(Description="The account number which to retrieve the daily balance of", IsRequired=true)
    public var accountNumber:Int?

    /**
    * OBSOLETE
    */
    // @DataMember
    // @ApiMember(Description="OBSOLETE")
    public var accountType:Int?

    /**
    * The start date for which to retrieve the day-ending balance for the account
    */
    // @DataMember
    // @ApiMember(Description="The start date for which to retrieve the day-ending balance for the account")
    public var fromDate:Date?

    /**
    * The end date for which to retrieve the day-ending balance for the account
    */
    // @DataMember
    // @ApiMember(Description="The end date for which to retrieve the day-ending balance for the account")
    public var toDate:Date?

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

    private enum CodingKeys : String, CodingKey {
        case accountNumber
        case accountType
        case fromDate
        case toDate
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        accountNumber = try container.decodeIfPresent(Int.self, forKey: .accountNumber)
        accountType = try container.decodeIfPresent(Int.self, forKey: .accountType)
        fromDate = try container.decodeIfPresent(Date.self, forKey: .fromDate)
        toDate = try container.decodeIfPresent(Date.self, forKey: .toDate)
    }

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

// @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 DailyEndingBalance 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.

POST /DailyEndingBalance HTTP/1.1 
Host: services.allianceassociationbank.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	AccountNumber: 0,
	AccountType: 0,
	FromDate: 0001-01-01,
	ToDate: 0001-01-01
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	IsSuccessful: False,
	StatusCode: 0,
	StatusMessage: String,
	ServiceDebugFields: 
	{
		ApiServiceHost: AZW-AABWPW02,
		ApiServiceHostVersion: 2016.1.18.3
	}
}