¿Cómo incrustar el portal de Toku en mi página?

Toku ofrece un script que sirve como interfaz para incrustar el portal de pagos en un sitio web, dentro de un iframe.

Autorizar host

Por defecto, el portal de pagos no permite ser incrustado en un iframe en cualquier sitio, así que es necesario comunicar a Toku cuál sera el host en el cuál se hará. Por ejemplo, si quiero incrustar el portal de pagos en mi sitio <https://example.com/site.php>, debo autorizar el host https://example.com/.

Obtener api key pública

Para poder incrustar el portal de pagos, es necesario proporcionar un api key para identificar la organización. Esta api key NO es la misma que la usada para las requests de backend, y debe ser solicitada a Toku ([email protected]) para 🇨🇱 o ([email protected]) para 🇲🇽.

Integración

Para incrustar el portal de pagos, se debe incluir el script de Toku en el HTML de la página web, de la siguiente forma:

<script src="https://storage.googleapis.com/toku-embedded-portal/index.min.js"></script>

La clase Toku

Una vez incluido el script en el HTML de la página, se disponibilizará la clase Toku, con la cual podrás controlar el comportamiento del iframe.

Instanciación

En primer lugar, se debe instanciar la clase Toku, con los siguientes argumentos:

const toku = new Toku(apiKey, {
  containerId,
  iframeId,
  onSuccess,
  onError,
});
ParámetroTipoRequeridoDescripción
apiKeystringEl api key pública de la organización.
containerIdstringEl id del tag HTML en el cual se quiere incrustar el iframe.
iframeIdstringNoEl id del iframe. Por defecto es toku-frame.
onSuccessfunctionNoCallback llamado cuando se inscribe un medio de pago o se realiza un cobro exitosamente.
onErrorfunctionNoCallback llamado si hay un error durante el proceso.

Inicialización

Para incrustar el portal de pagos en la página, se debe llamar al método init, el cual recibe los siguientes parámetros:

toku.init(step, options);

El formato de options depende del valor de step, y las combinaciones se describen a continuación

Dashboard

toku.init('dashboard', {
  customerId,
});
ParámetroTipoRequeridoDescripción
customerIdstringId del customer

Checkout recurrente

toku.init('recurringCheckout', {
  customerId,
  accountId,
  subscriptionId,
  gateway,
});
ParámetroTipoRequeridoDescripción
customerIdstringId del customer
accountIdstringId de la cuenta de pago. Se puede encontrar en Ajustes > Cuentas de cobro
subscriptionIdstringId de la subscription en la cual se inscribirá el medio de pago.
gatewaystringNoGateway específico por el cual pagar.
Si se indica, se redirigirá directamente a este gateway.
Si no se indica, se dirigirá a la vista general de checkout.

Checkout one-time

toku.init('oneTimeCheckout', {
  customerId,
  accountId,
  invoiceIds,
  gateway,
  subscriptionId,
});
ParámetroTipoRequeridoDescripción
customerIdstringId del customer
accountIdstringId de la cuenta de pago. Se puede encontrar en Ajustes > Cuentas de cobro
invoiceIdsArrayArreglo con los ids de los invoices a pagar.
gatewaystringNoGateway específico por el cual pagar.
Si se indica, se redirigirá directamente a este gateway.
Si no se indica, se dirigirá a la vista general de checkout.
subscriptionIdstringNoId de la subscription en la cual se inscribirá el medio de pago.

On Demand checkout recurrente

toku.init('onDemandRecurringCheckout', {
  checkoutSessionId: 'cs_lsFALPE9RH3Gf8qV-H-8W2CAUxejkg-9',
});
ParámetroTipoRequeridoDescripción
checkoutSessionIdstringId de la checkout session

Destrucción

Si quieres destruir el iframe de forma limpia, puedes llamar al método close:

toku.close();

Deep Links & Portales Adicionales en IFrame

Al momento de utilizar un IFrame, también es posible elegir que portal queremos mostrar al customer y que tan al interior del portal de pagos lo enviaremos. A continuación se muestran los pasos para la utilización de Deep Links y el funcionamiento de los Portales Adicionales

El siguiente script define la clase Toku, que se puede instanciar de la siguiente manera:

var toku = new Toku('<API_KEY>', options);

Donde options tiene las siguientes propiedades:

ParámetroDefault ValueDescripción
containerId'toku-container'id del elemento DOM que contendrá el IFrame
iframeId'toku-frame'id del IFrame creado.
portalId0El portal a utilizar, para clientes que no tengan más de un portal establecer siempre en 0 para utilizar el portal principal (valor por defecto). En caso de que desees utilizar otro portal, deberá asignarse el nombre del portal correspondiente. Puedes revisar todos los nombres de portales disponibles en el backoffice en Ajustes > Portal de Pagos > Portales de pago adicionales.

Para referirse al Portal adicional 1 y Portal adicional 2, basta con ingresar portalId=1 o portalId=2. Para los demás, puedes ingresar el nombre del portal de la forma portalId=NOMBRE_PORTAL.
onSuccess() => {}Respuesta ante una inscripción o pago exitoso.
onError() => {}Respuesta ante un error.

Para crear el IFrame e incrustarlo en el DOM, se debe llamar al método init de la siguiente manera:

toku.init('<STEP>', initOptions);

Reemplace <STEP> de acuerdo al deep link con el que desea iniciar el IFrame. Las opciones permitidas son:

Landing

Para mostrar el portal de pagos en la vista de buscador en donde el customer deberá ingresar su government_id o external_id según corresponda se debe ejecutar lo siguiente:

toku.init('landing');

Dashboard

En caso que el objetivo sea cargar el portal de pagos para un customer previamente identificado y que este pueda visualizar sus deudas o inscripciones de medios de pago.

toku.init('dashboard', { customerId: 'cus_bPMJqiDPCywqJ4SUAOY8wdWBV75wcGHt'});

Donde customerId corresponde al id del customer.

Recurring Checkout

Para enviar a pagos recurrentes se debe ejecutar la clase Toku como se muestra a continuación

toku.init('recurringCheckout', {
    customerId: 'cus_bPMJqiDPCywqJ4SUAOY8wdWBV75wcGHa',
    accountId: 'acc_6ar9C5NBJMllrrQpiu5PnLujq4zkMcQ2',
    subscriptionId: 'sub_lsFALPE9RH3Gf8qV-H-8W2CAUxejkg-5',
    gateway: 'pac_inscription',
});

Donde cada uno de los parámetros se define en la siguiente tabla.

ParámetroTipoRequeridoDescripción
customerIdstringId del customer
accountIdstringId de la cuenta de pago. Se puede encontrar en Ajustes > Cuentas de cobro
subscriptionIdstringId de la subscription en la cual se inscribirá el medio de pago. Es requerido si la organización está en modo suscripción.
gatewaystringNoGateway específico al cual será redirigido, en caso de omitir este valor, se mostrarán todos los gateways disponibles.

One Time Checkout

Para enviar a pagos spot se debe ejecutar la clase Toku como se muestra a continuación

toku.init('oneTimeCheckout', {
    customerId: 'cus_bPMJqiDPCywqJ4SUAOY8wdWBV75wcGH4',
    accountId: 'acc_6ar9C5NBJMllrrQpiu5PnLujq4zkMcQ1',
    invoiceIds: ['in_lsFALPE9RH3Gf8qV-H-8W2CAUxejkg-9'],
    gateway: 'transfer_cl',
    subscriptionId: 'sub_lsFALPE9RH3Gf8qV-H-8W2CAUxejkg-5',
});

Donde cada uno de los parámetros se define en la siguiente tabla.

ParámetroTipoRequeridoDescripción
customerIdstringyesId del customer
accountIdstringyesId de la cuenta de pago. Se puede encontrar en Ajustes > Cuentas de cobro
invoiceIdslist[string]yesArreglo con los ids de los invoices a pagar.
gatewaystringnoGateway específico al cual será redirigido, en caso de omitir este valor, se mostrarán todos los gateways disponibles.
subscriptionIdstringnoId de la subscription en la cual se inscribirá el medio de pago.