/Save-Restricted-Content-Bot-V2

A stable telegram bot to get restricted messages with custom thumbnail support , made by TEAM SPY This bot can run in channels directly + YouTube video downloading support along with 30+ more sites

Primary LanguagePython

V3 branch | Summer Release V2

Telegram | See Recent Updates


ABOUT THIS BRANCH

This branch is purely based on Pyrogram V2 with more stability And this is based on forced login means user must have to login in bot to use the bot you can use v4 branch to avoid this.


⚠️ Must Do: Configure Sensitive Variables Securely

Do not edit sensitive variables (e.g., API_ID, API_HASH, BOT_TOKEN, etc.) directly in config.py or any file in the repository on GitHub. Doing so can expose your credentials publicly, leading to security risks.

How to Configure Variables Safely:

  1. For VPS or Local Machine:

    • Use a text editor like nano to edit the config.py file directly on your system:
      nano config.py
    • Alternatively, export your variables as environment variables:
      export API_ID=your_api_id
      export API_HASH=your_api_hash
      export BOT_TOKEN=your_bot_token
  2. For Cloud Deployment (e.g., Heroku, Railway):

    • Set the variables as Environment Variables in the platform's settings.
  3. Using .env File:

    • Create a .env file in the root of your project and add your variables:
      API_ID=your_api_id
      API_HASH=your_api_hash
      BOT_TOKEN=your_bot_token
      etc
      
    • Make sure to exclude .env from version control by adding it to .gitignore.

Why This is Important?

Your credentials can be stolen if pushed to a public repository. Always keep them secure by using environment variables or local configuration files.


Commands

  • start: Launch the application.
  • myplan: View your personalized plan.
  • add: Add a new item or entry.
  • rem: Remove an existing item.
  • gcast: Broadcast a message or notification.
  • stats: Display statistics and insights.
  • speedtest: Run a network speed test.
  • settings: Access and modify your settings.

Features:

  • Able to extarct the content the from private or public entities/channels/group
  • direct rename and forward to channel/group/users
  • Custome caption/thumbnail
  • auto default thumbnail removal from videos
  • Deleting/Replacing words from file name and caption
  • Easy to use and deploy
  • auto pin messages(if they are pinned)
  • login via phone number

Deploying Guide - TEAM SPY

How to get required vars

  • API_ID and API_HASH from telegram.org
  • BOT_TOKEN: @Botfather on telegram
  • OWNER_ID : Go to @missrose_bot on telegram and send /info to know your ID
  • CHANNEL_ID : This will be used as Force Subscribe channel
  • LOG_GROUP: Create a Group or Channel add you bot there and forward any message of that channel/group to @userinfobot to know the ID of you channel/group
  • MONGO_DB: It is recommended to use your mongoDB to avoid session hacks and all Note : You must make bot admin in both channels

Deploy on VPS

Easy Method:

  • Fork repo
  • Go to config.py as below
  • Fill variables inside the double quoted commas ""
  • Now run following commands one by one...
sudo apt update
sudo apt install ffmpeg git python3-pip
git clone your_repo_link
cd you_repo_name
pip3 install -r requirements.txt
python3 -m devgagan
  • if you want bot to be running in background then enter screen -S gagan before python3 -m devgagan
  • after python3 -m devgagan, click ctrl+A, ctrl+D
  • if you want to stop bot, then enter screen -r gagan and to kill screen enter screen -S gagan -X quit.

Deploy your bot on heroku

  • Star the repo, and fork it in desktop mode
  • Click on Deploy
  • Fill your values and click deploy ✅

Deploy on Render

  • Fork and star the repo
  • edit config.py same as guided for VPS deployment (you can edit on render also by filling enviroment variables)
  • Go to render.com and singup/signin
  • create new web service and select free plan
  • connect github and your repository
  • Click Deploy
  • Done ✅

Koyeb Deployment

  • Fork and star the repo
  • edit config.py same as guided for VPS deployment (you can edit on koyeb also by filling enviroment variables)
  • Go to koyeb.com and singup/signin
  • create new web service make sure you must choose build type Dokerfile because in Koyeb as a default it is checked to buildpacks so you have to change that.
  • connect github and your repository
  • Click Deploy
  • Done ✅

Terms of USE / Modification

Visit Terms and accept the guidelines.

Updates


Update: 21 NOV 2024

Enhanced Functionality for Public Channels:

  1. Removed the unnecessary login requirement for processing links from public channels.
  2. Users can now process both single and batch links from public channels, even without logging in or setting up a default session.
  3. Introduced batch size limit variables: FREEMIUM_LIMIT and PREMIUM_LIMIT. These variables allow you to manage and customize the batch size accessible to users based on their subscription type.

👉 Note:
If you set the FREEMIUM_LIMIT value to 0, users will not be able to extract links, even with a single link. The OWNER_ID(s) are exempt from these limitations.

#repo_updated


Update: 20 Nov 2024

🚀 Changelogs :

  • Batch Process: Prevents starting new batch if one is already running.
  • Single Link: Checks if a process is ongoing before accepting a new link.
  • UserBot Management: Safely stops userbot after all processes.
  • /cancel: Improved to stop active processes with better feedback.
  • Loop Management: Prevents overlapping processes for the same user.
  • Bug Fixes: Fixed issues with userbot not stopping correctly.

Update: 16 Nov 2024

Changelog:

  1. Fixed .MOV Issue:

    • Resolved the problem with .MOV files. All video files sent as documents will now be uploaded as streamable videos.
    • The repository can now function as a file-to-video converter as well.
  2. Filename Replacement:

    • Fixed issues with filename replacements.
    • Made minor adjustments to captions to preserve the original formatting.

Branch: v3

Status: Complete ✅

Update: Nov 15 2024

  • fixed reset button to clear everything
  • topic group extraction fixed note : if you are extracting from public group then you must use the group id instead of username use apps like turbotel or anyother to do get id and replace for ex suppose main post link is https://t.me/username/12 or https://t.me/username/6/12 (topic enabled group) then you have to change like below https://t.me/c/1346789/12 or https://t.me/c/1346789/6/12 (topic enabled group) where 1346789 is group id you get from telegram client apps like turbotel, plus messenger etc

Update: 16 Aug 2024

  • Added /logout command to delete the session files from mongodb and local memory
  • Fixed premium membership auto expiration (after subscription ends).

Update: 7 JULY 2024

  • Added /login method via phone number
  • Added auto pinning of messages
  • fixed float division by zero
  • Session saving permanently
  • Fixed old bugs
  • Added /add and /remove along with parameters of user_id and time for the period of premium subscription.
  • All old features along with button handler

Important Note

Note: Changing the terms and commands doesn't magically make you a developer. Real development involves understanding the code, writing new functionalities, and debugging issues, not just renaming things. If only it were that easy!

Contributers

My group members contact... Join @save_restricted_content_bots to know them.

Thanks!