| POST | /PSBINCheck |
|---|
import java.math.*
import java.util.*
import net.servicestack.client.*
@DataContract
open class PSBINCheckRequest
{
@DataMember
var Credentials:RequestorCredentials? = null
@DataMember
var BIN:String? = null
}
open class RequestorCredentials
{
@Required()
var MerchantId:String? = null
@Required()
var UserName:String? = null
@Required()
var Password:String? = null
@Required()
var Version:String? = null
}
@DataContract
open class PSBINCheck : PaysecureVersion()
{
@DataMember
var BIN:String? = null
@DataMember
var InternetPinDebit:Boolean? = null
@DataMember
var EcomEBTSNAP:Boolean? = null
@DataMember
var EcomEBTCash:Boolean? = null
@DataMember
var POSFlag:Boolean? = null
@DataMember
var PinlessEcommerce:Boolean? = null
@DataMember
var PinlessBillPay:Boolean? = null
@DataMember
var OnDemandPaymentCredit:Boolean? = null
@DataMember
var OnDemandPaymentDebit:Boolean? = null
@DataMember
var PinlessA2ACredit:Boolean? = null
@DataMember
var PinlessA2ADebit:Boolean? = null
@DataMember
var PinlessPrePaidLoad:Boolean? = null
@DataMember
var DualMessage:Boolean? = null
@DataMember
var Recurring:Boolean? = null
@DataMember
var CardVerify:Boolean? = null
@DataMember
var POSPinlessDualMessageFlag:Boolean? = null
@DataMember
var ErrorMessage:String? = null
@DataMember
var ErrorCode:String? = null
@DataMember
var OTP:Boolean? = null
@DataMember
var FastFunds:String? = null
@DataMember
var IncrementalAuth:Boolean? = null
@DataMember
var WIC:Boolean? = null
@DataMember
var CardDesignation:String? = null
}
@DataContract
open class PaysecureVersion : PaysecureResponseInternal()
{
@DataMember(EmitDefaultValue=false)
var LocalDateTime:String? = null
@DataMember(EmitDefaultValue=false)
var Token:String? = null
@DataMember(EmitDefaultValue=false)
var ExtendedData:ExtendedResponse? = 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
{
}
@DataContract
open class ExtendedResponse
{
@DataMember(EmitDefaultValue=false)
var CardAccountUpdater:CardAccountUpdaterDescriptor? = null
@DataMember(EmitDefaultValue=false)
var ProductId:String? = null
@DataMember(EmitDefaultValue=false)
var NetworkResponseCode:String? = null
@DataMember(EmitDefaultValue=false)
var NetworkTransactionId:String? = null
@DataMember(EmitDefaultValue=false)
var CHEmailAddrResult:String? = null
}
open class CardAccountUpdaterDescriptor
{
var CardDataType:CardInfoType? = null
var CardNumberInfo:String? = null
var ExpiryDate:String? = null
var Status:String? = null
var ErrorCode:String? = null
var CardToken:String? = null
}
enum class CardInfoType
{
CardNumber,
Token,
Track,
Emv,
Encrypted,
Dpan,
ApplePay,
GooglePay,
SamsungPay,
CpToken,
EncryptedEnhanced,
EncryptedJWE,
}
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 /PSBINCheck 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
},
BIN: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
BIN: String,
InternetPinDebit: False,
EcomEBTSNAP: False,
EcomEBTCash: False,
POSFlag: False,
PinlessEcommerce: False,
PinlessBillPay: False,
OnDemandPaymentCredit: False,
OnDemandPaymentDebit: False,
PinlessA2ACredit: False,
PinlessA2ADebit: False,
PinlessPrePaidLoad: False,
DualMessage: False,
Recurring: False,
CardVerify: False,
POSPinlessDualMessageFlag: False,
ErrorMessage: String,
ErrorCode: String,
OTP: False,
FastFunds: String,
IncrementalAuth: False,
WIC: False,
CardDesignation: String,
LocalDateTime: String,
Token: String,
ExtendedData:
{
CardAccountUpdater:
{
CardDataType: CardNumber,
CardNumberInfo: String,
ExpiryDate: String,
Status: String,
ErrorCode: String,
CardToken: String
},
ProductId: String,
NetworkResponseCode: String,
NetworkTransactionId: String,
CHEmailAddrResult: 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
}
}
}