@captchahub/hcaptcha
v1.0.7
Published
**CaptchaHub HCaptcha is a TypeScript library that provides integration with the HCaptcha service, allowing for seamless captcha implementation within your applications.** This package extends the core functionality of CaptchaHub to support HCaptcha as a
Downloads
16
Readme
CaptchaHub HCaptcha
CaptchaHub HCaptcha is a TypeScript library that provides integration with the HCaptcha service, allowing for seamless captcha implementation within your applications. This package extends the core functionality of CaptchaHub to support HCaptcha as a captcha provider.
Installation
Install the package using pnpm:
pnpm add @captchahub/core
pnpm add @captchahub/hcaptchaFeatures
- User Privacy: HCaptcha is designed with user privacy in mind.
- Customizable: Easily customize the appearance and behavior of the captcha.
- Requires Core Package: This package requires the
@captchahub/corepackage for functionality.
Usage
Getting the Captcha Script
The getCaptchaScript function can be used as follows:
import { getCaptchaScript } from '@captchahub/core';
// Import the provider package to trigger self-registration
import '@captchahub/hcaptcha';
const config = {
CAPTCHA_PROVIDER: 'hcaptcha',
HCAPTCHA_SITE_KEY: process.env.HCAPTCHA_SITE_KEY, // Your HCaptcha site key
};
const CaptchaComponent = () => {
const CaptchaScript = getCaptchaScript(config);
return (
<div>
<CaptchaScript />
{/* Additional form elements */}
</div>
);
};Getting the Captcha Form Element
The getCaptchaFormElement function can be used as follows:
import { getCaptchaFormElement } from '@captchahub/core';
// Import the provider package to trigger self-registration
import '@captchahub/hcaptcha';
const config = {
CAPTCHA_PROVIDER: 'hcaptcha',
HCAPTCHA_SITE_KEY: process.env.HCAPTCHA_SITE_KEY, // Your HCaptcha site key
};
const CaptchaFormComponent = () => {
const CaptchaFormElement = getCaptchaFormElement(config);
return (
<div>
<CaptchaFormElement />
{/* Additional form elements */}
</div>
);
};Verifying the Captcha
The verifyCaptcha function can be used as follows:
import { verifyCaptcha } from '@captchahub/core';
// Import the provider package to trigger self-registration
import '@captchahub/hcaptcha';
const config = {
CAPTCHA_PROVIDER: 'hcaptcha',
HCAPTCHA_SECRET_KEY: process.env.HCAPTCHA_SECRET_KEY, // Your HCaptcha secret key
};
const formFieldValues = {
// Your form field values that need to be verified
};
const isValid = await verifyCaptcha(formFieldValues, config);
if (isValid) {
console.log('Captcha verified successfully!');
} else {
console.error('Captcha verification failed.');
}Configuration
Configuration for the HCaptcha provider can be defined in a configuration object passed to the factory when creating the captcha instance. The configuration object must include the CAPTCHA_PROVIDER property to specify which captcha provider to use. Additionally, you will need to provide the HCAPTCHA_SITE_KEY and HCAPTCHA_SECRET_KEY for proper functionality.
Extensibility
The @captchahub/hcaptcha package is designed to be extensible. You can create new captcha providers by implementing the CaptchaInterface. This allows you to add support for additional captcha services in the future.
Rationale
The @captchahub/hcaptcha package is designed to provide integration with the HCaptcha service for managing captcha workflows in TypeScript applications. By using the core package, developers can easily integrate HCaptcha capabilities into their web applications.
Contributing
Contributions are welcome! Feel free to fork this project and submit pull requests. Before submitting, please ensure your code passes all linting and unit tests.
You can format code using:
pnpm formatYou can run unit tests using:
pnpm test