POST | /ClientTokenizeACH |
---|
import java.math.*
import java.util.*
import net.servicestack.client.*
@DataContract
open class ClientTokenizeACHRequest
{
@DataMember
var Version:String? = null
@DataMember
var KeyId:String? = null
@DataMember
var FirstName:String? = null
@DataMember
var LastName:String? = null
@DataMember
var Email:String? = null
@DataMember
var PhoneType:String? = null
@DataMember
var PhoneNumber:String? = null
@DataMember
var RoutingNumber:String? = null
@DataMember
var EncryptedAccountNumber:String? = null
@DataMember
var BillingDetails:BillingDescriptor? = null
@DataMember
var VerifyACH:Boolean? = null
}
open class BillingDescriptor
{
var Address:String? = null
var City:String? = null
var State:String? = null
var Zip:String? = null
var Country:String? = null
}
@DataContract
open class ClientTokenizeACH : PaysecureResponseInternal()
{
@DataMember
var SessionToken:String? = null
@DataMember
var ResponseCode:String? = null
@DataMember
var ErrorMessage:String? = null
@DataMember
var ErrorCode:String? = null
}
@DataContract
open class PaysecureResponseInternal
{
@DataMember(EmitDefaultValue=false)
var Timestamps:RequestTimestamps? = null
}
@DataContract
open class RequestTimestamps
{
@DataMember(EmitDefaultValue=false)
var AppLayer:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var ParentLookup:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var RetryLookup:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var GetCardData:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var CardTokenize:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var CardEncrypt:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var DBInsert:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var BackendProcess:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var DBUpdate:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var ParentUpdate:InOutTimes? = null
@DataMember(EmitDefaultValue=false)
var Network:InOutTimes? = null
}
@DataContract
open class InOutTimes
{
}
Kotlin ClientTokenizeACHRequest 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 /ClientTokenizeACH HTTP/1.1
Host: api.paysecure.acculynk.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
Version: String,
KeyId: String,
FirstName: String,
LastName: String,
Email: String,
PhoneType: String,
PhoneNumber: String,
RoutingNumber: String,
EncryptedAccountNumber: String,
BillingDetails:
{
Address: String,
City: String,
State: String,
Zip: String,
Country: String
},
VerifyACH: False
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { SessionToken: String, ResponseCode: String, ErrorMessage: String, ErrorCode: String, 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 } } }