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 .xml suffix or ?format=xml

HTTP + XML

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: application/xml
Content-Type: application/xml
Content-Length: length

<CreateCardTokenRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.servicestack.net/types">
  <Credentials>
    <MerchantId>String</MerchantId>
    <Password>String</Password>
    <UserName>String</UserName>
    <Version>String</Version>
  </Credentials>
  <SessionId>String</SessionId>
  <VerifyCard>false</VerifyCard>
</CreateCardTokenRequest>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<CreateCardToken xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.servicestack.net/types">
  <Timestamps>
    <AppLayer>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </AppLayer>
    <BackendProcess>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </BackendProcess>
    <CardEncrypt>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </CardEncrypt>
    <CardTokenize>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </CardTokenize>
    <DBInsert>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </DBInsert>
    <DBUpdate>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </DBUpdate>
    <GetCardData>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </GetCardData>
    <Network>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </Network>
    <ParentLookup>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </ParentLookup>
    <ParentUpdate>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </ParentUpdate>
    <RetryLookup>
      <InTime>0001-01-01T00:00:00</InTime>
      <OutTime>0001-01-01T00:00:00</OutTime>
    </RetryLookup>
  </Timestamps>
  <AVS>String</AVS>
  <BINResults>
    <BIN>String</BIN>
    <CardDesignation>String</CardDesignation>
    <CardProduct>String</CardProduct>
    <CardSubCategory>String</CardSubCategory>
    <CardType>String</CardType>
    <CardVerify>false</CardVerify>
    <CountryCode>String</CountryCode>
    <DualMessage>false</DualMessage>
    <EcomEBTCash>false</EcomEBTCash>
    <EcomEBTSNAP>false</EcomEBTSNAP>
    <FastFunds>String</FastFunds>
    <IncrementalAuth>false</IncrementalAuth>
    <InternetPinDebit>false</InternetPinDebit>
    <Network>String</Network>
    <OTP>false</OTP>
    <OnDemandPaymentCredit>false</OnDemandPaymentCredit>
    <OnDemandPaymentDebit>false</OnDemandPaymentDebit>
    <POSFlag>false</POSFlag>
    <POSPinlessDualMessage>false</POSPinlessDualMessage>
    <PinlessA2ACredit>false</PinlessA2ACredit>
    <PinlessA2ADebit>false</PinlessA2ADebit>
    <PinlessBillPay>false</PinlessBillPay>
    <PinlessEcommerce>false</PinlessEcommerce>
    <PinlessPrePaidLoad>false</PinlessPrePaidLoad>
    <Recurring>false</Recurring>
    <RegulatedFlag>false</RegulatedFlag>
    <RegulatedWithFraud>false</RegulatedWithFraud>
  </BINResults>
  <CVN>String</CVN>
  <CardExpiration>String</CardExpiration>
  <CardLast4>String</CardLast4>
  <CardToken>String</CardToken>
  <CardZip>String</CardZip>
  <ErrorCode>String</ErrorCode>
  <ErrorMessage>String</ErrorMessage>
  <ExtendedData>
    <CHEmailAddrResult>String</CHEmailAddrResult>
    <CardAccountUpdater>
      <CardDataType>CardNumber</CardDataType>
      <CardNumberInfo>String</CardNumberInfo>
      <CardToken>String</CardToken>
      <ErrorCode>String</ErrorCode>
      <ExpiryDate>String</ExpiryDate>
      <Status>String</Status>
    </CardAccountUpdater>
    <NetworkResponseCode>String</NetworkResponseCode>
    <NetworkTransactionId>String</NetworkTransactionId>
    <ProductId>String</ProductId>
  </ExtendedData>
  <ResponseCode>String</ResponseCode>
</CreateCardToken>