Skip to main content

QuickStream-API.js reference

QuickStream-API.js is a JavaScript library containing helper functions for collecting credit card details, validating these details and obtaining a single-use-token without any sensitive details ever touching your servers. All sensitive data is sent directly from the customer's browser to our QuickStream servers.

Including QuickStream-API.js on your website

To begin using QuickStream-API.js on your website, you first need to include the library and initialise it with your publishable API key. You can do this by including the following on your page (replace the initialisation values with your own):

<script type="text/javascript" src="https://api.quickstream.westpac.com.au/rest/v1/quickstream-api-1.0.min.js"></script>
<script>
    QuickstreamAPI.init( {
        publishableApiKey: "PUBLISHABLE_API_KEY"
    } );
</script>

QuickstreamAPI module

QuickstreamAPI is the main module in the QuickStream-API.js library. It provides access to initialisation functions and to the submodules that rely on these values.

QuickstreamAPI contains the following submodules:

Before looking at these submodules, the callback function and the Error object must be introduced, since these supporting structures are extensively used throughout the library.

callback( errors, data ) → void

Many functions made available throughout the QuickStream-API.js library take a callback function as the final parameter. This callback function follows the error-first-callback pattern, where the first parameter will receive a list of errors if the calling function fails, and the second parameter will receive the resultant data if the calling function is successful.

PARAMETERS

Name Type Attributes Description
errors array of Error An array of Error objects that describe the errors encountered by the calling function.
data object An object that contains name/value pairs representing the successful result of the calling function.

EXAMPLE

let callback = function( errors, data ) {
    if ( errors ) {
        // Perform error handling here
    }
    else {
        console.log( data );
    }
}

callback( errors ) → void

This callback function will receive a list of errors if the calling function fails, and the function will not be invoked if the calling function is successful.

PARAMETERS

Name Type Attributes Description
errors array of Error An array of Error objects that describe the errors encountered by the calling function.

EXAMPLE

let callback = function( errors ) {
    // Perform error handling here
}

Error

This object represents an error condition. Generally an array of these objects are provided as the first parameter to callbacks throughout the library.

PROPERTIES

Name Type Attributes Description
fieldName string The name of the field for which an error has been generated.
messages array of string An array of error messages. Each message represents a different error with the current field.

EXAMPLE

{
    fieldName: "cardNumber",
    messages: [ "Invalid credit card number." ]
}

init( data ) → void

This is used to initialise the library.

PARAMETERS

Name Type Attributes Description
data object Contains initialisation data as name/value pairs.

The data parameter is a JavaScript object and must contain your publishable API key. All other name/value pairs you provide in data will be discarded.

EXAMPLE

QuickstreamAPI.init( {
    publishableApiKey: "PUBLISHABLE_API_KEY"
} );

getPublishableApiKey() → string

Returns the publishable API key that was passed in when init( data ) was called, or undefined if the library hasn't been initialised yet.

EXAMPLE

QuickstreamAPI.init( {
    publishableApiKey: "PUBLISHABLE_API_KEY"
} );

QuickstreamAPI.getPublishableApiKey(); // Returns "PUBLISHABLE_API_KEY"

isInitialised() → boolean

Returns true if the publishable API key has been initialised with a value. Otherwise returns false.

QuickstreamAPI.isInitialised(); // Returns false

QuickstreamAPI.init( {
    publishableApiKey: "PUBLISHABLE_API_KEY"
} );

QuickstreamAPI.isInitialised(); // Returns true

Credit cards module

QuickstreamAPI provides a Credit Cards module, which can accessed via QuickstreamAPI.creditCards. This module provides access to the following components:

  • Trusted Frame - automatically appends an iFrame containing a credit card form to your page. You don't host the credit card form (we do), so your PCI DSS obligations are minimised.
  • Challenge Frame - automatically appends an iFrame containing a 3D Secure challenge to your page with content served by the card issuer.

Trusted Frame

The Trusted Frame component of QuickstreamAPI.creditCards automatically adds an iFrame containing a card form to your page. Since the card form is not hosted by you (it is hosted on our servers), your PCI-DSS obligations are minimised.

You have the ability to configure the Trusted Frame on initialisation, and interact with the iFrame after initialisation. Using the provided helper functions, you can:

  • Clear fields
  • Change input placeholders
  • Change styles
  • Register event handlers for field events, including change, focus, blur and error

Continue reading for details on how to use Trusted Frame.

HTML structure

You can place the Trusted Frame anywhere on your page. All you need to do is mark a block element with the data-quickstream-api="creditCardContainer" attribute so that the QuickstreamAPI.creditCards module knows where to append your Trusted Frame.

EXAMPLE

This is an example snippet containing the required attribute.

<div data-quickstream-api="creditCardContainer">
  <!-- The Trusted Frame will be inserted in here -->
</div>
createTrustedFrame( options, callback ) → TrustedFrameInstance

Used to initialise and append the Trusted Frame to your webpage.

PARAMETERS

Name Type Attributes Description
options TrustedFrameConfigObject A standard JavaScript object containing name/value pairs describing the configuration of the Trusted Frame. See TrustedFrameConfigObject for the structure and available values of this object.
callback callback The callback function that is executed after the initialisation of the Trusted Frame.

When there are no errors, the data parameter of callback has the following form:

{
    trustedFrame: TrustedFrameInstance
}

Where TrustedFrameInstance is an object containing helper functions for interacting with the created iFrame (including submitting the credit card form).

EXAMPLE

var trustedFrame;

var options = {
    config: {
        supplierBusinessCode: "SUPPLIER_CODE" // This is a required config option
    }
};

QuickstreamAPI.creditCards.createTrustedFrame( options, function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        trustedFrame = data.trustedFrame
    }
} );
TrustedFrameConfigObject

A JavaScript object that encapsulates the configuration data used to initialise a Trusted Frame. See the tables below for more details on the structure.

Property Type Required Default Description
config ConfigObject Required Contains required configuration values for Trusted Frame initialisation. See ConfigObject for more details.
iframe IframeObject Optional See IframeObject for the default values. Contains configuration values relating to the visual styling of the iFrame. This includes the width, height, scrollbar visibility and other supported CSS properties. See IframeObject for more details.
showAcceptedCards boolean Optional true Set to false to hide the accepted card logos.
showRequiredIndicators boolean Optional false Set to true to show indicators for required fields.
body StyleableObject Optional Contains CSS properties for styling the body element of the Trusted Frame. This allows you to set font styles, color etc. that apply to the entire iFrame. See StyleableObject for more details.
labels StyleableObject Optional Contains CSS properties for styling the label elements of the Trusted Frame. This allows you to set font styles, padding, color etc. that apply to all labels in the iFrame. See StyleableObject for more details.
cardholderName HideableFieldObject Optional Contains configuration values relating to the appearance of the cardholder name form field. These include the ability to change the field's visibility, label, placeholder, input type and CSS properties. See HideableFieldObject for more details.
cardNumber FieldObject Optional Contains configuration values relating to the appearance of the card number form field. These include the ability to change the field's label, placeholder, input type and CSS properties. See FieldObject for more details.
expiryDateMonth ExpiryMonthFieldObject Optional Contains configuration values relating to the appearance of the expiry month form field. These include the ability to change the field's label, option format, default option visibility and CSS properties. See ExpiryMonthFieldObject for more details.
expiryDateYear ExpiryYearFieldObject Optional Contains configuration values relating to the appearance of the expiry year form field. These include the ability to change the field's label, default option visibility and CSS properties. See ExpiryYearFieldObject for more details.
cvn CvnFieldObject Optional Contains configuration values relating to the appearance of the CVN form field. These include the ability to change the field's visibility, label, placeholder, input type and CSS properties. See CvnFieldObject for more details.
ConfigObject
Property Type Required Default Description
supplierBusinessCode string Required The supplier business code that uniquely identifies your supplier business in the QuickStream system.
threeDS2 boolean Optional To opt-in to EMV 3D Secure, set to true when you call createTrustedFrame.
IframeObject
Property Type Required Default Description
width int Optional 800 Integer that sets the width of the iFrame.
height int Optional 300 Integer that sets the height of the iFrame.
scrolling string Optional "no" String that determines whether the iFrame has visible scrollbars. Supported values are:
  • no
  • yes
  • auto
style StyleObject Optional Contains CSS properties used to style the iFrame. See StyleObject for more details.
dummyTouchStart boolean Optional false Set to true to add an empty event listener to the touchstart event. Enable this if you use touch event listeners on your website and experience issues focusing on input fields within the Trusted Frame.
dummyTouchMove boolean Optional false Set to true to add an empty event listener to the touchmove event. Enable this if you use touch event listeners on your website and experience issues focusing on input fields within the Trusted Frame.
dummyTouchEnd boolean Optional false Set to true to add an empty event listener to the touchend event. Enable this if you use touch event listeners on your website and experience issues focusing on input fields within the Trusted Frame.
StyleableObject
Property Type Required Default Description
style StyleObject Optional Contains CSS properties used to style the target element/s. See StyleObject for more details.
HideableFieldObject
Property Type Required Default Description
hidden boolean Optional false Set to true to hide the field.
label string Optional Replace the field's default label with one of your choosing.
placeholder string Optional Specify a placeholder value for the target field.
inputType string Optional "text" Change the default input type to another. Supported values are as defined in the W3C Recommendation.
style StyleObject Optional Contains CSS properties used to style the target field. See StyleObject for more details.
FieldObject
Property Type Required Default Description
label string Optional Replace the field's default label with one of your choosing.
placeholder string Optional Specify a placeholder value for the target field.
inputType string Optional "text" Change the default input type to another. Supported values are as defined in the W3C Recommendation.
style StyleObject Optional Contains CSS properties used to style the target field. See StyleObject for more details.
ExpiryMonthFieldObject
Property Type Required Default Description
label string Optional Replace the field's default label with one of your choosing.
hideDefault boolean Optional false Set to true to hide the default expiry month value. This causes the first option (01 - January) to be auto-selected.
optionFormat string Optional "NUMBER" Change the format that expiry month options are presented in. Supported values are:
  • NUMBER
  • NAME
style StyleObject Optional Contains CSS properties used to style the expiry month field. See StyleObject for more details.
ExpiryYearFieldObject
Property Type Required Default Description
label string Optional Replace the field's default label with one of your choosing.
hideDefault boolean Optional false Set to true to hide the default expiry year value. This causes the first option (current year) to be auto-selected.
style StyleObject Optional Contains CSS properties used to style the expiry year field. See StyleObject for more details.
CvnFieldObject
Property Type Required Default Description
hidden boolean Optional false Set to true to hide the field.
label string Optional Replace the field's default label with one of your choosing.
placeholder string Optional Specify a placeholder value for the target field.
inputType string Optional "text" Change the default input type to another. Supported values are as defined in the W3C Recommendation.
style StyleObject Optional Contains CSS properties used to style the target field. See StyleObject for more details.
showHelp boolean Optional true Set to false to hide the CVN help icon
StyleObject
Property Type Required Default Description
"css-property-name" string Optional Each name/value pair in this object map directly to CSS property/value pairs. For example, a valid instance of StyleObject could look like the following:
{
    "border-color": "green"
    padding: "5px"
}

The supported CSS properties are:

  • appearance
  • background
  • background-attachment
  • background-blend-mode
  • background-clip
  • background-color
  • background-image
  • background-origin
  • background-position
  • background-repeat
  • background-size
  • border
  • border-block-end
  • border-block-end-color
  • border-block-end-style
  • border-block-end-width
  • border-block-start
  • border-block-start-color
  • border-block-start-style
  • border-block-start-width
  • border-bottom
  • border-bottom-color
  • border-bottom-left-radius
  • border-bottom-right-radius
  • border-bottom-style
  • border-bottom-width
  • border-collapse
  • border-color
  • border-image
  • border-image-outset
  • border-image-repeat
  • border-image-slice
  • border-image-source
  • border-image-width
  • border-inline-end
  • border-inline-end-color
  • border-inline-end-style
  • border-inline-end-width
  • border-inline-start
  • border-inline-start-color
  • border-inline-start-style
  • border-inline-start-width
  • border-left
  • border-left-color
  • border-left-style
  • border-left-width
  • border-radius
  • border-right
  • border-right-color
  • border-right-style
  • border-right-width
  • border-spacing
  • border-style
  • border-top
  • border-top-color
  • border-top-left-radius
  • border-top-right-radius
  • border-top-style
  • border-top-width
  • border-width
  • bottom
  • box-shadow
  • box-sizing
  • color
  • direction
  • display
  • font
  • font-family
  • font-size
  • font-size-adjust
  • font-stretch
  • font-style
  • font-variant
  • font-variant-alternates
  • font-variant-caps
  • font-variant-east-asian
  • font-variant-ligatures
  • font-variant-numeric
  • font-variant-position
  • font-weight
  • height
  • left
  • letter-spacing
  • line-height
  • margin
  • margin-block-end
  • margin-block-start
  • margin-bottom
  • margin-inline-end
  • margin-inline-start
  • margin-left
  • margin-right
  • margin-top
  • max-height
  • max-width
  • min-height
  • min-width
  • opacity
  • outline
  • outline-color
  • outline-offset
  • outline-style
  • outline-width
  • overflow
  • overflow-wrap
  • overflow-x
  • overflow-y
  • padding
  • padding-bottom
  • padding-left
  • padding-right
  • padding-top
  • position
  • right
  • text-align
  • text-decoration
  • text-decoration-color
  • text-decoration-line
  • text-decoration-style
  • text-emphasis
  • text-emphasis-color
  • text-emphasis-position
  • text-emphasis-style
  • text-indent
  • text-orientation
  • text-overflow
  • text-shadow
  • text-transform
  • text-underline-position
  • top
  • transform
  • transform-box
  • transform-origin
  • transform-style
  • transition
  • transition-delay
  • transition-duration
  • transition-property
  • transition-timing-function
  • vertical-align
  • white-space
  • width
  • word-break
  • word-spacing
  • word-wrap
  • z-index
TrustedFrameInstance

The TrustedFrameInstance allows you to interact with the Trusted Frame and the credit card form within it. The following functions are available:

clearField( fieldName, callback ) → void

Use this function to clear the contents of a field.

PARAMETERS

Name Type Description
fieldName string The name of the field that you would like to clear. Available field names are:
  • cardholderName
  • cardNumber
  • expiryDateMonth
  • expiryDateYear
  • cvn
callback callback A callback function to be executed after sending the action message to the Trusted Frame.

EXAMPLE

trustedFrame.clearField( "cardNumber", function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "cardNumber has been cleared!" );
    }
} );
changePlaceholder( fieldName, placeholder, callback ) → void

Allows you to change the placeholder text of a field input.

PARAMETERS

Name Type Description
fieldName string The name of the field for which you would like to set the placeholder text. Available field names are:
  • cardholderName
  • cardNumber
  • expiryDateMonth
  • expiryDateYear
  • cvn
placeholder string Your chosen placeholder text.
callback callback A callback function to be executed after sending the action message to the Trusted Frame.

EXAMPLE

trustedFrame.changePlaceholder( "cardholderName", "John Smith", function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "cardholderName placeholder has been changed!" );
    }
} );
changeStyle( elementName, style, callback ) → void

Apply your choice of supported CSS properties to the chosen Trusted Frame element.

PARAMETERS

Name Type Description
elementName string The name of the element to which you would like to apply the specified CSS properties. Available element names are:
  • body
  • labels
  • cardholderName
  • cardNumber
  • expiryDateMonth
  • expiryDateYear
  • cvn
style StyleObject Contains CSS properties used to style the target element/s. See StyleObject for more details.
callback callback A callback function to be executed after sending the action message to the Trusted Frame.

EXAMPLE

var style = {
    color: "blue",
    "margin-right": "25px"
};

trustedFrame.changeStyle( "labels", style, function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "labels styling has been changed!" );
    }
} );
setEventHandler( fieldName, event, handler ) → void

Allows you to trigger a handler function when a specified event occurs for a field.

PARAMETERS

Name Type Description
fieldName string The name of the field for which you would like to register the event handler function. Available field names are:
  • cardholderName
  • cardNumber
  • expiryDateMonth
  • expiryDateYear
  • cvn
event string The event type that should trigger the event handler function. Available event types are:
  • focus
  • change
  • error
  • blur
handler function A function to be executed when an event occurs.

For focus, change and blur events, the argument passed to handler has the following form:

{
    eventType: "focus"
    fieldName: "cardNumber"
}

For the error event, the argument passed to handler has the form:

{
    eventType: "error"
    fieldName: "cvn"
    errorMessages: [ "Required field." ]
}

EXAMPLE

trustedFrame.setEventHandler( "cvn", "error", function( event ) {
    console.log( event.fieldName + ": " + event.errorMessages[0] ); // cvn: Required field.
} );
getEventHandlers() → EventHandlersObject

Returns an EventHandlersObject that contains all of the event handlers registered to the Trusted Frame. The EventHandlersObject has the following form:

{
    cardNumber: {
        focus: function( event ) { ... },
        blur: function( event ) { ... }
    },
    expiryDateMonth: {
        error: function( event ) { ... }
    },
    cvn : {
        change: function( event ) { ... }
    }
}

Where first-level properties are named after the fields, second-level properties are the events for that field, and the values of these the event handlers that are triggered.

submitForm( callback ) → void

Submits the credit card form within the Trusted Frame. You can provide a callback function which will receive either the field errors (if the form fails validation), or the generated single-use-token.

PARAMETERS

Name Type Description
callback callback A callback function to be executed after receiving the results of the credit card form submission.

When there are no errors, the data parameter of callback has the following form:

{
    singleUseToken: {
        singleUseTokenId: "TOKEN_VALUE"
        accountType: "CREDIT_CARD"
        creditCard: {
            cardNumber: "424242...242"
            expiryDateMonth: "01"
            expiryDateYear: "17"
            cardScheme: "VISA"
            cardType: "CREDIT"
            cardholderName: "Jane Smith"
            surchargePercentage: "0.400"
        }
    }
    token: "TOKEN_VALUE"
}

Note: The token field has been deprecated in favour of using singleUseTokenId.

EXAMPLE

trustedFrame.submitForm( function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "singleUseTokenId is " + data.singleUseToken.singleUseTokenId ); // singleUseTokenId is TOKEN_VALUE
    }
} );
teardown( callback ) → void

Call this function to destroy and remove the Trusted Frame from your webpage. Once a Trusted Frame has been torn down, it can no longer be used. Subsequent calls to other Trusted Frame functions will result in an error message.

PARAMETERS

Name Type Description
callback callback A callback function to be executed after the Trusted Frame has been destroyed.

EXAMPLE

trustedFrame.teardown( function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "Trusted Frame has been destroyed." );
    }
} );

Challenge Frame

The Challenge Frame component of QuickstreamAPI.creditCards automatically adds an iFrame containing a 3D Secure challenge to your form.

The Challenge Frame is initialised using a singleUseTokenId that you have posted to the 3D Secure Authentication endpoint and received a transStatus value of C (indicating that you must challenge the cardholder.)

The iFrame content is served by the card issuer, and the content is not customisable. However, you can choose where to display it on your webpage and the size of the window.

HTML structure

You can place the Challenge Frame anywhere on your page. All you need to do is mark a block element with the data-quickstream-api="quickstream-challenge" attribute so that the QuickstreamAPI.creditCards module knows where to append your Challenge Frame.

EXAMPLE

This is an example snippet containing the required attribute.

<div data-quickstream-api="quickstream-challenge">
  <!-- The Challenge Frame will be inserted in here -->
</div>

The Challenge Frame works in two modes:

  • challengeMode is post (default)
  • challengeMode is callback.

When challengeMode is post the container must be a child of a form element. When the cardholder completes the challenge, a hidden input field is appended to the encapsulating form. The hidden input has the name attribute transStatus and the value is either Y (successfully completed the challenge) or N (challenge failed).

<form id="challenge-form">
  <div data-quickstream-api="quickstream-challenge"></div>
</form>

When challengeMode is callback the container does not need to be a child of a form element. You must implement two callback functions:

  • onSuccess() - called when cardholder successfully completes the challenge.
  • onFaliure() - called when the cardholder fails the challenge.
createChallengeFrame( options, callback ) → ChallengeFrameInstance

Used to initialise and append the Challenge Frame to your webpage.

PARAMETERS

Name Type Attributes Description
options ChallengeFrameConfigObject A standard JavaScript object containing name/value pairs describing the configuration of the Challenge Frame. See ChallengeFrameConfigObject for the structure and available values of this object.
createdChallengeCallback callback The callback function that is executed after the initialisation of the Challenge Frame.

When there are no errors, the data parameter of callback is a ChallengeFrameInstance object.

ChallengeFrameInstance is an object containing helper functions for interacting with the created iFrame.

EXAMPLE

let challengeFrame;
let transStatus;
let options = {
  singleUseTokenId: "SINGLE_USE_TOKEN_ID", // this is a required config option
  challengeWindowSize: "02",
  challengeMode: "callback",
  onSuccess: function(){
    // remove the challenge iframe and handle success
    challengeFrame.destroy();
    transStatus= "Y";
  },
  onFailure: function(){
    // remove the challenge iframe and handle failure
    challengeFrame.destroy();
    transStatus= "N";
  }
};

QuickstreamAPI.creditCards.createChallengeFrame( options, function( errors, data ){
  if( errors ) {
    // Handle errors here
  } else {
    challengeFrame = data;
  }
} );
ChallengeFrameConfigObject

Used to initialise the Challenge Frame to your webpage.

PARAMETERS

Name Type Required Default Description
singleUseTokenId string Required The singleUseTokenId used for the 3D Secure Authentication where transStatus = C.
challengeWindowSize string Optional 05

The size of the challenge window to be displayed to the cardholder, width x height in pixels.

01 250 x 400
02 390 x 400
03 500 x 600
04 600 x 400
05 Fullscreen
challengeMode string Optional post

The mode in which the result of the challenge is provided back to your website.

post A hidden input field with name=transStatus and value (Y or N) is appended as a child of the encapsulating form. The quickstream-challenge container must be a child of a form element.
callback The onSuccess function is called when the cardholder completes the challenge (transStatus is Y), otherwise the onFailure function is called (transStatus is N).
onSuccess function Required when challengeMode=callback This function is called after the cardholder successfully completes the challenge (transStatus is Y).
onFailure function Required when challengeMode=callback This function is called after the cardholder unsuccessfully completes the challenge (transStatus is N).
ChallengeFrameInstance

The ChallengeFrameInstance allows you to interact with the Challenge Frame. The following functions are available:

destroy( callback ) → void

Call this function to destroy and remove the Challenge Frame from your webpage. Once a Challenge Frame has been torn down, it can no longer be used. Subsequent calls to other Challenge Frame functions will result in an error message.

PARAMETERS

None.

EXAMPLE

challengeFrame.destroy();

Bank accounts module

QuickstreamAPI provides a Bank Accounts module, which can accessed via QuickstreamAPI.bankAccounts. This module provides access to the following component:

  • Trusted Frame - automatically appends an iFrame containing a bank account form to your page.

Trusted Frame

The Trusted Frame component of QuickstreamAPI.bankAccounts automatically adds an iFrame containing a bank account form to your page.

You have the ability to configure the Trusted Frame on initialisation, and interact with the iFrame after initialisation. Using the provided helper functions, you can:

  • Clear fields
  • Change input placeholders
  • Change styles
  • Register event handlers for field events, including change, focus, blur and error

Continue reading for details on how to use Trusted Frame.

HTML structure

You can place the Trusted Frame anywhere on your page. All you need to do is mark a block element with the data-quickstream-api="bankAccountContainer" attribute so that the QuickstreamAPI.bankAccounts module knows where to append your Trusted Frame.

EXAMPLE

This is an example snippet containing the required attribute.

<div data-quickstream-api="bankAccountContainer">
  <!-- The Trusted Frame will be inserted in here -->
</div>
createTrustedFrame( options, callback ) → TrustedFrameInstance

Used to initialise and append the Trusted Frame to your webpage.

PARAMETERS

Name Type Attributes Description
options TrustedFrameConfigObject A standard JavaScript object containing name/value pairs describing the configuration of the Trusted Frame. See TrustedFrameConfigObject for the structure and available values of this object.
callback callback The callback function that is executed after the initialisation of the Trusted Frame.

When there are no errors, the data parameter of callback has the following form:

{
    trustedFrame: TrustedFrameInstance
}

Where TrustedFrameInstance is an object containing helper functions for interacting with the created iFrame (including submitting the bank account form).

EXAMPLE

var trustedFrame;

var options = {
    config: {
        supplierBusinessCode: "SUPPLIER_CODE" // This is a required config option
    }
};

QuickstreamAPI.bankAccounts.createTrustedFrame( options, function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        trustedFrame = data.trustedFrame
    }
} );
TrustedFrameConfigObject

A JavaScript object that encapsulates the configuration data used to initialise a Trusted Frame. See the tables below for more details on the structure.

Property Type Required Default Description
config ConfigObject Required Contains required configuration values for Trusted Frame initialisation. See ConfigObject for more details.
iframe IframeObject Optional See IframeObject for the default values. Contains configuration values relating to the visual styling of the iFrame. This includes the width, height, scrollbar visibility and other supported CSS properties. See IframeObject for more details.
body StyleableObject Optional Contains CSS properties for styling the body element of the Trusted Frame. This allows you to set font styles, color etc. that apply to the entire iFrame. See StyleableObject for more details.
labels StyleableObject Optional Contains CSS properties for styling the label elements of the Trusted Frame. This allows you to set font styles, padding, color etc. that apply to all labels in the iFrame. See StyleableObject for more details.
accountName FieldObject Optional Contains configuration values relating to the appearance of the account name form field. These include the ability to change the field's label, placeholder, input type and CSS properties. See FieldObject for more details.
bsb FieldObject Optional Contains configuration values relating to the appearance of the BSB form field. These include the ability to change the field's label, placeholder, input type and CSS properties. See FieldObject for more details.
accountNumber FieldObject Optional Contains configuration values relating to the appearance of the account number form field. These include the ability to change the field's label, placeholder, input type and CSS properties. See FieldObject for more details.
ConfigObject
Property Type Required Default Description
supplierBusinessCode string Required The supplier business code that uniquely identifies your supplier business in the QuickStream system.
IframeObject
Property Type Required Default Description
width int Optional 800 Integer that sets the width of the iFrame.
height int Optional 300 Integer that sets the height of the iFrame.
scrolling string Optional "no" String that determines whether the iFrame has visible scrollbars. Supported values are:
  • no
  • yes
  • auto
style StyleObject Optional Contains CSS properties used to style the iFrame. See StyleObject for more details.
dummyTouchStart boolean Optional false Set to true to add an empty event listener to the touchstart event. Enable this if you use touch event listeners on your website and experience issues focusing on input fields within the Trusted Frame.
dummyTouchMove boolean Optional false Set to true to add an empty event listener to the touchmove event. Enable this if you use touch event listeners on your website and experience issues focusing on input fields within the Trusted Frame.
dummyTouchEnd boolean Optional false Set to true to add an empty event listener to the touchend event. Enable this if you use touch event listeners on your website and experience issues focusing on input fields within the Trusted Frame.
StyleableObject
Property Type Required Default Description
style StyleObject Optional Contains CSS properties used to style the target element/s. See StyleObject for more details.
FieldObject
Property Type Required Default Description
label string Optional Replace the field's default label with one of your choosing.
placeholder string Optional Specify a placeholder value for the target field.
inputType string Optional "text" Change the default input type to another. Supported values are as defined in the W3C Recommendation.
style StyleObject Optional Contains CSS properties used to style the target field. See StyleObject for more details.
StyleObject
Property Type Required Default Description
"css-property-name" string Optional Each name/value pair in this object map directly to CSS property/value pairs. For example, a valid instance of StyleObject could look like the following:
{
    "border-color": "green"
    padding: "5px"
}

The supported CSS properties are:

  • appearance
  • background
  • background-attachment
  • background-blend-mode
  • background-clip
  • background-color
  • background-image
  • background-origin
  • background-position
  • background-repeat
  • background-size
  • border
  • border-block-end
  • border-block-end-color
  • border-block-end-style
  • border-block-end-width
  • border-block-start
  • border-block-start-color
  • border-block-start-style
  • border-block-start-width
  • border-bottom
  • border-bottom-color
  • border-bottom-left-radius
  • border-bottom-right-radius
  • border-bottom-style
  • border-bottom-width
  • border-collapse
  • border-color
  • border-image
  • border-image-outset
  • border-image-repeat
  • border-image-slice
  • border-image-source
  • border-image-width
  • border-inline-end
  • border-inline-end-color
  • border-inline-end-style
  • border-inline-end-width
  • border-inline-start
  • border-inline-start-color
  • border-inline-start-style
  • border-inline-start-width
  • border-left
  • border-left-color
  • border-left-style
  • border-left-width
  • border-radius
  • border-right
  • border-right-color
  • border-right-style
  • border-right-width
  • border-spacing
  • border-style
  • border-top
  • border-top-color
  • border-top-left-radius
  • border-top-right-radius
  • border-top-style
  • border-top-width
  • border-width
  • bottom
  • box-shadow
  • box-sizing
  • color
  • direction
  • display
  • font
  • font-family
  • font-size
  • font-size-adjust
  • font-stretch
  • font-style
  • font-variant
  • font-variant-alternates
  • font-variant-caps
  • font-variant-east-asian
  • font-variant-ligatures
  • font-variant-numeric
  • font-variant-position
  • font-weight
  • height
  • left
  • letter-spacing
  • line-height
  • margin
  • margin-block-end
  • margin-block-start
  • margin-bottom
  • margin-inline-end
  • margin-inline-start
  • margin-left
  • margin-right
  • margin-top
  • max-height
  • max-width
  • min-height
  • min-width
  • opacity
  • outline
  • outline-color
  • outline-offset
  • outline-style
  • outline-width
  • overflow
  • overflow-wrap
  • overflow-x
  • overflow-y
  • padding
  • padding-bottom
  • padding-left
  • padding-right
  • padding-top
  • position
  • right
  • text-align
  • text-decoration
  • text-decoration-color
  • text-decoration-line
  • text-decoration-style
  • text-emphasis
  • text-emphasis-color
  • text-emphasis-position
  • text-emphasis-style
  • text-indent
  • text-orientation
  • text-overflow
  • text-shadow
  • text-transform
  • text-underline-position
  • top
  • transform
  • transform-box
  • transform-origin
  • transform-style
  • transition
  • transition-delay
  • transition-duration
  • transition-property
  • transition-timing-function
  • vertical-align
  • white-space
  • width
  • word-break
  • word-spacing
  • word-wrap
  • z-index
TrustedFrameInstance

The TrustedFrameInstance allows you to interact with the Trusted Frame and the credit card form within it. The following functions are available:

clearField( fieldName, callback ) → void

Use this function to clear the contents of a field.

PARAMETERS

Name Type Description
fieldName string The name of the field that you would like to clear. Available field names are:
  • accountName
  • bsb
  • accountNumber
callback callback A callback function to be executed after sending the action message to the Trusted Frame.

EXAMPLE

trustedFrame.clearField( "bsb", function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "bsb has been cleared!" );
    }
} );
changePlaceholder( fieldName, placeholder, callback ) → void

Allows you to change the placeholder text of a field input.

PARAMETERS

Name Type Description
fieldName string The name of the field for which you would like to set the placeholder text. Available field names are:
  • accountName
  • bsb
  • accountNumber
placeholder string Your chosen placeholder text.
callback callback A callback function to be executed after sending the action message to the Trusted Frame.

EXAMPLE

trustedFrame.changePlaceholder( "accountName", "John Smith", function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "accountName placeholder has been changed!" );
    }
} );
changeStyle( elementName, style, callback ) → void

Apply your choice of supported CSS properties to the chosen Trusted Frame element.

PARAMETERS

Name Type Description
elementName string The name of the element to which you would like to apply the specified CSS properties. Available element names are:
  • body
  • labels
  • accountName
  • bsb
  • accountNumber
style StyleObject Contains CSS properties used to style the target element/s. See StyleObject for more details.
callback callback A callback function to be executed after sending the action message to the Trusted Frame.

EXAMPLE

var style = {
    color: "blue",
    "margin-right": "25px"
};

trustedFrame.changeStyle( "labels", style, function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "labels styling has been changed!" );
    }
} );
setEventHandler( fieldName, event, handler ) → void

Allows you to trigger a handler function when a specified event occurs for a field.

PARAMETERS

Name Type Description
fieldName string The name of the field for which you would like to register the event handler function. Available field names are:
  • accountName
  • bsb
  • accountNumber
event string The event type that should trigger the event handler function. Available event types are:
  • focus
  • change
  • error
  • blur
handler function A function to be executed when an event occurs.

For focus, change and blur events, the argument passed to handler has the following form:

{
    eventType: "focus"
    fieldName: "accountNumber"
}

For the error event, the argument passed to handler has the form:

{
    eventType: "error"
    fieldName: "bsb"
    errorMessages: [ "Required field." ]
}

EXAMPLE

trustedFrame.setEventHandler( "bsb", "error", function( event ) {
    console.log( event.fieldName + ": " + event.errorMessages[0] ); // bsb: Required field.
} );

getEventHandlers() → EventHandlersObject

Returns an EventHandlersObject that contains all of the event handlers registered to the Trusted Frame. The EventHandlersObject has the following form:

{
    accountName: {
        focus: function( event ) { ... },
        blur: function( event ) { ... }
    },
    bsb: {
        error: function( event ) { ... }
    },
    accountNumber : {
        change: function( event ) { ... }
    }
}

Where first-level properties are named after the fields, second-level properties are the events for that field, and the values of these the event handlers that are triggered.

submitForm( callback ) → void

Submits the bank account form within the Trusted Frame. You can provide a callback function which will receive either the field errors (if the form fails validation), or the generated single-use-token.

PARAMETERS

Name Type Description
callback callback A callback function to be executed after receiving the results of the bank account form submission.

When there are no errors, the data parameter of callback has the following form:

{
    singleUseToken: {
        singleUseTokenId: "TOKEN_VALUE"
        accountType: "DIRECT_DEBIT"
        bankAccount: {
            bsb: "xxx-000"
            accountNumber: "xxx007"
            accountName: "Jane Smith"
        }
    }
    token: "TOKEN_VALUE"
}

Note: The token field has been deprecated in favour of using singleUseTokenId.

EXAMPLE

trustedFrame.submitForm( function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "singleUseTokenId is " + data.singleUseToken.singleUseTokenId ); // singleUseTokenId is TOKEN_VALUE
    }
} );
teardown( callback ) → void

Call this function to destroy and remove the Trusted Frame from your webpage. Once a Trusted Frame has been torn down, it can no longer be used. Subsequent calls to other Trusted Frame functions will result in an error message.

PARAMETERS

Name Type Description
callback callback A callback function to be executed after the Trusted Frame has been destroyed.

EXAMPLE

trustedFrame.teardown( function( errors, data ) {
    if ( errors ) {
        // Handle errors here
    }
    else {
        console.log( "Trusted Frame has been destroyed." );
    }
} );

Payment request button module

QuickstreamAPI provides a Payment Request Button module, which can be accessed via QuickstreamAPI.paymentRequestButton. This module allows you to add an Apple Pay and Google Pay button to your page. When the user clicks this button a payment sheet will popup displaying the total amount to be paid, shipping options and contact information. Once the user approves these details, a single-use-token is returned that encapsulates your customer's credit card information. This token can subsequently be passed to the QuickStream server in a REST API request to perform a transaction.

Supported platforms

Apple Pay is supported in Safari on iOS 11.3 and later and macOS 10.12.6 and later and Chrome on iOS 16 and later. Google Pay is supported in Chrome 61 and later on Desktop and Android. Apple Pay and Google Pay are not supported outside of these platforms.

Payment Request Button

You can place the Payment Request button anywhere on your page. All you need to do is mark a block element with the attribute data-quickstream-api="paymentRequestButtonContainer" so that the QuickstreamAPI.paymentRequestButton module knows where to append your button.

EXAMPLE

This is an example snippet containing the required attribute.


<div data-quickstream-api="paymentRequestButtonContainer">
  <!-- The Apple Pay or Google Pay button will be inserted in here -->
</div>
createButton( paymentRequestConfig, paymentRequestCallback ) → void

Used to initialise and append the Payment Request button to your webpage.

PARAMETERS

Name Type Attributes Description
details PaymentRequestConfigObject A standard JavaScript object containing name/value pairs describing the transaction. See PaymentRequestConfigObject for the structure and available values of this object.
paymentRequestCallback callback The callback function is executed when the user confirms the payment on the payment payment sheet. See callback for more information.

EXAMPLE

var config = {
  supplierBusinessCode: "SUPPLIER_CODE",
  googleMerchantId: "YOUR_GOOGLE_MERCHANT_ID",
  details: {
    total: {
      label: "Your company name",
      amount: {
        value: "10.00",
        currency: "AUD"
      }
    }
  }
};

QuickstreamAPI.paymentRequestButton.createButton(config, function(errors, paymentResponse) {
  if (errors) {
    // Handle errors here
  } else {
    console.log("singleUseTokenId is " + paymentResponse.singleUseTokenId);
    // Take payment then call paymentResponse.complete with the appropriate status
    paymentResponse.complete("success");
  }
});

EXAMPLE WITH SHIPPING

var config = {
  supplierBusinessCode: "SUPPLIER_CODE",
  googleMerchantId: "YOUR_GOOGLE_MERCHANT_ID",
  details: {
    total: {
      label: "Your company name",
      amount: {
        value: "10.00",
        currency: "AUD"
      }
    },
    shippingOptions: [{
      "id": "FreeShip",
      "label": "Free Shipping (5 to 7 days)",
      "amount": {
        value: "0.00",
        currency: "AUD"
      }
    }]
  },
  options: {
    requestShipping: true
  },
  onshippingaddresschange: handleShippingAddressChange,
  onshippingoptionchange: handleShippingAddressChange
};

QuickstreamAPI.paymentRequestButton.createButton(config, function(errors, paymentResponse) {
    if (errors) {
        // Handle errors here
    } else {
        console.log("singleUseTokenId is " + paymentResponse.singleUseTokenId);
        console.log("shippingAddress is " + paymentResponse.shippingAddress);
        // Take payment then call paymentResponse.complete with the appropriate status
        paymentResponse.complete("success");
    }
});

function handleShippingAddressChange(event) {
  // Validate shipping address and calculate new total then
  // call event.updateWith with the new total or an error
  event.updateWith({
    total: {
      label: "Your company name",
      amount: {
        value: newTotal,
        currency: "AUD"
      },
    }
  });
}
PaymentRequestConfigObject

A JavaScript object that encapsulates the configuration data used to initialise a Payment Request button. See the tables below for more details on the structure.

Property Type Required Default Description
supplierBusinessCode string Required The supplier business code that uniquely identifies your supplier business in the QuickStream system.
googleMerchantId string Required for Google Pay in production Your Google-provided merchant id, obtained from the Google Pay Business Console. This is only required in production.
details PaymentRequestDetailsObject Required Contains values relating to the amount of the payment and any shipping options that will be displayed on the payment sheet. See PaymentRequestDetailsObject for more details.
options PaymentRequestOptionsObject Required Contains values relating to the amounts and shipping options that will be displayed on the payment sheet. See PaymentRequestOptionsObject for more details.
onshippingaddresschange function Optional A function that accepts a PaymentRequestUpdateEvent argument. Required if shipping address is requested.
onshippingoptionchange function Optional A function that accepts a PaymentRequestUpdateEvent argument.
onInitialise function Optional A function that accepts a PaymentRequestInitialisedObject argument. This will be called once available payment methods have been determined and before the button is created.
customButton boolean Optional Set to true to disable rendering of the default button. Use this in combination with the onInitialise callback to render your own button inside the paymentRequestButtonContainer element.
PaymentRequestCallback( errors, paymentResponse ) → void

This function will be called when there are errors during initialisation of the module and when the user confirms the payment on the payment sheet.

Name Type Attributes Description
errors array of Error An array of Error objects that describe the errors encountered by the calling function.
paymentResponse PaymentRequestResponseObject An object that contains name/value pairs representing the successful result of the payment request. See PaymentRequestResponseObject for more information.
PaymentRequestDetailsObject

A JavaScript object that encapsulates the details for the transaction. See the tables below for more details on the structure.

Property Type Required Default Description
total PaymentRequestTotalObject Required Contains a label and the total amount for the transaction. See PaymentRequestTotalObject for more details.
shippingOptions array of PaymentRequestShippingOptionObject Required The shipping options the user may choose from. If this sequence is blank, it indicates the merchant cannot ship to the current shipping address. The default shipping option may be indicated in this sequence. See PaymentRequestShippingOptionObject for more details.
error string Optional Used to present an error to the user after validating shipping details.
PaymentRequestOptionsObject

A JavaScript object that controls what details will be collected on the payment sheet. See the tables below for more details on the structure.

Property Type Required Default Description
requestPayerName boolean Optional false Set to true to require the payer's name in the returned data.
requestPayerEmail boolean Optional false Set to true to require the payer's email in the returned data.
requestPayerPhone boolean Optional false Set to true to require the payer's phone in the returned data.
requestShipping boolean Optional false Set to true to require the payer's shipping address in the returned data.
shippingType string Optional shipping Lets you specify how the payment sheet refers to shipping when the word 'shipping' isn't appropriate for your use case. For example, delivery in English speaking countries might be "pizza delivery" not "pizza shipping". Valid values are shipping, delivery, and pickup.
PaymentRequestTotalObject

A JavaScript object that encapsulates an amount and label. See the tables below for more details on the structure.

Property Type Required Default Description
amount PaymentRequestAmountObject Required Contains the amount and currency. See PaymentRequestAmountObject for more details.
label string Optional Your supplier business name Provide a business name for the label field. Use the same business name people will see when they look for the charge on their credit card statement. For example, "COMPANY, INC."
PaymentRequestAmountObject

A JavaScript object that encapsulates an amount value and currency. See the tables below for more details on the structure.

Property Type Required Default Description
value string Required The amount of the transaction.
currency string Required The currency for the transaction. Allowed values: AUD.
PaymentRequestShippingOptionObject

A JavaScript object that encapsulates the selected shipping contact information. See the tables below for more details on the structure.

Property Type Required Description
id string Required The ID of the shipping option. This will be returned in the PaymentRequestUpdateEvent and PaymentRequestResponseObject.
label string Required The label for the shipping option. This will be displayed on the payment sheet.
amount PaymentRequestAmountObject Required Contains the amount and currency. See PaymentRequestAmountObject for more details.
PaymentRequestShippingAddressObject

A JavaScript object that encapsulates the selected shipping contact information. See the tables below for more details on the structure.

Property Type Description
addressLine array of strings Includes each line of the address not included among the other properties. The exact size and content varies by country or location and can include, for example, a street name, house number, apartment number, rural delivery route, descriptive instructions, or post office box number.
country string The country in which the address is located, using the ISO-3166-1 alpha-2 standard, eg. AU.
city string The city or town portion of the address.
postalCode string The post code of the address.
recipient string The name of the recipient, purchaser, or contact person at the payment address.
region string The state code of the address, eg. NSW.
PaymentRequestUpdateEvent

A JavaScript object that stores the selected shipping option and shipping address, and a method to update the transaction details. See the tables below for more details on the structure.

Property Type Description
shippingAddress PaymentRequestShippingAddressObject A redacted copy of the selected shipping address.
shippingOption PaymentRequestShippingOptionObject The selected shipping option.
updateWith function that accepts PaymentRequestDetailsObject This function must be called after a shipping address or option is selected with a new PaymentRequestDetailsObject containing an updated total and any errors relating to the validation of the shipping address.
PaymentRequestResponseObject

A JavaScript object that stores the singleUseTokenId, selected shipping option and shipping address, and a method to complete the payment sheet. See the tables below for more details on the structure.

Property Type Description
singleUseTokenId string The single-use-token. You should send the singleUseTokenId in a request to take a payment.
shippingAddress PaymentRequestShippingAddressObject A redacted copy of the selected shipping address.
shippingOption PaymentRequestShippingOptionObject The selected shipping option.
complete function that accepts a string This function should be called after processing the transaction with the Transactions API. It accepts a string of success or fail depending on the summaryCode returned from the Transactions API. After calling complete the payment sheet will be closed.
PaymentRequestInitialisedObject

A JavaScript object that contains the availability of each payment method.

Property Type Description
applePay boolean Returns true when Apple Pay is available in the browser and configured for your facility, otherwise returns false.
googlePay boolean Returns true when Google Pay is available in the browser and configured for your facility, otherwise returns false.
Westpac Privacy Statement

Privacy Statement (for individuals whose personal information may be collected - in this clause referred to as "you"). All personal information we collect about you is collected, used and disclosed by us in accordance with our Privacy Statement which is available at Privacy Statement or by calling us through your relationship manager or Westpac representative. Our Privacy Statement also provides information about how you can access and correct your personal information and make a complaint. You do not have to provide us with any personal information but, if you don't, we may not be able to process an application or a request for a product or service.