Skip to main content
Zen Installation instructions
Setup and Installation of Zen for Node.js

Setup and Installation of Zen for Node.js

This guide will walk you through installing and setting up Zen by Aikido for your application. Follow the steps below to protect your application.

We have first class support for multiple frameworks and database drivers, for the full list check our README on GitHub.

1. Install Zen by Aikido

First, you need to install the Zen package. Open your terminal and run:

# The --save-exact makes sure that you don't automatically install a newer version
$ npm install --save-exact @aikidosec/firewall

# The --exact makes sure that you don't automatically install a newer version
$ yarn add --exact @aikidosec/firewall

2. Include Zen in app.js

Next, you need to include Zen in your app.js file. This should be done before any other code or imports:

require('@aikidosec/firewall'); // <-- Include this before any other code or imports

const express = require('express');

const app = express();

// Your other middleware and routes

app.listen(3000, () => {
  console.log("Server is running on port 3000");
});

Alternatively, if you are using ESM import style:

import '@aikidosec/firewall';

import express from 'express';

const app = express();

// Your other middleware and routes

app.listen(3000, () => {
  console.log("Server is running on port 3000");
});

When using esbuild as your bundler, follow these additional configuration steps.

3. Create an app in the dashboard and generate a token

  1. Go to the Zen section in Aikido.

  2. Click on Add app.

  3. Choose a name for your app and click Generate token.

  4. Copy the generated token.

4. Start Zen in dry / detection-only mode

Set the token as an environment variable, AIKIDO_TOKEN, using dotenv or another method of your choosing. Start your app in dry mode to ensure it works as expected without blocking any requests:

$ AIKIDO_BLOCKING=false node app.js

Tip: You can use AIKIDO_DEBUG=true to enable debug mode (To verify that you set AIKIDO_TOKEN correctly)

5. Test your app

Browse to GET /auth/login and perform a login as you normally would (e.g., POST /auth/login). Zen will automatically discover the routes in your application:

app.get('/auth/login', (req, res) => {
  res.send('Login Page');
});

app.post('/auth/login', (req, res) => {
  // Handle login logic
  res.send('Logged In');
});

6. Setup rate limiting in the dashboard

Log in to your Aikido account and navigate to the Zen dashboard. Click on the created app and check the Events tab to verify that a “started” event was recorded:

To protect your POST /auth/login route from brute force attacks, set up rate limiting in the Aikido Dashboard:

  1. Click on the created app.

  2. Go to the Routes tab.

  3. Find the POST /auth/login route and click Setup rate limiting.

  4. Follow the instructions to configure the rate limit (e.g., 5 requests per minute).

7. Verify Rate Limiting

Start your app and try to log in 5 times within a minute. After the fifth attempt, you should receive a rate limit error:

You are rate limited by Aikido firewall. (Your IP: 1.2.3.4)

Requests from localhost will not be rate limited when NODE_ENV is "production". When you are developing your app locally, you'll be able to verify the rate limiting.