@friendlycaptcha/server-sdk
v0.1.2
Published
Serverside client SDK for the Friendly Captcha V2 API
Downloads
80
Readme
friendly-captcha-javascript
A Javascript client for the Friendly Captcha service. This client allows for easy integration and verification of captcha responses with the Friendly Captcha API.
This library is for Friendly Captcha v2 only. If you are looking for V1, look here
This is the library you use in your backend code. For the code that you use in your frontend, see @friendlycaptcha/sdk.
Installation
Install using NPM
npm install @friendlycaptcha/server-sdk
Usage
Below are some basic examples of how to use the client.
For a more detailed example, take a look at the example directory.
Initialization
import { FriendlyCaptchaClient } from "@friendlycaptcha/server-sdk";
const frcClient = new FriendlyCaptchaClient({
apiKey: "YOUR_API_KEY",
sitekey: "YOUR_SITEKEY",
});
Verifying a Captcha Response
After calling verifyCaptchaResponse
with the captcha response there are two functions on the result object that you should check:
wasAbleToVerify()
indicates whether we were able to verify the captcha response. This will befalse
in case there was an issue with the network/our service or if there was a mistake in the configuration.shouldAccept()
indicates whether the captcha response was correct. If the client is running in non-strict mode (default) andwasAbleToVerify()
returnedfalse
, this will betrue
.
Below are some examples of this behaviour.
Verifying a correct captcha response without issues when veryfing:
const result = await frcClient.verifyCaptchaResponse("CORRECT_CAPTCHA_RESPONSE_HERE");
console.log(result.wasAbleToVerify()); // true
console.log(result.shouldAccept()); // true
Verifying an incorrect captcha response without issues when veryfing:
const result = await frcClient.verifyCaptchaResponse("INCORRECT_CAPTCHA_RESPONSE_HERE");
console.log(result.wasAbleToVerify()); // true
console.log(result.shouldAccept()); // false
Verifying an incorrect captcha response with issues (network issues or bad configuration) when veryfing in non-strict mode (default):
const result = await frcClient.verifyCaptchaResponse("INCORRECT_CAPTCHA_RESPONSE_HERE");
console.log(result.wasAbleToVerify()); // false
console.log(result.shouldAccept()); // true
Verifying an incorrect captcha response with issues (network/service issues or bad configuration) when veryfing in strict mode:
const frcClient = new FriendlyCaptchaClient({
...
strict: true,
});
const result = await frcClient.verifyCaptchaResponse("INCORRECT_CAPTCHA_RESPONSE_HERE");
console.log(result.wasAbleToVerify()); // false
console.log(result.shouldAccept()); // false
Configuration
Configuration
The client offers several configuration options:
- apiKey: Your Friendly Captcha API key.
- sitekey: Your Friendly Captcha sitekey.
- strict: (Optional) In case the client was not able to verify the captcha response at all (for example if there is a network failure or a mistake in configuration), by default
verifyCaptchaResponse
returnstrue
regardless. By passingstrict: true
, it will returnfalse
instead: every response needs to be strictly verified. - siteverifyEndpoint: (Optional) The endpoint URL for the site verification API. Shorthands
eu
orglobal
are also accepted. Default isglobal
. - fetch: (Optional) The fetch implementation to use. Defaults to
globalThis.fetch
.
Development
Install dependencies
npm install
Run the tests
First run the SDK Test server, then run npm test
.
docker run -p 1090:1090 friendlycaptcha/sdk-testserver:latest
npm test
Build for production
npm run build:dist
License
Open source under MIT.