Nephila Tartarus

<back to all web services

GetCitiBankAccountBalanceRequest

Cash
Requires Authentication
Required role:Tartarus.Read
The following routes are available for this service:
GET,POST/api/citi-bank-account-balance
namespace Nephila.Tartarus.ServiceModel

open System
open System.IO
open System.Collections
open System.Collections.Generic
open System.Runtime.Serialization
open ServiceStack
open ServiceStack.DataAnnotations

    type BankEntryType =
        | Balance = 1
        | Transaction = 2

    [<AllowNullLiteral>]
    type CitiBankAccountEntry() = 
        member val EntryType:BankEntryType = new BankEntryType() with get,set
        member val Description:String = null with get,set
        member val Amount:Nullable<Decimal> = new Nullable<Decimal>() with get,set
        member val CurrencyCode:String = null with get,set
        member val CreditDebitIndicator:String = null with get,set
        member val EntryDate:Nullable<DateTime> = new Nullable<DateTime>() with get,set

    [<AllowNullLiteral>]
    type CitiBankEntriesResponse() = 
        member val ResponseStatus:ResponseStatus = null with get,set
        member val StatementIsStillGenerating:Boolean = new Boolean() with get,set
        member val Entries:ResizeArray<CitiBankAccountEntry> = null with get,set

    [<AllowNullLiteral>]
    type GetCitiBankAccountBalanceRequest() = 
        interface IGet
        interface IPost
        member val AccountNumber:String = null with get,set
        member val CurrencyCode:String = null with get,set
        member val FromDate:DateTime = new DateTime() with get,set
        member val ToDate:DateTime = new DateTime() with get,set

F# GetCitiBankAccountBalanceRequest 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 /api/citi-bank-account-balance HTTP/1.1 
Host: tartarus.nephila.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	accountNumber: String,
	currencyCode: String,
	fromDate: 0001-01-01,
	toDate: 0001-01-01
}
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
		}
	},
	statementIsStillGenerating: False,
	entries: 
	[
		{
			entryType: Balance,
			description: String,
			amount: 0,
			currencyCode: String,
			creditDebitIndicator: String,
			entryDate: 0001-01-01
		}
	]
}