POST | /PinDebit |
---|
import Foundation
import ServiceStack
// @DataContract
public class AuthorizePinDebitRequest : Codable
{
// @DataMember
public var credentials:RequestorCredentials
// @DataMember
public var cardNumberInfo:Card
// @DataMember
public var amount:Int
// @DataMember
public var expirationDate:String
// @DataMember
public var referenceKey:String
// @DataMember
public var currencyCode:String
// @DataMember
public var cvn:String
// @DataMember
public var avs:Avs
// @DataMember
public var merchantDetails:MerchantDescriptor
// @DataMember
public var custom1:String
// @DataMember
public var custom2:String
// @DataMember
public var custom3:String
// @DataMember
public var custom4:String
// @DataMember
public var custom5:String
// @DataMember
public var signatureHash:String
// @DataMember
public var extendedData:ExtendedData
// @DataMember
public var otp:String
// @DataMember
public var pinData:String
// @DataMember
public var mfk:String
// @DataMember
public var transType:PINTransType
required public init(){}
}
public class RequestorCredentials : Codable
{
// @Required()
public var merchantId:String?
// @Required()
public var userName:String?
// @Required()
public var password:String?
// @Required()
public var version:String?
required public init(){}
}
public class Card : Codable
{
public var cardDataType:CardInfoType
public var cardNumberData:String
public var keyID:String
required public init(){}
}
public enum CardInfoType : String, Codable
{
case CardNumber
case Token
case Track
case EMV
case Encrypted
case DPAN
case ApplePay
case GooglePay
case SamsungPay
case CPToken
case EncryptedEnhanced
case EncryptedJWE
}
public class Avs : Codable
{
public var address:String
public var city:String
public var state:String
public var zip:String
public var country:String
public var email:String
public var ipAddress:String
public var telephoneNumber:String
public var telephoneType:TelephoneType
public var deliveryMethod:Int
public var firstName:String
public var middleName:String
public var lastName:String
required public init(){}
}
public enum TelephoneType : String, Codable
{
case D
case H
case N
case W
}
public class MerchantDescriptor : MerchantDescriptorBase
{
public var name:String
public var address:String
public var city:String
public var state:String
public var zip:String
public var country:String
public var customerServiceNumber:String
public var mcc:String
public var fnSnum:String
public var email:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case name
case address
case city
case state
case zip
case country
case customerServiceNumber
case mcc
case fnSnum
case email
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
name = try container.decodeIfPresent(String.self, forKey: .name)
address = try container.decodeIfPresent(String.self, forKey: .address)
city = try container.decodeIfPresent(String.self, forKey: .city)
state = try container.decodeIfPresent(String.self, forKey: .state)
zip = try container.decodeIfPresent(String.self, forKey: .zip)
country = try container.decodeIfPresent(String.self, forKey: .country)
customerServiceNumber = try container.decodeIfPresent(String.self, forKey: .customerServiceNumber)
mcc = try container.decodeIfPresent(String.self, forKey: .mcc)
fnSnum = try container.decodeIfPresent(String.self, forKey: .fnSnum)
email = try container.decodeIfPresent(String.self, forKey: .email)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if name != nil { try container.encode(name, forKey: .name) }
if address != nil { try container.encode(address, forKey: .address) }
if city != nil { try container.encode(city, forKey: .city) }
if state != nil { try container.encode(state, forKey: .state) }
if zip != nil { try container.encode(zip, forKey: .zip) }
if country != nil { try container.encode(country, forKey: .country) }
if customerServiceNumber != nil { try container.encode(customerServiceNumber, forKey: .customerServiceNumber) }
if mcc != nil { try container.encode(mcc, forKey: .mcc) }
if fnSnum != nil { try container.encode(fnSnum, forKey: .fnSnum) }
if email != nil { try container.encode(email, forKey: .email) }
}
}
public class MerchantDescriptorBase : Codable
{
public var dataElements:MerchantDataElements
required public init(){}
}
public class MerchantDataElements : Codable
{
public var refundSettlementTypeDetails:Int
public var sendRecurringPOSEntryModeFeature:Bool
public var useOrgPOSCode:Bool
required public init(){}
}
// @DataContract
public class ExtendedData : Codable
{
// @DataMember
public var track2DataForEMVTransaction:String
// @DataMember
public var senderInfo:SenderInfo
// @DataMember
public var cashbackAmount:Int
// @DataMember
public var network:NetworkName
// @DataMember
public var receiverInfo:ReceiverInfo
// @DataMember
public var billPayGroup:BillPayGroup
// @DataMember
public var walletData:WalletDescriptor
// @DataMember
public var secureData:SecureDescriptor
// @DataMember
public var level2Data:Level2Descriptor
// @DataMember
public var paymentFacilitatorData:PaymentFacilitatorDescriptor
// @DataMember
public var tokenData:TokenDescriptor
// @DataMember
public var otpTranId:String
// @DataMember
public var currentShipment:Int
// @DataMember
public var totalShipments:Int
// @DataMember
public var isTokenRequested:Bool
// @DataMember
public var cardonFileIndicator:CardonFileIndicatorDescriptor
// @DataMember
public var cardAccountUpdater:CardAccountUpdaterInfo
// @DataMember
public var retryAttemptCount:Int
// @DataMember
public var totalAuthAmount:Int
// @DataMember
public var signatureHashVersion:String
// @DataMember
public var orderTypeDetail:OrderTypeInfo
// @DataMember
public var billPayGroupIndicator:BillPayGroupIndicator
// @DataMember
public var chargeTypeDetail:ChargeTypeInfo
// @DataMember
public var safEligible:SAFEligibleFlag
required public init(){}
}
public class SenderInfo : Codable
{
public var referenceNumber:String
public var accountNumber:String
/**
* Name Format FirstName{Space}LastName. For Example :- Alvaro Morata
*/
public var name:String
public var address:String
public var city:String
public var state:String
public var country:String
/**
* DateOfBirth Format MMDDYYYY. For Example :- 05051960
*/
public var dateOfBirth:String
public var zip:String
public var phoneNumber:String
public var fundingSource:FundingSourceType
required public init(){}
}
public enum FundingSourceType : String, Codable
{
case DepositAccount
case Credit
case Debit
case Prepaid
}
public enum NetworkName : String, Codable
{
case Default
case NYCE
case CU24
case XCEL
case STAR
case PULS
case SHZM
case VISA
case MAST
case DISC
case AMEX
case ALIP
case UPIN
case STAC
case STNE
case MAES
case INTL
}
public class ReceiverInfo : Codable
{
public var referenceNumber:String
public var accountNumber:String
/**
* Name Format FirstName{Space}LastName. For Example :- Alvaro Morata
*/
public var name:String
public var address:String
public var city:String
public var state:String
public var country:String
public var zip:String
public var phoneNumber:String
required public init(){}
}
public enum BillPayGroup : String, Codable
{
case Default
case Single
case Recurring
case Installment
case Deferred
}
public class WalletDescriptor : Codable
{
public var type:String
public var encryptedData:String
public var applicationDataHash:String
public var ephemeralPublicKey:String
public var publicKeyHash:String
public var transactionId:String
public var signature:String
public var version:String
public var applicationData:String
public var merchantIdentifier:String
public var specialPayment:String
public var digitalWalletIndicator:DigitalWalletInfo
required public init(){}
}
public enum DigitalWalletInfo : String, Codable
{
case Default
case Staged
case Passthrough
}
public class SecureDescriptor : Codable
{
public var cavv:String
public var secureTransactionId:String
required public init(){}
}
public class Level2Descriptor : Codable
{
public var taxDetails:TaxIndicator
public var merchantReferenceNumber:String
public var merchantTaxId:String
public var orderNumber:String
public var taxAmount:Int
public var destinationPostalCode:String
public var productDescription:String
required public init(){}
}
public enum TaxIndicator : String, Codable
{
case Default
case NoTaxInfoProvided
case TaxInfoProvided
case TaxExemptItem
}
public class PaymentFacilitatorDescriptor : Codable
{
public var paymentFacilitatorIndicator:String
public var pfPhoneNumber:String
public var subMerchID:String
public var sellerID:String
required public init(){}
}
public class TokenDescriptor : Codable
{
public var tokenType:TokenTypes
public var tokenCryptogramData1:String
public var tokenCryptogramData2:String
required public init(){}
}
public enum TokenTypes : String, Codable
{
case Default
case UCAF
case DSRP
case UCAFDSRP
case VisaVerified
case DigitalWallet
case VisaVerifiedDigitalWallet
}
public class CardonFileIndicatorDescriptor : Codable
{
public var cardonFile:CardonFileInfo
public var storedCredentialIndicator:StoredCredentialIndicatorInfo
public var transactionInitiate:TransactionInitiateInfo
public var scheduleIndicator:ScheduleIndicatorInfo
public var networkTransactionId:String
required public init(){}
}
public enum CardonFileInfo : String, Codable
{
case Default
case Supported
case NotSupported
}
public enum StoredCredentialIndicatorInfo : String, Codable
{
case Default
case Initial
case Subsequent
}
public enum TransactionInitiateInfo : String, Codable
{
case Default
case Merchant
case Terminal
case Customer
}
public enum ScheduleIndicatorInfo : String, Codable
{
case Default
case Scheduled
case Unscheduled
}
public enum CardAccountUpdaterInfo : String, Codable
{
case Default
case Supported
case NotSupported
}
public enum OrderTypeInfo : String, Codable
{
case Default
case Standing
case Subscription
}
public class BillPayGroupIndicator : Codable
{
public var mitTotalPaymentCount:String
public var mitAmountType:String
public var mitAmount:String
public var mitUniqueID:String
public var mitFrequency:String
public var mitValidationFlag:String
public var mitValidationReference:String
public var mitSequenceIndicator:String
required public init(){}
}
public enum ChargeTypeInfo : String, Codable
{
case Default
case PartialShipment
case Delayed
case NoShow
case Resubmission
}
public enum SAFEligibleFlag : String, Codable
{
case Default
case True
case False
}
public enum PINTransType : Int, Codable
{
case IPD = 9
case eCommerce = 11
}
// @DataContract
public class AuthorizePinDebit : PaysecureResponseInternal
{
// @DataMember
public var tranId:String
// @DataMember
public var approvalCode:String
// @DataMember
public var responseCode:String
// @DataMember
public var network:String
// @DataMember
public var approvedAmount:Int
// @DataMember
public var avs:String
// @DataMember
public var cvn:String
// @DataMember
public var otp:String
// @DataMember
public var errorMessage:String
// @DataMember
public var errorCode:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case tranId
case approvalCode
case responseCode
case network
case approvedAmount
case avs
case cvn
case otp
case errorMessage
case errorCode
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
tranId = try container.decodeIfPresent(String.self, forKey: .tranId)
approvalCode = try container.decodeIfPresent(String.self, forKey: .approvalCode)
responseCode = try container.decodeIfPresent(String.self, forKey: .responseCode)
network = try container.decodeIfPresent(String.self, forKey: .network)
approvedAmount = try container.decodeIfPresent(Int.self, forKey: .approvedAmount)
avs = try container.decodeIfPresent(String.self, forKey: .avs)
cvn = try container.decodeIfPresent(String.self, forKey: .cvn)
otp = try container.decodeIfPresent(String.self, forKey: .otp)
errorMessage = try container.decodeIfPresent(String.self, forKey: .errorMessage)
errorCode = try container.decodeIfPresent(String.self, forKey: .errorCode)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if tranId != nil { try container.encode(tranId, forKey: .tranId) }
if approvalCode != nil { try container.encode(approvalCode, forKey: .approvalCode) }
if responseCode != nil { try container.encode(responseCode, forKey: .responseCode) }
if network != nil { try container.encode(network, forKey: .network) }
if approvedAmount != nil { try container.encode(approvedAmount, forKey: .approvedAmount) }
if avs != nil { try container.encode(avs, forKey: .avs) }
if cvn != nil { try container.encode(cvn, forKey: .cvn) }
if otp != nil { try container.encode(otp, forKey: .otp) }
if errorMessage != nil { try container.encode(errorMessage, forKey: .errorMessage) }
if errorCode != nil { try container.encode(errorCode, forKey: .errorCode) }
}
}
// @DataContract
public class PaysecureResponseInternal : Codable
{
// @DataMember(EmitDefaultValue=false)
public var timestamps:RequestTimestamps
required public init(){}
}
// @DataContract
public class RequestTimestamps : Codable
{
// @DataMember(EmitDefaultValue=false)
public var appLayer:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var parentLookup:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var retryLookup:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var getCardData:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var cardTokenize:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var cardEncrypt:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var dbInsert:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var backendProcess:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var dbUpdate:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var parentUpdate:InOutTimes
// @DataMember(EmitDefaultValue=false)
public var network:InOutTimes
required public init(){}
}
// @DataContract
public class InOutTimes : Codable
{
required public init(){}
}
Swift AuthorizePinDebitRequest 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 /PinDebit 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
},
CardNumberInfo:
{
CardDataType: CardNumber,
CardNumberData: String,
KeyID: String
},
Amount: 0,
ExpirationDate: String,
ReferenceKey: String,
CurrencyCode: String,
CVN: String,
AVS:
{
Address: String,
City: String,
State: String,
Zip: String,
Country: String,
Email: String,
IPAddress: String,
TelephoneNumber: String,
TelephoneType: D,
DeliveryMethod: 0,
FirstName: String,
MiddleName: String,
LastName: String
},
MerchantDetails:
{
Name: String,
Address: String,
City: String,
State: String,
Zip: String,
Country: String,
CustomerServiceNumber: String,
MCC: String,
FNSnum: String,
Email: String,
DataElements:
{
RefundSettlementTypeDetails: 0,
SendRecurringPOSEntryModeFeature: False,
UseOrgPOSCode: False
}
},
Custom1: String,
Custom2: String,
Custom3: String,
Custom4: String,
Custom5: String,
SignatureHash: String,
ExtendedData:
{
Track2DataForEMVTransaction: String,
SenderInfo:
{
ReferenceNumber: String,
AccountNumber: String,
Name: String,
Address: String,
City: String,
State: String,
Country: String,
DateOfBirth: String,
Zip: String,
PhoneNumber: String,
FundingSource: DepositAccount
},
CashbackAmount: 0,
Network: Default,
ReceiverInfo:
{
ReferenceNumber: String,
AccountNumber: String,
Name: String,
Address: String,
City: String,
State: String,
Country: String,
Zip: String,
PhoneNumber: String
},
BillPayGroup: Default,
WalletData:
{
Type: String,
EncryptedData: String,
ApplicationDataHash: String,
EphemeralPublicKey: String,
PublicKeyHash: String,
TransactionId: String,
Signature: String,
Version: String,
ApplicationData: String,
MerchantIdentifier: String,
SpecialPayment: String,
DigitalWalletIndicator: Default
},
SecureData:
{
CAVV: String,
SecureTransactionId: String
},
Level2Data:
{
TaxDetails: Default,
MerchantReferenceNumber: String,
MerchantTaxId: String,
OrderNumber: String,
TaxAmount: 0,
DestinationPostalCode: String,
ProductDescription: String
},
PaymentFacilitatorData:
{
PaymentFacilitatorIndicator: String,
PFPhoneNumber: String,
SubMerchID: String,
SellerID: String
},
TokenData:
{
TokenType: Default,
TokenCryptogramData1: String,
TokenCryptogramData2: String
},
OTPTranId: String,
CurrentShipment: 0,
TotalShipments: 0,
IsTokenRequested: False,
CardonFileIndicator:
{
CardonFile: Default,
StoredCredentialIndicator: Default,
TransactionInitiate: Default,
ScheduleIndicator: Default,
NetworkTransactionId: String
},
CardAccountUpdater: Default,
RetryAttemptCount: 0,
TotalAuthAmount: 0,
SignatureHashVersion: String,
OrderTypeDetail: Default,
BillPayGroupIndicator:
{
MITTotalPaymentCount: String,
MITAmountType: String,
MITAmount: String,
MITUniqueID: String,
MITFrequency: String,
MITValidationFlag: String,
MITValidationReference: String,
MITSequenceIndicator: String
},
ChargeTypeDetail: Default,
SAFEligible: Default
},
OTP: String,
PINData: String,
MFK: String,
TransType: IPD
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { TranId: String, ApprovalCode: String, ResponseCode: String, Network: String, ApprovedAmount: 0, AVS: String, CVN: String, OTP: 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 } } }