POST | /CreateAchSession |
---|
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class RequestorCredentials:
# @Required()
merchant_id: Optional[str] = None
# @Required()
user_name: Optional[str] = None
# @Required()
password: Optional[str] = None
# @Required()
version: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ACHExtendedData:
cashback_amount: int = 0
connect_pay_sub_scriber_id: Optional[str] = None
organization_id: Optional[str] = None
device_finger_print: Optional[str] = None
merchant_session_id: Optional[str] = None
currency_code: Optional[str] = None
payment_type: Optional[str] = None
verify_customer: bool = False
customer_external_id: Optional[str] = None
description: Optional[str] = None
customer_name: Optional[str] = None
address_line1: Optional[str] = None
address_line2: Optional[str] = None
city: Optional[str] = None
state: Optional[str] = None
zip: Optional[str] = None
country: Optional[str] = None
email: Optional[str] = None
telephone_number: Optional[str] = None
return_url: Optional[str] = None
cancel_url: Optional[str] = None
establish_data: Optional[str] = None
redirect_url: Optional[str] = None
retry_attempt_count: int = 0
signature_hash_version: Optional[str] = None
deadline_hash_date: Optional[datetime.datetime] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CreateAchSessionRequest:
credentials: Optional[RequestorCredentials] = None
ach_session_expiry_in_min: float = 0.0
ach_session_t_t_l: float = 0.0
extended_data: Optional[ACHExtendedData] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class InOutTimes:
pass
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class RequestTimestamps:
app_layer: Optional[InOutTimes] = None
parent_lookup: Optional[InOutTimes] = None
retry_lookup: Optional[InOutTimes] = None
get_card_data: Optional[InOutTimes] = None
card_tokenize: Optional[InOutTimes] = None
card_encrypt: Optional[InOutTimes] = None
db_insert: Optional[InOutTimes] = None
backend_process: Optional[InOutTimes] = None
db_update: Optional[InOutTimes] = None
parent_update: Optional[InOutTimes] = None
network: Optional[InOutTimes] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PaysecureResponseInternal:
timestamps: Optional[RequestTimestamps] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CreateAchSession(PaysecureResponseInternal):
session_id: Optional[str] = None
error_code: Optional[str] = None
error_message: Optional[str] = None
extended_data: Optional[ACHExtendedData] = None
Python CreateAchSessionRequest 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 /CreateAchSession HTTP/1.1
Host: api.paysecure.acculynk.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
Credentials:
{
MerchantId: String,
UserName: String,
Password: String,
Version: String
},
ACHSessionExpiryInMin: 0,
ACHSessionTTL: 0,
ExtendedData:
{
CashbackAmount: 0,
ConnectPaySubScriberId: String,
OrganizationId: String,
DeviceFingerPrint: String,
MerchantSessionId: String,
CurrencyCode: String,
PaymentType: String,
VerifyCustomer: False,
CustomerExternalId: String,
Description: String,
CustomerName: String,
AddressLine1: String,
AddressLine2: String,
City: String,
State: String,
Zip: String,
Country: String,
Email: String,
TelephoneNumber: String,
ReturnUrl: String,
CancelUrl: String,
EstablishData: String,
RedirectUrl: String,
RetryAttemptCount: 0,
SignatureHashVersion: String,
DeadlineHashDate: 0001-01-01
}
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { SessionId: String, ErrorCode: String, ErrorMessage: String, ExtendedData: { CashbackAmount: 0, ConnectPaySubScriberId: String, OrganizationId: String, DeviceFingerPrint: String, MerchantSessionId: String, CurrencyCode: String, PaymentType: String, VerifyCustomer: False, CustomerExternalId: String, Description: String, CustomerName: String, AddressLine1: String, AddressLine2: String, City: String, State: String, Zip: String, Country: String, Email: String, TelephoneNumber: String, ReturnUrl: String, CancelUrl: String, EstablishData: String, RedirectUrl: String, RetryAttemptCount: 0, SignatureHashVersion: String, DeadlineHashDate: 0001-01-01 }, Timestamps: { AppLayer: { InTime: 0001-01-01, OutTime: 0001-01-01 }, ParentLookup: { InTime: 0001-01-01, OutTime: 0001-01-01 }, RetryLookup: { InTime: 0001-01-01, OutTime: 0001-01-01 }, GetCardData: { InTime: 0001-01-01, OutTime: 0001-01-01 }, CardTokenize: { InTime: 0001-01-01, OutTime: 0001-01-01 }, CardEncrypt: { InTime: 0001-01-01, OutTime: 0001-01-01 }, DBInsert: { InTime: 0001-01-01, OutTime: 0001-01-01 }, BackendProcess: { InTime: 0001-01-01, OutTime: 0001-01-01 }, DBUpdate: { InTime: 0001-01-01, OutTime: 0001-01-01 }, ParentUpdate: { InTime: 0001-01-01, OutTime: 0001-01-01 }, Network: { InTime: 0001-01-01, OutTime: 0001-01-01 } } }