Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
T
tg
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
tg
Commits
168c6b7a
Commit
168c6b7a
authored
Nov 25, 2013
by
Vysheng
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
added chat info to binlog
parent
20adb1af
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
268 additions
and
80 deletions
+268
-80
binlog.c
binlog.c
+138
-0
binlog.h
binlog.h
+10
-1
mtproto-client.c
mtproto-client.c
+62
-29
queries.c
queries.c
+7
-7
structures.c
structures.c
+48
-42
structures.h
structures.h
+3
-1
No files found.
binlog.c
View file @
168c6b7a
...
@@ -616,6 +616,93 @@ void replay_log_event (void) {
...
@@ -616,6 +616,93 @@ void replay_log_event (void) {
C
->
chat
.
users_num
=
*
(
rptr
++
);
C
->
chat
.
users_num
=
*
(
rptr
++
);
};
};
break
;
break
;
case
CODE_binlog_set_chat_admin
:
rptr
++
;
{
peer_t
*
C
=
user_chat_get
(
MK_CHAT
(
*
(
rptr
++
)));
assert
(
C
&&
(
C
->
flags
&
FLAG_CREATED
));
C
->
chat
.
admin_id
=
*
(
rptr
++
);
};
break
;
case
CODE_binlog_set_chat_participants
:
rptr
++
;
{
peer_t
*
C
=
user_chat_get
(
MK_CHAT
(
*
(
rptr
++
)));
assert
(
C
&&
(
C
->
flags
&
FLAG_CREATED
));
C
->
chat
.
user_list_version
=
*
(
rptr
++
);
C
->
chat
.
user_list_size
=
*
(
rptr
++
);
if
(
C
->
chat
.
user_list
)
{
free
(
C
->
chat
.
user_list
);
}
C
->
chat
.
user_list
=
malloc
(
12
*
C
->
chat
.
user_list_size
);
memcpy
(
C
->
chat
.
user_list
,
rptr
,
12
*
C
->
chat
.
user_list_size
);
rptr
+=
3
*
C
->
chat
.
user_list_size
;
};
break
;
case
CODE_binlog_chat_full_photo
:
in_ptr
++
;
{
peer_id_t
id
=
MK_CHAT
(
fetch_int
());
peer_t
*
U
=
user_chat_get
(
id
);
assert
(
U
&&
(
U
->
flags
&
FLAG_CREATED
));
if
(
U
->
flags
&
FLAG_HAS_PHOTO
)
{
free_photo
(
&
U
->
chat
.
photo
);
}
fetch_photo
(
&
U
->
chat
.
photo
);
}
rptr
=
in_ptr
;
break
;
case
CODE_binlog_add_chat_participant
:
rptr
++
;
{
peer_id_t
id
=
MK_CHAT
(
*
(
rptr
++
));
peer_t
*
_C
=
user_chat_get
(
id
);
assert
(
_C
&&
(
_C
->
flags
&
FLAG_CREATED
));
struct
chat
*
C
=
&
_C
->
chat
;
int
version
=
*
(
rptr
++
);
int
user
=
*
(
rptr
++
);
int
inviter
=
*
(
rptr
++
);
int
date
=
*
(
rptr
++
);
assert
(
C
->
user_list_version
<
version
);
int
i
;
for
(
i
=
0
;
i
<
C
->
user_list_size
;
i
++
)
{
assert
(
C
->
user_list
[
i
].
user_id
!=
user
);
}
C
->
user_list_size
++
;
C
->
user_list
=
realloc
(
C
->
user_list
,
12
*
C
->
user_list_size
);
C
->
user_list
[
C
->
user_list_size
-
1
].
user_id
=
user
;
C
->
user_list
[
C
->
user_list_size
-
1
].
inviter_id
=
inviter
;
C
->
user_list
[
C
->
user_list_size
-
1
].
date
=
date
;
C
->
user_list_version
=
version
;
}
break
;
case
CODE_binlog_del_chat_participant
:
rptr
++
;
{
peer_id_t
id
=
MK_CHAT
(
*
(
rptr
++
));
peer_t
*
_C
=
user_chat_get
(
id
);
assert
(
_C
&&
(
_C
->
flags
&
FLAG_CREATED
));
struct
chat
*
C
=
&
_C
->
chat
;
int
version
=
*
(
rptr
++
);
int
user
=
*
(
rptr
++
);
assert
(
C
->
user_list_version
<
version
);
int
i
;
for
(
i
=
0
;
i
<
C
->
user_list_size
;
i
++
)
{
if
(
C
->
user_list
[
i
].
user_id
==
user
)
{
struct
chat_user
t
;
t
=
C
->
user_list
[
i
];
C
->
user_list
[
i
]
=
C
->
user_list
[
C
->
user_list_size
-
1
];
C
->
user_list
[
C
->
user_list_size
-
1
]
=
t
;
}
}
assert
(
C
->
user_list
[
C
->
user_list_size
-
1
].
user_id
==
user
);
C
->
user_list_size
--
;
C
->
user_list
=
realloc
(
C
->
user_list
,
12
*
C
->
user_list_size
);
C
->
user_list_version
=
version
;
}
break
;
case
CODE_update_user_photo
:
case
CODE_update_user_photo
:
case
CODE_update_user_name
:
case
CODE_update_user_name
:
work_update_binlog
();
work_update_binlog
();
...
@@ -1120,3 +1207,54 @@ void bl_do_set_chat_version (struct chat *C, int version, int user_num) {
...
@@ -1120,3 +1207,54 @@ void bl_do_set_chat_version (struct chat *C, int version, int user_num) {
ev
[
3
]
=
user_num
;
ev
[
3
]
=
user_num
;
add_log_event
(
ev
,
16
);
add_log_event
(
ev
,
16
);
}
}
void
bl_do_set_chat_admin
(
struct
chat
*
C
,
int
admin
)
{
if
(
C
->
admin_id
==
admin
)
{
return
;
}
int
*
ev
=
alloc_log_event
(
12
);
ev
[
0
]
=
CODE_binlog_set_chat_admin
;
ev
[
1
]
=
get_peer_id
(
C
->
id
);
ev
[
2
]
=
admin
;
add_log_event
(
ev
,
12
);
}
void
bl_do_set_chat_participants
(
struct
chat
*
C
,
int
version
,
int
user_num
,
struct
chat_user
*
users
)
{
if
(
C
->
user_list_version
>=
version
)
{
return
;
}
int
*
ev
=
alloc_log_event
(
12
*
user_num
+
16
);
ev
[
0
]
=
CODE_binlog_set_chat_participants
;
ev
[
1
]
=
get_peer_id
(
C
->
id
);
ev
[
2
]
=
version
;
ev
[
3
]
=
user_num
;
memcpy
(
ev
+
4
,
users
,
12
*
user_num
);
add_log_event
(
ev
,
12
*
user_num
+
16
);
}
void
bl_do_set_chat_full_photo
(
struct
chat
*
U
,
const
int
*
start
,
int
len
)
{
if
(
U
->
photo
.
id
==
*
(
long
long
*
)(
start
+
1
))
{
return
;
}
int
*
ev
=
alloc_log_event
(
len
+
8
);
ev
[
0
]
=
CODE_binlog_chat_full_photo
;
ev
[
1
]
=
get_peer_id
(
U
->
id
);
memcpy
(
ev
+
2
,
start
,
len
);
add_log_event
(
ev
,
len
+
8
);
}
void
bl_do_chat_add_user
(
struct
chat
*
C
,
int
version
,
int
user
,
int
inviter
,
int
date
)
{
if
(
C
->
user_list_version
>=
version
||
!
C
->
user_list_version
)
{
return
;
}
int
*
ev
=
alloc_log_event
(
24
);
ev
[
0
]
=
CODE_binlog_add_chat_participant
;
ev
[
1
]
=
get_peer_id
(
C
->
id
);
ev
[
2
]
=
version
;
ev
[
3
]
=
user
;
ev
[
4
]
=
inviter
;
ev
[
5
]
=
date
;
add_log_event
(
ev
,
24
);
}
void
bl_do_chat_del_user
(
struct
chat
*
C
,
int
version
,
int
user
)
{
if
(
C
->
user_list_version
>=
version
||
!
C
->
user_list_version
)
{
return
;
}
int
*
ev
=
alloc_log_event
(
16
);
ev
[
0
]
=
CODE_binlog_add_chat_participant
;
ev
[
1
]
=
get_peer_id
(
C
->
id
);
ev
[
2
]
=
version
;
ev
[
3
]
=
user
;
add_log_event
(
ev
,
16
);
}
binlog.h
View file @
168c6b7a
...
@@ -46,7 +46,11 @@
...
@@ -46,7 +46,11 @@
#define CODE_binlog_set_chat_photo 0xb4ea1fd2
#define CODE_binlog_set_chat_photo 0xb4ea1fd2
#define CODE_binlog_set_chat_date 0x78d1114e
#define CODE_binlog_set_chat_date 0x78d1114e
#define CODE_binlog_set_chat_version 0xa5d3504f
#define CODE_binlog_set_chat_version 0xa5d3504f
#define CODE_binlog_set_chat_admin 0x1e7cea04
#define CODE_binlog_set_chat_participants 0x3a29d335
#define CODE_binlog_chat_full_photo 0x6cca6629
#define CODE_binlog_add_chat_participant 0x63345108
#define CODE_binlog_del_chat_participant 0x82d1f0ee
void
*
alloc_log_event
(
int
l
);
void
*
alloc_log_event
(
int
l
);
void
replay_log
(
void
);
void
replay_log
(
void
);
...
@@ -93,4 +97,9 @@ void bl_do_set_chat_photo (struct chat *C, struct file_location *big, struct fil
...
@@ -93,4 +97,9 @@ void bl_do_set_chat_photo (struct chat *C, struct file_location *big, struct fil
void
bl_do_set_chat_date
(
struct
chat
*
C
,
int
date
);
void
bl_do_set_chat_date
(
struct
chat
*
C
,
int
date
);
void
bl_do_set_chat_set_in_chat
(
struct
chat
*
C
,
int
on
);
void
bl_do_set_chat_set_in_chat
(
struct
chat
*
C
,
int
on
);
void
bl_do_set_chat_version
(
struct
chat
*
C
,
int
version
,
int
user_num
);
void
bl_do_set_chat_version
(
struct
chat
*
C
,
int
version
,
int
user_num
);
void
bl_do_set_chat_admin
(
struct
chat
*
C
,
int
admin
);
void
bl_do_set_chat_participants
(
struct
chat
*
C
,
int
version
,
int
user_num
,
struct
chat_user
*
users
);
void
bl_do_set_chat_full_photo
(
struct
chat
*
U
,
const
int
*
start
,
int
len
);
void
bl_do_chat_add_user
(
struct
chat
*
C
,
int
version
,
int
user
,
int
inviter
,
int
date
);
void
bl_do_chat_del_user
(
struct
chat
*
C
,
int
version
,
int
user
);
#endif
#endif
mtproto-client.c
View file @
168c6b7a
...
@@ -701,7 +701,7 @@ void fetch_seq (void) {
...
@@ -701,7 +701,7 @@ void fetch_seq (void) {
int
x
=
fetch_int
();
int
x
=
fetch_int
();
if
(
x
>
seq
+
1
)
{
if
(
x
>
seq
+
1
)
{
logprintf
(
"Hole in seq: seq = %d, x = %d
\n
"
,
seq
,
x
);
logprintf
(
"Hole in seq: seq = %d, x = %d
\n
"
,
seq
,
x
);
//
do_get_difference ();
do_get_difference
();
//seq = x;
//seq = x;
}
else
if
(
x
==
seq
+
1
)
{
}
else
if
(
x
==
seq
+
1
)
{
seq
=
x
;
seq
=
x
;
...
@@ -879,19 +879,18 @@ void work_update (struct connection *c UU, long long msg_id UU) {
...
@@ -879,19 +879,18 @@ void work_update (struct connection *c UU, long long msg_id UU) {
{
{
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_t
*
UC
=
user_chat_get
(
user_id
);
peer_t
*
UC
=
user_chat_get
(
user_id
);
if
(
UC
)
{
if
(
UC
&&
(
UC
->
flags
&
FLAG_CREATED
))
{
int
l1
=
prefetch_strlen
();
char
*
f
=
fetch_str
(
l1
);
int
l2
=
prefetch_strlen
();
char
*
l
=
fetch_str
(
l2
);
struct
user
*
U
=
&
UC
->
user
;
struct
user
*
U
=
&
UC
->
user
;
bl_do_set_user_name
(
U
,
f
,
l1
,
l
,
l2
);
print_start
();
print_start
();
push_color
(
COLOR_YELLOW
);
push_color
(
COLOR_YELLOW
);
print_date
(
time
(
0
));
print_date
(
time
(
0
));
printf
(
" User "
);
printf
(
" User "
);
print_user_name
(
user_id
,
UC
);
print_user_name
(
user_id
,
UC
);
if
(
U
->
first_name
)
{
free
(
U
->
first_name
);
}
if
(
U
->
last_name
)
{
free
(
U
->
last_name
);
}
if
(
U
->
print_name
)
{
free
(
U
->
print_name
);
}
U
->
first_name
=
fetch_str_dup
();
U
->
last_name
=
fetch_str_dup
();
U
->
print_name
=
create_print_name
(
U
->
id
,
U
->
first_name
,
U
->
last_name
,
0
,
0
);
printf
(
" changed name to "
);
printf
(
" changed name to "
);
print_user_name
(
user_id
,
UC
);
print_user_name
(
user_id
,
UC
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
...
@@ -911,8 +910,25 @@ void work_update (struct connection *c UU, long long msg_id UU) {
...
@@ -911,8 +910,25 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_t
*
UC
=
user_chat_get
(
user_id
);
peer_t
*
UC
=
user_chat_get
(
user_id
);
fetch_date
();
fetch_date
();
if
(
UC
)
{
if
(
UC
&&
(
UC
->
flags
&
FLAG_CREATED
)
)
{
struct
user
*
U
=
&
UC
->
user
;
struct
user
*
U
=
&
UC
->
user
;
unsigned
y
=
fetch_int
();
long
long
photo_id
;
struct
file_location
big
;
struct
file_location
small
;
memset
(
&
big
,
0
,
sizeof
(
big
));
memset
(
&
small
,
0
,
sizeof
(
small
));
if
(
y
==
CODE_user_profile_photo_empty
)
{
photo_id
=
0
;
big
.
dc
=
-
2
;
small
.
dc
=
-
2
;
}
else
{
assert
(
y
==
CODE_user_profile_photo
);
photo_id
=
fetch_long
();
fetch_file_location
(
&
small
);
fetch_file_location
(
&
big
);
}
bl_do_set_user_profile_photo
(
U
,
photo_id
,
&
big
,
&
small
);
print_start
();
print_start
();
push_color
(
COLOR_YELLOW
);
push_color
(
COLOR_YELLOW
);
...
@@ -922,17 +938,6 @@ void work_update (struct connection *c UU, long long msg_id UU) {
...
@@ -922,17 +938,6 @@ void work_update (struct connection *c UU, long long msg_id UU) {
printf
(
" updated profile photo
\n
"
);
printf
(
" updated profile photo
\n
"
);
pop_color
();
pop_color
();
print_end
();
print_end
();
unsigned
y
=
fetch_int
();
if
(
y
==
CODE_user_profile_photo_empty
)
{
U
->
photo_id
=
0
;
U
->
photo_big
.
dc
=
-
2
;
U
->
photo_small
.
dc
=
-
2
;
}
else
{
assert
(
y
==
CODE_user_profile_photo
);
U
->
photo_id
=
fetch_long
();
fetch_file_location
(
&
U
->
photo_small
);
fetch_file_location
(
&
U
->
photo_big
);
}
}
else
{
}
else
{
struct
file_location
t
;
struct
file_location
t
;
unsigned
y
=
fetch_int
();
unsigned
y
=
fetch_int
();
...
@@ -981,14 +986,32 @@ void work_update (struct connection *c UU, long long msg_id UU) {
...
@@ -981,14 +986,32 @@ void work_update (struct connection *c UU, long long msg_id UU) {
assert
(
x
==
CODE_chat_participants
||
x
==
CODE_chat_participants_forbidden
);
assert
(
x
==
CODE_chat_participants
||
x
==
CODE_chat_participants_forbidden
);
peer_id_t
chat_id
=
MK_CHAT
(
fetch_int
());
peer_id_t
chat_id
=
MK_CHAT
(
fetch_int
());
int
n
=
0
;
int
n
=
0
;
peer_t
*
C
=
user_chat_get
(
chat_id
);
if
(
C
&&
(
C
->
flags
&
FLAG_CREATED
))
{
if
(
x
==
CODE_chat_participants
)
{
bl_do_set_chat_admin
(
&
C
->
chat
,
fetch_int
());
assert
(
fetch_int
()
==
CODE_vector
);
n
=
fetch_int
();
struct
chat_user
*
users
=
malloc
(
12
*
n
);
int
i
;
for
(
i
=
0
;
i
<
n
;
i
++
)
{
assert
(
fetch_int
()
==
(
int
)
CODE_chat_participant
);
users
[
i
].
user_id
=
fetch_int
();
users
[
i
].
inviter_id
=
fetch_int
();
users
[
i
].
date
=
fetch_int
();
}
int
version
=
fetch_int
();
bl_do_set_chat_participants
(
&
C
->
chat
,
version
,
n
,
users
);
}
}
else
{
if
(
x
==
CODE_chat_participants
)
{
if
(
x
==
CODE_chat_participants
)
{
fetch_int
();
// admin_id
fetch_int
();
// admin_id
assert
(
fetch_int
()
==
CODE_vector
);
assert
(
fetch_int
()
==
CODE_vector
);
int
n
=
fetch_int
();
n
=
fetch_int
();
fetch_skip
(
n
*
4
);
fetch_skip
(
n
*
4
);
fetch_int
();
// version
fetch_int
();
// version
}
}
peer_t
*
C
=
user_chat_get
(
chat_id
);
}
print_start
();
print_start
();
push_color
(
COLOR_YELLOW
);
push_color
(
COLOR_YELLOW
);
print_date
(
time
(
0
));
print_date
(
time
(
0
));
...
@@ -1187,7 +1210,12 @@ void work_update (struct connection *c UU, long long msg_id UU) {
...
@@ -1187,7 +1210,12 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_id_t
chat_id
=
MK_CHAT
(
fetch_int
());
peer_id_t
chat_id
=
MK_CHAT
(
fetch_int
());
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_id_t
inviter_id
=
MK_USER
(
fetch_int
());
peer_id_t
inviter_id
=
MK_USER
(
fetch_int
());
fetch_int
();
// version
int
version
=
fetch_int
();
peer_t
*
C
=
user_chat_get
(
chat_id
);
if
(
C
&&
(
C
->
flags
&
FLAG_CREATED
))
{
bl_do_chat_add_user
(
&
C
->
chat
,
version
,
get_peer_id
(
user_id
),
get_peer_id
(
inviter_id
),
time
(
0
));
}
print_start
();
print_start
();
push_color
(
COLOR_YELLOW
);
push_color
(
COLOR_YELLOW
);
...
@@ -1207,7 +1235,12 @@ void work_update (struct connection *c UU, long long msg_id UU) {
...
@@ -1207,7 +1235,12 @@ void work_update (struct connection *c UU, long long msg_id UU) {
{
{
peer_id_t
chat_id
=
MK_CHAT
(
fetch_int
());
peer_id_t
chat_id
=
MK_CHAT
(
fetch_int
());
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
peer_id_t
user_id
=
MK_USER
(
fetch_int
());
fetch_int
();
// version
int
version
=
fetch_int
();
peer_t
*
C
=
user_chat_get
(
chat_id
);
if
(
C
&&
(
C
->
flags
&
FLAG_CREATED
))
{
bl_do_chat_del_user
(
&
C
->
chat
,
version
,
get_peer_id
(
user_id
));
}
print_start
();
print_start
();
push_color
(
COLOR_YELLOW
);
push_color
(
COLOR_YELLOW
);
...
...
queries.c
View file @
168c6b7a
...
@@ -1618,14 +1618,14 @@ int chat_info_on_answer (struct query *q UU) {
...
@@ -1618,14 +1618,14 @@ int chat_info_on_answer (struct query *q UU) {
print_chat_name
(
U
->
id
,
U
);
print_chat_name
(
U
->
id
,
U
);
printf
(
" members:
\n
"
);
printf
(
" members:
\n
"
);
int
i
;
int
i
;
for
(
i
=
0
;
i
<
C
->
user
s_num
;
i
++
)
{
for
(
i
=
0
;
i
<
C
->
user
_list_size
;
i
++
)
{
printf
(
"
\t\t
"
);
printf
(
"
\t\t
"
);
print_user_name
(
MK_USER
(
C
->
user
s
[
i
].
user_id
),
user_chat_get
(
MK_USER
(
C
->
users
[
i
].
user_id
)));
print_user_name
(
MK_USER
(
C
->
user
_list
[
i
].
user_id
),
user_chat_get
(
MK_USER
(
C
->
user_list
[
i
].
user_id
)));
printf
(
" invited by "
);
printf
(
" invited by "
);
print_user_name
(
MK_USER
(
C
->
user
s
[
i
].
inviter_id
),
user_chat_get
(
MK_USER
(
C
->
users
[
i
].
inviter_id
)));
print_user_name
(
MK_USER
(
C
->
user
_list
[
i
].
inviter_id
),
user_chat_get
(
MK_USER
(
C
->
user_list
[
i
].
inviter_id
)));
printf
(
" at "
);
printf
(
" at "
);
print_date_full
(
C
->
user
s
[
i
].
date
);
print_date_full
(
C
->
user
_list
[
i
].
date
);
if
(
C
->
user
s
[
i
].
user_id
==
C
->
admin_id
)
{
if
(
C
->
user
_list
[
i
].
user_id
==
C
->
admin_id
)
{
printf
(
" admin"
);
printf
(
" admin"
);
}
}
printf
(
"
\n
"
);
printf
(
"
\n
"
);
...
@@ -2424,8 +2424,8 @@ int get_difference_on_answer (struct query *q UU) {
...
@@ -2424,8 +2424,8 @@ int get_difference_on_answer (struct query *q UU) {
get_difference_active
=
0
;
get_difference_active
=
0
;
unsigned
x
=
fetch_int
();
unsigned
x
=
fetch_int
();
if
(
x
==
CODE_updates_difference_empty
)
{
if
(
x
==
CODE_updates_difference_empty
)
{
fetch_date
(
);
bl_do_set_date
(
fetch_int
()
);
fetch_seq
(
);
bl_do_set_seq
(
fetch_int
()
);
difference_got
=
1
;
difference_got
=
1
;
}
else
if
(
x
==
CODE_updates_difference
||
x
==
CODE_updates_difference_slice
)
{
}
else
if
(
x
==
CODE_updates_difference
||
x
==
CODE_updates_difference_slice
)
{
int
n
,
i
;
int
n
,
i
;
...
...
structures.c
View file @
168c6b7a
...
@@ -34,14 +34,33 @@
...
@@ -34,14 +34,33 @@
#define sha1 SHA1
#define sha1 SHA1
static
int
id_cmp
(
struct
message
*
M1
,
struct
message
*
M2
);
#define peer_cmp(a,b) (cmp_peer_id (a->id, b->id))
DEFINE_TREE
(
peer
,
peer_t
*
,
peer_cmp
,
0
)
DEFINE_TREE
(
message
,
struct
message
*
,
id_cmp
,
0
)
struct
message
message_list
=
{
.
next_use
=
&
message_list
,
.
prev_use
=
&
message_list
};
struct
tree_peer
*
peer_tree
;
struct
tree_message
*
message_tree
;
int
users_allocated
;
int
chats_allocated
;
int
messages_allocated
;
int
our_id
;
int
verbosity
;
int
verbosity
;
peer_t
*
Peers
[
MAX_USER_NUM
];
peer_t
*
Peers
[
MAX_USER_NUM
];
int
peer_num
;
int
peer_num
;
int
encr_chats_allocated
;
int
encr_chats_allocated
;
int
geo_chats_allocated
;
int
geo_chats_allocated
;
extern
int
binlog_enabled
;
extern
int
binlog_enabled
;
void
fetch_skip_photo
(
void
);
void
fetch_skip_photo
(
void
);
#define code_assert(x) if (!(x)) { logprintf ("Can not parse at line %d\n", __LINE__); assert (0); return -1; }
#define code_assert(x) if (!(x)) { logprintf ("Can not parse at line %d\n", __LINE__); assert (0); return -1; }
...
@@ -98,8 +117,6 @@ int fetch_user_status (struct user_status *S) {
...
@@ -98,8 +117,6 @@ int fetch_user_status (struct user_status *S) {
return
0
;
return
0
;
}
}
int
our_id
;
char
*
create_print_name
(
peer_id_t
id
,
const
char
*
a1
,
const
char
*
a2
,
const
char
*
a3
,
const
char
*
a4
)
{
char
*
create_print_name
(
peer_id_t
id
,
const
char
*
a1
,
const
char
*
a2
,
const
char
*
a3
,
const
char
*
a4
)
{
const
char
*
d
[
4
];
const
char
*
d
[
4
];
d
[
0
]
=
a1
;
d
[
1
]
=
a2
;
d
[
2
]
=
a3
;
d
[
3
]
=
a4
;
d
[
0
]
=
a1
;
d
[
1
]
=
a2
;
d
[
2
]
=
a3
;
d
[
3
]
=
a4
;
...
@@ -516,35 +533,32 @@ void fetch_chat_full (struct chat *C) {
...
@@ -516,35 +533,32 @@ void fetch_chat_full (struct chat *C) {
assert
(
x
==
CODE_messages_chat_full
);
assert
(
x
==
CODE_messages_chat_full
);
assert
(
fetch_int
()
==
CODE_chat_full
);
assert
(
fetch_int
()
==
CODE_chat_full
);
C
->
id
=
MK_CHAT
(
fetch_int
());
C
->
id
=
MK_CHAT
(
fetch_int
());
C
->
flags
&=
~
(
FLAG_DELETED
|
FLAG_FORBIDDEN
|
FLAG_CHAT_IN_CHAT
);
//
C->flags &= ~(FLAG_DELETED | FLAG_FORBIDDEN | FLAG_CHAT_IN_CHAT);
C
->
flags
|=
FLAG_CREATED
;
//
C->flags |= FLAG_CREATED;
x
=
fetch_int
();
x
=
fetch_int
();
int
version
=
0
;
struct
chat_user
*
users
=
0
;
int
users_num
=
0
;
int
admin_id
=
0
;
if
(
x
==
CODE_chat_participants
)
{
if
(
x
==
CODE_chat_participants
)
{
assert
(
fetch_int
()
==
get_peer_id
(
C
->
id
));
assert
(
fetch_int
()
==
get_peer_id
(
C
->
id
));
C
->
admin_id
=
fetch_int
();
admin_id
=
fetch_int
();
assert
(
fetch_int
()
==
CODE_vector
);
assert
(
fetch_int
()
==
CODE_vector
);
if
(
C
->
users
)
{
users_num
=
fetch_int
();
free
(
C
->
users
);
users
=
malloc
(
sizeof
(
struct
chat_user
)
*
users_num
);
}
C
->
users_num
=
fetch_int
();
C
->
users
=
malloc
(
sizeof
(
struct
chat_user
)
*
C
->
users_num
);
int
i
;
int
i
;
for
(
i
=
0
;
i
<
C
->
users_num
;
i
++
)
{
for
(
i
=
0
;
i
<
C
->
users_num
;
i
++
)
{
assert
(
fetch_int
()
==
(
int
)
CODE_chat_participant
);
assert
(
fetch_int
()
==
(
int
)
CODE_chat_participant
);
C
->
users
[
i
].
user_id
=
fetch_int
();
users
[
i
].
user_id
=
fetch_int
();
C
->
users
[
i
].
inviter_id
=
fetch_int
();
users
[
i
].
inviter_id
=
fetch_int
();
C
->
users
[
i
].
date
=
fetch_int
();
users
[
i
].
date
=
fetch_int
();
}
C
->
version
=
fetch_int
();
}
else
{
C
->
flags
|=
FLAG_FORBIDDEN
;
assert
(
x
==
CODE_chat_participants_forbidden
);
}
}
if
(
C
->
flags
&
FLAG_HAS_PHOTO
)
{
version
=
fetch_int
();
free_photo
(
&
C
->
photo
);
}
}
fetch_photo
(
&
C
->
photo
);
int
*
start
=
in_ptr
;
C
->
flags
|=
FLAG_HAS_PHOTO
;
fetch_skip_photo
();
int
*
end
=
in_ptr
;
fetch_notify_settings
();
fetch_notify_settings
();
int
n
,
i
;
int
n
,
i
;
...
@@ -558,6 +572,14 @@ void fetch_chat_full (struct chat *C) {
...
@@ -558,6 +572,14 @@ void fetch_chat_full (struct chat *C) {
for
(
i
=
0
;
i
<
n
;
i
++
)
{
for
(
i
=
0
;
i
<
n
;
i
++
)
{
fetch_alloc_user
();
fetch_alloc_user
();
}
}
if
(
admin_id
)
{
bl_do_set_chat_admin
(
C
,
admin_id
);
}
if
(
version
>
0
)
{
bl_do_set_chat_participants
(
C
,
version
,
users_num
,
users
);
free
(
users
);
}
bl_do_set_chat_full_photo
(
C
,
start
,
4
*
(
end
-
start
));
}
}
void
fetch_photo_size
(
struct
photo_size
*
S
)
{
void
fetch_photo_size
(
struct
photo_size
*
S
)
{
...
@@ -1019,8 +1041,8 @@ void fetch_geo_message (struct message *M) {
...
@@ -1019,8 +1041,8 @@ void fetch_geo_message (struct message *M) {
}
}
}
}
int
*
decr_ptr
;
static
int
*
decr_ptr
;
int
*
decr_end
;
static
int
*
decr_end
;
int
decrypt_encrypted_message
(
struct
secret_chat
*
E
)
{
int
decrypt_encrypted_message
(
struct
secret_chat
*
E
)
{
int
*
msg_key
=
decr_ptr
;
int
*
msg_key
=
decr_ptr
;
...
@@ -1180,22 +1202,6 @@ static int id_cmp (struct message *M1, struct message *M2) {
...
@@ -1180,22 +1202,6 @@ static int id_cmp (struct message *M1, struct message *M2) {
else
{
return
0
;
}
else
{
return
0
;
}
}
}
#define peer_cmp(a,b) (cmp_peer_id (a->id, b->id))
DEFINE_TREE
(
peer
,
peer_t
*
,
peer_cmp
,
0
)
DEFINE_TREE
(
message
,
struct
message
*
,
id_cmp
,
0
)
struct
tree_peer
*
peer_tree
;
struct
tree_message
*
message_tree
;
int
users_allocated
;
int
chats_allocated
;
int
messages_allocated
;
struct
message
message_list
=
{
.
next_use
=
&
message_list
,
.
prev_use
=
&
message_list
};
struct
user
*
fetch_alloc_user
(
void
)
{
struct
user
*
fetch_alloc_user
(
void
)
{
int
data
[
2
];
int
data
[
2
];
prefetch_data
(
data
,
8
);
prefetch_data
(
data
,
8
);
...
...
structures.h
View file @
168c6b7a
...
@@ -172,7 +172,9 @@ struct chat {
...
@@ -172,7 +172,9 @@ struct chat {
struct
photo
photo
;
struct
photo
photo
;
char
*
title
;
char
*
title
;
int
users_num
;
int
users_num
;
struct
chat_user
*
users
;
int
user_list_size
;
int
user_list_version
;
struct
chat_user
*
user_list
;
int
date
;
int
date
;
int
version
;
int
version
;
int
admin_id
;
int
admin_id
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment