Merge github.com:vysheng/tg
This commit is contained in:
commit
9d57c85f20
@ -20,8 +20,8 @@ DIR_LIST=${DEP} ${AUTO} ${EXE} ${OBJ} ${LIB} ${DEP}/auto ${OBJ}/auto
|
|||||||
EXE_LIST=${EXE}/generate ${EXE}/tlc ${EXE}/telegram-cli
|
EXE_LIST=${EXE}/generate ${EXE}/tlc ${EXE}/telegram-cli
|
||||||
LIB_LIST=${LIB}/libtgl.a
|
LIB_LIST=${LIB}/libtgl.a
|
||||||
|
|
||||||
TG_OBJECTS=${OBJ}/main.o ${OBJ}/loop.o ${OBJ}/interface.o ${OBJ}/lua-tg.o
|
TG_OBJECTS=${OBJ}/main.o ${OBJ}/loop.o ${OBJ}/interface.o ${OBJ}/net.o ${OBJ}/lua-tg.o ${OBJ}/tgl-timers.o
|
||||||
TGL_OBJECTS=${OBJ}/net.o ${OBJ}/mtproto-common.o ${OBJ}/mtproto-client.o ${OBJ}/queries.o ${OBJ}/structures.o ${OBJ}/binlog.o ${OBJ}/auto/auto.o ${OBJ}/tgl.o ${OBJ}/updates.o ${OBJ}/tgl-timers.o
|
TGL_OBJECTS=${OBJ}/mtproto-common.o ${OBJ}/mtproto-client.o ${OBJ}/queries.o ${OBJ}/structures.o ${OBJ}/binlog.o ${OBJ}/auto/auto.o ${OBJ}/tgl.o ${OBJ}/updates.o
|
||||||
TLC_OBJECTS=${OBJ}/tlc.o ${OBJ}/tl-parser.o ${OBJ}/crc32.o
|
TLC_OBJECTS=${OBJ}/tlc.o ${OBJ}/tl-parser.o ${OBJ}/crc32.o
|
||||||
TLD_OBJECTS=${OBJ}/dump-tl-file.o
|
TLD_OBJECTS=${OBJ}/dump-tl-file.o
|
||||||
GENERATE_OBJECTS=${OBJ}/generate.o
|
GENERATE_OBJECTS=${OBJ}/generate.o
|
||||||
|
8
binlog.c
8
binlog.c
@ -1422,7 +1422,7 @@ static void create_new_binlog (struct tgl_state *TLS) {
|
|||||||
out_int (2);
|
out_int (2);
|
||||||
}
|
}
|
||||||
|
|
||||||
int fd = open (get_binlog_file_name (), O_WRONLY | O_EXCL | O_CREAT, 0600);
|
int fd = open (TLS->binlog_name, O_WRONLY | O_EXCL | O_CREAT, 0600);
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
perror ("Write new binlog");
|
perror ("Write new binlog");
|
||||||
exit (2);
|
exit (2);
|
||||||
@ -1434,11 +1434,11 @@ static void create_new_binlog (struct tgl_state *TLS) {
|
|||||||
|
|
||||||
void tgl_replay_log (struct tgl_state *TLS) {
|
void tgl_replay_log (struct tgl_state *TLS) {
|
||||||
if (!TLS->binlog_enabled) { return; }
|
if (!TLS->binlog_enabled) { return; }
|
||||||
if (access (get_binlog_file_name (), F_OK) < 0) {
|
if (access (TLS->binlog_name, F_OK) < 0) {
|
||||||
printf ("No binlog found. Creating new one\n");
|
printf ("No binlog found. Creating new one\n");
|
||||||
create_new_binlog (TLS);
|
create_new_binlog (TLS);
|
||||||
}
|
}
|
||||||
int fd = open (get_binlog_file_name (), O_RDONLY);
|
int fd = open (TLS->binlog_name, O_RDONLY);
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
perror ("binlog open");
|
perror ("binlog open");
|
||||||
exit (2);
|
exit (2);
|
||||||
@ -1477,7 +1477,7 @@ void tgl_replay_log (struct tgl_state *TLS) {
|
|||||||
static int b_packet_buffer[PACKET_BUFFER_SIZE];
|
static int b_packet_buffer[PACKET_BUFFER_SIZE];
|
||||||
|
|
||||||
void tgl_reopen_binlog_for_writing (struct tgl_state *TLS) {
|
void tgl_reopen_binlog_for_writing (struct tgl_state *TLS) {
|
||||||
TLS->binlog_fd = open (get_binlog_file_name (), O_WRONLY);
|
TLS->binlog_fd = open (TLS->binlog_name, O_WRONLY);
|
||||||
if (TLS->binlog_fd < 0) {
|
if (TLS->binlog_fd < 0) {
|
||||||
perror ("binlog open");
|
perror ("binlog open");
|
||||||
exit (2);
|
exit (2);
|
||||||
|
@ -24,6 +24,7 @@ decryptedMessageActionScreenshotMessages#8ac1f475 random_ids:Vector<long> = Decr
|
|||||||
decryptedMessageActionFlushHistory#6719e45c = DecryptedMessageAction;
|
decryptedMessageActionFlushHistory#6719e45c = DecryptedMessageAction;
|
||||||
decryptedMessageActionNotifyLayer#f3048883 layer:int = DecryptedMessageAction;
|
decryptedMessageActionNotifyLayer#f3048883 layer:int = DecryptedMessageAction;
|
||||||
|
|
||||||
|
decryptedMessageActionResend#511110b0 start_seq_no:int end_seq_no:int = DecryptedMessageAction;
|
||||||
|
|
||||||
decryptedMessageActionTyping#ccb27641 action:SendMessageAction = DecryptedMessageAction;
|
decryptedMessageActionTyping#ccb27641 action:SendMessageAction = DecryptedMessageAction;
|
||||||
|
|
||||||
|
115
interface.c
115
interface.c
@ -1050,7 +1050,6 @@ extern struct event *term_ev;
|
|||||||
|
|
||||||
void do_clear (int arg_num, struct arg args[], struct in_ev *ev) {
|
void do_clear (int arg_num, struct arg args[], struct in_ev *ev) {
|
||||||
logprintf ("Do_clear\n");
|
logprintf ("Do_clear\n");
|
||||||
tgl_free_all (TLS);
|
|
||||||
free (default_username);
|
free (default_username);
|
||||||
free (config_filename);
|
free (config_filename);
|
||||||
free (prefix);
|
free (prefix);
|
||||||
@ -1064,6 +1063,7 @@ void do_clear (int arg_num, struct arg args[], struct in_ev *ev) {
|
|||||||
clear_history ();
|
clear_history ();
|
||||||
event_free (term_ev);
|
event_free (term_ev);
|
||||||
event_base_free (TLS->ev_base);
|
event_base_free (TLS->ev_base);
|
||||||
|
tgl_free_all (TLS);
|
||||||
do_halt (0);
|
do_halt (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1075,66 +1075,66 @@ void do_send_location (int arg_num, struct arg args[], struct in_ev *ev) {
|
|||||||
|
|
||||||
|
|
||||||
struct command commands[] = {
|
struct command commands[] = {
|
||||||
{"help", {ca_none}, do_help, "help\tPrints this help"},
|
{"accept_secret_chat", {ca_secret_chat, ca_none}, do_accept_secret_chat, "accept_secret_chat <secret chat>\tAccepts secret chat. Only useful with -E option"},
|
||||||
{"contact_list", {ca_none}, do_contact_list, "contact_list\tPrints contact list"},
|
|
||||||
{"stats", {ca_none}, do_stats, "stats\tFor debug purpose"},
|
|
||||||
{"history", {ca_peer, ca_number | ca_optional, ca_number | ca_optional, ca_none}, do_history, "history <peer> [limit] [offset]\tPrints messages with this peer (most recent message lower). Also marks messages as read"},
|
|
||||||
{"dialog_list", {ca_none}, do_dialog_list, "dialog_list\tList of last conversations"},
|
|
||||||
{"send_photo", {ca_peer, ca_file_name_end, ca_none}, do_send_photo, "send_photo <peer> <file>\tSends photo to peer"},
|
|
||||||
{"send_video", {ca_peer, ca_file_name_end, ca_none}, do_send_video, "send_video <peer> <file>\tSends video to peer"},
|
|
||||||
{"send_audio", {ca_peer, ca_file_name_end, ca_none}, do_send_audio, "send_audio <peer> <file>\tSends audio to peer"},
|
|
||||||
{"send_document", {ca_peer, ca_file_name_end, ca_none}, do_send_document, "send_document <peer> <file>\tSends document to peer"},
|
|
||||||
{"send_text", {ca_peer, ca_file_name_end, ca_none}, do_send_text, "send_text <peer> <file>\tSends contents of text file as plain text message"},
|
|
||||||
{"chat_info", {ca_chat, ca_none}, do_chat_info, "chat_info <chat>\tPrints info about chat (id, members, admin, etc.)"},
|
|
||||||
{"user_info", {ca_user, ca_none}, do_user_info, "user_info <user>\tPrints info about user (id, last online, phone)"},
|
|
||||||
{"fwd", {ca_peer, ca_number, ca_none}, do_fwd, "fwd <peer> <msg-id>\tForwards message to peer. Forward to secret chats is forbidden"},
|
|
||||||
{"fwd_media", {ca_peer, ca_number, ca_none}, do_fwd_media, "fwd <peer> <msg-id>\tForwards message media to peer. Forward to secret chats is forbidden. Result slightly differs from fwd"},
|
|
||||||
{"msg", {ca_peer, ca_string_end, ca_none}, do_msg, "msg <peer> <text>\tSends text message to peer"},
|
|
||||||
{"rename_chat", {ca_chat, ca_string_end, ca_none}, do_rename_chat, "rename_chat <chat> <new name>\tRenames chat"},
|
|
||||||
{"load_photo", {ca_number, ca_none}, do_load_photo, "load_photo <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
|
||||||
{"load_video", {ca_number, ca_none}, do_load_video, "load_video <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
|
||||||
{"load_audio", {ca_number, ca_none}, do_load_audio, "load_audio <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
|
||||||
{"load_document", {ca_number, ca_none}, do_load_document, "load_document <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
|
||||||
{"load_video_thumb", {ca_number, ca_none}, do_load_video_thumb, "load_video_thumb <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
|
||||||
{"load_document_thumb", {ca_number, ca_none}, do_load_document_thumb, "load_document_thumb <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
|
||||||
{"view_photo", {ca_number, ca_none}, do_open_photo, "view_photo <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
|
||||||
{"view_video", {ca_number, ca_none}, do_open_video, "view_video <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
|
||||||
{"view_audio", {ca_number, ca_none}, do_open_audio, "view_audio <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
|
||||||
{"view_document", {ca_number, ca_none}, do_open_document, "view_document <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
|
||||||
{"view_video_thumb", {ca_number, ca_none}, do_open_video_thumb, "view_video_thumb <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
|
||||||
{"view_document_thumb", {ca_number, ca_none}, do_open_document_thumb, "view_document_thumb <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
|
||||||
{"add_contact", {ca_string, ca_string, ca_string, ca_none}, do_add_contact, "add_contact <phone> <first name> <last name>\tTries to add user to contact list"},
|
{"add_contact", {ca_string, ca_string, ca_string, ca_none}, do_add_contact, "add_contact <phone> <first name> <last name>\tTries to add user to contact list"},
|
||||||
{"del_contact", {ca_user, ca_none}, do_del_contact, "del_contact <user>\tDeletes contact from contact list"},
|
|
||||||
{"rename_contact", {ca_user, ca_string, ca_string, ca_none}, do_rename_contact, "rename_contact <user> <first name> <last name>\tRenames contact"},
|
|
||||||
{"show_license", {ca_none}, do_show_license, "show_license\tPrints contents of GPL license"},
|
|
||||||
{"search", {ca_peer | ca_optional, ca_number | ca_optional, ca_number | ca_optional, ca_number | ca_optional, ca_number | ca_optional, ca_string_end}, do_search, "search [peer] [limit] [from] [to] [offset] pattern\tSearch for pattern in messages from date from to date to (unixtime) in messages with peer (if peer not present, in all messages)"},
|
|
||||||
{"mark_read", {ca_peer, ca_none}, do_mark_read, "mark_read <peer>\tMarks messages with peer as read"},
|
|
||||||
{"contact_search", {ca_string, ca_number | ca_optional, ca_none}, do_contact_search, "contact_search username [limit]\tSearches contacts by username"},
|
|
||||||
{"visualize_key", {ca_secret_chat, ca_none}, do_visualize_key, "visualize_key <secret chat>\tPrints visualization of encryption key (first 16 bytes sha1 of it in fact}"},
|
|
||||||
{"create_secret_chat", {ca_user, ca_none}, do_create_secret_chat, "create_secret_chat <user>\tStarts creation of secret chat"},
|
|
||||||
{"chat_add_user", {ca_chat, ca_user, ca_number | ca_optional, ca_none}, do_chat_add_user, "chat_add_user <chat> <user> [msgs-to-forward]\tAdds user to chat. Sends him last msgs-to-forward message from this chat. Default 100"},
|
{"chat_add_user", {ca_chat, ca_user, ca_number | ca_optional, ca_none}, do_chat_add_user, "chat_add_user <chat> <user> [msgs-to-forward]\tAdds user to chat. Sends him last msgs-to-forward message from this chat. Default 100"},
|
||||||
{"chat_del_user", {ca_chat, ca_user, ca_none}, do_chat_del_user, "chat_del_user <chat> <user>\tDeletes user from chat"},
|
{"chat_del_user", {ca_chat, ca_user, ca_none}, do_chat_del_user, "chat_del_user <chat> <user>\tDeletes user from chat"},
|
||||||
|
{"chat_info", {ca_chat, ca_none}, do_chat_info, "chat_info <chat>\tPrints info about chat (id, members, admin, etc.)"},
|
||||||
|
{"chat_set_photo", {ca_chat, ca_file_name_end, ca_none}, do_chat_set_photo, "chat_set_photo <chat> <filename>\tSets chat photo. Photo will be cropped to square"},
|
||||||
|
{"chat_with_peer", {ca_peer, ca_none}, do_chat_with_peer, "chat_with_peer <peer>\tInterface option. All input will be treated as messages to this peer. Type /quit to end this mode"},
|
||||||
|
{"clear", {ca_none}, do_clear, "clear\tClears all data and exits. For debug."},
|
||||||
|
{"contact_list", {ca_none}, do_contact_list, "contact_list\tPrints contact list"},
|
||||||
|
{"contact_search", {ca_string, ca_number | ca_optional, ca_none}, do_contact_search, "contact_search username [limit]\tSearches contacts by username"},
|
||||||
|
{"create_group_chat", {ca_string, ca_user, ca_period, ca_none}, do_create_group_chat, "create_group_chat <name> <user>+\tCreates group chat with users"},
|
||||||
|
{"create_secret_chat", {ca_user, ca_none}, do_create_secret_chat, "create_secret_chat <user>\tStarts creation of secret chat"},
|
||||||
|
{"del_contact", {ca_user, ca_none}, do_del_contact, "del_contact <user>\tDeletes contact from contact list"},
|
||||||
|
{"delete_msg", {ca_number, ca_none}, do_delete_msg, "delete_msg <msg-id>\tDeletes message"},
|
||||||
|
{"dialog_list", {ca_none}, do_dialog_list, "dialog_list\tList of last conversations"},
|
||||||
|
{"export_card", {ca_none}, do_export_card, "export_card\tPrints card that can be imported by another user with import_card method"},
|
||||||
|
{"fwd", {ca_peer, ca_number, ca_none}, do_fwd, "fwd <peer> <msg-id>\tForwards message to peer. Forward to secret chats is forbidden"},
|
||||||
|
{"fwd_media", {ca_peer, ca_number, ca_none}, do_fwd_media, "fwd <peer> <msg-id>\tForwards message media to peer. Forward to secret chats is forbidden. Result slightly differs from fwd"},
|
||||||
|
{"help", {ca_none}, do_help, "help\tPrints this help"},
|
||||||
|
{"history", {ca_peer, ca_number | ca_optional, ca_number | ca_optional, ca_none}, do_history, "history <peer> [limit] [offset]\tPrints messages with this peer (most recent message lower). Also marks messages as read"},
|
||||||
|
{"import_card", {ca_string, ca_none}, do_import_card, "import_card <card>\tGets user by card and prints it name. You can then send messages to him as usual"},
|
||||||
|
{"load_audio", {ca_number, ca_none}, do_load_audio, "load_audio <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
||||||
|
{"load_document", {ca_number, ca_none}, do_load_document, "load_document <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
||||||
|
{"load_document_thumb", {ca_number, ca_none}, do_load_document_thumb, "load_document_thumb <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
||||||
|
{"load_photo", {ca_number, ca_none}, do_load_photo, "load_photo <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
||||||
|
{"load_video", {ca_number, ca_none}, do_load_video, "load_video <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
||||||
|
{"load_video_thumb", {ca_number, ca_none}, do_load_video_thumb, "load_video_thumb <msg-id>\tDownloads file to downloads dirs. Prints file name after download end"},
|
||||||
|
{"main_session", {ca_none}, do_main_session, "main_session\tSends updates to this connection (or terminal). Useful only with listening socket"},
|
||||||
|
{"mark_read", {ca_peer, ca_none}, do_mark_read, "mark_read <peer>\tMarks messages with peer as read"},
|
||||||
|
{"msg", {ca_peer, ca_string_end, ca_none}, do_msg, "msg <peer> <text>\tSends text message to peer"},
|
||||||
|
{"quit", {ca_none}, do_quit, "quit\tQuits immediately"},
|
||||||
|
{"rename_chat", {ca_chat, ca_string_end, ca_none}, do_rename_chat, "rename_chat <chat> <new name>\tRenames chat"},
|
||||||
|
{"rename_contact", {ca_user, ca_string, ca_string, ca_none}, do_rename_contact, "rename_contact <user> <first name> <last name>\tRenames contact"},
|
||||||
|
{"restore_msg", {ca_number, ca_none}, do_restore_msg, "restore_msg <msg-id>\tRestores message. Only available shortly (one hour?) after deletion"},
|
||||||
|
{"safe_quit", {ca_none}, do_safe_quit, "safe_quit\tWaits for all queries to end, then quits"},
|
||||||
|
{"search", {ca_peer | ca_optional, ca_number | ca_optional, ca_number | ca_optional, ca_number | ca_optional, ca_number | ca_optional, ca_string_end}, do_search, "search [peer] [limit] [from] [to] [offset] pattern\tSearch for pattern in messages from date from to date to (unixtime) in messages with peer (if peer not present, in all messages)"},
|
||||||
|
{"send_audio", {ca_peer, ca_file_name_end, ca_none}, do_send_audio, "send_audio <peer> <file>\tSends audio to peer"},
|
||||||
|
{"send_contact", {ca_peer, ca_string, ca_string, ca_string, ca_none}, do_send_contact, "send_contact <peer> <phone> <first-name> <last-name>\tSends contact (not necessary telegram user)"},
|
||||||
|
{"send_document", {ca_peer, ca_file_name_end, ca_none}, do_send_document, "send_document <peer> <file>\tSends document to peer"},
|
||||||
|
{"send_location", {ca_peer, ca_double, ca_double, ca_none}, do_send_location, "send_location <peer> <latitude> <longitude>\tSends geo location"},
|
||||||
|
{"send_photo", {ca_peer, ca_file_name_end, ca_none}, do_send_photo, "send_photo <peer> <file>\tSends photo to peer"},
|
||||||
|
{"send_text", {ca_peer, ca_file_name_end, ca_none}, do_send_text, "send_text <peer> <file>\tSends contents of text file as plain text message"},
|
||||||
|
{"send_video", {ca_peer, ca_file_name_end, ca_none}, do_send_video, "send_video <peer> <file>\tSends video to peer"},
|
||||||
|
{"set", {ca_string, ca_number, ca_none}, do_set, "set <param> <value>\tSets value of param. Currently available: log_level, debug_verbosity, alarm, msg_num"},
|
||||||
|
{"set_profile_name", {ca_string, ca_string, ca_none}, do_set_profile_name, "set_profile_name <first-name> <last-name>\tSets profile name."},
|
||||||
|
{"set_profile_photo", {ca_file_name_end, ca_none}, do_set_profile_photo, "set_profile_photo <filename>\tSets profile photo. Photo will be cropped to square"},
|
||||||
|
{"set_ttl", {ca_secret_chat, ca_number, ca_none}, do_set_ttl, "set_ttl <secret chat>\tSets secret chat ttl. Client itself ignores ttl"},
|
||||||
|
{"set_username", {ca_string, ca_none}, do_set_username, "set_username <name>\tSets username."},
|
||||||
|
{"show_license", {ca_none}, do_show_license, "show_license\tPrints contents of GPL license"},
|
||||||
|
{"stats", {ca_none}, do_stats, "stats\tFor debug purpose"},
|
||||||
{"status_online", {ca_none}, do_status_online, "status_online\tSets status as online"},
|
{"status_online", {ca_none}, do_status_online, "status_online\tSets status as online"},
|
||||||
{"status_offline", {ca_none}, do_status_offline, "status_offline\tSets status as offline"},
|
{"status_offline", {ca_none}, do_status_offline, "status_offline\tSets status as offline"},
|
||||||
{"quit", {ca_none}, do_quit, "quit\tQuits immediately"},
|
{"user_info", {ca_user, ca_none}, do_user_info, "user_info <user>\tPrints info about user (id, last online, phone)"},
|
||||||
{"safe_quit", {ca_none}, do_safe_quit, "safe_quit\tWaits for all queries to end, then quits"},
|
{"view_audio", {ca_number, ca_none}, do_open_audio, "view_audio <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
||||||
{"set", {ca_string, ca_number, ca_none}, do_set, "set <param> <value>\tSets value of param. Currently available: log_level, debug_verbosity, alarm, msg_num"},
|
{"view_document", {ca_number, ca_none}, do_open_document, "view_document <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
||||||
{"chat_with_peer", {ca_peer, ca_none}, do_chat_with_peer, "chat_with_peer <peer>\tInterface option. All input will be treated as messages to this peer. Type /quit to end this mode"},
|
{"view_document_thumb", {ca_number, ca_none}, do_open_document_thumb, "view_document_thumb <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
||||||
{"delete_msg", {ca_number, ca_none}, do_delete_msg, "delete_msg <msg-id>\tDeletes message"},
|
{"view_photo", {ca_number, ca_none}, do_open_photo, "view_photo <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
||||||
{"restore_msg", {ca_number, ca_none}, do_restore_msg, "restore_msg <msg-id>\tRestores message. Only available shortly (one hour?) after deletion"},
|
{"view_video", {ca_number, ca_none}, do_open_video, "view_video <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
||||||
{"create_group_chat", {ca_string, ca_user, ca_period, ca_none}, do_create_group_chat, "create_group_chat <name> <user>+\tCreates group chat with users"},
|
{"view_video_thumb", {ca_number, ca_none}, do_open_video_thumb, "view_video_thumb <msg-id>\tDownloads file to downloads dirs. Then tries to open it with system default action"},
|
||||||
{"chat_set_photo", {ca_chat, ca_file_name_end, ca_none}, do_chat_set_photo, "chat_set_photo <chat> <filename>\tSets chat photo. Photo will be cropped to square"},
|
{"visualize_key", {ca_secret_chat, ca_none}, do_visualize_key, "visualize_key <secret chat>\tPrints visualization of encryption key (first 16 bytes sha1 of it in fact}"},
|
||||||
{"set_profile_photo", {ca_file_name_end, ca_none}, do_set_profile_photo, "set_profile_photo <filename>\tSets profile photo. Photo will be cropped to square"},
|
|
||||||
{"set_profile_name", {ca_string, ca_string, ca_none}, do_set_profile_name, "set_profile_name <first-name> <last-name>\tSets profile name."},
|
|
||||||
{"set_username", {ca_string, ca_none}, do_set_username, "set_username <name>\tSets username."},
|
|
||||||
{"accept_secret_chat", {ca_secret_chat, ca_none}, do_accept_secret_chat, "accept_secret_chat <secret chat>\tAccepts secret chat. Only useful with -E option"},
|
|
||||||
{"set_ttl", {ca_secret_chat, ca_number, ca_none}, do_set_ttl, "set_ttl <secret chat>\tSets secret chat ttl. Client itself ignores ttl"},
|
|
||||||
{"export_card", {ca_none}, do_export_card, "export_card\tPrints card that can be imported by another user with import_card method"},
|
|
||||||
{"import_card", {ca_string, ca_none}, do_import_card, "import_card <card>\tGets user by card and prints it name. You can then send messages to him as usual"},
|
|
||||||
{"send_contact", {ca_peer, ca_string, ca_string, ca_string, ca_none}, do_send_contact, "send_contact <peer> <phone> <first-name> <last-name>\tSends contact (not necessary telegram user)"},
|
|
||||||
{"main_session", {ca_none}, do_main_session, "main_session\tSends updates to this connection (or terminal). Useful only with listening socket"},
|
|
||||||
{"clear", {ca_none}, do_clear, "clear\tClears all data and exits. For debug."},
|
|
||||||
{"send_location", {ca_peer, ca_double, ca_double, ca_none}, do_send_location, "send_location <peer> <latitude> <longitude>\tSends geo location"},
|
|
||||||
{0, {ca_none}, 0, ""}
|
{0, {ca_none}, 0, ""}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -2612,6 +2612,9 @@ void print_service_message (struct in_ev *ev, struct tgl_message *M) {
|
|||||||
case tgl_message_action_flush_history:
|
case tgl_message_action_flush_history:
|
||||||
mprintf (ev, " cleared history\n");
|
mprintf (ev, " cleared history\n");
|
||||||
break;
|
break;
|
||||||
|
case tgl_message_action_resend:
|
||||||
|
mprintf (ev, " resend query\n");
|
||||||
|
break;
|
||||||
case tgl_message_action_notify_layer:
|
case tgl_message_action_notify_layer:
|
||||||
mprintf (ev, " updated layer to %d\n", M->action.layer);
|
mprintf (ev, " updated layer to %d\n", M->action.layer);
|
||||||
break;
|
break;
|
||||||
|
2
loop.c
2
loop.c
@ -699,6 +699,7 @@ static void accept_incoming (evutil_socket_t efd, short what, void *arg) {
|
|||||||
bufferevent_enable(bev, EV_READ|EV_WRITE);
|
bufferevent_enable(bev, EV_READ|EV_WRITE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *get_downloads_directory (void);
|
||||||
int loop (void) {
|
int loop (void) {
|
||||||
//on_start ();
|
//on_start ();
|
||||||
tgl_set_callback (TLS, &upd_cb);
|
tgl_set_callback (TLS, &upd_cb);
|
||||||
@ -707,6 +708,7 @@ int loop (void) {
|
|||||||
tgl_set_ev_base (TLS, ev);
|
tgl_set_ev_base (TLS, ev);
|
||||||
tgl_set_net_methods (TLS, &tgl_conn_methods);
|
tgl_set_net_methods (TLS, &tgl_conn_methods);
|
||||||
tgl_set_timer_methods (TLS, &tgl_libevent_timers);
|
tgl_set_timer_methods (TLS, &tgl_libevent_timers);
|
||||||
|
tgl_set_download_directory (TLS, get_downloads_directory ());
|
||||||
tgl_init (TLS);
|
tgl_init (TLS);
|
||||||
|
|
||||||
if (binlog_enabled) {
|
if (binlog_enabled) {
|
||||||
|
1
lua-tg.c
1
lua-tg.c
@ -295,6 +295,7 @@ void push_message (struct tgl_message *M) {
|
|||||||
static char s[30];
|
static char s[30];
|
||||||
snprintf (s, 30, "%lld", M->id);
|
snprintf (s, 30, "%lld", M->id);
|
||||||
lua_add_string_field ("id", s);
|
lua_add_string_field ("id", s);
|
||||||
|
if (!(M->flags & FLAG_CREATED)) { return; }
|
||||||
lua_add_num_field ("flags", M->flags);
|
lua_add_num_field ("flags", M->flags);
|
||||||
|
|
||||||
if (tgl_get_peer_type (M->fwd_from_id)) {
|
if (tgl_get_peer_type (M->fwd_from_id)) {
|
||||||
|
@ -61,7 +61,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
//int want_dc_num;
|
//int want_dc_num;
|
||||||
char *get_downloads_directory (void);
|
//char *get_downloads_directory (void);
|
||||||
//extern int offline_mode;
|
//extern int offline_mode;
|
||||||
|
|
||||||
//long long cur_uploading_bytes;
|
//long long cur_uploading_bytes;
|
||||||
@ -2492,9 +2492,9 @@ static void load_next_part (struct tgl_state *TLS, struct download *D, void *cal
|
|||||||
static char buf[PATH_MAX];
|
static char buf[PATH_MAX];
|
||||||
int l;
|
int l;
|
||||||
if (!D->id) {
|
if (!D->id) {
|
||||||
l = tsnprintf (buf, sizeof (buf), "%s/download_%lld_%d", get_downloads_directory (), D->volume, D->local_id);
|
l = tsnprintf (buf, sizeof (buf), "%s/download_%lld_%d.jpg", TLS->downloads_directory, D->volume, D->local_id);
|
||||||
} else {
|
} else {
|
||||||
l = tsnprintf (buf, sizeof (buf), "%s/download_%lld", get_downloads_directory (), D->id);
|
l = tsnprintf (buf, sizeof (buf), "%s/download_%lld", TLS->downloads_directory, D->id);
|
||||||
}
|
}
|
||||||
if (l >= (int) sizeof (buf)) {
|
if (l >= (int) sizeof (buf)) {
|
||||||
vlogprintf (E_ERROR, "Download filename is too long");
|
vlogprintf (E_ERROR, "Download filename is too long");
|
||||||
|
12
structures.c
12
structures.c
@ -1010,6 +1010,11 @@ void tglf_fetch_message_action_encrypted (struct tgl_state *TLS, struct tgl_mess
|
|||||||
M->type = tgl_message_action_typing;
|
M->type = tgl_message_action_typing;
|
||||||
M->typing = tglf_fetch_typing ();
|
M->typing = tglf_fetch_typing ();
|
||||||
break;
|
break;
|
||||||
|
case CODE_decrypted_message_action_resend:
|
||||||
|
M->type = tgl_message_action_resend;
|
||||||
|
M->start_seq_no = fetch_int ();
|
||||||
|
M->end_seq_no = fetch_int ();
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
vlogprintf (E_ERROR, "x = 0x%08x\n", x);
|
vlogprintf (E_ERROR, "x = 0x%08x\n", x);
|
||||||
assert (0);
|
assert (0);
|
||||||
@ -1250,10 +1255,11 @@ void tglf_fetch_encrypted_message (struct tgl_state *TLS, struct tgl_message *M)
|
|||||||
vlogprintf (E_DEBUG - 2, "layer = %d, in = %d, out = %d\n", layer, in_seq_no, out_seq_no);
|
vlogprintf (E_DEBUG - 2, "layer = %d, in = %d, out = %d\n", layer, in_seq_no, out_seq_no);
|
||||||
}
|
}
|
||||||
if (!(x == CODE_decrypted_message || x == CODE_decrypted_message_service || x == CODE_decrypted_message_l16 || x == CODE_decrypted_message_service_l16)) {
|
if (!(x == CODE_decrypted_message || x == CODE_decrypted_message_service || x == CODE_decrypted_message_l16 || x == CODE_decrypted_message_service_l16)) {
|
||||||
vlogprintf (E_ERROR, "x = 0x%08x\n", x);
|
vlogprintf (E_ERROR, "Incorrect message: x = 0x%08x\n", x);
|
||||||
assert (x == CODE_decrypted_message || x == CODE_decrypted_message_service || x == CODE_decrypted_message_l16 || x == CODE_decrypted_message_service_l16);
|
drop = 1;
|
||||||
}
|
}
|
||||||
//assert (id == fetch_long ());
|
//assert (id == fetch_long ());
|
||||||
|
if (!drop) {
|
||||||
long long new_id = fetch_long ();
|
long long new_id = fetch_long ();
|
||||||
if (P && P->encr_chat.layer >= 17) {
|
if (P && P->encr_chat.layer >= 17) {
|
||||||
assert (new_id == id);
|
assert (new_id == id);
|
||||||
@ -1280,6 +1286,7 @@ void tglf_fetch_encrypted_message (struct tgl_state *TLS, struct tgl_message *M)
|
|||||||
}
|
}
|
||||||
end = in_ptr;
|
end = in_ptr;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
in_ptr = save_in_ptr;
|
in_ptr = save_in_ptr;
|
||||||
in_end = save_in_end;
|
in_end = save_in_end;
|
||||||
}
|
}
|
||||||
@ -1661,6 +1668,7 @@ void tgls_free_message_action (struct tgl_state *TLS, struct tgl_message_action
|
|||||||
case tgl_message_action_delete_messages:
|
case tgl_message_action_delete_messages:
|
||||||
case tgl_message_action_screenshot_messages:
|
case tgl_message_action_screenshot_messages:
|
||||||
case tgl_message_action_flush_history:
|
case tgl_message_action_flush_history:
|
||||||
|
case tgl_message_action_resend:
|
||||||
case tgl_message_action_notify_layer:
|
case tgl_message_action_notify_layer:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -119,6 +119,7 @@ enum tgl_message_action_type {
|
|||||||
tgl_message_action_delete_messages,
|
tgl_message_action_delete_messages,
|
||||||
tgl_message_action_screenshot_messages,
|
tgl_message_action_screenshot_messages,
|
||||||
tgl_message_action_flush_history,
|
tgl_message_action_flush_history,
|
||||||
|
tgl_message_action_resend,
|
||||||
tgl_message_action_notify_layer,
|
tgl_message_action_notify_layer,
|
||||||
tgl_message_action_typing
|
tgl_message_action_typing
|
||||||
};
|
};
|
||||||
@ -386,6 +387,10 @@ struct tgl_message_action {
|
|||||||
int delete_cnt;
|
int delete_cnt;
|
||||||
int screenshot_cnt;
|
int screenshot_cnt;
|
||||||
enum tgl_typing_status typing;
|
enum tgl_typing_status typing;
|
||||||
|
struct {
|
||||||
|
int start_seq_no;
|
||||||
|
int end_seq_no;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
5
tgl.h
5
tgl.h
@ -30,11 +30,12 @@
|
|||||||
#define TG_SERVER_3 "174.140.142.6"
|
#define TG_SERVER_3 "174.140.142.6"
|
||||||
#define TG_SERVER_4 "149.154.167.91"
|
#define TG_SERVER_4 "149.154.167.91"
|
||||||
#define TG_SERVER_5 "149.154.171.5"
|
#define TG_SERVER_5 "149.154.171.5"
|
||||||
|
#define TG_SERVER_DEFAULT 4
|
||||||
|
|
||||||
#define TG_SERVER_TEST_1 "173.240.5.253"
|
#define TG_SERVER_TEST_1 "173.240.5.253"
|
||||||
#define TG_SERVER_TEST_2 "149.154.167.40"
|
#define TG_SERVER_TEST_2 "149.154.167.40"
|
||||||
#define TG_SERVER_TEST_3 "174.140.142.5"
|
#define TG_SERVER_TEST_3 "174.140.142.5"
|
||||||
|
#define TG_SERVER_TEST_DEFAULT 2
|
||||||
|
|
||||||
// JUST RANDOM STRING
|
// JUST RANDOM STRING
|
||||||
#define TGL_BUILD "2590"
|
#define TGL_BUILD "2590"
|
||||||
@ -201,6 +202,8 @@ struct tgl_state {
|
|||||||
void *pubKey;
|
void *pubKey;
|
||||||
|
|
||||||
struct tree_query *queries_tree;
|
struct tree_query *queries_tree;
|
||||||
|
|
||||||
|
char *base_path;
|
||||||
};
|
};
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
//extern struct tgl_state tgl_state;
|
//extern struct tgl_state tgl_state;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user