fixes
This commit is contained in:
parent
337be90978
commit
5c1da6c955
327
binlog.c
327
binlog.c
@ -173,80 +173,63 @@ int fetch_comb_binlog_new_user (void *extra) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
int fetch_comb_binlog_new_user (void *extra) {
|
||||
int fetch_comb_binlog_user_delete (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
U->flags |= FLAG_DELETED;
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (U);
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_start)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_dc_option)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_auth_key)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_default_dc)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_our_id)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_dc_signed)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_dc_salt)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_new_user)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_user_delete)
|
||||
|
||||
void replay_log_event (void) {
|
||||
int *start = rptr;
|
||||
in_replay_log = 1;
|
||||
assert (rptr < wptr);
|
||||
int op = *rptr;
|
||||
|
||||
if (verbosity >= 2) {
|
||||
logprintf ("log_pos %lld, op 0x%08x\n", binlog_pos, op);
|
||||
}
|
||||
|
||||
in_ptr = rptr;
|
||||
in_end = wptr;
|
||||
switch (op) {
|
||||
case CODE_binlog_set_user_access_token:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_USER (*(rptr ++));
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
U->user.access_hash = *(long long *)rptr;
|
||||
rptr += 2;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_user_phone:
|
||||
in_ptr ++;
|
||||
{
|
||||
int fetch_comb_binlog_set_user_access_token (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
if (U->user.phone) { tfree_str (U->user.phone); }
|
||||
U->user.access_hash = fetch_long ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
int fetch_comb_binlog_set_user_phone (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
if (U->user.phone) {
|
||||
tfree_str (U->user.phone);
|
||||
}
|
||||
U->user.phone = fetch_str_dup ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
rptr = in_ptr;
|
||||
break;
|
||||
case CODE_binlog_set_user_friend:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_USER (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_set_user_friend (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
int friend = *(rptr ++);
|
||||
if (U->user.phone) {
|
||||
tfree_str (U->user.phone);
|
||||
}
|
||||
int friend = fetch_int ();
|
||||
if (friend) { U->flags |= FLAG_USER_CONTACT; }
|
||||
else { U->flags &= ~FLAG_USER_CONTACT; }
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_user_full_photo:
|
||||
in_ptr ++;
|
||||
{
|
||||
|
||||
int fetch_comb_binlog_user_full_photo (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
@ -254,24 +237,31 @@ void replay_log_event (void) {
|
||||
free_photo (&U->user.photo);
|
||||
}
|
||||
fetch_photo (&U->user.photo);
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
rptr = in_ptr;
|
||||
break;
|
||||
case CODE_binlog_user_blocked:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_USER (*(rptr ++));
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
U->user.blocked = *(rptr ++);
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_user_full_name:
|
||||
in_ptr ++;
|
||||
{
|
||||
|
||||
int fetch_comb_binlog_user_blocked (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
|
||||
U->user.blocked = fetch_int ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
int fetch_comb_binlog_set_user_full_name (void *extra) {
|
||||
peer_id_t id = MK_USER (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
|
||||
if (U->user.real_first_name) { tfree_str (U->user.real_first_name); }
|
||||
if (U->user.real_last_name) { tfree_str (U->user.real_last_name); }
|
||||
U->user.real_first_name = fetch_str_dup ();
|
||||
@ -280,13 +270,11 @@ void replay_log_event (void) {
|
||||
#ifdef USE_LUA
|
||||
lua_user_update (&U->user);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
rptr = in_ptr;
|
||||
break;
|
||||
case CODE_binlog_encr_chat_delete:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_encr_chat_delete (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *_U = user_chat_get (id);
|
||||
assert (_U);
|
||||
struct secret_chat *U = &_U->encr_chat;
|
||||
@ -301,12 +289,15 @@ void replay_log_event (void) {
|
||||
tfree_secure (U->g_key, 256);
|
||||
U->g_key = 0;
|
||||
}
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (U);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_encr_chat_requested:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_encr_chat_requested (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *_U = user_chat_get (id);
|
||||
if (!_U) {
|
||||
_U = talloc0 (sizeof (*_U));
|
||||
@ -316,11 +307,10 @@ void replay_log_event (void) {
|
||||
assert (!(_U->flags & FLAG_CREATED));
|
||||
}
|
||||
struct secret_chat *U = (void *)_U;
|
||||
U->access_hash = *(long long *)rptr;
|
||||
rptr += 2;
|
||||
U->date = *(rptr ++);
|
||||
U->admin_id = *(rptr ++);
|
||||
U->user_id = *(rptr ++);
|
||||
U->access_hash = fetch_long ();
|
||||
U->date = fetch_int ();
|
||||
U->admin_id = fetch_int ();
|
||||
U->user_id = fetch_int ();
|
||||
|
||||
peer_t *Us = user_chat_get (MK_USER (U->user_id));
|
||||
assert (!U->print_name);
|
||||
@ -334,47 +324,56 @@ void replay_log_event (void) {
|
||||
peer_insert_name ((void *)U);
|
||||
U->g_key = talloc (256);
|
||||
U->nonce = talloc (256);
|
||||
memcpy (U->g_key, rptr, 256);
|
||||
rptr += 64;
|
||||
memcpy (U->nonce, rptr, 256);
|
||||
rptr += 64;
|
||||
fetch_ints (U->g_key, 64);
|
||||
fetch_ints (U->nonce, 64);
|
||||
|
||||
U->flags |= FLAG_CREATED;
|
||||
U->state = sc_request;
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (U);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_encr_chat_access_hash:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_set_encr_chat_access_hash (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
U->encr_chat.access_hash = *(long long *)rptr;
|
||||
rptr += 2;
|
||||
U->encr_chat.access_hash = fetch_long ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (&U->encr_chat);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_encr_chat_date:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_set_encr_chat_date (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
U->encr_chat.date = *(rptr ++);
|
||||
U->encr_chat.date = fetch_int ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (&U->encr_chat);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_encr_chat_state:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_set_encr_chat_state (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *U = user_chat_get (id);
|
||||
assert (U);
|
||||
U->encr_chat.state = *(rptr ++);
|
||||
U->encr_chat.state = fetch_int ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (&U->encr_chat);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_encr_chat_accepted:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_encr_chat_accepted (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *_U = user_chat_get (id);
|
||||
assert (_U);
|
||||
struct secret_chat *U = &_U->encr_chat;
|
||||
@ -384,42 +383,106 @@ void replay_log_event (void) {
|
||||
if (!U->nonce) {
|
||||
U->nonce = talloc (256);
|
||||
}
|
||||
memcpy (U->g_key, rptr, 256);
|
||||
rptr += 64;
|
||||
memcpy (U->nonce, rptr, 256);
|
||||
rptr += 64;
|
||||
U->key_fingerprint = *(long long *)rptr;
|
||||
rptr += 2;
|
||||
|
||||
fetch_ints (U->g_key, 256);
|
||||
fetch_ints (U->nonce, 256);
|
||||
U->key_fingerprint = fetch_long ();
|
||||
|
||||
if (U->state == sc_waiting) {
|
||||
do_create_keys_end (U);
|
||||
}
|
||||
U->state = sc_ok;
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (U);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_encr_chat_key:
|
||||
rptr ++;
|
||||
{
|
||||
peer_id_t id = MK_ENCR_CHAT (*(rptr ++));
|
||||
|
||||
int fetch_comb_binlog_set_encr_chat_key (void *extra) {
|
||||
peer_id_t id = MK_ENCR_CHAT (fetch_int ());
|
||||
peer_t *_U = user_chat_get (id);
|
||||
assert (_U);
|
||||
struct secret_chat *U = &_U->encr_chat;
|
||||
memcpy (U->key, rptr, 256);
|
||||
rptr += 64;
|
||||
U->key_fingerprint = *(long long *)rptr;
|
||||
rptr += 2;
|
||||
fetch_ints (U->key, 64);
|
||||
U->key_fingerprint = fetch_long ();
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (U);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
case CODE_binlog_set_dh_params:
|
||||
rptr ++;
|
||||
{
|
||||
|
||||
int fetch_comb_binlog_set_dh_params (void *extra) {
|
||||
if (encr_prime) { tfree (encr_prime, 256); }
|
||||
encr_root = *(rptr ++);
|
||||
encr_root = fetch_int ();
|
||||
encr_prime = talloc (256);
|
||||
memcpy (encr_prime, rptr, 256);
|
||||
rptr += 64;
|
||||
encr_param_version = *(rptr ++);
|
||||
fetch_ints (encr_prime, 64);
|
||||
encr_param_version = fetch_int ();
|
||||
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
|
||||
int fetch_comb_binlog_encr_chat_init (void *extra) {
|
||||
peer_t *P = talloc0 (sizeof (*P));
|
||||
P->id = MK_ENCR_CHAT (fetch_int ());
|
||||
assert (!user_chat_get (P->id));
|
||||
P->encr_chat.user_id = fetch_int ();
|
||||
P->encr_chat.admin_id = our_id;
|
||||
insert_encrypted_chat (P);
|
||||
peer_t *Us = user_chat_get (MK_USER (P->encr_chat.user_id));
|
||||
assert (Us);
|
||||
P->print_name = create_print_name (P->id, "!", Us->user.first_name, Us->user.last_name, 0);
|
||||
peer_insert_name (P);
|
||||
|
||||
fetch_ints (P->encr_chat.key, 64);
|
||||
fetch_ints (P->encr_chat.g_key, 64);
|
||||
P->flags |= FLAG_CREATED;
|
||||
|
||||
#ifdef USE_LUA
|
||||
lua_secret_chat_update (U);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_start)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_dc_option)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_auth_key)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_default_dc)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_our_id)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_dc_signed)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_dc_salt)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_new_user)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_user_delete)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_user_access_token)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_user_phone)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_user_friend)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_user_full_photo)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_user_blocked)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_user_full_name)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_encr_chat_delete)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_encr_chat_requested)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_encr_chat_access_hash)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_encr_chat_date)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_encr_chat_state)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_encr_chat_accepted)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_encr_chat_key)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_set_dh_params)
|
||||
FETCH_COMBINATOR_FUNCTION (binlog_encr_chat_init)
|
||||
|
||||
void replay_log_event (void) {
|
||||
int *start = rptr;
|
||||
in_replay_log = 1;
|
||||
assert (rptr < wptr);
|
||||
int op = *rptr;
|
||||
|
||||
if (verbosity >= 2) {
|
||||
logprintf ("log_pos %lld, op 0x%08x\n", binlog_pos, op);
|
||||
}
|
||||
|
||||
in_ptr = rptr;
|
||||
in_end = wptr;
|
||||
switch (op) {
|
||||
case CODE_binlog_encr_chat_init:
|
||||
rptr ++;
|
||||
{
|
||||
|
15
binlog.h
15
binlog.h
@ -36,22 +36,7 @@
|
||||
#define LOG_ENCR_CHAT_REQUESTED 0x9011011a
|
||||
#define LOG_ENCR_CHAT_OK 0x7612ce13
|
||||
|
||||
#define CODE_binlog_user_delete 0xf7a27c79
|
||||
#define CODE_binlog_set_user_access_token 0x1349f615
|
||||
#define CODE_binlog_set_user_phone 0x5d3afde2
|
||||
#define CODE_binlog_set_user_friend 0x75a7ec5a
|
||||
#define CODE_binlog_dc_option 0x08c0ef19
|
||||
#define CODE_binlog_user_full_photo 0xfaa35824
|
||||
#define CODE_binlog_user_blocked 0xb2dea7cd
|
||||
#define CODE_binlog_set_user_full_name 0x4ceb4cf0
|
||||
#define CODE_binlog_encr_chat_delete 0xb9d33f87
|
||||
#define CODE_binlog_encr_chat_requested 0xf57d1ea2
|
||||
#define CODE_binlog_set_encr_chat_access_hash 0xe5612bb3
|
||||
#define CODE_binlog_set_encr_chat_date 0x54f16911
|
||||
#define CODE_binlog_set_encr_chat_state 0x76a6e45b
|
||||
#define CODE_binlog_encr_chat_accepted 0x4627e926
|
||||
#define CODE_binlog_set_encr_chat_key 0x179df2d4
|
||||
#define CODE_binlog_set_dh_params 0x20ba46bc
|
||||
#define CODE_binlog_encr_chat_init 0x939cd1c7
|
||||
#define CODE_binlog_set_pts 0x844e4c1c
|
||||
#define CODE_binlog_set_qts 0x3cf22b79
|
||||
|
18
binlog.tl
18
binlog.tl
@ -7,5 +7,23 @@ binlog.ourId id:int = binlog.Update;
|
||||
binlog.dcSigned id:int = binlog.Update;
|
||||
binlog.dcSalt id:int salt:long = binlog.Update;
|
||||
|
||||
binlog.setDhParams root:int prime:64*[int] version:int = binlog.Update;
|
||||
|
||||
binlog.newUser id:int first_name:string last_name:string hash:long phone:string is_contact:int = binlog.Update;
|
||||
binlog.userDelete id:int = binlog.Update;
|
||||
binlog.setUserAccessToken id:int hash:long = binlog.Update;
|
||||
binlog.setUserPhone id:int phone:string = binlog.Update;
|
||||
binlog.setUserFriend id:int friend:int = binlog.Update;
|
||||
binlog.userFullPhoto id:int photo:Photo = binlog.Update;
|
||||
binlog.userBlocked id:int blocked:int = binlog.Update;
|
||||
binlog.setUserFullName id:int real_first_name:string real_last_name:string = binlog.Update;
|
||||
|
||||
binlog.encrChatDelete id:int = binlog.Update;
|
||||
binlog.encrChatRequested id:int hash:long date:int admin:int user:int key:64*[int] nonce:64*[int] = binlog.Update;
|
||||
binlog.setEncrChatAccessHash id:int hash:long = binlog.Update;
|
||||
binlog.setEncrChatDate id:int date:int = binlog.Update;
|
||||
binlog.setEncrChatState id:int state:int = binlog.Update;
|
||||
binlog.encrChatAccepted id:int key:64*[int] nonce:64*[int] fingerprint:long = binlog.Update;
|
||||
binlog.setEncrChatKey id:int key:64*[int] fingerprint:long = binlog.Update;
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user