Edgio

DataDome Edgio integration detects and protects against bot activity.

❗️

This module is deprecated

This module relies on the EdgeJS implementation which has reached its End-of-Life on January 10, 2025.

Please contact the support to find another way to integrate.

DataDome Bot protection can be integrated directly inside Edgio.

Requirements

DataDome integration is available with EdgeJS implementation.

Please ensure that Edgio prerequisites are taken into account.

Installation

The module is distributed as a npm package. You can use it in your process by slightly modifying the code.

1 - Add your own API server key provided by DataDome inside Edgio environnement variables by accessing the configuration page through: SITE >> ENVIRONMENT >> configuration. You can find this API key inside our dashboard.
Add DataDome parameters DATADOME_ENDPOINTHOST with value api.datadome.co and DATADOME_TIMEOUT with value 150.

2 - Install DataDome module into your application (using npm) with the following command:

npm i @datadome/module-edgio

3 - Update your application to integrate DataDome module by making the following changes on this application in the routes.js file:

import DataDome from '@datadome/module-edgio'
import { Router } from '@layer0/core/router'

const ddParameters = {
    endpointHost: process.env['DATADOME_ENDPOINTHOST'],
    timeout: parseInt(process.env['DATADOME_TIMEOUT']),
};

const datadomeClient = new DataDome(process.env['DATADOME_KEY'], ddParameters);


export default new Router()
  // Avoid calling EdgIO compute for each static content
	.match(
        '/:path*/:file.:ext(avi|flv|mka|mkv|mov|mp4|mpeg|mpg|mp3|flac|ogg|ogm|opus|wav|webm|webp|bmp|gif|ico|jpeg|jpg|png|svg|svgz|swf|eot|otf|ttf|woff|woff2|css|less|js|map)',
        ({ proxy }) => {
            proxy('origin');
        }
    )

  // DataDome will process all requests which didn’t match any pattern set up before
  .match('/(.*)', async({ compute, cache, proxy }) => {
    cache({ edge: false, browser: false })

    compute(async(request, response) => {
			const ddResult = await datadomeClient.validateRequest(request, response);
      return proxy('origin')
    })
  })

🚧

Matching static assets must be done before matching all other requests to avoid calling Edgio compute.

📘

Requests going through DataDome will not be cached as they contain a set-cookie header.

4 - Update the DataDome settings if needed. We recommend not to change these settings without referring to DataDome support team first.

5 - Deploy your application as usual:

edgio deploy

You should be able to see the traffic in your DataDome dashboard.

Settings

OptionDefault valueDescription
endpointHostapi.datadome.coHostname of the API Server
Available endpoints
timeout150Timeout in ms, after which the request will be passed

FAQ

How to create a default routing configuration

If you already have defined default routing configuration you can skip the current step. Otherwise you should create it using the command:

npx @edgio/cli@latest init \
    --name <DOMAIN> \
    --environment default \
    --origin <DOMAIN> \
    --deploy

Please check Edgio environnements for further details.

When it is done, you should have access to two main files:

  • edgio.config.js
  • routes.js