🤖Captcha

A continuación, te explicaremos como utilizar Captcha con Forms para maximizar la seguridad e integridad de tu cuenta.

Por motivos de seguridad, no es posible quitar Captcha.

Este SDK permite que puedas añadir una validación captcha (Completely Automated Public Turing test to tell Computers and Humans Apart) única de forma sencilla sin importar el proveedor disponible.

Estamos trabajando para ofrecer más integraciones con proveedores que ofrezcan captcha invisibles.

Proveedores compatibles

  • hCaptcha

  • Google reCaptcha Enterprise

  • Cloudflare Turnstile

Instalación

Para utilizar Forms SDK podrás instarlo mediante nuestro CDN.

<script src="https://cdn.videsk.io/sdk/captcha.min.js"></script>

Modo de uso

const captcha = new CaptchaSDK(providerName, options);

Deberás usar este SDK junto con Phone, el cual provee los argumentos para instanciar Captcha.

Opciones

El segundo argumento de Captcha es un object de opciones, el cual debe contener:

  • siteKey: clave del sitio, el cual debes obtener mediante Phone

  • resource: URL del recurso JS del proveedor captcha

  • node: id DOM como string sin query, es decir, #myButton debe ser myButton.

Definir la opción node solo aplica para proveedores: hCaptcha.

La opción node utiliza document.getElementById(node), por lo tanto NO puedes utilizar selectores CSS.

Podrás encontrar un ejemplo funcional junto a nuestro Phone SDK.

Métodos

Ya instanciado el SDK podrás acceder a los siguientes métodos:

on

Este método tiene como objetivo que definas un oyente cuando un evento ocurra. Los dos argumentos que recibe son:

  • event: nombre del evento

  • callback: función que se ejecutará al ocurrir el evento

captcha.on('token', callback);

exec

Este método ejecuta la activación del captcha, el cual podría ser visible o invisible. Esto último dependerá del proveedor.

captcha.exec();

remove

Este método permite eliminar el nodo captcha generado.

captcha.remove();

Como buena práctica utiliza este método al momento en que la validación captcha se complete exitosamente.

Eventos

Los eventos disponibles son token, close, error.

token

Este evento se dispara una vez que se ha completado la validación de forma exitosa. El único argumento es un token.

captcha.on('token', token => {
    doSomething();
})

Este token es un valor generado automáticamente que utilizamos para validar la autenticidad del usuario.

close

Este evento se dispara solo si el proveedor captcha es visible y se ha cerrado/ocultado la interfaz de validación. No hay argumentos.

captcha.on('close', () => {});

error

Este evento se dispara cuando existe un error en la validación, el cual no necesariamente debe estar relacionado con la validación robot-humano.

captcha.on('error', (error) => {
  doSomething();
});

Para más información sobre errores de hCaptcha visita esta página.

Ejemplo

const captcha = new CaptchaSDK('hcaptcha', {
    siteKey: '...',
    resource: '...',
    node: 'myButton'
});

captcha.on('token', token => sendMyForm(token));

myButton.addEventListener('click', () => captcha.exec());

Última actualización