CDN

👍

[ACTION REQUIRED] Origin URL Whitelisting

In order to bolster security on our platform, Aeropay will need to whitelisting any origin URLs using the Aerosync CDN in production.

Prior to go-live, please share your origin URLs with your Aeropay representative to be whitelisted.

Introduction

This CDN-hosted JavaScript package allows you to easily integrate a secure bank account linking experience into any web application without requiring a build process. With a simple script tag, you can embed a fast, tokenized, and secure flow that connects users to their bank through their official online banking portal. The integration ensures that user credentials are never stored, shared, or exposed — maintaining strict privacy and security standards.

📘

NPM Package Versioning

For all new Aeropay integrations, please use v1.0. Versions 2.0 and later are still in beta and may be unstable.

1. Installation

Add the CDN Script Tag

Add the following script tag to your HTML to include the widget:

<script src="https://cdn.sync.com/v1.1.3/aerosync-widget.js"></script>

Content Security Policy (CSP)

If your application uses CSP headers, ensure the following directive is included to allow loading the widget from our CDN:

Content-Security-Policy:
  default-src 'self';
  script-src 'self' https://cdn.sync.com;
  connect-src 'self' https://api.aerosync.com;
  frame-src https://cdn.sync.com;
📋

If you are using the sandbox environment, update theconnect-src directive as follows::

connect-src 'self' https://api.sandbox.aerosync.com;


2. Set Up HTML Elements for the Aerosync Widget

Add a button to launch the widget and a container element where the widget iframe will be rendered.

<!-- Button to launch the AeroSync widget -->
<!-- 'id' is optional but useful for CSS/JS targeting -->
<!-- Vue syntax, replace with onclick="openAerosyncWidget()" if using plain JS -->
<button
  id="openBank"
  @click="openAerosyncWidget()"
>
  Connect Bank
</button>

<!-- This div is where the AeroSync widget iframe will be embedded -->
<!-- Make sure the 'id' here matches the 'elementId' passed during initialization -->
<div id="widgetId"></div>

3. Import and Configure the AeroSync Widget

👍

Fetch SDK token GET /aggregatorCredentials

The token for the Aerosync SDK will be returned in the response to GET /aggregatorCredentials. Read the Aerosync guide for details.

To initialize the AeroSync widget in your app, create a reference to the widget and load the configuration parameters. Below is an example of how to integrate and launch the widget.

// Function to initialize and open the AeroSync widget
function openAerosyncWidget() {

  // Initialize the widget using the global aerosync object
  const widgetControls = window?.aerosync?.initWidget({
    elementId: 'widgetId', // ID of the DOM element where the widget will be attached
    iframeTitle: 'Connect', // Title for the iframe
    environment: 'production', // Widget environment (e.g., 'sandbox' or 'production')
    token: 'XXXX', //  AeroSync token (Important: Do not use an AeroPay token)
    consumerId: 'xxxx', // Aeorsync configuration ID (optional)

    // Event callback for various widget lifecycle events
    onEvent: function(event) {
      console.log('onEvent', JSON.stringify(event))
    },

    // Called when the widget is fully loaded
    onLoad: function() {
      toast.info('Sync onload')
    },

    // Called on successful sync completion
    onSuccess: function(event) {
      console.log('onSuccess', JSON.stringify(event))
    },

    // Called when the widget is closed
    onClose: function() {
      console.log('Sync onclose')
    },

    // Called when an error occurs
    onError: function(error) {
      console.log('onError', error)
    }
  })

  // Launch the widget UI
  if (widgetControls) {
    widgetControls.launch()
  }
}

4. Handle OAuth Bank Authentication

Aerosync launches the OAuth URL in the external system browser by default. If you want to manually handle the OAuth URL within the Capacitor in-app browser, you can capture the event as shown below:

4.1 Enable Manual OAuth Handling

Set handleOAuthManually to true in the widget configuration of the Web SDK to prevent Aerosync from automatically launching the OAuth window. This gives you control to trigger the OAuth flow manually when needed.

4.2 Launch OAuth Manually via URL

Listen for the onEvent callback to receive the OAuth URL. Then open it using an in-app browser or system browser, based on your app’s flow.

// 📦 Event listener
async onEvent(event) {
  try {
    // Check if the app is running on a native platform (iOS or Android)
    if (Capacitor.isNativePlatform()) {
      // Verify that the event payload exists, pageTitle equals "launchExternalWindow",
      // and onLoadApi URL is present
      if (
        event?.payload?.pageTitle === "launchExternalWindow" &&
        event?.payload?.onLoadApi
      ) {
        // Open the URL in Capacitor's in-app browser
        await Browser.open({ url: event.payload.onLoadApi });
      }
    }
  } catch (error) {
    console.error("Failed to open URL in Capacitor Browser:", error);
  }
}

5. Widget configuration

The AeroSync widget accepts a set of configuration parameters that control its behavior, appearance, and integration flow. The table below outlines each parameter, its type, requirement level, and purpose. Use this as a reference when initializing the widget in your application.

Parameter

Type

Required

Description

token

string

Yes

Request AeroSync Token using GET /aggregatorCredentials endpoint.

Reference:https://api-aeropay.readme.io/reference/aggregatorcredentialshttps://developer.aeropay.com/api/aeropay/doc/

elementId

string

Yes

Specifies a unique id for an HTML element. The default value is "widget".

iframeTitle

string

Yes

Adds title text to the iframe.

width

string

Yes

Specifies the width of the iframe in pixels.

height

string

Yes

Specifies the height of the iframe in pixels.

environment

string

Yes

Permitted values are [sandbox, production]

deeplink

string

Conditional

Aerosync will redirect to this link on mobile app after authentication to resume the workflow for OAuth bank experiences

Required for mobile applications.Not required for web applications. You can send the deeplink as empty string. Eg: let deeplink:string = ""For more guidance refer to our article here

handleOAuthManually

boolean

No

Set this to true if you want to manually open the external OAuth login window instead of having it open automatically.

targetDocument

ShadowRoot

No

The widget will be rendered inside the shadow dom instead of root document

consumerId

string

Yes

Unique ID assigned to you to apply widget customizations.

zIndex

string

No

To override the stacking order of the widget elements provide the appropriate value. The default value is 1.

manualLinkOnly

boolean

No

User will only be able to link their bank manually.

embeddedBankView

object (embeddedBankViewType)

No

Enables embedding the bank view directly inside a custom container. Requires an elementId. Optional properties include width, height, and a callback onEmbedded() that is triggered when the embedded view is ready. Example:{elementId: 'embeddedId',width: '572px', height: '348px', onEmbedded: () => { //onEmbedded ready} }

For more information, click here: https://dev.aero.inc/docs/embedded-view

style

object

No

Allows you to customize the widget’s appearance. You can set width, height, bgColor, and opacity. Example: { width: '375px', height: '688px', bgColor: '#000000', opacity: 0.7 }


6. Define postMessage events

The AeroSync widget communicates with your application using postMessage events. These callbacks allow you to handle lifecycle events such as loading, success, errors, and user interactions. Below is a list of supported events and their expected behaviors.

Ask ChatGPT

ParameterTypeRequiredDescription
onLoadfunction(response)NoCall JavaScript function after the contents of a webpage have been loaded.
onSuccessfunction(response)YesThis method will be triggered when a bank is added successfully and the user clicks on "continue" button in the final AeroSync-UI page.
onErrorfunction(response)YesThe method is called if AeroSync-UI dispatches any error events.
onClosefunction()YesThis event will be triggered if the user closes the AeroSync-UI window.
onEventfunction(response)YesAeroSync-UI will trigger event on each page load.