Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

botblocker.pro

Package Overview
Dependencies
Maintainers
0
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

botblocker.pro

BotBlocker.Pro is an essential package for protecting your website from unwanted bots that can harm performance and security. Our powerful real-time web traffic filtering and analytics service helps you track and understand your visitors while effectively

  • 1.0.0
  • latest
  • npm
  • Socket score

Version published
Maintainers
0
Created
Source

BotBlocker.Pro - Bot Detection, Visitor Filtering & IP Address Intelligence

BotBlocker.Pro is a powerful Node.js and TypeScript module designed to enhance web security, filter traffic, and provide valuable analytics. It protects your application by identifying and blocking potentially harmful traffic based on IP addresses, user agents, and visitor behaviors. With BotBlocker.Pro, you can effectively defend your website against bots, competitors, and unwanted visitors while also gaining valuable insights into your audience.

To get started with BotBlocker.Pro, you'll need an API key and a subscription to our BotBlocker.Pro service. For further information, please check our comprehensive documentation.

Installation

Install BotBlocker.Pro using npm:

npm install botblocker.pro

Usage

Method 1: Using Express Middleware

import express from 'express';
import { BotBlocker } from 'botblocker.pro';

// Create an Express application
const app = express();
const port = 3000;

// Replace with your API key
const apiKey = 'YOUR-API-KEY';
const botBlocker = new BotBlocker(apiKey);

// Route handler for the root URL
app.get('/', async (req, res) => {
    try {
        const result = await botBlocker.checkReq(req);

        // User info (location and other data)
        let info = result.data.info;
        let location = info.ipinfo;

        if (result.data.block_access) {
            // Action to take if the user should be blocked
            res.status(403).json({message: 'Access denied'});
        } else {
            // Action to take if the user is allowed
            res.json({message: 'Welcome', location: location});
        }
    } catch (error) {
        // Handle any errors that occur
        console.error('Error:', error.message);
        res.status(500).json({error: 'Internal Server Error', details: error.message});
    }
});

// Start the Express server and listen on the specified port
app.listen(port, () => {
    console.log(`Server running at http://localhost:${port}`);
});

Method 2: Manually Providing IP, User-Agent, URL (Page)

const { BotBlocker } = require('botblocker.pro');

// Replace with your API key
const apiKey = 'YOUR-API-KEY';
const botBlocker = new BotBlocker(apiKey);

// Example visitor data
const userIP = '1.1.1.1'; // Replace with the visitor's IP
const userAgent = 'Mozilla/5.0 ...'; // Replace with the visitor's User-Agent
const url = 'blog/slug?query='; // Replace with URL or the page that the visitor accessed

// Manually evaluate visitor
botBlocker.check(userIP, userAgent, url)
    .then(result => {
        // User info (location and other data)
        let info = result.data.info;
        let location = info.ipinfo;

        console.log('Check result:', result);
        if (result.data.block_access) {
            // Action to take if the user should be blocked
            console.log('Block the user');
        } else {
            // Action to take if the user is allowed
            console.log('Allow the user');
        }
    })
    .catch(error => {
        // Handle any errors that occur
        console.error('Error:', error);
    });

Replace YOUR-API-KEY with your actual BotBlocker.Pro API credentials in both methods.

Contributing

We appreciate your contributions! If you're planning to make significant changes, please start by opening an issue to discuss your proposed modifications. Additionally, ensure that you update any relevant tests as needed.

License

This project is licensed under the MIT license.

Keywords

FAQs

Package last updated on 03 Nov 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc