PaySecure Pinless Web Services 2023:07:03:07

<back to all web services

CreateCardTokenRequest

The following routes are available for this service:
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

HTTP + 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
		}
	}
}