tgt. Please consider to open an issue if you find any bug or if you have any suggestion.
A simple TUI for Telegram
tgt is a terminal user interface for Telegram, written in Rust.
From crates.io
cargo install tgtFrom source downloading the tdlib
cargo build --release --features download-tdlibAfter the installation, you can run tgt with the following command:
tgt --helpBuild features can be combined (e.g. cargo build --release --features download-tdlib,chafa-dyn).
| Feature | Description |
|---|---|
default |
Enables download-tdlib and voice-message. |
download-tdlib |
Download and use TDLib automatically (recommended for most users). |
local-tdlib |
Use TDLib from path in LOCAL_TDLIB_PATH. |
pkg-config |
Find TDLib via pkg-config. |
voice-message |
Play Telegram voice notes (OGG Opus) and other audio (e.g. MP3). Requires CMake to build the Opus dependency. Enabled by default; use --no-default-features and then add back only the features you need (e.g. --features download-tdlib) to disable voice. |
chafa-dyn |
Enable chafa-based image rendering in the photo viewer (dynamic linking). Requires the chafa library installed on the system. Not supported on Windows ARM. |
chafa-static |
Same as chafa-dyn but links chafa statically. Not supported on Windows ARM. |
Voice messages
If you build with the default features (or with voice-message enabled), you must have CMake installed so the Opus library can be built. Other audio formats (e.g. MP3) use rodio only; only Telegram voice notes (Opus) need this. If you build with --no-default-features and do not enable voice-message, voice playback is disabled and the app will show a message when you try to play a voice note.
Installation methods for CMake (when using voice-message)
- macOS β Homebrew:
brew install cmake - Linux β use your package manager, e.g.
sudo apt install cmake(Debian/Ubuntu),sudo dnf install cmake(Fedora),sudo pacman -S cmake(Arch) - Windows β CMake installer or e.g.
winget install Kitware.CMake
Chafa (image rendering)
The chafa-dyn and chafa-static features use the chafa library to display images in the terminal. You must have chafa installed to use these features.
Installation methods for chafa
- Linux (Debian/Ubuntu/Kali, Fedora, Arch, openSUSE, etc.) β use your package manager:
sudo apt install chafa(Debian/Ubuntu/Kali)sudo dnf install chafa(Fedora)sudo pacman -S chafa(Arch Linux)sudo zypper in chafa(openSUSE)sudo emerge media-gfx/chafa(Gentoo)
- macOS β Homebrew or MacPorts:
brew install chafasudo port install chafa
- Windows β Scoop or Windows Package Manager (winget):
scoop install chafawinget install hpjansson.Chafa
Thanks to x-leehe for creating the AUR package. You can install tgt from the AUR:
yay -S tgt-client-gitFrom flake.nix
Config directories are created automatically on first run, or you can generate initial config with tgt init-config (see CONFIG.md). Then you have two installation options:
- Run directly with
nix run:
nix run github:FedericoBruzzone/tgt- Add
tgtto your system packages:
Add the following to your flake.nix:
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"
tgt.url = "github:FedericoBruzzone/tgt";
tgt.inputs.nixpkgs.follows = "nixpkgs";
};
outputs = { nixpkgs, tgt, ... }: { /* ... */ }
}Then add it to your environment.systemPackages:
{pkgs, tgt, ...}: {
environment = {
systemPackages = [
(tgt.packages.${pkgs.system}.default)
];
};
}To use a specific version of the program, override the src attribute:
{pkgs, tgt, ...}: {
environment = {
systemPackages = [
(tgt.packages.${pkgs.system}.default.overrideAttrs (old: {
src = pkgs.fetchFromGitHub {
owner = old.src.owner;
repo = old.src.repo;
rev = "00000000000000000000000000000000000000";
sha256 = "sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=";
};
cargoHash = "sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=";
}))
];
};
}-
The Docker image is built using
rust:1.91-trixieas the base. -
Run Docker image in interactive mode to open a bash shell. Specify a container name to reuse when required.
docker run -it --name <container_name> ghcr.io/FedericoBruzzone/tgt:<version>- Run
tgtcommand from bash shell.
tgt- for reusing the same container for next boot cycles, start the container
docker container start <container_name>- run
tgtby opening interactive shell from the container
docker exec -it <container_name> bashtgt is fully customizable. Config uses XDG-style paths (e.g. ~/.config/tgt on Linux) with backwards compatibility for the legacy ~/.tgt folder. The app creates config directories at startup if missing, and bundles default configs so it works out of the box after cargo install. Configs are versioned and the program adds missing keybindings on upgrade. Use tgt init-config to generate initial config files and tgt clear --config (or --data / --logs / --all) to remove them for a fresh start.
For config locations, versioning, CLI commands, keybindings, and per-file details, see CONFIG.md.
Contributions to this project are welcome! If you have any suggestions, improvements, or bug fixes, feel free to submit a pull request. For more information, do not hesitate to contact us (see the Contact section).
Build instructions
There are three ways to build tgt:
- Using the
download-tdlibfeature of tdlib-rs you do not need to set any environment variable. Then you can compiletgtusingcargo build --features download-tdlib. - By default,
tgtassumes that you have the tdlib built and theLOCAL_TDLIB_PATHenvironment variable set to the path of thetdlibdirectory. You can set the environment variable with the following command:export LOCAL_TDLIB_PATH="/path/to/tdlib". Then you can compiletgtusingcargo buildorcargo build --feature default. - You can use
pkg-configto find the path of the library. In this case see the CONTRIBUTING.md file for more information. Then you can compiletgtusingcargo build --features pkg-config.
The CONTRIBUTING.md file contains information for building tgt and the steps to configure the tdlib in your local environment, starting from the compilation to the configuration of the environment variables.
You can find the road map of the project here (in the pinned issues).
You can use make or cargo, as build tools.
If you want to use cargo, please make sure to read the the Makefile to understand the flags used for each command.
Here are the available commands:
make COMMAND
COMMAND:
all # Run fmt, clippy and test
build # Build the project
run # Run the project
test # Run the tests
clippy # Run clippy
fmt # Run rustfmt
clean # Clean the project
This repository is licensed under either of
-
Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
-
MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Please review the license file provided in the repository for more information regarding the terms and conditions of the license.
If you have any questions, suggestions, or feedback, do not hesitate to contact me.
Maintainers:

