POST | /CreateCardToken |
---|
export class RequestorCredentials
{
// @Required()
public MerchantId: string;
// @Required()
public UserName: string;
// @Required()
public Password: string;
// @Required()
public Version: string;
public constructor(init?: Partial<RequestorCredentials>) { (Object as any).assign(this, init); }
}
// @DataContract
export class CreateCardTokenRequest
{
// @DataMember
public Credentials: RequestorCredentials;
// @DataMember
public SessionId: string;
// @DataMember
public VerifyCard: boolean;
public constructor(init?: Partial<CreateCardTokenRequest>) { (Object as any).assign(this, init); }
}
// @DataContract
export class InOutTimes
{
public constructor(init?: Partial<InOutTimes>) { (Object as any).assign(this, init); }
}
// @DataContract
export class RequestTimestamps
{
// @DataMember(EmitDefaultValue=false)
public AppLayer: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public ParentLookup: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public RetryLookup: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public GetCardData: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public CardTokenize: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public CardEncrypt: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public DBInsert: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public BackendProcess: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public DBUpdate: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public ParentUpdate: InOutTimes;
// @DataMember(EmitDefaultValue=false)
public Network: InOutTimes;
public constructor(init?: Partial<RequestTimestamps>) { (Object as any).assign(this, init); }
}
// @DataContract
export class PaysecureResponseInternal
{
// @DataMember(EmitDefaultValue=false)
public Timestamps: RequestTimestamps;
public constructor(init?: Partial<PaysecureResponseInternal>) { (Object as any).assign(this, init); }
}
export class BINResults
{
public BIN: string;
public Network: string;
public InternetPinDebit: boolean;
public EcomEBTCash: boolean;
public EcomEBTSNAP: boolean;
public POSFlag: boolean;
public PinlessEcommerce: boolean;
public PinlessBillPay: boolean;
public OnDemandPaymentCredit: boolean;
public OnDemandPaymentDebit: boolean;
public PinlessA2ACredit: boolean;
public PinlessA2ADebit: boolean;
public PinlessPrePaidLoad: boolean;
public DualMessage: boolean;
public Recurring: boolean;
public CardVerify: boolean;
public RegulatedFlag: boolean;
public OTP: boolean;
public POSPinlessDualMessage: boolean;
public FastFunds: string;
public RegulatedWithFraud: boolean;
public CountryCode: string;
public CardType: string;
public CardProduct: string;
public CardDesignation: string;
public CardSubCategory: string;
public IncrementalAuth: boolean;
public constructor(init?: Partial<BINResults>) { (Object as any).assign(this, init); }
}
export enum CardInfoType
{
CardNumber = 'CardNumber',
Token = 'Token',
Track = 'Track',
EMV = 'EMV',
Encrypted = 'Encrypted',
DPAN = 'DPAN',
ApplePay = 'ApplePay',
GooglePay = 'GooglePay',
SamsungPay = 'SamsungPay',
CPToken = 'CPToken',
EncryptedEnhanced = 'EncryptedEnhanced',
EncryptedJWE = 'EncryptedJWE',
}
export class CardAccountUpdaterDescriptor
{
public CardDataType: CardInfoType;
public CardNumberInfo: string;
public ExpiryDate: string;
public Status: string;
public ErrorCode: string;
public CardToken: string;
public constructor(init?: Partial<CardAccountUpdaterDescriptor>) { (Object as any).assign(this, init); }
}
// @DataContract
export class ExtendedResponse
{
// @DataMember(EmitDefaultValue=false)
public CardAccountUpdater: CardAccountUpdaterDescriptor;
// @DataMember(EmitDefaultValue=false)
public ProductId: string;
// @DataMember(EmitDefaultValue=false)
public NetworkResponseCode: string;
// @DataMember(EmitDefaultValue=false)
public NetworkTransactionId: string;
// @DataMember(EmitDefaultValue=false)
public CHEmailAddrResult: string;
public constructor(init?: Partial<ExtendedResponse>) { (Object as any).assign(this, init); }
}
// @DataContract
export class CreateCardToken extends PaysecureResponseInternal
{
// @DataMember
public CardToken: string;
// @DataMember
public CardZip: string;
// @DataMember
public CardLast4: string;
// @DataMember
public CardExpiration: string;
// @DataMember
public CVN: string;
// @DataMember
public AVS: string;
// @DataMember
public BINResults: BINResults;
// @DataMember
public ResponseCode: string;
// @DataMember
public ErrorMessage: string;
// @DataMember
public ErrorCode: string;
// @DataMember(EmitDefaultValue=false)
public ExtendedData: ExtendedResponse;
public constructor(init?: Partial<CreateCardToken>) { super(init); (Object as any).assign(this, init); }
}
TypeScript CreateCardTokenRequest 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 /CreateCardToken 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
},
SessionId: String,
VerifyCard: False
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { CardToken: String, CardZip: String, CardLast4: String, CardExpiration: String, CVN: String, AVS: String, BINResults: { BIN: String, Network: String, InternetPinDebit: False, EcomEBTCash: False, EcomEBTSNAP: False, POSFlag: False, PinlessEcommerce: False, PinlessBillPay: False, OnDemandPaymentCredit: False, OnDemandPaymentDebit: False, PinlessA2ACredit: False, PinlessA2ADebit: False, PinlessPrePaidLoad: False, DualMessage: False, Recurring: False, CardVerify: False, RegulatedFlag: False, OTP: False, POSPinlessDualMessage: False, FastFunds: String, RegulatedWithFraud: False, CountryCode: String, CardType: String, CardProduct: String, CardDesignation: String, CardSubCategory: String, IncrementalAuth: False }, ResponseCode: String, ErrorMessage: String, ErrorCode: 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 } } }