This commit is contained in:
vvaltman 2014-08-18 20:39:04 +04:00
parent cedc1d17d4
commit 2b2cc686fc
9 changed files with 328 additions and 134 deletions

1
.gitignore vendored
View File

@ -11,3 +11,4 @@ bin/
objs/
dep/
auto/
libs/

View File

@ -4,7 +4,7 @@ CFLAGS=@CFLAGS@
LDFLAGS=@LDFLAGS@
CPPFLAGS=@CPPFLAGS@
DEFS=@DEFS@
COMPILE_FLAGS=${CFLAGS} ${CPPFLAGS} ${DEFS} -Wall -Wextra -Werror -Wno-deprecated-declarations -fno-strict-aliasing -fno-omit-frame-pointer -ggdb -Wno-unused-parameter
COMPILE_FLAGS=${CFLAGS} ${CPPFLAGS} ${DEFS} -Wall -Wextra -Werror -Wno-deprecated-declarations -fno-strict-aliasing -fno-omit-frame-pointer -ggdb -Wno-unused-parameter -fPIC
EXTRA_LIBS=@LIBS@ @EXTRA_LIBS@
LOCAL_LDFLAGS=-rdynamic -ggdb -levent ${EXTRA_LIBS}
@ -14,16 +14,19 @@ DEP=${srcdir}/dep
AUTO=${srcdir}/auto
EXE=${srcdir}/bin
OBJ=${srcdir}/objs
DIR_LIST=${DEP} ${AUTO} ${EXE} ${OBJ} ${DEP}/auto ${OBJ}/auto
LIB=${srcdir}/libs
DIR_LIST=${DEP} ${AUTO} ${EXE} ${OBJ} ${LIB} ${DEP}/auto ${OBJ}/auto
EXE_LIST=${EXE}/generate ${EXE}/tlc ${EXE}/telegram-cli
LIB_LIST=${LIB}/libtgl.a
TG_OBJECTS=${OBJ}/main.o ${OBJ}/loop.o ${OBJ}/interface.o ${OBJ}/net.o ${OBJ}/mtproto-common.o ${OBJ}/mtproto-client.o ${OBJ}/queries.o ${OBJ}/structures.o ${OBJ}/binlog.o ${OBJ}/lua-tg.o ${OBJ}/auto/auto.o ${OBJ}/tgl.o ${OBJ}/updates.o
TG_OBJECTS=${OBJ}/main.o ${OBJ}/loop.o ${OBJ}/interface.o ${OBJ}/lua-tg.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
TLC_OBJECTS=${OBJ}/tlc.o ${OBJ}/tl-parser.o ${OBJ}/crc32.o
GENERATE_OBJECTS=${OBJ}/generate.o
COMMON_OBJECTS=${OBJ}/tools.o
OBJ_LIST=${TG_OBJECTS} ${TLC_OBJECTS} ${GENERATE_OBJECTS} ${COMMON_OBJECTS}
OBJ_C=${TLC_OBJECTS} ${GENERATE_OBJECTS} ${COMMON_OBJECTS}
OBJ_LIST=${TG_OBJECTS} ${TLC_OBJECTS} ${GENERATE_OBJECTS} ${COMMON_OBJECTS} ${TGL_OBJECTS}
OBJ_C=${TLC_OBJECTS} ${GENERATE_OBJECTS} ${COMMON_OBJECTS} ${TGL_OBJECTS}
DEPENDENCE=$(subst ${OBJ}/,${DEP}/,$(patsubst %.o,%.d,${OBJ_LIST}))
DEPENDENCE_LIST=${DEPENDENCE}
@ -35,7 +38,7 @@ CC=@CC@
.SUFFIXES: .c .h .o
all: ${EXE_LIST} ${DIR_LIST}
all: ${EXE_LIST} ${DIR_LIST} ${LIB_LIST}
create_dirs_and_headers: ${DIR_LIST} ${AUTO}/auto.c ${AUTO}/auto-header.h ${AUTO}/constants.h
create_dirs: ${DIR_LIST}
@ -53,8 +56,11 @@ ${OBJ_C}: ${OBJ}/%.o: %.c | create_dirs
${EXE}/tlc: ${TLC_OBJECTS} ${COMMON_OBJECTS}
${CC} ${TLC_OBJECTS} ${COMMON_OBJECTS} ${LINK_FLAGS} -o $@
${EXE}/telegram-cli: ${TG_OBJECTS} ${COMMON_OBJECTS}
${CC} ${TG_OBJECTS} ${COMMON_OBJECTS} ${LINK_FLAGS} -o $@
${EXE}/telegram-cli: ${TG_OBJECTS} ${COMMON_OBJECTS} ${LIB}/libtgl.a
${CC} ${TG_OBJECTS} ${COMMON_OBJECTS} ${LINK_FLAGS} -L${LIB} -l tgl -o $@
${LIB}/libtgl.a: ${TGL_OBJECTS} ${COMMON_OBJECTS}
ar ruv $@ ${TGL_OBJECTS} ${COMMON_OBJECTS}
${EXE}/generate: ${GENERATE_OBJECTS} ${COMMON_OBJECTS}
${CC} ${GENERATE_OBJECTS} ${COMMON_OBJECTS} ${LINK_FLAGS} -o $@

View File

@ -198,6 +198,9 @@ static int fetch_comb_binlog_user_add (void *extra) {
#ifdef USE_LUA
lua_user_update (U);
#endif
if (tgl_state.callback.new_user) {
tgl_state.callback.new_user (U);
}
return 0;
}
@ -210,6 +213,9 @@ static int fetch_comb_binlog_user_delete (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.delete_user) {
tgl_state.callback.delete_user ((void *)U);
}
return 0;
}
@ -237,6 +243,10 @@ static int fetch_comb_binlog_user_set_phone (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -254,6 +264,9 @@ static int fetch_comb_binlog_user_set_friend (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -269,6 +282,9 @@ static int fetch_comb_binlog_user_set_full_photo (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -282,6 +298,9 @@ static int fetch_comb_binlog_user_set_blocked (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -298,6 +317,9 @@ static int fetch_comb_binlog_user_set_real_name (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -320,6 +342,9 @@ static int fetch_comb_binlog_user_set_name (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -344,6 +369,9 @@ static int fetch_comb_binlog_user_set_photo (void *extra) {
#ifdef USE_LUA
lua_user_update (&U->user);
#endif
if (tgl_state.callback.update_user_info) {
tgl_state.callback.update_user_info ((void *)U);
}
return 0;
}
@ -367,6 +395,9 @@ static int fetch_comb_binlog_encr_chat_delete (void *extra) {
#ifdef USE_LUA
lua_secret_chat_update (U);
#endif
if (tgl_state.callback.secret_chat_deleted) {
tgl_state.callback.secret_chat_deleted (U);
}
return 0;
}
@ -407,6 +438,9 @@ static int fetch_comb_binlog_encr_chat_requested (void *extra) {
#ifdef USE_LUA
lua_secret_chat_update (U);
#endif
if (tgl_state.callback.secret_chat_request) {
tgl_state.callback.secret_chat_request (U);
}
return 0;
}
@ -470,6 +504,9 @@ static int fetch_comb_binlog_encr_chat_accepted (void *extra) {
#ifdef USE_LUA
lua_secret_chat_update (U);
#endif
if (tgl_state.callback.secret_chat_accepted) {
tgl_state.callback.secret_chat_accepted (U);
}
return 0;
}
@ -507,6 +544,9 @@ static int fetch_comb_binlog_encr_chat_init (void *extra) {
#ifdef USE_LUA
lua_secret_chat_update (U);
#endif
if (tgl_state.callback.secret_chat_created) {
tgl_state.callback.secret_chat_created ((void *)P);
}
return 0;
}
@ -536,6 +576,9 @@ static int fetch_comb_binlog_chat_create (void *extra) {
#ifdef USE_LUA
lua_chat_update (C);
#endif
if (tgl_state.callback.chat_created) {
tgl_state.callback.chat_created (C);
}
return 0;
}
@ -548,6 +591,9 @@ static int fetch_comb_binlog_chat_change_flags (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -567,6 +613,9 @@ static int fetch_comb_binlog_chat_set_title (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -579,6 +628,9 @@ static int fetch_comb_binlog_chat_set_photo (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -590,6 +642,9 @@ static int fetch_comb_binlog_chat_set_date (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -602,6 +657,9 @@ static int fetch_comb_binlog_chat_set_version (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -613,6 +671,9 @@ static int fetch_comb_binlog_chat_set_admin (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -628,6 +689,9 @@ static int fetch_comb_binlog_chat_set_participants (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -644,6 +708,9 @@ static int fetch_comb_binlog_chat_set_full_photo (void *extra) {
#ifdef USE_LUA
lua_chat_update (&C->chat);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update ((void *)C);
}
return 0;
}
@ -674,6 +741,9 @@ static int fetch_comb_binlog_chat_add_participant (void *extra) {
#ifdef USE_LUA
lua_chat_update (C);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update (C);
}
return 0;
}
@ -704,6 +774,9 @@ static int fetch_comb_binlog_chat_del_participant (void *extra) {
#ifdef USE_LUA
lua_chat_update (C);
#endif
if (tgl_state.callback.chat_update) {
tgl_state.callback.chat_update (C);
}
return 0;
}
@ -734,9 +807,9 @@ static int fetch_comb_binlog_create_message_text (void *extra) {
M->message_len = l;
if (t == TGL_PEER_ENCR_CHAT) {
M->media.type = CODE_decrypted_message_media_empty;
M->media.type = tgl_message_media_none;
} else {
M->media.type = CODE_message_media_empty;
M->media.type = tgl_message_media_none;
}
M->unread = 1;
@ -777,9 +850,9 @@ static int fetch_comb_binlog_send_message_text (void *extra) {
M->message_len = l;
if (t == TGL_PEER_ENCR_CHAT) {
M->media.type = CODE_decrypted_message_media_empty;
M->media.type = tgl_message_media_none;
} else {
M->media.type = CODE_message_media_empty;
M->media.type = tgl_message_media_none;
}
M->unread = 1;
@ -812,7 +885,7 @@ static int fetch_comb_binlog_send_message_action_encr (void *extra) {
M->to_id = tgl_set_peer_id (t, fetch_int ());
M->date = fetch_int ();
M->media.type = CODE_decrypted_message_media_empty;
M->media.type = tgl_message_media_none;
tglf_fetch_message_action_encrypted (&M->action);
M->unread = 1;
@ -859,9 +932,9 @@ static int fetch_comb_binlog_create_message_text_fwd (void *extra) {
M->message_len = l;
if (t == TGL_PEER_ENCR_CHAT) {
M->media.type = CODE_decrypted_message_media_empty;
M->media.type = tgl_message_media_none;
} else {
M->media.type = CODE_message_media_empty;
M->media.type = tgl_message_media_none;
}
M->unread = 1;

View File

@ -42,7 +42,7 @@
#include "interface.h"
#include "telegram.h"
#include "auto/constants.h"
//#include "auto/constants.h"
//#include "tools.h"
//#include "structures.h"
@ -145,6 +145,7 @@ tgl_peer_id_t next_token_user (void) {
}
char c = s[l];
s[l] = 0;
tgl_peer_t *P = tgl_peer_get_by_name (s);
s[l] = c;
@ -169,6 +170,7 @@ tgl_peer_id_t next_token_chat (void) {
}
char c = s[l];
s[l] = 0;
tgl_peer_t *P = tgl_peer_get_by_name (s);
s[l] = c;
@ -185,6 +187,7 @@ tgl_peer_id_t next_token_encr_chat (void) {
if (!s) { return TGL_PEER_NOT_FOUND; }
char c = s[l];
s[l] = 0;
tgl_peer_t *P = tgl_peer_get_by_name (s);
s[l] = c;
@ -216,6 +219,7 @@ tgl_peer_id_t next_token_peer (void) {
}
char c = s[l];
s[l] = 0;
tgl_peer_t *P = tgl_peer_get_by_name (s);
s[l] = c;
@ -545,6 +549,7 @@ void print_user_list_gw (void *extra, int success, int num, struct tgl_user *UL[
int i;
for (i = num - 1; i >= 0; i--) {
print_user_name (UL[i]->id, (void *)UL[i]);
printf ("\n");
}
print_end ();
}
@ -571,7 +576,10 @@ void open_filename_gw (void *extra, int success, char *name) {
}
void print_chat_info_gw (void *extra, int success, struct tgl_chat *C) {
if (!success) { return; }
if (!success) {
vlogprintf (E_NOTICE, "Failed to get chat info\n");
return;
}
print_start ();
tgl_peer_t *U = (void *)C;
@ -711,8 +719,14 @@ void type_in_chat_notification_upd (struct tgl_user *U, struct tgl_chat *C) {
}
void print_message_gw (struct tgl_message *M) {
print_start ();
print_message (M);
print_end ();
}
struct tgl_update_callback upd_cb = {
.new_msg = print_message,
.new_msg = print_message_gw,
.marked_read = mark_read_upd,
.logprintf = logprintf,
.type_notification = type_notification_upd,
@ -722,9 +736,11 @@ struct tgl_update_callback upd_cb = {
.user_registered = 0,
.user_activated = 0,
.new_authorization = 0,
.secret_chat_created = 0,
.secret_chat_request = 0,
.secret_chat_established = 0,
.secret_chat_deleted = 0
.secret_chat_deleted = 0,
.secret_chat_accepted = 0
};
@ -831,7 +847,7 @@ void interpreter (char *line UU) {
printf ("Empty file name\n");
RET;
}
tgl_do_send_photo (CODE_input_media_uploaded_photo, id, strndup (s, t), print_msg_gw, 0);
tgl_do_send_photo (tgl_message_media_photo, id, strndup (s, t), print_msg_gw, 0);
} else if (IS_WORD("send_video")) {
GET_PEER;
int t;
@ -840,7 +856,7 @@ void interpreter (char *line UU) {
printf ("Empty file name\n");
RET;
}
tgl_do_send_photo (CODE_input_media_uploaded_video, id, strndup (s, t), print_msg_gw, 0);
tgl_do_send_photo (tgl_message_media_video, id, strndup (s, t), print_msg_gw, 0);
} else if (IS_WORD ("send_text")) {
GET_PEER;
int t;
@ -865,9 +881,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_photo) {
if (M && !M->service && M->media.type == tgl_message_media_photo) {
tgl_do_load_photo (&M->media.photo, print_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_photo) {
} else if (M && !M->service && M->media.type == tgl_message_media_photo_encr) {
tgl_do_load_encr_video (&M->media.encr_video, print_filename_gw, 0); // this is not a bug.
} else {
printf ("Bad msg id\n");
@ -880,9 +896,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_photo) {
if (M && !M->service && M->media.type == tgl_message_media_photo) {
tgl_do_load_photo (&M->media.photo, open_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_photo) {
} else if (M && !M->service && M->media.type == tgl_message_media_photo_encr) {
tgl_do_load_encr_video (&M->media.encr_video, open_filename_gw, 0); // this is not a bug.
} else {
printf ("Bad msg id\n");
@ -895,7 +911,7 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_video) {
if (M && !M->service && M->media.type == tgl_message_media_video) {
tgl_do_load_video_thumb (&M->media.video, print_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -908,7 +924,7 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_video) {
if (M && !M->service && M->media.type == tgl_message_media_video) {
tgl_do_load_video_thumb (&M->media.video, open_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -921,9 +937,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_video) {
if (M && !M->service && M->media.type == tgl_message_media_video) {
tgl_do_load_video (&M->media.video, print_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_video) {
} else if (M && !M->service && M->media.type == tgl_message_media_video_encr) {
tgl_do_load_encr_video (&M->media.encr_video, print_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -936,9 +952,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_video) {
if (M && !M->service && M->media.type == tgl_message_media_video) {
tgl_do_load_video (&M->media.video, open_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_video) {
} else if (M && !M->service && M->media.type == tgl_message_media_video_encr) {
tgl_do_load_encr_video (&M->media.encr_video, open_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1136,7 +1152,7 @@ void interpreter (char *line UU) {
printf ("Empty file name\n");
RET;
}
tgl_do_send_photo (CODE_input_media_uploaded_audio, id, strndup (s, t), print_msg_gw, 0);
tgl_do_send_photo (tgl_message_media_audio, id, strndup (s, t), print_msg_gw, 0);
} else if (IS_WORD("send_document")) {
GET_PEER;
int t;
@ -1145,7 +1161,7 @@ void interpreter (char *line UU) {
printf ("Empty file name\n");
RET;
}
tgl_do_send_photo (CODE_input_media_uploaded_document, id, strndup (s, t), print_msg_gw, 0);
tgl_do_send_photo (tgl_message_media_document, id, strndup (s, t), print_msg_gw, 0);
} else if (IS_WORD ("load_audio")) {
long long num = next_token_int ();
if (num == NOT_FOUND) {
@ -1153,9 +1169,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_audio) {
if (M && !M->service && M->media.type == tgl_message_media_audio) {
tgl_do_load_audio (&M->media.video, print_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_audio) {
} else if (M && !M->service && M->media.type == tgl_message_media_audio_encr) {
tgl_do_load_encr_video (&M->media.encr_video, print_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1168,9 +1184,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_audio) {
if (M && !M->service && M->media.type == tgl_message_media_audio) {
tgl_do_load_audio (&M->media.video, open_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_audio) {
} else if (M && !M->service && M->media.type == tgl_message_media_audio_encr) {
tgl_do_load_encr_video (&M->media.encr_video, open_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1183,7 +1199,7 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == (int)CODE_message_media_document) {
if (M && !M->service && M->media.type == (int)tgl_message_media_document) {
tgl_do_load_document_thumb (&M->media.document, print_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1196,7 +1212,7 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == (int)CODE_message_media_document) {
if (M && !M->service && M->media.type == (int)tgl_message_media_document) {
tgl_do_load_document_thumb (&M->media.document, open_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1209,9 +1225,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_document) {
if (M && !M->service && M->media.type == tgl_message_media_document) {
tgl_do_load_document (&M->media.document, print_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_document) {
} else if (M && !M->service && M->media.type == tgl_message_media_document_encr) {
tgl_do_load_encr_video (&M->media.encr_video, print_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1224,9 +1240,9 @@ void interpreter (char *line UU) {
RET;
}
struct tgl_message *M = tgl_message_get (num);
if (M && !M->service && M->media.type == CODE_message_media_document) {
if (M && !M->service && M->media.type == tgl_message_media_document) {
tgl_do_load_document (&M->media.document, open_filename_gw, 0);
} else if (M && !M->service && M->media.type == CODE_decrypted_message_media_document) {
} else if (M && !M->service && M->media.type == tgl_message_media_document_encr) {
tgl_do_load_encr_video (&M->media.encr_video, open_filename_gw, 0);
} else {
printf ("Bad msg id\n");
@ -1387,65 +1403,80 @@ void pop_color (void) {
void print_media (struct tgl_message_media *M) {
assert (M);
switch (M->type) {
case CODE_message_media_empty:
case CODE_decrypted_message_media_empty:
case tgl_message_media_none:
return;
case CODE_message_media_photo:
case tgl_message_media_photo:
if (M->photo.caption && strlen (M->photo.caption)) {
printf ("[photo %s]", M->photo.caption);
} else {
printf ("[photo]");
}
return;
case CODE_message_media_video:
case tgl_message_media_video:
if (M->video.mime_type) {
printf ("[video: type %s]", M->video.mime_type);
} else {
printf ("[video]");
}
return;
case CODE_message_media_audio:
case tgl_message_media_audio:
if (M->audio.mime_type) {
printf ("[audio: type %s]", M->audio.mime_type);
} else {
printf ("[audio]");
}
return;
case CODE_message_media_document:
case tgl_message_media_document:
if (M->document.mime_type && M->document.caption) {
printf ("[document %s: type %s]", M->document.caption, M->document.mime_type);
} else {
printf ("[document]");
}
return;
case CODE_decrypted_message_media_photo:
case tgl_message_media_photo_encr:
printf ("[photo]");
if (M->photo.caption && strlen (M->photo.caption)) {
printf ("[photo %s]", M->photo.caption);
} else {
printf ("[photo]");
}
return;
case CODE_decrypted_message_media_video:
case CODE_decrypted_message_media_video_l12:
case tgl_message_media_video_encr:
if (M->encr_video.mime_type) {
printf ("[video: type %s]", M->encr_video.mime_type);
} else {
printf ("[video]");
}
return;
case CODE_decrypted_message_media_audio:
case CODE_decrypted_message_media_audio_l12:
case tgl_message_media_audio_encr:
if (M->encr_audio.mime_type) {
printf ("[audio: type %s]", M->encr_audio.mime_type);
} else {
printf ("[audio]");
}
return;
case CODE_decrypted_message_media_document:
case tgl_message_media_document_encr:
if (M->encr_document.mime_type && M->encr_document.file_name) {
printf ("[document %s: type %s]", M->encr_document.file_name, M->encr_document.mime_type);
} else {
printf ("[document]");
}
return;
case CODE_message_media_geo:
case tgl_message_media_geo:
printf ("[geo] https://maps.google.com/?q=%.6lf,%.6lf", M->geo.latitude, M->geo.longitude);
return;
case CODE_message_media_contact:
case tgl_message_media_contact:
printf ("[contact] ");
push_color (COLOR_RED);
printf ("%s %s ", M->first_name, M->last_name);
pop_color ();
printf ("%s", M->phone);
return;
case CODE_message_media_unsupported:
case tgl_message_media_unsupported:
printf ("[unsupported]");
return;
default:
printf ("x = %d\n", M->type);
assert (0);
}
}
@ -1542,7 +1573,7 @@ void print_date_full (long t) {
void print_service_message (struct tgl_message *M) {
assert (M);
print_start ();
//print_start ();
push_color (COLOR_GREY);
push_color (COLOR_MAGENTA);
@ -1562,61 +1593,61 @@ void print_service_message (struct tgl_message *M) {
print_user_name (M->from_id, tgl_peer_get (M->from_id));
switch (M->action.type) {
case CODE_message_action_empty:
case tgl_message_action_none:
printf ("\n");
break;
case CODE_message_action_geo_chat_create:
case tgl_message_action_geo_chat_create:
printf ("Created geo chat\n");
break;
case CODE_message_action_geo_chat_checkin:
case tgl_message_action_geo_chat_checkin:
printf ("Checkin in geochat\n");
break;
case CODE_message_action_chat_create:
case tgl_message_action_chat_create:
printf (" created chat %s. %d users\n", M->action.title, M->action.user_num);
break;
case CODE_message_action_chat_edit_title:
case tgl_message_action_chat_edit_title:
printf (" changed title to %s\n",
M->action.new_title);
break;
case CODE_message_action_chat_edit_photo:
case tgl_message_action_chat_edit_photo:
printf (" changed photo\n");
break;
case CODE_message_action_chat_delete_photo:
case tgl_message_action_chat_delete_photo:
printf (" deleted photo\n");
break;
case CODE_message_action_chat_add_user:
case tgl_message_action_chat_add_user:
printf (" added user ");
print_user_name (tgl_set_peer_id (TGL_PEER_USER, M->action.user), tgl_peer_get (tgl_set_peer_id (TGL_PEER_USER, M->action.user)));
printf ("\n");
break;
case CODE_message_action_chat_delete_user:
case tgl_message_action_chat_delete_user:
printf (" deleted user ");
print_user_name (tgl_set_peer_id (TGL_PEER_USER, M->action.user), tgl_peer_get (tgl_set_peer_id (TGL_PEER_USER, M->action.user)));
printf ("\n");
break;
case CODE_decrypted_message_action_set_message_t_t_l:
case tgl_message_action_set_message_ttl:
printf (" set ttl to %d seconds. Unsupported yet\n", M->action.ttl);
break;
case CODE_decrypted_message_action_read_messages:
case tgl_message_action_read_messages:
printf (" %d messages marked read\n", M->action.read_cnt);
break;
case CODE_decrypted_message_action_delete_messages:
case tgl_message_action_delete_messages:
printf (" %d messages deleted\n", M->action.delete_cnt);
break;
case CODE_decrypted_message_action_screenshot_messages:
case tgl_message_action_screenshot_messages:
printf (" %d messages screenshoted\n", M->action.screenshot_cnt);
break;
case CODE_decrypted_message_action_flush_history:
case tgl_message_action_flush_history:
printf (" cleared history\n");
break;
case CODE_decrypted_message_action_notify_layer:
case tgl_message_action_notify_layer:
printf (" updated layer to %d\n", M->action.layer);
break;
default:
assert (0);
}
pop_color ();
print_end ();
//print_end ();
}
tgl_peer_id_t last_from_id;
@ -1640,7 +1671,7 @@ void print_message (struct tgl_message *M) {
last_from_id = M->from_id;
last_to_id = M->to_id;
print_start ();
//print_start ();
if (tgl_get_peer_type (M->to_id) == TGL_PEER_USER) {
if (M->out) {
push_color (COLOR_GREEN);
@ -1743,13 +1774,13 @@ void print_message (struct tgl_message *M) {
if (M->message && strlen (M->message)) {
printf ("%s", M->message);
}
if (M->media.type != CODE_message_media_empty) {
if (M->media.type != tgl_message_media_none) {
print_media (&M->media);
}
pop_color ();
assert (!color_stack_pos);
printf ("\n");
print_end();
//print_end();
}
void play_sound (void) {

2
net.c
View File

@ -236,7 +236,7 @@ static void try_write (struct connection *c);
static void conn_try_read (evutil_socket_t fd, short what, void *arg) {
struct connection *c = arg;
vlogprintf (2, "Try read. Fd = %d\n", c->fd);
vlogprintf (E_DEBUG + 1, "Try read. Fd = %d\n", c->fd);
try_read (c);
}
static void conn_try_write (evutil_socket_t fd, short what, void *arg) {

View File

@ -757,7 +757,7 @@ void tgl_do_send_encr_chat_layer (struct tgl_secret_chat *E) {
long long t;
tglt_secure_random (&t, 8);
int action[2];
action[0] = CODE_decrypted_message_action_notify_layer;
action[0] = tgl_message_action_notify_layer;
action[1] = 15;
bl_do_send_message_action_encr (t, tgl_state.our_id, tgl_get_peer_type (E->id), tgl_get_peer_id (E->id), time (0), 2, action);
@ -886,7 +886,7 @@ void tgl_do_send_encr_msg_action (struct tgl_message *M, void (*callback)(void *
out_cstring ((void *)buf, 16);
switch (M->action.type) {
case CODE_decrypted_message_action_notify_layer:
case tgl_message_action_notify_layer:
out_int (M->action.type);
out_int (M->action.layer);
break;
@ -1081,6 +1081,9 @@ static int get_history_on_answer (struct query *q UU) {
int i;
int x = fetch_int ();
assert (x == (int)CODE_messages_messages_slice || x == (int)CODE_messages_messages);
if (x == (int)CODE_messages_messages_slice) {
fetch_int ();
}
assert (fetch_int () == CODE_vector);
int n = fetch_int ();
struct tgl_message **ML = talloc (sizeof (void *) * n);
@ -1555,7 +1558,7 @@ static void send_part (struct send_file *f, void *callback, void *callback_extra
tglq_send_query (tgl_state.DC_working, packet_ptr - packet_buffer, packet_buffer, &send_file_part_methods, f, callback, callback_extra);
}*/
void tgl_do_send_photo (int type, tgl_peer_id_t to_id, char *file_name, void (*callback)(void *callback_extra, int success, struct tgl_message *M), void *callback_extra) {
void tgl_do_send_photo (enum tgl_message_media_type type, tgl_peer_id_t to_id, char *file_name, void (*callback)(void *callback_extra, int success, struct tgl_message *M), void *callback_extra) {
int fd = open (file_name, O_RDONLY);
if (fd < 0) {
vlogprintf (E_WARNING, "No such file '%s'\n", file_name);
@ -1592,7 +1595,26 @@ void tgl_do_send_photo (int type, tgl_peer_id_t to_id, char *file_name, void (*c
f->id = lrand48 () * (1ll << 32) + lrand48 ();
f->to_id = to_id;
f->media_type = type;
switch (type) {
case tgl_message_media_photo:
f->media_type = CODE_input_media_uploaded_photo;
break;
case tgl_message_media_video:
f->media_type = CODE_input_media_uploaded_video;
break;
case tgl_message_media_audio:
f->media_type = CODE_input_media_uploaded_audio;
break;
case tgl_message_media_document:
f->media_type = CODE_input_media_uploaded_document;
break;
default:
close (fd);
vlogprintf (E_WARNING, "Unknown type %d.\n", type);
tfree (f, sizeof (*f));
callback (callback_extra, 0, 0);
return;
}
f->file_name = tstrdup (file_name);
if (tgl_get_peer_type (f->to_id) == TGL_PEER_ENCR_CHAT) {
f->encr = 1;
@ -1728,7 +1750,7 @@ static int chat_info_on_answer (struct query *q UU) {
struct tgl_chat *C = tglf_fetch_alloc_chat_full ();
//print_chat_info (C);
if (q->callback) {
((void (*)(void *, int, struct tgl_chat *))q->callback) (q->callback_extra, 0, C);
((void (*)(void *, int, struct tgl_chat *))q->callback) (q->callback_extra, 1, C);
}
return 0;
}
@ -1783,7 +1805,7 @@ void tgl_do_get_chat_info (tgl_peer_id_t id, int offline_mode, void (*callback)(
static int user_info_on_answer (struct query *q UU) {
struct tgl_user *U = tglf_fetch_alloc_user_full ();
if (q->callback) {
((void (*)(void *, int, struct tgl_user *))q->callback) (q->callback_extra, 0, U);
((void (*)(void *, int, struct tgl_user *))q->callback) (q->callback_extra, 1, U);
}
return 0;
}

View File

@ -580,12 +580,13 @@ void tglf_fetch_document (struct tgl_document *V) {
void tglf_fetch_message_action (struct tgl_message_action *M) {
memset (M, 0, sizeof (*M));
unsigned x = fetch_int ();
M->type = x;
switch (x) {
case CODE_message_action_empty:
M->type = tgl_message_action_none;
break;
case CODE_message_action_geo_chat_create:
{
M->type = tgl_message_action_geo_chat_create;
int l = prefetch_strlen (); // title
char *s = fetch_str (l);
int l2 = prefetch_strlen (); // checkin
@ -594,8 +595,10 @@ void tglf_fetch_message_action (struct tgl_message_action *M) {
}
break;
case CODE_message_action_geo_chat_checkin:
M->type = tgl_message_action_geo_chat_checkin;
break;
case CODE_message_action_chat_create:
M->type = tgl_message_action_chat_create;
M->title = fetch_str_dup ();
assert (fetch_int () == (int)CODE_vector);
M->user_num = fetch_int ();
@ -603,17 +606,22 @@ void tglf_fetch_message_action (struct tgl_message_action *M) {
fetch_ints (M->users, M->user_num);
break;
case CODE_message_action_chat_edit_title:
M->type = tgl_message_action_chat_edit_title;
M->new_title = fetch_str_dup ();
break;
case CODE_message_action_chat_edit_photo:
M->type = tgl_message_action_chat_edit_photo;
tglf_fetch_photo (&M->photo);
break;
case CODE_message_action_chat_delete_photo:
M->type = tgl_message_action_chat_delete_photo;
break;
case CODE_message_action_chat_add_user:
M->type = tgl_message_action_chat_add_user;
M->user = fetch_int ();
break;
case CODE_message_action_chat_delete_user:
M->type = tgl_message_action_chat_delete_user;
M->user = fetch_int ();
break;
default:
@ -681,32 +689,41 @@ void tglf_fetch_message_short_chat (struct tgl_message *M) {
void tglf_fetch_message_media (struct tgl_message_media *M) {
memset (M, 0, sizeof (*M));
M->type = fetch_int ();
switch (M->type) {
//M->type = fetch_int ();
int x = fetch_int ();
switch (x) {
case CODE_message_media_empty:
M->type = tgl_message_media_none;
break;
case CODE_message_media_photo:
M->type = tgl_message_media_photo;
tglf_fetch_photo (&M->photo);
break;
case CODE_message_media_video:
M->type = tgl_message_media_video;
tglf_fetch_video (&M->video);
break;
case CODE_message_media_audio:
M->type = tgl_message_media_audio;
tglf_fetch_audio (&M->audio);
break;
case CODE_message_media_document:
M->type = tgl_message_media_document;
tglf_fetch_document (&M->document);
break;
case CODE_message_media_geo:
M->type = tgl_message_media_geo;
tglf_fetch_geo (&M->geo);
break;
case CODE_message_media_contact:
M->type = tgl_message_media_contact;
M->phone = fetch_str_dup ();
M->first_name = fetch_str_dup ();
M->last_name = fetch_str_dup ();
M->user_id = fetch_int ();
break;
case CODE_message_media_unsupported:
M->type = tgl_message_media_unsupported;
M->data_size = prefetch_strlen ();
M->data = talloc (M->data_size);
memcpy (M->data, fetch_str (M->data_size), M->data_size);
@ -723,10 +740,12 @@ void tglf_fetch_message_media_encrypted (struct tgl_message_media *M) {
int l;
switch (x) {
case CODE_decrypted_message_media_empty:
M->type = CODE_message_media_empty;
M->type = tgl_message_media_none;
//M->type = CODE_message_media_empty;
break;
case CODE_decrypted_message_media_photo:
M->type = x;
M->type = tgl_message_media_photo_encr;
//M->type = x;
l = prefetch_strlen ();
fetch_str (l); // thumb
fetch_int (); // thumb_w
@ -756,7 +775,8 @@ void tglf_fetch_message_media_encrypted (struct tgl_message_media *M) {
break;
case CODE_decrypted_message_media_video:
case CODE_decrypted_message_media_video_l12:
M->type = CODE_decrypted_message_media_video;
//M->type = CODE_decrypted_message_media_video;
M->type = tgl_message_media_video_encr;
l = prefetch_strlen ();
fetch_str (l); // thumb
fetch_int (); // thumb_w
@ -789,7 +809,8 @@ void tglf_fetch_message_media_encrypted (struct tgl_message_media *M) {
break;
case CODE_decrypted_message_media_audio:
case CODE_decrypted_message_media_audio_l12:
M->type = CODE_decrypted_message_media_audio;
//M->type = CODE_decrypted_message_media_audio;
M->type = tgl_message_media_audio_encr;
M->encr_audio.duration = fetch_int ();
if (x == CODE_decrypted_message_media_audio) {
M->encr_audio.mime_type = fetch_str_dup ();
@ -814,7 +835,7 @@ void tglf_fetch_message_media_encrypted (struct tgl_message_media *M) {
}
break;
case CODE_decrypted_message_media_document:
M->type = x;
M->type = tgl_message_media_document_encr;
l = prefetch_strlen ();
fetch_str (l); // thumb
fetch_int (); // thumb_w
@ -857,12 +878,12 @@ void tglf_fetch_message_media_encrypted (struct tgl_message_media *M) {
break;
*/
case CODE_decrypted_message_media_geo_point:
M->type = tgl_message_media_geo;
M->geo.longitude = fetch_double ();
M->geo.latitude = fetch_double ();
M->type = CODE_message_media_geo;
break;
case CODE_decrypted_message_media_contact:
M->type = CODE_message_media_contact;
M->type = tgl_message_media_contact;
M->phone = fetch_str_dup ();
M->first_name = fetch_str_dup ();
M->last_name = fetch_str_dup ();
@ -878,11 +899,11 @@ void tglf_fetch_message_action_encrypted (struct tgl_message_action *M) {
unsigned x = fetch_int ();
switch (x) {
case CODE_decrypted_message_action_set_message_t_t_l:
M->type = x;
M->type = tgl_message_action_set_message_ttl;
M->ttl = fetch_int ();
break;
case CODE_decrypted_message_action_read_messages:
M->type = x;
M->type = tgl_message_action_read_messages;
{
assert (fetch_int () == CODE_vector);
int n = fetch_int ();
@ -897,7 +918,7 @@ void tglf_fetch_message_action_encrypted (struct tgl_message_action *M) {
}
break;
case CODE_decrypted_message_action_delete_messages:
M->type = x;
M->type = tgl_message_action_delete_messages;
{
assert (fetch_int () == CODE_vector);
int n = fetch_int ();
@ -908,7 +929,7 @@ void tglf_fetch_message_action_encrypted (struct tgl_message_action *M) {
}
break;
case CODE_decrypted_message_action_screenshot_messages:
M->type = x;
M->type = tgl_message_action_screenshot_messages;
{
assert (fetch_int () == CODE_vector);
int n = fetch_int ();
@ -919,11 +940,11 @@ void tglf_fetch_message_action_encrypted (struct tgl_message_action *M) {
}
break;
case CODE_decrypted_message_action_notify_layer:
M->type = x;
M->type = tgl_message_action_notify_layer;
M->layer = fetch_int ();
break;
case CODE_decrypted_message_action_flush_history:
M->type = x;
M->type = tgl_message_action_flush_history;
break;
default:
vlogprintf (E_ERROR, "x = 0x%08x\n", x);
@ -1168,9 +1189,9 @@ void tglf_fetch_encrypted_message_file (struct tgl_message_media *M) {
unsigned x = fetch_int ();
assert (x == CODE_encrypted_file || x == CODE_encrypted_file_empty);
if (x == CODE_encrypted_file_empty) {
assert (M->type != CODE_decrypted_message_media_photo && M->type != CODE_decrypted_message_media_video);
assert (M->type != tgl_message_media_photo_encr && M->type != tgl_message_media_video_encr);
} else {
assert (M->type == CODE_decrypted_message_media_document || M->type == CODE_decrypted_message_media_photo || M->type == CODE_decrypted_message_media_video || M->type == CODE_decrypted_message_media_audio);
assert (M->type == tgl_message_media_document_encr || M->type == tgl_message_media_photo_encr || M->type == tgl_message_media_video_encr || M->type == tgl_message_media_audio_encr);
M->encr_photo.id = fetch_long();
M->encr_photo.access_hash = fetch_long();
@ -1421,36 +1442,34 @@ void tgls_free_document (struct tgl_document *D) {
void tgls_free_message_media (struct tgl_message_media *M) {
switch (M->type) {
case CODE_message_media_empty:
case CODE_message_media_geo:
case CODE_message_media_audio:
case tgl_message_media_none:
case tgl_message_media_geo:
case tgl_message_media_audio:
return;
case CODE_message_media_photo:
case tgl_message_media_photo:
tgls_free_photo (&M->photo);
return;
case CODE_message_media_video:
case tgl_message_media_video:
tgls_free_video (&M->video);
return;
case CODE_message_media_contact:
case tgl_message_media_contact:
tfree_str (M->phone);
tfree_str (M->first_name);
tfree_str (M->last_name);
return;
case CODE_message_media_document:
case tgl_message_media_document:
tgls_free_document (&M->document);
return;
case CODE_message_media_unsupported:
case tgl_message_media_unsupported:
tfree (M->data, M->data_size);
return;
case CODE_decrypted_message_media_photo:
case CODE_decrypted_message_media_video:
case CODE_decrypted_message_media_audio:
case CODE_decrypted_message_media_document:
case tgl_message_media_photo_encr:
case tgl_message_media_video_encr:
case tgl_message_media_audio_encr:
case tgl_message_media_document_encr:
tfree_secure (M->encr_photo.key, 32);
tfree_secure (M->encr_photo.iv, 32);
return;
case 0:
break;
default:
vlogprintf (E_ERROR, "type = 0x%08x\n", M->type);
assert (0);
@ -1459,25 +1478,23 @@ void tgls_free_message_media (struct tgl_message_media *M) {
void tgls_free_message_action (struct tgl_message_action *M) {
switch (M->type) {
case CODE_message_action_empty:
case tgl_message_action_none:
break;
case CODE_message_action_chat_create:
case tgl_message_action_chat_create:
tfree_str (M->title);
tfree (M->users, M->user_num * 4);
break;
case CODE_message_action_chat_edit_title:
case tgl_message_action_chat_edit_title:
tfree_str (M->new_title);
break;
case CODE_message_action_chat_edit_photo:
case tgl_message_action_chat_edit_photo:
tgls_free_photo (&M->photo);
break;
case CODE_message_action_chat_delete_photo:
case tgl_message_action_chat_delete_photo:
break;
case CODE_message_action_chat_add_user:
case tgl_message_action_chat_add_user:
break;
case CODE_message_action_chat_delete_user:
break;
case 0:
case tgl_message_action_chat_delete_user:
break;
default:
assert (0);

View File

@ -22,6 +22,39 @@
typedef struct { int type; int id; } tgl_peer_id_t;
enum tgl_message_media_type {
tgl_message_media_none,
tgl_message_media_photo,
tgl_message_media_video,
tgl_message_media_audio,
tgl_message_media_document,
tgl_message_media_geo,
tgl_message_media_contact,
tgl_message_media_unsupported,
tgl_message_media_photo_encr,
tgl_message_media_video_encr,
tgl_message_media_audio_encr,
tgl_message_media_document_encr,
};
enum tgl_message_action_type {
tgl_message_action_none,
tgl_message_action_geo_chat_create,
tgl_message_action_geo_chat_checkin,
tgl_message_action_chat_create,
tgl_message_action_chat_edit_title,
tgl_message_action_chat_edit_photo,
tgl_message_action_chat_delete_photo,
tgl_message_action_chat_add_user,
tgl_message_action_chat_delete_user,
tgl_message_action_set_message_ttl,
tgl_message_action_read_messages,
tgl_message_action_delete_messages,
tgl_message_action_screenshot_messages,
tgl_message_action_flush_history,
tgl_message_action_notify_layer
};
struct tgl_file_location {
int dc;
long long volume;
@ -251,7 +284,7 @@ struct tgl_document {
};
struct tgl_message_action {
unsigned type;
enum tgl_message_action_type type;
union {
struct {
char *title;
@ -270,7 +303,7 @@ struct tgl_message_action {
};
struct tgl_message_media {
unsigned type;
enum tgl_message_media_type type;
union {
struct tgl_photo photo;
struct tgl_video video;

13
tgl.h
View File

@ -25,9 +25,20 @@ struct tgl_update_callback {
void (*user_registered)(struct tgl_user *U);
void (*user_activated)(struct tgl_user *U);
void (*new_authorization)(const char *device, const char *location);
void (*secret_chat_created)(struct tgl_secret_chat *E);
void (*secret_chat_request)(struct tgl_secret_chat *E);
void (*secret_chat_established)(struct tgl_secret_chat *E);
void (*secret_chat_deleted)(struct tgl_secret_chat *E);
void (*secret_chat_accepted)(struct tgl_secret_chat *E);
void (*new_user)(struct tgl_user *U);
void (*delete_user)(struct tgl_user *U);
void (*update_user_info)(struct tgl_user *U);
//void (*secret_chat_delete)(struct tgl_secret_chat *U);
//void (*secret_chat_requested)(struct tgl_secret_chat *U);
//void (*secret_chat_accepted)(struct tgl_secret_chat *U);
//void (*secret_chat_created)(struct tgl_secret_chat *U);
void (*chat_created)(struct tgl_chat *C);
void (*chat_update)(struct tgl_chat *C);
};
struct tgl_net_methods {
@ -165,7 +176,7 @@ void tgl_do_send_text (tgl_peer_id_t id, char *file, void (*callback)(void *call
void tgl_do_mark_read (tgl_peer_id_t id, void (*callback)(void *callback_extra, int success), void *callback_extra);
void tgl_do_get_history (tgl_peer_id_t id, int limit, int offline_mode, void (*callback)(void *callback_extra, int success, int size, struct tgl_message *list[]), void *callback_extra);
void tgl_do_get_dialog_list (void (*callback)(void *callback_extra, int success, int size, tgl_peer_id_t peers[], int last_msg_id[], int unread_count[]), void *callback_extra);
void tgl_do_send_photo (int type, tgl_peer_id_t to_id, char *file_name, void (*callback)(void *callback_extra, int success, struct tgl_message *M), void *callback_extra);
void tgl_do_send_photo (enum tgl_message_media_type type, tgl_peer_id_t to_id, char *file_name, void (*callback)(void *callback_extra, int success, struct tgl_message *M), void *callback_extra);
void tgl_do_forward_message (tgl_peer_id_t id, int n, void (*callback)(void *callback_extra, int success, struct tgl_message *M), void *callback_extra);
void tgl_do_rename_chat (tgl_peer_id_t id, char *name, void (*callback)(void *callback_extra, int success, struct tgl_message *M), void *callback_extra);
void tgl_do_get_chat_info (tgl_peer_id_t id, int offline_mode, void (*callback)(void *callback_extra, int success, struct tgl_chat *C), void *callback_extra);