How to install the hCaptcha® integration through Azion Marketplace
hCaptcha® is a CAPTCHA (which stands for “Completely Automated Public Turing test to tell Computers and Humans Apart”) service that aims to improve user privacy and security by using puzzles that are harder for bots to solve, and by using the solved puzzles to train machine learning models to improve the overall security of the internet. You can use it to avoid bots, web crawlers, and other automated tools that misuse your resources.
Azion’s integration with hCaptcha® runs on the edge nodes of Azion. It ensures that only authentic requests get access to your infrastructure by identifying whether the request is valid before accessing the origin. Rather than figuring out the logic of when, where, and how to display requests, you can speed up your requests by simply enabling and configuring JSON args.
Getting the integration
To install this integration provided by Azion’s Marketplace, you have to:
- Access Azion Console > Marketplace.
- On the Marketplace homepage, select the integration’s card.
- Once the integration’s page opens, click the Install button, at the bottom-right corner of the page.
You’ll see a message indicating that your integration was successfully installed.
- Access Real-Time Manager (RTM) > Marketplace.
- On the Marketplace homepage, select the integration’s card.
- Once the integration’s page opens, click the Get It Now button, at the bottom-right corner of the page.
You’ll see a message indicating that your integration was successfully installed.
Getting the keys
To configure this integration, you have to provide two keys: your secret-key
and your site-key
. To get these credentials, you’ll have to register at the hCaptcha site.
To do so, follow these steps:
- Go to the hCaptcha dashboard.
- If you don’t have an account, you can create one here.
- Pay attention when creating a new account, because the site will provide your secret key. This secret key will be used to configure the integration later on.
- On the dashboard click the New Site button.
- It’s optional, but recommended, to name your instance of hCaptcha.
- Fill in the
hostnames
you want to use the challenge on and click the Add Domain button. - Choose your challenge mode. You have three options:
- Always Challenge (Free. Every request will load a challenge)
- Passive (Paid. There’s no challenge and the CAPTCHA will be triggered according to the behavior of the user)
- 99.9% Passive (Paid. The challenge will only appear for users at high risk of being bots).
- Choose the passing threshold you want for your site according to the difficulty level: auto, easy, moderate, and difficult. These modes will determine how accurate the user’s answers should be to pass the test.
- With everything filled-up, click the Save button on the top-right corner.
Now your site is configured to use the hCaptcha integration.
To configure Azion’s integration, you now have to get the site-key from hCaptcha. Still in the hCaptcha site, follow these steps:
- In your dashboard, on the upper-menu, click on Sites.
- After loading your sites listed, find the one you configured above.
In the first column, you’ll see a label with a string chain that’ll look like this:
efdb42c7-10ee-4969-8013-cfcb5f7ad007
. This is your site key. - Hover over the string and click to copy your site key.
- Save the site key and the secret key to configure Azion’s integration as explained in the next sections.
Configuring the integration
Setting up an edge firewall
To start the configuration, follow these steps:
- On the Products menu, select Edge Firewall in the SECURE section.
- Click the + Edge Firewall button.
- Give an easy-to-remember name to your edge firewall.
- Select the domains you want to protect with the function.
- Click the Edge Functions switch.
- Click the Save button.
Done. Now you’ve instantiated the edge firewall for your integration and it has access to edge functions.
- On the Products menu, select Edge Firewall in the SECURE section.
- Click the Add Rule Set button.
- Give an easy-to-remember name to your edge firewall.
- Select the domains you want to protect with the function.
- Click the Edge Functions switch.
- Click the Save button.
Done. Now you’ve instantiated the edge firewall for your integration and it has access to edge functions.
Setting up the integration
To instantiate the integration, while still on the Edge Firewall page:
- Select the Functions tab.
- Click the Add Function button.
- Give a name to your instance.
- On the dropdown menu, select the hCaptcha function.
- This action will load the function, showing a form with the function’s source-code and, just above it, two tabs: Code and Args. By clicking on the Code tab, you’ll be able to navigate through the source-code, but won’t be able to change it.
- In the Args tab, you’ll pass the two keys your keys and your variables:
Where:
Variable | Required | Description |
---|---|---|
site_key | Yes | The site key you obtained at the hCaptcha page |
secret_key | Yes | The secret key you obtained at the hCaptcha page |
expiration_in_seconds | Yes | The time in seconds until the challenge expires |
origin_address | Yes | Your domain from which the function will fetch the content after the user solves the challenge |
origin_headers | No | Whenever the access to the origin requires the usage of specific request headers |
captcha_args | No | These args modify and customize the layout of the challenge box |
custom_message | No | A customized message you want to show users |
custom_html | No | The customized HTML to render the challenge box |
cookie_secret | Yes | This cookie is generated by the function and used in order for the functions not to be re-run |
- Click the Save button to save your configuration.
Done. Now your hCaptcha instance is saved.
- Select the Functions Instances tab.
- Click the + Function Instance button.
- Give a name to your instance.
- On the dropdown menu, select the hCaptcha function.
- This action will load the Arguments tab, where you can add the parameters to execute your application.
- In the Arguments tab, pass the two keys your keys and your variables:
Where:
Variable | Required | Description |
---|---|---|
site_key | Yes | The site key you obtained at the hCaptcha page |
secret_key | Yes | The secret key you obtained at the hCaptcha page |
expiration_in_seconds | Yes | The time in seconds until the challenge expires |
origin_address | Yes | Your domain from which the function will fetch the content after the user solves the challenge |
origin_headers | No | Whenever the access to the origin requires the usage of specific request headers |
captcha_args | No | These args modify and customize the layout of the challenge box |
custom_message | No | A customized message you want to show users |
custom_html | No | The customized HTML to render the challenge box |
cookie_secret | Yes | This cookie is generated by the function and used in order for the functions not to be re-run |
- Click the Save button to save your configuration.
Done. Now your hCaptcha instance is saved.
Setting up the Edge Firewall Rules Engine
To finish, you have to set up the Rules Engine to configure the behavior and the criteria to run the function.
Still on the Edge Firewall page:
- Select the Rules Engine tab.
- Click the + Rule Engine button.
- Give a name to the rule.
- Select a criteria to run and catch the domain you want to run the integration on. Example:
if Hostname is equal xxxxxxxxxxxx.map.azionedge.net
. - Below, select a behavior to the criteria. In this case, it’ll be Run Function.
- Select the adequate function according to the name you gave it in the instantiate step.
- Click the Save button.
Done. Now the integration is running for every request made to the domain you indicated.
- Select the Rules Engine tab.
- Click the New Rule button.
- Give a name to the rule.
- Select a criteria to run and catch the domain you want to run the integration on. Example:
if Hostname is equal xxxxxxxxxxxx.map.azionedge.net
. - Below, select a behavior to the criteria. In this case, it’ll be Run Function.
- Select the adequate function according to the name you gave it in the instantiate step.
- Click the Save button.
Done. Now the integration is running for every request made to the domain you indicated.
Trademarks
hCaptcha is a registered trademark of Intuition Machines, Inc.
Watch a video on how to install the hCaptcha® integration through Azion Marketplace on Azion’s YouTube channel.