2013-12-21 03:00:35 +03:00
## Telegram messenger CLI [![Build Status](https://travis-ci.org/vysheng/tg.png)](https://travis-ci.org/vysheng/tg)
2013-10-24 22:25:37 +04:00
Command-line interface for [Telegram ](http://telegram.org ). Uses readline interface.
### API, Protocol documentation
Documentation for Telegram API is available here: http://core.telegram.org/api
2013-10-25 10:02:29 +04:00
2013-10-24 22:25:37 +04:00
Documentation for MTproto protocol is available here: http://core.telegram.org/mtproto
2014-08-31 20:51:41 +01:00
### Upgrading to version 1.0
First of all, the binary is now in ./bin folder and is named telegram-cli. So be careful, not to use old binary.
2014-08-31 20:51:57 +01:00
2014-08-31 20:51:41 +01:00
Second, config folder is now ${HOME}/.telegram-cli
2014-08-31 20:51:57 +01:00
2014-08-31 20:51:41 +01:00
Third, database is not compatible with older versions, so you'll have to login again.
2014-09-03 20:02:50 +04:00
Fourth, in peer_name '#' are substitued to '@'. (Not applied to appending of '#%d' in case of two peers having same name).
2013-10-24 22:25:37 +04:00
### Installation
2013-11-28 17:49:20 -02:00
Clone GitHub Repository
2014-11-12 17:38:44 +03:00
git clone --recursive https://github.com/vysheng/tg.git & & cd tg
2014-03-04 17:17:09 +05:30
2015-05-23 17:38:15 -07:00
### Python Support
2015-05-23 17:37:29 -07:00
Python support is currently limited to Python 2.7 or Python 3.1+. Other versions may work but are not tested.
2014-02-27 01:09:56 +01:00
#### Linux and BSDs
2015-05-23 17:37:29 -07:00
Install libs: readline, openssl and (if you want to use config) libconfig, liblua, python and libjansson.
If you do not want to use them pass options --disable-libconfig, --disable-liblua, --disable-python and --disable-json respectively.
2013-10-24 22:25:37 +04:00
2014-09-03 17:28:37 +03:00
On Ubuntu/Debian use:
2014-03-04 17:17:09 +05:30
2015-05-23 17:37:29 -07:00
sudo apt-get install libreadline-dev libconfig-dev libssl-dev lua5.2 liblua5.2-dev libevent-dev libjansson-dev libpython-dev make
2014-02-27 01:09:56 +01:00
2013-12-24 00:22:44 +03:00
On gentoo:
2014-03-04 17:17:09 +05:30
2015-05-23 17:37:29 -07:00
sudo emerge -av sys-libs/readline dev-libs/libconfig dev-libs/openssl dev-lang/lua dev-libs/libevent dev-libs/jansson dev-lang/python
2014-02-02 12:11:29 +01:00
2014-03-04 17:17:09 +05:30
On Fedora:
2014-03-05 00:58:47 +03:00
2015-07-02 10:11:20 +02:00
sudo dnf install lua-devel openssl-devel libconfig-devel readline-devel libevent-devel libjansson-devel python-devel
2014-02-02 12:11:29 +01:00
2015-06-04 14:22:37 +04:30
On Archlinux:
yaourt -S telegram-git
2014-02-27 01:09:56 +01:00
On FreeBSD:
2014-03-05 00:58:47 +03:00
2015-05-23 17:37:29 -07:00
pkg install libconfig libexecinfo lua52 python
2014-02-27 01:09:56 +01:00
On OpenBSD:
2014-03-05 00:58:47 +03:00
2015-05-23 17:37:29 -07:00
pkg_add libconfig libexecinfo lua python
2014-01-15 15:04:59 +03:00
2015-06-02 17:26:58 +02:00
On openSUSE:
sudo zypper in lua-devel libconfig-devel readline-devel libevent-devel libjansson-devel python-devel libopenssl-devel
2014-03-04 17:17:09 +05:30
Then,
2013-11-12 21:15:48 +03:00
2014-03-05 14:50:49 +02:00
./configure
make
2013-11-12 21:15:48 +03:00
2014-09-10 18:38:46 +04:00
#### Other methods to install on linux
On Gentoo: use ebuild provided.
On Arch: https://aur.archlinux.org/packages/telegram-git/
2013-11-12 21:15:48 +03:00
#### Mac OS X
2014-09-09 13:39:01 +02:00
The client depends on [readline library ](http://cnswww.cns.cwru.edu/php/chet/readline/rltop.html ) and [libconfig ](http://www.hyperrealm.com/libconfig/ ), which are not included in OS X by default. You have to install these libraries manually.
If using [Homebrew ](http://brew.sh/ ):
2013-11-12 21:15:48 +03:00
2015-06-27 14:56:05 +07:00
brew install libconfig readline lua python libevent jansson
2014-10-30 00:07:31 +01:00
export CFLAGS="-I/usr/local/include -I/usr/local/Cellar/readline/6.3.8/include"
export LDFLAGS="-L/usr/local/lib -L/usr/local/Cellar/readline/6.3.8/lib"
2014-03-05 14:50:49 +02:00
./configure & & make
2014-03-04 17:17:09 +05:30
2013-11-12 21:15:48 +03:00
Thanks to [@jfontan ](https://github.com/vysheng/tg/issues/3#issuecomment-28293731 ) for this solution.
2013-12-19 02:26:29 +08:00
2014-09-09 13:39:01 +02:00
If using [MacPorts ](https://www.macports.org ):
sudo port install libconfig-hr
sudo port install readline
sudo port install lua51
2015-05-23 17:37:29 -07:00
sudo port install python34
2014-10-27 20:55:55 +01:00
sudo port install libevent
export CFLAGS="-I/usr/local/include -I/opt/local/include -I/opt/local/include/lua-5.1"
export LDFLAGS="-L/usr/local/lib -L/opt/local/lib -L/opt/local/lib/lua-5.1"
2014-09-09 13:39:01 +02:00
./configure & & make
2013-12-19 02:26:29 +08:00
Install these ports:
2013-12-19 02:37:46 +08:00
2013-12-19 02:26:29 +08:00
* devel/libconfig
* devel/libexecinfo
2014-02-18 22:59:18 +08:00
* lang/lua52
2013-12-19 02:26:29 +08:00
2013-12-19 02:37:46 +08:00
Then build:
2014-03-05 14:50:49 +02:00
env CC=clang CFLAGS=-I/usr/local/include LDFLAGS=-L/usr/local/lib LUA=/usr/local/bin/lua52 LUA_INCLUDE=-I/usr/local/include/lua52 LUA_LIB=-llua-5.2 ./configure
make
2014-03-04 17:17:09 +05:30
2013-11-12 21:15:48 +03:00
#### Other UNIX
If you manage to launch it on other UNIX, please let me know.
2013-10-25 10:02:29 +04:00
2014-09-09 17:11:37 +04:00
### Contacts
If you would like to ask a question, you can write to my telegram or to the github (or both). To contact me via telegram, you should use import_card method with argument 000653bf:0738ca5d:5521fbac:29246815:a27d0cda
2013-10-24 22:25:37 +04:00
### Usage
2014-09-03 14:33:45 +04:00
bin/telegram-cli -k < public-server-key >
2013-10-24 22:25:37 +04:00
2015-01-17 15:26:54 +01:00
By default, the public key is stored in tg-server.pub in the same folder or in /etc/telegram-cli/server.pub. If not, specify where to find it:
2013-10-24 22:25:37 +04:00
2014-09-03 14:33:45 +04:00
bin/telegram-cli -k tg-server.pub
2013-11-22 23:36:37 +04:00
Client support TAB completion and command history.
2014-01-30 11:09:16 +05:30
2014-01-30 16:01:15 +03:00
Peer refers to the name of the contact or dialog and can be accessed by TAB completion.
For user contacts peer name is Name < underscore > Lastname with all spaces changed to underscores.
For chats it is it's title with all spaces changed to underscores
2014-01-31 01:11:17 +03:00
For encrypted chats it is < Exс lamation mark > < underscore > Name < underscore > Lastname with all spaces changed to underscores.
2014-01-30 16:01:15 +03:00
2014-01-31 01:11:17 +03:00
If two or more peers have same name, < sharp > number is appended to the name. (for example A_B, A_B#1 , A_B#2 and so on)
2013-10-24 22:25:37 +04:00
2013-11-22 23:51:58 +04:00
### Supported commands
2013-11-22 23:49:59 +04:00
2013-11-22 23:51:58 +04:00
#### Messaging
2013-11-22 23:49:59 +04:00
2013-11-12 21:15:48 +03:00
* **msg** \<peer\> Text - sends message to this peer
2013-11-22 23:49:59 +04:00
* **fwd** \<user\> \<msg-seqno\> - forward message to user. You can see message numbers starting client with -N
2014-01-30 11:09:16 +05:30
* **chat_with_peer** \<peer\> starts one on one chat session with this peer. /exit or /quit to end this mode.
2013-11-22 23:49:59 +04:00
* **add_contact** \<phone-number\> \<first-name\> \<last-name\> - tries to add contact to contact-list by phone
* **rename_contact** \<user\> \<first-name\> \<last-name\> - tries to rename contact. If you have another device it will be a fight
* **mark_read** \<peer\> - mark read all received messages with peer
2014-09-11 16:05:25 +04:00
* **delete_msg** \<msg-seqno\> - deletes message (not completly, though)
* **restore_msg** \<msg-seqno\> - restores delete message. Impossible for secret chats. Only possible short time (one hour, I think) after deletion
2013-11-22 23:49:59 +04:00
2013-11-22 23:51:58 +04:00
#### Multimedia
2013-11-22 23:49:59 +04:00
2013-11-12 21:15:48 +03:00
* **send_photo** \<peer\> \<photo-file-name\> - sends photo to peer
* **send_video** \<peer\> \<video-file-name\> - sends video to peer
* **send_text** \<peer\> \<text-file-name> - sends text file as plain messages
2014-09-11 16:05:25 +04:00
* **load_photo**/load_video/load_video_thumb/load_audio/load_document/load_document_thumb \<msg-seqno\> - loads photo/video/audio/document to download dir
* **view_photo**/view_video/view_video_thumb/view_audio/view_document/view_document_thumb \<msg-seqno\> - loads photo/video to download dir and starts system default viewer
* **fwd_media** \<msg-seqno\> send media in your message. Use this to prevent sharing info about author of media (though, it is possible to determine user_id from media itself, it is not possible get access_hash of this user)
* **set_profile_photo** \<photo-file-name\> - sets userpic. Photo should be square, or server will cut biggest central square part
2013-11-22 23:49:59 +04:00
2013-11-22 23:51:58 +04:00
#### Group chat options
2013-11-22 23:49:59 +04:00
2013-11-12 21:15:48 +03:00
* **chat_info** \<chat\> - prints info about chat
2013-11-22 12:34:29 +04:00
* **chat_add_user** \<chat\> \<user\> - add user to chat
* **chat_del_user** \<chat\> \<user\> - remove user from chat
2013-11-12 21:15:48 +03:00
* **rename_chat** \<chat\> \<new-name\>
2014-11-13 12:58:53 +03:00
* **create_group_chat** \<chat topic\> \<user1\> \<user2\> \<user3\> ... - creates a groupchat with users, use chat_add_user to add more users
2014-09-11 16:05:25 +04:00
* **chat_set_photo** \<chat\> \<photo-file-name\> - sets group chat photo. Same limits as for profile photos.
2013-11-22 23:49:59 +04:00
2013-11-22 23:51:58 +04:00
#### Search
2013-11-22 23:49:59 +04:00
2013-11-12 21:15:48 +03:00
* **search** \<peer\> pattern - searches pattern in messages with peer
* **global_search** pattern - searches pattern in all messages
2013-11-22 23:49:59 +04:00
2013-11-22 23:51:58 +04:00
#### Secret chat
2013-11-22 23:49:59 +04:00
2013-11-12 21:15:48 +03:00
* **create_secret_chat** \<user\> - creates secret chat with this user
* **visualize_key** \<secret_chat\> - prints visualization of encryption key. You should compare it to your partner's one
2014-09-11 16:05:25 +04:00
* **set_ttl** \<secret_chat\> \<ttl\> - sets ttl to secret chat. Though client does ignore it, client on other end can make use of it
* **accept_secret_chat** \<secret_chat\> - manually accept secret chat (only useful when starting with -E key)
2013-11-22 23:49:59 +04:00
2013-11-22 23:51:58 +04:00
#### Stats and various info
2013-11-22 23:49:59 +04:00
* **user_info** \<user\> - prints info about user
* **history** \<peer\> [limit] - prints history (and marks it as read). Default limit = 40
* **dialog_list** - prints info about your dialogs
* **contact_list** - prints info about users in your contact list
* **suggested_contacts** - print info about contacts, you have max common friends
* **stats** - just for debugging
2013-11-12 21:15:48 +03:00
* **show_license** - prints contents of GPLv2
* **help** - prints this help
2015-06-07 23:06:46 +02:00
* **get_self** - get our user info
2014-09-11 16:05:25 +04:00
#### Card
* **export_card** - print your 'card' that anyone can later use to import your contact
* **import_card** \<card\> - gets user by card. You can write messages to him after that.
#### Other
* **quit** - quit
* **safe_quit** - wait for all queries to end then quit