recaptcha-v3-enterprise
Version:
A simple and easy to use reCAPTCHA Enterprise (v3 only) library for the browser.
92 lines (63 loc) • 4.3 kB
Markdown
# reCAPTCHA-v3-enterprise
A simple and easy to use reCAPTCHA Enterprise (v3 only) library for the browser.
## Install
With NPM:
```bash
$ npm install recaptcha-v3-enterprise
```
With Yarn:
```bash
$ yarn add recaptcha-v3-enterprise
```
## Prerequisites
To use this package you only need a valid site key for your domain, which you can easily get [here](https://cloud.google.com/recaptcha-enterprise/docs/instrument-web-pages).
## Usage
With promises:
```javascript
import { load } from 'recaptcha-v3-enterprise';
load('<site key>').then((recaptcha) => {
recaptcha.execute('<action>').then((token) => {
console.log(token); // Will print the token
});
});
```
With async/await:
```javascript
import { load } from 'recaptcha-v3-enterprise';
async function asyncFunction() {
const recaptcha = await load('<site key>');
const token = await recaptcha.execute('<action>');
console.log(token); // Will also print the token
}
```
## Loader options
The loader takes care of loading the reCAPTCHA script from Google.
Therefore the loader offers optional options for additional configuration:
| Name | Description | Type | Default value |
| ---------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------- | ------------- |
| **useRecaptchaNet** | Due to limitations in certain countries it's required to use `recaptcha.net` instead of `google.com`. | _boolean_ | `false` |
| **autoHideBadge** | Will automatically hide the reCAPTCHA badge. Warning: The usage is only allowed if you follow the offical guide for hiding the badge from Google ([see here](https://developers.google.com/recaptcha/docs/faq#id-like-to-hide-the-recaptcha-v3-badge-what-is-allowed)) | _boolean_ | `false` |
| **renderParameters** | Will add the given parameters to the reCAPTCHA script. The given object will be converted into a query string and will then be added to the URL. | Object | `{}` |
| **explicitRenderParameters** | Will set the parameters to the explicit rendering. [See here](#explicit-render-parameters) | Object | `{}` |
### Load options usage
To use the options just pass an additional object to the `load(...)` method.
For example:
```javascript
import { load } from 'recaptcha-v3-enterprise';
load('<site key>', {
useRecaptchaNet: true,
autoHideBadge: true,
}).then((recaptcha) => {
// ...
});
```
### Explicit render parameters
The ReCaptcha widget will be explicity loaded, which means you can add parameters to the rendering process.
| Name | Description | Type |
| ------------- | ----------------------------------------------------- | ----------------------------------------------- |
| **container** | The container if you want to render the inline widget | `string` or `Element` |
| **badge** | The positioning for the widget | `'bottomright'` or `'bottomleft'` or `'inline'` |
| **size** | The size of the widget | `'invisible'` |
| **tabindex** | The tab index of the widget | `number` |
## Credits
- [AurityLab](https://github.com/AurityLab)