| Required role: | Tartarus.Read |
| GET,POST | /api/citi-bank-account-balance |
|---|
import 'package:servicestack/servicestack.dart';
enum BankEntryType
{
Balance,
Transaction,
}
class CitiBankAccountEntry implements IConvertible
{
BankEntryType? entryType;
String? description;
double? amount;
String? currencyCode;
String? creditDebitIndicator;
DateTime? entryDate;
CitiBankAccountEntry({this.entryType,this.description,this.amount,this.currencyCode,this.creditDebitIndicator,this.entryDate});
CitiBankAccountEntry.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
entryType = JsonConverters.fromJson(json['entryType'],'BankEntryType',context!);
description = json['description'];
amount = JsonConverters.toDouble(json['amount']);
currencyCode = json['currencyCode'];
creditDebitIndicator = json['creditDebitIndicator'];
entryDate = JsonConverters.fromJson(json['entryDate'],'DateTime',context!);
return this;
}
Map<String, dynamic> toJson() => {
'entryType': JsonConverters.toJson(entryType,'BankEntryType',context!),
'description': description,
'amount': amount,
'currencyCode': currencyCode,
'creditDebitIndicator': creditDebitIndicator,
'entryDate': JsonConverters.toJson(entryDate,'DateTime',context!)
};
getTypeName() => "CitiBankAccountEntry";
TypeContext? context = _ctx;
}
class CitiBankEntriesResponse implements IConvertible
{
ResponseStatus? responseStatus;
bool? statementIsStillGenerating;
List<CitiBankAccountEntry>? entries = [];
CitiBankEntriesResponse({this.responseStatus,this.statementIsStillGenerating,this.entries});
CitiBankEntriesResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
statementIsStillGenerating = json['statementIsStillGenerating'];
entries = JsonConverters.fromJson(json['entries'],'List<CitiBankAccountEntry>',context!);
return this;
}
Map<String, dynamic> toJson() => {
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!),
'statementIsStillGenerating': statementIsStillGenerating,
'entries': JsonConverters.toJson(entries,'List<CitiBankAccountEntry>',context!)
};
getTypeName() => "CitiBankEntriesResponse";
TypeContext? context = _ctx;
}
class GetCitiBankAccountBalanceRequest implements IGet, IPost, IConvertible
{
String? accountNumber;
String? currencyCode;
DateTime? fromDate;
DateTime? toDate;
GetCitiBankAccountBalanceRequest({this.accountNumber,this.currencyCode,this.fromDate,this.toDate});
GetCitiBankAccountBalanceRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
accountNumber = json['accountNumber'];
currencyCode = json['currencyCode'];
fromDate = JsonConverters.fromJson(json['fromDate'],'DateTime',context!);
toDate = JsonConverters.fromJson(json['toDate'],'DateTime',context!);
return this;
}
Map<String, dynamic> toJson() => {
'accountNumber': accountNumber,
'currencyCode': currencyCode,
'fromDate': JsonConverters.toJson(fromDate,'DateTime',context!),
'toDate': JsonConverters.toJson(toDate,'DateTime',context!)
};
getTypeName() => "GetCitiBankAccountBalanceRequest";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'tartarus.nephila.com', types: <String, TypeInfo> {
'BankEntryType': TypeInfo(TypeOf.Enum, enumValues:BankEntryType.values),
'CitiBankAccountEntry': TypeInfo(TypeOf.Class, create:() => CitiBankAccountEntry()),
'CitiBankEntriesResponse': TypeInfo(TypeOf.Class, create:() => CitiBankEntriesResponse()),
'List<CitiBankAccountEntry>': TypeInfo(TypeOf.Class, create:() => <CitiBankAccountEntry>[]),
'GetCitiBankAccountBalanceRequest': TypeInfo(TypeOf.Class, create:() => GetCitiBankAccountBalanceRequest()),
});
Dart GetCitiBankAccountBalanceRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=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
}
]
}