whisper-transcriber-telegram-bot
whisper-transcriber-telegram-bot copied to clipboard
Python-based Whisper transcriber bot for Telegram
whisper-transcriber-telegram-bot
A local Whisper AI transcriber bot for Telegram, utilizing local GPU's or CPU for processing. No Whisper API access required -- just utilize whatever available hardware you have. The bot uses GPUtil to automatically select an available CUDA GPU, or reverts to CPU-only if none is found.
Runs on the latest Whisper v3 turbo model (released Sept 30, 2024) by default. Models can be selected both from config.ini and with the user command /model.
The program has been written in Python and it works on Python version 3.10+, tested up to Python 3.12.2.
Designed for transcribing audio from various media source, such as URLs supported by yt-dlp, or via Telegram's audio messages or over media file uploads on Telegram (.mp3, .wav, .ogg, .flac, etc.)
Sites supported by yt-dlp are listed here. Supported audio and video file uploads can be configured separately from config.ini. Compatible with all ffmpeg-supported media formats), with up to 20MB direct file transfer sizes as supported by Telegram in their bot API.
Can be safely installed and deployed with Docker by using the included Dockerfile.
Features
- 🚀 (New!) Now supporting OpenAI's
turbomodel of the Whisper v3 series- (Whisper-v3
turboreleased on September 30, 2024) - 8x transcription speed (vs. real-time)
- Nearly on par with the previous
v3-largemodel with only 6GB VRAM usage
- (Whisper-v3
- 🎥 Downloads and processes media URLs from any source supported by
yt-dlp- (can be configured to use
cookies.txtinconfig.inifor better availability)
- (can be configured to use
- 📲 Can receive Telegram audio messages as well as files, i.e.
.mp3and.wavfor transcription- Direct video file uploads in supported media formats is also supported
- (all other
ffmpegsupported formats also configurable viaconfig.ini)
- 🤖 Uses a local Whisper model from the
openai-whisperpackage for transcription- (no API required, use your own PC & available CUDA GPU!)
- 🖥️ Automatically uses
GPUtilto map out the best available CUDA-enabled local GPU- (auto-switching to CPU-only mode if no CUDA GPU is available)
- 📝 Transcribes audio using OpenAI's Whisper model (can be user-selected with
/model)- (see openai/whisper for more info on Whisper)
- 📄 Returns transcription in text, SRT, and VTT formats
- 🔄 Handles concurrent transcription requests efficiently with async & task queuing
- 🕒 Features an asynchronous automatic queue system to manage multiple transcription requests seamlessly
Installation (non-Docker version)
To set up the Whisper Transcriber Telegram Bot, follow these steps:
-
Clone the repository:
git clone https://github.com/FlyingFathead/whisper-transcriber-telegram-bot.git cd whisper-transcriber-telegram-bot -
Install the required Python packages:
pip install -r requirements.txt -
Install ffmpeg (required for media processing):
On Ubuntu or Debian tree Linux:
sudo apt update && sudo apt install ffmpegOn Arch Linux:
sudo pacman -S ffmpegOn macOS using Homebrew:
brew install ffmpegOn Windows using Chocolatey:
choco install ffmpegOn Windows using Scoop:
scoop install ffmpeg -
Set up your Telegram bot token either in
config/bot_token.txtor as an environment variableTELEGRAM_BOT_TOKEN. -
Run the bot:
python src/main.py
Dockerized Installation
Prerequisites
- Docker installed on your machine
- If you want to run your Whisper transcripts GPU accelerated with CUDA (recommended), you'll need a Nvidia GPU and the NVIDIA Container Toolkit installed on the host machine that is running the Docker container
To enable GPU processing inside Docker files, install the NVIDIA Container Toolkit in i.e. Ubuntu (on the host machine) with these steps:
-
Add NVIDIA GPG Key and Repository: Use the following commands to configure the repository securely with the GPG key:
curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | sudo gpg --dearmor -o /usr/share/keyrings/nvidia-container-toolkit-keyring.gpg && curl -s -L https://nvidia.github.io/libnvidia-container/stable/deb/nvidia-container-toolkit.list | \ sed 's#deb https://#deb [signed-by=/usr/share/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \ sudo tee /etc/apt/sources.list.d/nvidia-container-toolkit.list -
Update the Package List: Run the following to refresh your package list:
sudo apt-get update -
Install the NVIDIA Container Toolkit: Install the toolkit using:
sudo apt-get install -y nvidia-container-toolkit -
Configure Docker to Use NVIDIA Runtime: Configure the NVIDIA runtime for Docker:
sudo nvidia-ctk runtime configure --runtime=docker -
Restart Docker: Restart the Docker service to apply the changes:
sudo systemctl restart docker -
Test the Setup: You can verify if the setup is working correctly by running a base CUDA container:
sudo docker run --rm --runtime=nvidia --gpus all nvidia/cuda:11.6.2-base-ubuntu22.04 nvidia-smi
If everything is set up correctly, you should see your GPUs listed.
Dockerfile Install Option 1: Pull the prebuilt image from GHCR
Just grab the latest pre-built version with:
docker pull ghcr.io/flyingfathead/whisper-transcriber-telegram-bot:latest
Dockerfile Install Option 2: Build the Docker image yourself
If there's something wrong with GHCR's prebuilt image, you can also build the Docker image yourself.
-
Navigate to the root directory of the project where the
Dockerfileis located. -
Build the Docker image using the following command:
docker build -t whisper-transcriber-telegram-bot .This command builds a Docker image named
whisper-transcriber-telegram-botbased on the instructions in yourDockerfile.
Running the Bot Using Docker
To run the bot using Docker (may require sudo, depending on whether or not you're using a docker group or not):
docker run --gpus all --name whisper-transcriber-telegram-bot -d \
-e TELEGRAM_BOT_TOKEN='YourTelegramBotToken' \
-v whisper_cache:/root/.cache/whisper \
ghcr.io/flyingfathead/whisper-transcriber-telegram-bot:latest
Replace 'YourTelegramBotToken' with your actual Telegram bot token. This command also mounts the config directory and the Whisper model cache directory to preserve settings and downloaded models across container restarts.
Getting the Telegram Bot API Token
-
If you haven't got an active Telegram Bot API token yet, set up a new Telegram bot by interacting with Telegram's
@BotFather. Use Telegram's user lookup to search for the user, message it and run the necessary bot setup to get your API key. -
After setting up your bot and receiving your Telegram Bot API token from
@BotFather, either copy-paste the Telegram Bot API authentication token into a text file (config/bot_token.txt) or set the API token as an environment variable with the nameTELEGRAM_BOT_TOKEN. The program will look for both during startup, and you can choose whichever you want.
Usage
After launching your bot successfully, you can interact with it via Telegram (send a message to @your_bot_name_Bot, or whatever your bot name is):
- Send a video URL (for
yt-dlpto download), a voice message or an audio file (i.e..wavor.mp3format) to the bot. - The bot will acknowledge the request and begin processing, notifying the user of the process.
- Once processing is complete, the bot will send the transcription to you. By default, the transcription is sent as a message as well as
.txt,.srtand.vttfiles. Transcription delivery formats can be adjusted from theconfig.ini.
Commands
/infoto view current settings, uptime, GPU info and queue status/helpand/about- get help on bot use, list version number, available models and commands, etc./model- view the model in usedef process_url or change to another available model./language- set the model's transcription language (auto= autodetect); if you know the language spoken in the audio, setting the transcription language manually with this command may improve both transcription speed and accuracy.
Changes
- v0.1708 - Direct video file uploads are now available
- (to prevent abuse, they're disabled by default, see
config.ini)
- (to prevent abuse, they're disabled by default, see
- v0.1707 - New
config.inioption: add sites that require full video download- some media sites don't work well with
yt-dlp's audio-only download method - there are now two new options in
config.iniunder[YTDLPSettings]: download_original_video_for_domains_active = true(default)download_original_video_domains = site1.com, site2.com, site3.com- at the moment it's used for media platforms that have had reported issues during testing
- when active, a comma-separated list is used to check up on media sites that require their contents to be downloaded as the original video instead of audio-only
- (the tradeoff is obviously download size and hence speed; the audio-only method is usually the fastest and should be preferred for most popular sites, hence only add problematic sites to the video-only list)
- using worst available video quality (with audio in it) is usually recommended
- video quality selection is in
config.ini:use_worst_video_quality = true(default is true, set to false if it doesn't work for your setup) - again, the default setup in this version should work for most users
- some media sites don't work well with
- v0.1706 - Disable asking for token if running inside Docker
- by default, the app will ask for the token if it's not found, unless Dockerized
- can be better for headless use case scenarios where you need the error message rather than a prompt for the bot token
Dockerfilenow hasRUNNING_IN_DOCKERenvironment variable set for detection
- v0.1705 - Dockerized pre-builds; thanks to jonmjr for assistance!
- updated
src/utils/bot_token.pyto query for a bot token if it's not found from either env vars or from the file - can be useful when running the bot in Docker containers
- this option can be set on/off in
config.iniwithAskForTokenIfNotFound = True(default istrue)
- updated
- v0.1704 - Token logic /
bot_token.pyupdates; addedconfig.inipreferences for reading the bot tokenpreferenvforbottoken = Trueis now on by default to prefer the environment variable entry for the bot token.- set to
falseto preferconfig/bot_token.txtover the environment variable AllowBotTokenFallback = Trueto allow fallbacks (whether from the env var tobot_token.txtor the other way around)- set to
falseto strictly disallow fallback bot API token checking - improved error catching + exit logic when the token is not found
- v0.1703 - included and updated welcome message (
/start) - v0.17021 - updated model info in
/model - v0.1702 - prevent queue hang cases with new method
- v0.1701 - better exception catching when chunking long transcripts (due to Telegram's message limits) See issue
- v0.17 - (1. Oct 2024) Now supports OpenAI's brand new Whisper v3
turbomodelturbois enabled by default
- v0.1658 -
UpdateSettingssetting added toconfig.inito update your bot on startup (can be set toTrueorFalse), as i.e.yt-dlpis highly recommended to be kept up to date constantly. You can modify the command line string to whatever modules you want to check updates on during startup.- fixed a parsing bug in YouTube urls
- bot now announces successful downloads
- added a few emojis here and there for clarity (feel free to comment if you don't like them)
- v0.1657 - more verbose error messages from
yt-dlpif the download failed - v0.1656 - introduced
safe_split_messageto split transcription better and more reliably (edge cases etc) into chunks when longer transcripts are sent as messages - v0.1655 - added
diarization.pyandresemblyzer_safety_check.pyundersrc/utils/for Resemblyzer diarization support- these are WIP; for future in-bot diarization implementations (requires
pip install resemblyzerto be installed first in order to run) - the current resemblyzer pip version (
resemblyzer==0.1.4) can be patched withresemblyzer_safety_check.pyto ensure safe pickle/depickle as per up-to-date standards diarization.pycan be used as a standalone diarization module for testing (requiresresemblyzer)- (try with i.e.
python diarization.py inputfile.mp3 textfile.txt)
- (try with i.e.
- both will pave the way for future diarization options that will be implemented in the bot's functionalities in the future
- these are WIP; for future in-bot diarization implementations (requires
- v0.1654 -
yt-dlpcan now be configured to use cookies (for i.e. YouTube downloads) inconfig.ini - v0.1653 - even more exception and error catching, especially for YouTube URLs
- v0.1652 - maximum file size checks (20MB) as per to Telegram API
- v0.1651 - improved parsing for Youtube URLs, better error handling
- v0.165 - select allowed audio types if transcription from audio files is enabled
- (default formats:
mp3, wav, m4a, aac, flac, ogg, wma, aiff, can be expanded to anyffmpegsupported format)
- (default formats:
- v0.1603 - error message to the user whenever cookies are needed for
yt-dlp - v0.1602 - adjustable transcription completion message (in use y/n, its contents) in
config.ini - v0.1601 - process order fixes for transcripts (send as msg <> file)
- v0.16 - added configurable cooldowns & rate limits, see
config.ini:- under
[RateLimitSettings]:cooldown_seconds,max_requests_per_minute
- under
- v0.15 - added
config.inioptionssendasfilesandsendasmessages- can be set to
trueorfalsedepending on your preferences sendasmessages(when set totrue) sends the transcripts as Telegram messages in chatsendasfiles(when set totrue) sends the transcripts as.stt,.vttand.txt- small fixes to i.e. url handling (
allowallsiteschecks; YouTube)
- can be set to
- v0.14.6 - fixed occasional queue hangs with sent audio files (wav/mp3)
- v0.14.5 - fixed following the "keep/don't keep audio files" config rule
- v0.14.4 - added the
/infocommand for viewing current settings & queue status - v0.14.3 - Whisper model language selection via
/languagecommand - v0.14.2 - display duration & estimates
- v0.14.1 - small fixes to the file handler; more detailed exception catching
- v0.14 - now handles both Telegram's audio messages as well as audio files (.wav, .mp3)
- v0.13 - added
GPUtilGPU mapping to figure out the best available CUDA GPU instance to use- (by default, uses a CUDA-enabled GPU on the system with the most free VRAM available)
- v0.12 - async handling & user model change fixes, improved error handling
- v0.11.1 - bot logic + layout changes, model list with
/model(also inconfig.ini) - v0.11 - bugfixes & rate limits for
/modelcommand changes for users - v0.10 -
/help&/aboutcommands added for further assistanceconfig.ininow has a list of supported models that can be changed as needed
- v0.09 - users can now change the model Whisper model with
/modelcommand - v0.08 - auto-retry TG connection on start-up connection failure
- can be set in
config.iniwithRestartOnConnectionFailure
- can be set in
- v0.07.7 - log output from
whisperto logging - v0.07.6 - update interval for logging
yt-dlpdownloads now configurable fromconfig.ini - v0.07.5 - 10-second interval update for
yt-dlplogging - v0.07.4 - fixes for non-youtube urls
- v0.07.2 - job queues fine-tuned to be more informative
- v0.07.1 - job queues introduced
- v0.07 - transcript queuing, more precise transcript time estimates
- v0.06 - better handling of details for all video sources, transcription time estimates
- v0.05 - universal video description parsing (platform-agnostic)
- v0.04.1 - version number printouts and added utils
- v0.04 - expanded support for various media sources via
yt-dlp, supported sites listed here - v0.03 - better logging to console, Whisper model + keep audio y/n can now be set in
config.ini - v0.02 - add video information to the transcript text file
- (see:
config.ini=>IncludeHeaderInTranscription = True)
- (see:
- v0.01 - initial commit
Contributing
Contributions are welcome! If you have suggestions for improvements or bug fixes, please open an issue or submit a pull request.
License
Licensed under the MIT License. See the LICENSE file for more details.
Credits
- FlyingFathead - Project creator
- ChaosWhisperer - Contributions to the Whisper integration and documentation
- Thanks for additional code contributions: GRbit (Dockerization), jonmjr (more Dockerization)