aftabkh505 / Torrent-Mirror-Bot

🔥 This is a telegram bot writen in python for mirroring files on the internet to our beloved Google Drive.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Torrent Mirror Bot

donate

issues license author language author


This is a telegram bot writen in python for mirroring files on the internet to our beloved Google Drive.

Donate

Features supported:

  • Mirroring direct download links to google drive
  • Download progress
  • Upload progress
  • Download/upload speeds and ETAs
  • Docker support
  • Uploading To Team Drives.
  • Index Link support
  • Service account support
  • Mirror all youtube-dl supported links
  • Mirror telegram files

How to deploy in Heroku?

Hit the deploy to heroku button and follow the further instructions in the screen:

NB: This may lead to the suspension of your heroku account so deploy at your own risk.

Deploy

Getting Google OAuth API credential or SECRET_JSON

  • Visit the Google Cloud Console
  • Go to the OAuth Consent tab, fill it, and save.
  • Go to the Credentials tab and click Create Credentials -> OAuth Client ID
  • Choose Other and Create.
  • Visit Google API page
  • Search for Drive and enable it if it is disabled
  • Finally, run the script to generate SECRET_JSON for Google Drive
pip install oauth2client
python3 generate_drive_token.py

Termux:

pkg install python wget

wget https://raw.githubusercontent.com/imsawankumar/Torrent-Mirror-Bot/master/generate_drive_token.py

pip install oauth2client

python3 generate_drive_token.py


Fill up rest of the fields in app.json. Meaning of each fields are discussed below:

  • BOT_TOKEN : The telegram bot token that you get from @BotFather
  • GDRIVE_FOLDER_ID : This is the folder ID of the Google Drive Folder to which you want to upload all the mirrors.
  • DOWNLOAD_DIR : The path to the local folder where the downloads should be downloaded to
  • DOWNLOAD_STATUS_UPDATE_INTERVAL : A short interval of time in seconds after which the Mirror progress message is updated. (I recommend to keep it 5 seconds at least)
  • OWNER_ID : The Telegram user ID (not username) of the owner of the bot
  • AUTO_DELETE_MESSAGE_DURATION : Interval of time (in seconds), after which the bot deletes it's message (and command message) which is expected to be viewed instantly. Note: Set to -1 to never automatically delete messages
  • IS_TEAM_DRIVE : (Optional field) Set to "True" if GDRIVE_FOLDER_ID is from a Team Drive else False or Leave it empty.
  • USE_SERVICE_ACCOUNTS: (Optional field) (Leave empty if unsure) Whether to use service accounts or not. For this to work see "Using service accounts" section below.
  • INDEX_URL : (Optional field) Refer to https://github.com/maple3142/GDIndex/ The URL should not have any trailing '/'
  • API_ID : This is to authenticate to your telegram account for downloading Telegram files. You can get this from https://my.telegram.org DO NOT put this in quotes.
  • API_HASH : This is to authenticate to your telegram account for downloading Telegram files. You can get this from https://my.telegram.org
  • SESSION_STRING : Session string generated by running:
pip install pyrogram tgcrypto
python3 generate_string_session.py

Termux:

pkg install python wget (if not installed earlier)

wget https://raw.githubusercontent.com/imsawankumar/Torrent-Mirror-Bot/master/generate_string_session.py

pip install pyrogram tgcrypto

python3 generate_string_session.py


Note: You can limit maximum concurrent downloads by changing the value of MAX_CONCURRENT_DOWNLOADS in aria.sh. By default, it's set to 2

Youtube-dl authentication using .netrc file

For using your premium accounts in youtube-dl, edit the netrc file (in the root directory of this repository) according to following format:

machine host login username password my_youtube_password

where host is the name of extractor (eg. youtube, twitch). Multiple accounts of different hosts can be added each separated by a new line

About

🔥 This is a telegram bot writen in python for mirroring files on the internet to our beloved Google Drive.

License:GNU General Public License v3.0


Languages

Language:Python 98.9%Language:Shell 0.4%Language:Dockerfile 0.4%Language:Batchfile 0.2%