A Simple to Use Python based Telegram Bot Script designed to work with Adlinlfly PHP Link Shortener Website using the Adlinkfly Developer API!
- 1-click deployment is the easiest way to deploy this bot! Click on these buttons to deploy the bot in corresponding platform. Just make sure to fill-up/replace proper environmental variable values when asked. Parameters are explained below in details (in Configuration / Environment Vriables section).
- Python Packages:
- Must have a Adlinkfly Link Shortener Website hosted on the web with a valid domain name
- Your Adlinkfly website has a valid SSL Certificate installed (Accessable via HTTPS protocol!)
- Must have configured a suitable runtime envioronment (WSGI Compatible) to run python scripts! (Recommended: Render, Koyeb, Replit -OR- A Docker Container in your Custom Server)
- Easy to Integrate and Customiseable (All-in-One Config File!)
- Auto URL Detection and Shortening (No extra commands needed! Just send the link to shorten...It's too easy..!!)
- Supports Link Shortening with Custom Alias
- Auto userinput Link Validation with Error Messages.
- Available Telegram Commands:
- /start - Shows a custom welcome message when user starts the first conversation with the bot
- /help - Shows a custom help and support message when the /help command is given by the user
- /ads - Shortens the link with Ads. Also creates a separate Short Link Page! (* By default the link shortening method is set to Direct Shortening without any Ads and Short Link Page, if the User wants to shorten the link with Ads and Short Link Page the /ads command is required everytime!)
- /alias - Shortens the link with a custom alias of your choice (eg: yourdomain.com/cool-alias)
- /alias_ads - Shortens the link with a custom alias of your choice and also creates a separate Short Link Page which includes Ads
- You don't need to download anything for most cases (except: you are deploying this in your own custom server directly)
- For Custom Server deployment (direct) Download the Latest ZIP from Releases Section: adlinkfly-telegram-bot-vX.X.X.zip Download Now
- There is only one global configuration file ' .env ' also known as Environment Variables which you need to configure for your bot! An example of available fields are shown in ' .env.example ' file and also described below (If you are using the 1-click deployment solutions you don't need to create any separate ' .env ' file. All the KEYs are predefined for you! You just need to input/replace their values when asked)
HOST_PORT = 8080 #Only for Docker Container Deployment - OPTIONAL - DEFAULT: 8080
DOMAIN_NAME = yourdomain.com
BOT_TOKEN = Paste Your Telegram Bot API Token
ADLINKFLY_TOKEN = Paste Your Adlinkfly API Token
START = Type the start message here you want to show the user \nNew Line Starts Here
HELP = Type the help message here you want to show the user \nNew Line Starts Here
#Don't use https:// on DOMAIN_NAME field just type the nacked domain name as shown!
#To change the line (New Line) of START or HELP message use ' \n ' between the lines (Works as Enter Key of Keyboard! Python Syntax... :-)
- Important Fields:
- DOMAIN_NAME = Write the Domain Name of your Adlinkfly Website (Write nacked domain name without: www, http://, https://) (eg: yourdomain.com)
- API_TOKEN = Paste your Telegram Bot API Token Here. Don't know how to get one? read Here
- ADLINKFLY_TOKEN = Paste your Adlinkfly Developer API Token Here. Don't know how to get one? read Here
- Optional Fields:
- HOST_PORT = Maps the internal Docker Container Port (8080) to the specified port in your host machine. Useful when another process is running on the same port in your host machine for some reason, which may lead to malfunction. By default it uses the same port (8080) of your host machine which can be overwritten by this variable
- Custom Messages:
- START = Write the custom message you want to show to the user when they use the telegram command ' /start '
- HELP = Write the custom message you want to show to the user when they use the telegram command ' /help '
- Further customization of commands is possible by modifying the python source code....if you want you can try...!!!
-
1-Click Deployment (Easiest):
- Just click on any one of the button given at the top (in which platform you want to deploy) and follow the steps. NOTE: Make sure to Login the platform first before clicking on the button
- You will be asked to fill-up the Environment Variable values (check Configuration / Environment Vriables section for more info) Fill-up the values properly and proceed. That's it...!!
- Your platform is not listed? -> I'm continuously trying to integrate more and more platforms. But, if it's still not listed You can try the custom deployment option or contact me for further info.
-
Replit Deployment:
- Use 'Import from GitHub' option to import this repo. Don't know how to do so? read Here
- Use this URL to Import:
https://github.com/techishfellow/adlinkfly-telegram-bot.git
- Use this run command:
python3 adlinkfly_bot.py
- Open a 'Shell' window and run this command to install all dependencies:
pip install -r requirements.txt
-
Open a 'Secrets' window and configure all secrets as explained earlier (in Configuration / Environment Vriables section). Replit Secrets works the same as Environment Variables. Don't know how to use Replit Secrets? read Here
-
Now just click on the green 'Run' button at the top to start the bot. That's it...!!
-
Custom Server Deployment (With Docker) (Recommended):
- Install Docker and Docker Compose Plugin (on Ubuntu / Debian):
curl -sSL https://get.docker.com/ | CHANNEL=stable sh && apt install docker-compose-plugin
- Clone the Adlinkfly Telegram Bot Git Repository to /opt/adlinkfly-telegram-bot:
git clone https://github.com/techishfellow/adlinkfly-telegram-bot.git /opt/adlinkfly-telegram-bot
- Navigate to /opt/adlinkfly-telegram-bot then create a blank .env file and modify it (as explained earlier, in Configuration / Environment Vriables section) using command line text editor nano:
cd /opt/adlinkfly-telegram-bot && touch /opt/adlinkfly-telegram-bot/.env && nano /opt/adlinkfly-telegram-bot/.env
Save it with
CTRL
+O
and then pressingEnter
, Exit nanoCTRL
+X
- Not to build and start Adlinkfly Telegram Bot, go to /opt/adlinkfly-telegram-bot then build and launch the docker containers:
cd /opt/adlinkfly-telegram-bot && docker compose build && docker compose up -d
- To STOP the bot you can use this command anytime:
cd /opt/adlinkfly-telegram-bot && docker compose down
-
Custom Server Deployment (Directly) (Not Recommended):
- IMPORTANT: This script only works in WSGI Compitable Servers (Most Linux Distros will work fine...!! Windows is not supported...!!)
- Unzip the downloaded release ZIP file (using any zip extractor software. eg: WinRAR, 7zip etc.)
- Open the extracted folder and Create a new ' .env ' file on that location and configure it as explained earlier (in Configuration / Environment Vriables section) (Use any text editor software or terminal text editors. eg: notepad, vim, nano)
- Upload all the extracted files along with the .env file in your server root
- Make sure you have already installed python3 and pip in your server (Most linux distros comes with python3 pre-installed. You just need to install pip) To install pip with apt package manager in Ubuntu run this below command in your server terminal:
sudo apt install python3-pip
- Now, to install all the dependencies run this command:
pip install -r requirements.txt
- Now, to start the bot run this command:
python3 adlinkfly_bot.py
- To, STOP the bot you can use CTRL + C or this command:
pkill -SIGINT -f 'gunicorn -b 0.0.0.0:8080 -w 4 webserver:adlinkflytgbot'
- Want to be the part of this project? Feel free to contribute..!! Pull Requests are always welcome....!! Follow this simple steps to start building . . .
- Using Linux Development Environment is Required | for Windows use WSL or just spin up a Docker Container
- Fork this repo in your github account
- Git clone the forked repo in your local machine
- Create your .env file as explained earlier
- Install all dependencies:
pip install -r requirements.txt
- Run the bot:
python3 adlinkfly_bot.py
- Do the changes, Send a Pull Request with proper Description (NOTE: Pull Requests Without Proper Description will be Rejected)
Adlinkfly Telegram Bot is an Open Sourced Project Licensed under GPL-3.0 Anyone can View, Modify or Use (Personal and Commercial) it's Sources without any extra permissions. If you want to Distribute it's Sources then please consider giving it an attribution of this repo. NOTE: This Script is Not Officially developed, supported or affiliated by MightyScripts. This is just a hobby project of mine!
An Open Sourced Project - Developed with ♥ by Subhamoy