autoft-bot-wildcard

1.2.3Β β€’Β PublicΒ β€’Β Published

🌐 AutoFT Bot Wildcard

npm version Downloads License: MIT Node.js GitHub stars

πŸš€ The most advanced Telegram bot for automated Cloudflare wildcard domain management

πŸ“– Documentation β€’ πŸš€ Quick Start β€’ πŸ’¬ Support β€’ πŸ› Issues


πŸ“‹ Table of Contents


✨ Features

🎯 Core Functionality

  • 🌐 Wildcard Domain Management - Automated Cloudflare wildcard DNS setup
  • πŸ€– Telegram Bot Interface - Complete bot management via Telegram
  • πŸ‘₯ Multi-User Support - Each user manages their own domains
  • πŸ” Secure Configuration - Encrypted API key storage
  • πŸ“Š Real-time Analytics - Domain statistics and monitoring
  • ⚑ Lightning Fast - Optimized for performance
  • πŸ“’ Telegram Notifications - Real-time alerts and updates

πŸ›‘οΈ Security & Management

  • πŸ‘‘ Admin Dashboard - Complete administrative control
  • πŸ”’ Permission System - Role-based access control
  • πŸ“’ Broadcast System - Mass communication tools
  • πŸ›‘οΈ Rate Limiting - Built-in abuse protection
  • πŸ“ Comprehensive Logging - Detailed activity tracking

πŸ”§ Technical Features

  • πŸ“¦ NPM Package - Global installation support
  • 🎨 Interactive Setup - Beautiful CLI wizard
  • πŸ”„ Auto-restart - Process management ready
  • πŸ“± Simplified Setup - Only requires bot token and group ID
  • 🌍 Environment Variables - Flexible configuration

πŸš€ Quick Start

Get your bot running in under 3 minutes!

1️⃣ Install Globally

npm install -g autoft-bot-wildcard

2️⃣ Run Interactive Setup

autoft-bot-wildcard

3️⃣ Start Your Bot

cd autoft-bot-wildcard
npm start

πŸŽ‰ That's it! Your bot is now live and ready to manage wildcard domains!


πŸ“¦ Installation

Prerequisites

Method 1: Global Installation (Recommended)

# Install globally
npm install -g autoft-bot-wildcard

# Run setup wizard
autoft-bot-wildcard

Method 2: Local Installation

# Clone repository
git clone https://github.com/AutoFTbot/Wildcard-Bot.git
cd Wildcard-Bot

# Install dependencies
npm install

# Copy environment template
cp .env.example .env

# Edit configuration
nano .env

# Start bot
npm start

Method 3: Docker (Coming Soon)

docker run -d --name autoft-bot-wildcard \
  -e BOT_TOKEN=your_token \
  -e ADMIN_IDS=your_id \
  autoft-bot-wildcard:latest

βš™οΈ Configuration

Environment Variables

Create a .env file in your project root:

# πŸ€– Bot Configuration
BOT_TOKEN=1234567890:ABCdefGHIjklMNOpqrsTUVwxyz
ADMIN_IDS=123456789,987654321

# πŸ“’ Notifications (Optional)
TELEGRAM_GROUP_ID=-1001234567890

# πŸ”§ Optional Settings
MAX_CUSTOM_DOMAINS=5
NODE_ENV=production
LOG_LEVEL=info

Configuration File

Customize your bot behavior in config/default.js:

module.exports = {
    // Admin Configuration
    ADMIN_IDS: [123456789, 987654321],

    // Domain Limits
    MAX_CUSTOM_DOMAINS: 5,
    MAX_DOMAINS_PER_USER: 10,

    // Available Domains
    DEFAULT_DOMAINS: [
        'yourdomain.com',
        'example.org',
        'demo.net'
    ],

    // Notification Settings - Only Telegram supported
    NOTIFICATIONS: {
        TELEGRAM: {
            enabled: true,
            groupId: process.env.TELEGRAM_GROUP_ID || '',
        },
    },

    // Security Settings
    FORBIDDEN_KEYWORDS: [
        'admin', 'root', 'api', 'mail'
    ],

    // Rate Limiting
    RATE_LIMITS: {
        SETUP_WILDCARD: {
            PER_USER: 3,
            COOLDOWN: 3600
        }
    }
};

πŸ“± Usage

For End Users

1. Initial Setup

/start β†’ Welcome message and setup guide
/addcf <api_key> <email> β†’ Register Cloudflare credentials

2. Domain Management

/listdomain β†’ View available domains
/setupwildcard example.com β†’ Setup wildcard for domain
/new subdomain.example.com β†’ Create custom subdomain
/mysub β†’ View your subdomains

3. Analytics & Monitoring

/analytics example.com β†’ View domain statistics
/clearcache example.com β†’ Clear Cloudflare cache

For Bot Owners (Admins)

1. User Management

/stats β†’ Bot usage statistics
/userinfo 123456789 β†’ View user details
/broadcast Hello everyone! β†’ Message all users

2. System Management

/testnotif β†’ Test notification system

🎯 Commands

πŸ”° Basic Commands

Command Description Usage
/start Welcome message & setup guide /start
/help Show all available commands /help
/ping Check bot responsiveness /ping

πŸ”§ Configuration Commands

Command Description Usage
/addcf Add Cloudflare credentials /addcf <api_key> <email>
/cfconfig View current configuration /cfconfig
/updatecf Update Cloudflare credentials /updatecf <api_key> <email>
/deletecf Remove configuration /deletecf

🌐 Domain Management Commands

Command Description Usage
/listdomain Show available domains /listdomain
/setupwildcard Setup wildcard domain /setupwildcard <domain>
/new Create custom subdomain /new <subdomain.domain.com>
/mysub View your subdomains /mysub
/searchdomain Search domains /searchdomain <keyword>
/delsub Delete subdomain /delsub <subdomain>

πŸ“Š Analytics Commands

Command Description Usage
/analytics View domain statistics /analytics <domain>
/clearcache Clear Cloudflare cache /clearcache <domain>

πŸ‘‘ Admin Features

πŸ“Š Statistics Dashboard

πŸ“Š BOT STATISTICS

πŸ‘₯ Users & Domains:
β€’ Registered Users: 150
β€’ Active Domains: 45
β€’ Total Subdomains: 1,234

⚑ System Status:
β€’ Uptime: 7d 12h 30m
β€’ Memory Usage: 45.2 MB
β€’ Node.js Version: v20.10.0

πŸ€– Bot Info:
β€’ Bot Username: @YourWildcardBot
β€’ Last Updated: 2024-01-15 14:30:25

πŸ“’ Broadcast System

Send messages to all registered users:

/broadcast 🚨 Scheduled maintenance in 1 hour. All services will be temporarily unavailable.

πŸ‘€ User Management

Get detailed user information:

/userinfo 123456789

πŸ‘€ USER INFORMATION
πŸ†” User ID: 123456789
πŸ“± Telegram: @username (John Doe)
πŸ“§ Cloudflare Email: user@example.com
🌐 Custom Domains: 5
πŸ“… Registration: 2024-01-10 09:15:32

πŸ”§ Advanced Configuration

Custom Domain Setup

Add your own domains to the bot:

// config/default.js
DEFAULT_DOMAINS: [
    'your-domain.com',
    'another-domain.net',
    'example.org'
]

Notification Customization

Configure Telegram notifications:

NOTIFICATIONS: {
    TELEGRAM: {
        enabled: true,
        groupId: process.env.TELEGRAM_GROUP_ID,
        // Custom message templates
        templates: {
            welcome: 'πŸŽ‰ New user registered: {username}',
            domainSetup: '🌐 Wildcard setup: {domain} by {user}'
        }
    }
}

Rate Limiting Configuration

Prevent abuse with custom rate limits:

RATE_LIMITS: {
    SETUP_WILDCARD: {
        PER_USER: 5,        // Max 5 setups per user
        COOLDOWN: 3600      // 1 hour cooldown
    },
    ANALYTICS: {
        PER_USER: 10,       // Max 10 requests per hour
        COOLDOWN: 300       // 5 minutes between requests
    }
}

πŸš€ Deployment

Production Deployment with PM2

# Install PM2 globally
npm install -g pm2

# Start bot with PM2
pm2 start index.js --name "autoft-bot-wildcard"

# Enable auto-restart on server reboot
pm2 startup
pm2 save

# Monitor logs
pm2 logs autoft-bot-wildcard

# Restart bot
pm2 restart autoft-bot-wildcard

Environment Setup for Production

# Set production environment
export NODE_ENV=production

# Increase memory limit if needed
node --max-old-space-size=2048 index.js

Nginx Reverse Proxy (Optional)

If you plan to add webhooks:

server {
    listen 80;
    server_name your-bot-domain.com;

    location /webhook {
        proxy_pass http://localhost:3000;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
    }
}

πŸ› οΈ Development

Project Structure

autoft-bot-wildcard/
β”œβ”€β”€ πŸ“ bin/
β”‚   └── wildcard-bot.js         # CLI entry point
β”œβ”€β”€ πŸ“ config/
β”‚   β”œβ”€β”€ constants.js            # Application constants
β”‚   └── default.js              # Default configuration
β”œβ”€β”€ πŸ“ handlers/
β”‚   β”œβ”€β”€ adminHandlers.js        # Admin command handlers
β”‚   β”œβ”€β”€ cloudflareHandlers.js   # Cloudflare operations
β”‚   β”œβ”€β”€ configHandlers.js       # Configuration management
β”‚   β”œβ”€β”€ domainHandlers.js       # Domain operations
β”‚   └── generalHandlers.js      # General bot commands
β”œβ”€β”€ πŸ“ lib/
β”‚   └── WildcardBot.js          # Main bot class
β”œβ”€β”€ πŸ“ services/
β”‚   β”œβ”€β”€ CloudflareManager.js    # Cloudflare API wrapper
β”‚   └── NotificationService.js  # Notification system
β”œβ”€β”€ πŸ“ utils/
β”‚   β”œβ”€β”€ fileUtils.js            # File operations
β”‚   β”œβ”€β”€ systemUtils.js          # System utilities
β”‚   └── validation.js           # Input validation
β”œβ”€β”€ πŸ“ data/                    # Bot data storage
β”œβ”€β”€ .env.example                # Environment template
β”œβ”€β”€ index.js                    # Application entry point
β”œβ”€β”€ package.json                # Dependencies
└── README.md                   # Documentation

Running in Development Mode

# Clone repository
git clone https://github.com/AutoFTbot/Wildcard-Bot.git
cd Wildcard-Bot

# Install dependencies
npm install

# Copy environment file
cp .env.example .env

# Edit configuration
nano .env

# Start in development mode
npm run dev

Code Style and Linting

# Run linter
npm run lint

# Fix linting issues
npm run lint:fix

# Format code
npm run format

# Run all checks
npm run check

Testing

# Test configuration
npm run test:config

# Test notifications
npm run test:notifications

# Test Cloudflare connection
npm run test:cloudflare

❓ FAQ

Q: How do I get a Telegram Bot Token?

A: Message @BotFather on Telegram, use /newbot command, and follow the instructions.

Q: Where do I find my Cloudflare Global API Key?

A: Go to Cloudflare Dashboard β†’ My Profile β†’ API Tokens β†’ Global API Key β†’ View

Q: How do I get my Telegram ID?

A: Message @userinfobot on Telegram to get your user ID.

Q: Can I use custom domains?

A: Yes! Add your domains to the DEFAULT_DOMAINS array in config/default.js.

Q: Is there a limit on users or domains?

A: You can configure limits in config/default.js. Default is 5 domains per user.

Q: How do I update the bot?

A: Run npm update -g autoft-bot-wildcard for global installations.

Q: "autoft-bot-wildcard command not found" error

This happens when the global installation didn't complete properly:

# Reinstall globally
npm install -g autoft-bot-wildcard --force

# Clear npm cache if needed
npm cache clean --force

# Check if command is available
which autoft-bot-wildcard

# Alternative: run directly with npx
npx autoft-bot-wildcard

πŸ†˜ Troubleshooting

Common Issues

πŸ”΄ Bot not responding

# Check if bot is running
ps aux | grep node

# Check logs
pm2 logs autoft-bot-wildcard

# Restart bot
pm2 restart autoft-bot-wildcard

πŸ”΄ "Bot token invalid" error

  • Verify your bot token in .env file
  • Make sure token format is correct: 1234567890:ABCdefGHIjklMNOpqrsTUVwxyz
  • Check if bot was deleted in @BotFather

πŸ”΄ Cloudflare API errors

  • Verify Global API Key and email in user configuration
  • Check if domain is added to Cloudflare account
  • Ensure API key has necessary permissions

πŸ”΄ Notifications not working

  • Verify TELEGRAM_GROUP_ID in environment variables
  • Make sure bot is added to the notification group
  • Check if bot has permission to send messages

πŸ”΄ Domain setup fails

  • Ensure domain is registered in Cloudflare
  • Check DNS propagation status
  • Verify Cloudflare account permissions

πŸ”΄ Installation fails

  • Make sure you have Node.js 16+ installed
  • Try clearing npm cache: npm cache clean --force
  • Use the latest npm version: npm install -g npm@latest

Debug Mode

Enable detailed logging:

export LOG_LEVEL=debug
npm start

Getting Help

  1. Check our Wiki
  2. Search existing issues
  3. Join our Telegram group
  4. Create a new issue

🀝 Contributing

We welcome contributions! Here's how you can help:

πŸ› Bug Reports

  • Use the issue template
  • Include detailed reproduction steps
  • Provide relevant logs and screenshots

✨ Feature Requests

πŸ’» Code Contributions

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make your changes and test thoroughly
  4. Follow our coding standards (run npm run lint)
  5. Commit with clear messages: git commit -m 'Add amazing feature'
  6. Push to your branch: git push origin feature/amazing-feature
  7. Open a Pull Request

πŸ“š Documentation

  • Improve existing documentation
  • Add examples and use cases
  • Translate to other languages
  • Create video tutorials

πŸ“ˆ Roadmap

πŸš€ Upcoming Features

  • [ ] Web Dashboard - Browser-based management interface
  • [ ] Docker Support - Containerized deployment
  • [ ] Multi-language - Support for multiple languages
  • [ ] Advanced Analytics - Detailed usage statistics
  • [ ] Custom Commands - User-defined bot commands
  • [ ] Backup System - Automated data backups
  • [ ] Plugin System - Extensible architecture

🎯 Long-term Goals

  • [ ] Cloud Hosting - Managed hosting service
  • [ ] Mobile App - Native mobile application
  • [ ] Enterprise Features - Advanced business features
  • [ ] API Gateway - RESTful API interface

πŸ“Š Statistics

GitHub repo size GitHub code size Lines of code GitHub commit activity


πŸ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

MIT License

Copyright (c) 2024 AutoFTbot Team

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

πŸ™ Acknowledgments

  • Telegraf.js - Telegram Bot API framework
  • Cloudflare - DNS and CDN services
  • Node.js Community - Runtime environment
  • Contributors - Everyone who helped improve this project

πŸ“ž Support & Community

πŸ’¬ Get Help

Telegram GitHub Issues

🌟 Stay Updated

GitHub Watch GitHub Star GitHub Fork


⭐ If this project helped you, please give it a star!

Made with ❀️ by the AutoFTbot Team

πŸš€ Get Started Now β€’ πŸ“– Read the Docs β€’ πŸ’¬ Join Community

Package Sidebar

Install

npm i autoft-bot-wildcard

Weekly Downloads

12

Version

1.2.3

License

MIT

Unpacked Size

159 kB

Total Files

19

Last publish

Collaborators

  • fightertunnel