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
f3636ced
Commit
f3636ced
authored
Aug 21, 2014
by
vvaltman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
updates
parent
839e9cd4
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
162 additions
and
129 deletions
+162
-129
binlog.c
binlog.c
+7
-7
generate.c
generate.c
+3
-1
mtproto-client.c
mtproto-client.c
+19
-21
mtproto-common.c
mtproto-common.c
+28
-27
mtproto-common.h
mtproto-common.h
+32
-23
queries.c
queries.c
+10
-18
structures.c
structures.c
+1
-1
structures.h
structures.h
+1
-1
tgl.c
tgl.c
+4
-0
tgl.h
tgl.h
+23
-2
tools.c
tools.c
+7
-25
tools.h
tools.h
+27
-3
No files found.
binlog.c
View file @
f3636ced
...
@@ -182,7 +182,7 @@ static int fetch_comb_binlog_user_add (void *extra) {
...
@@ -182,7 +182,7 @@ static int fetch_comb_binlog_user_add (void *extra) {
U
->
first_name
=
fetch_str_dup
();
U
->
first_name
=
fetch_str_dup
();
U
->
last_name
=
fetch_str_dup
();
U
->
last_name
=
fetch_str_dup
();
assert
(
!
U
->
print_name
);
assert
(
!
U
->
print_name
);
U
->
print_name
=
create_print_name
(
U
->
id
,
U
->
first_name
,
U
->
last_name
,
0
,
0
);
U
->
print_name
=
tgl_state
.
callback
.
create_print_name
(
U
->
id
,
U
->
first_name
,
U
->
last_name
,
0
,
0
);
tglp_peer_insert_name
((
void
*
)
U
);
tglp_peer_insert_name
((
void
*
)
U
);
U
->
access_hash
=
fetch_long
();
U
->
access_hash
=
fetch_long
();
...
@@ -311,7 +311,7 @@ static int fetch_comb_binlog_user_set_name (void *extra) {
...
@@ -311,7 +311,7 @@ static int fetch_comb_binlog_user_set_name (void *extra) {
tglp_peer_delete_name
(
U
);
tglp_peer_delete_name
(
U
);
tfree_str
(
U
->
print_name
);
tfree_str
(
U
->
print_name
);
}
}
U
->
print_name
=
create_print_name
(
U
->
id
,
U
->
user
.
first_name
,
U
->
user
.
last_name
,
0
,
0
);
U
->
print_name
=
tgl_state
.
callback
.
create_print_name
(
U
->
id
,
U
->
user
.
first_name
,
U
->
user
.
last_name
,
0
,
0
);
tglp_peer_insert_name
((
void
*
)
U
);
tglp_peer_insert_name
((
void
*
)
U
);
if
(
tgl_state
.
callback
.
user_update
)
{
if
(
tgl_state
.
callback
.
user_update
)
{
...
@@ -386,11 +386,11 @@ static int fetch_comb_binlog_encr_chat_requested (void *extra) {
...
@@ -386,11 +386,11 @@ static int fetch_comb_binlog_encr_chat_requested (void *extra) {
tgl_peer_t
*
Us
=
tgl_peer_get
(
TGL_MK_USER
(
U
->
user_id
));
tgl_peer_t
*
Us
=
tgl_peer_get
(
TGL_MK_USER
(
U
->
user_id
));
assert
(
!
U
->
print_name
);
assert
(
!
U
->
print_name
);
if
(
Us
)
{
if
(
Us
)
{
U
->
print_name
=
create_print_name
(
id
,
"!"
,
Us
->
user
.
first_name
,
Us
->
user
.
last_name
,
0
);
U
->
print_name
=
tgl_state
.
callback
.
create_print_name
(
id
,
"!"
,
Us
->
user
.
first_name
,
Us
->
user
.
last_name
,
0
);
}
else
{
}
else
{
static
char
buf
[
100
];
static
char
buf
[
100
];
tsnprintf
(
buf
,
99
,
"user#%d"
,
U
->
user_id
);
tsnprintf
(
buf
,
99
,
"user#%d"
,
U
->
user_id
);
U
->
print_name
=
create_print_name
(
id
,
"!"
,
buf
,
0
,
0
);
U
->
print_name
=
tgl_state
.
callback
.
create_print_name
(
id
,
"!"
,
buf
,
0
,
0
);
}
}
tglp_peer_insert_name
((
void
*
)
U
);
tglp_peer_insert_name
((
void
*
)
U
);
U
->
g_key
=
talloc
(
256
);
U
->
g_key
=
talloc
(
256
);
...
@@ -480,7 +480,7 @@ static int fetch_comb_binlog_encr_chat_init (void *extra) {
...
@@ -480,7 +480,7 @@ static int fetch_comb_binlog_encr_chat_init (void *extra) {
tglp_insert_encrypted_chat
(
P
);
tglp_insert_encrypted_chat
(
P
);
tgl_peer_t
*
Us
=
tgl_peer_get
(
TGL_MK_USER
(
P
->
encr_chat
.
user_id
));
tgl_peer_t
*
Us
=
tgl_peer_get
(
TGL_MK_USER
(
P
->
encr_chat
.
user_id
));
assert
(
Us
);
assert
(
Us
);
P
->
print_name
=
create_print_name
(
P
->
id
,
"!"
,
Us
->
user
.
first_name
,
Us
->
user
.
last_name
,
0
);
P
->
print_name
=
tgl_state
.
callback
.
create_print_name
(
P
->
id
,
"!"
,
Us
->
user
.
first_name
,
Us
->
user
.
last_name
,
0
);
tglp_peer_insert_name
(
P
);
tglp_peer_insert_name
(
P
);
P
->
encr_chat
.
g_key
=
talloc
(
256
);
P
->
encr_chat
.
g_key
=
talloc
(
256
);
...
@@ -508,7 +508,7 @@ static int fetch_comb_binlog_chat_create (void *extra) {
...
@@ -508,7 +508,7 @@ static int fetch_comb_binlog_chat_create (void *extra) {
C
->
flags
=
FLAG_CREATED
|
fetch_int
();
C
->
flags
=
FLAG_CREATED
|
fetch_int
();
C
->
title
=
fetch_str_dup
();
C
->
title
=
fetch_str_dup
();
assert
(
!
C
->
print_title
);
assert
(
!
C
->
print_title
);
C
->
print_title
=
create_print_name
(
id
,
C
->
title
,
0
,
0
,
0
);
C
->
print_title
=
tgl_state
.
callback
.
create_print_name
(
id
,
C
->
title
,
0
,
0
,
0
);
tglp_peer_insert_name
((
void
*
)
C
);
tglp_peer_insert_name
((
void
*
)
C
);
C
->
users_num
=
fetch_int
();
C
->
users_num
=
fetch_int
();
C
->
date
=
fetch_int
();
C
->
date
=
fetch_int
();
...
@@ -545,7 +545,7 @@ static int fetch_comb_binlog_chat_set_title (void *extra) {
...
@@ -545,7 +545,7 @@ static int fetch_comb_binlog_chat_set_title (void *extra) {
tglp_peer_delete_name
((
void
*
)
C
);
tglp_peer_delete_name
((
void
*
)
C
);
tfree_str
(
C
->
print_name
);
tfree_str
(
C
->
print_name
);
}
}
C
->
print_name
=
create_print_name
(
C
->
id
,
C
->
chat
.
title
,
0
,
0
,
0
);
C
->
print_name
=
tgl_state
.
callback
.
create_print_name
(
C
->
id
,
C
->
chat
.
title
,
0
,
0
,
0
);
tglp_peer_insert_name
((
void
*
)
C
);
tglp_peer_insert_name
((
void
*
)
C
);
if
(
tgl_state
.
callback
.
chat_update
)
{
if
(
tgl_state
.
callback
.
chat_update
)
{
...
...
generate.c
View file @
f3636ced
...
@@ -871,7 +871,9 @@ int parse_tlo_file (void) {
...
@@ -871,7 +871,9 @@ int parse_tlo_file (void) {
printf
(
"#include
\"
auto.h
\"\n
"
);
printf
(
"#include
\"
auto.h
\"\n
"
);
printf
(
"#include <assert.h>
\n
"
);
printf
(
"#include <assert.h>
\n
"
);
printf
(
"extern int *in_ptr, *in_end;
\n
"
);
printf
(
"extern int *tgl_in_ptr, *tgl_in_end;
\n
"
);
printf
(
"#define in_ptr tgl_in_ptr
\n
"
);
printf
(
"#define in_end tgl_in_end
\n
"
);
printf
(
"#include
\"
auto-static.c
\"\n
"
);
printf
(
"#include
\"
auto-static.c
\"\n
"
);
for
(
i
=
0
;
i
<
tn
;
i
++
)
{
for
(
i
=
0
;
i
<
tn
;
i
++
)
{
...
...
mtproto-client.c
View file @
f3636ced
...
@@ -96,7 +96,7 @@ static long long precise_time;
...
@@ -96,7 +96,7 @@ static long long precise_time;
static
double
get_utime
(
int
clock_id
)
{
static
double
get_utime
(
int
clock_id
)
{
struct
timespec
T
;
struct
timespec
T
;
my_clock_gettime
(
clock_id
,
&
T
);
tgl_
my_clock_gettime
(
clock_id
,
&
T
);
double
res
=
T
.
tv_sec
+
(
double
)
T
.
tv_nsec
*
1e-9
;
double
res
=
T
.
tv_sec
+
(
double
)
T
.
tv_nsec
*
1e-9
;
if
(
clock_id
==
CLOCK_REALTIME
)
{
if
(
clock_id
==
CLOCK_REALTIME
)
{
precise_time
=
(
long
long
)
(
res
*
(
1LL
<<
32
));
precise_time
=
(
long
long
)
(
res
*
(
1LL
<<
32
));
...
@@ -139,9 +139,7 @@ static int rsa_load_public_key (const char *public_key_name) {
...
@@ -139,9 +139,7 @@ static int rsa_load_public_key (const char *public_key_name) {
return
-
1
;
return
-
1
;
}
}
if
(
verbosity
)
{
vlogprintf
(
E_WARNING
,
"public key '%s' loaded successfully
\n
"
,
rsa_public_key_name
);
vlogprintf
(
E_WARNING
,
"public key '%s' loaded successfully
\n
"
,
rsa_public_key_name
);
}
return
0
;
return
0
;
}
}
...
@@ -173,12 +171,12 @@ static int encrypt_buffer[ENCRYPT_BUFFER_INTS];
...
@@ -173,12 +171,12 @@ static int encrypt_buffer[ENCRYPT_BUFFER_INTS];
static
int
decrypt_buffer
[
ENCRYPT_BUFFER_INTS
];
static
int
decrypt_buffer
[
ENCRYPT_BUFFER_INTS
];
static
int
encrypt_packet_buffer
(
void
)
{
static
int
encrypt_packet_buffer
(
void
)
{
return
pad_rsa_encrypt
((
char
*
)
packet_buffer
,
(
packet_ptr
-
packet_buffer
)
*
4
,
(
char
*
)
encrypt_buffer
,
ENCRYPT_BUFFER_INTS
*
4
,
pubKey
->
n
,
pubKey
->
e
);
return
tgl_
pad_rsa_encrypt
((
char
*
)
packet_buffer
,
(
packet_ptr
-
packet_buffer
)
*
4
,
(
char
*
)
encrypt_buffer
,
ENCRYPT_BUFFER_INTS
*
4
,
pubKey
->
n
,
pubKey
->
e
);
}
}
static
int
encrypt_packet_buffer_aes_unauth
(
const
char
server_nonce
[
16
],
const
char
hidden_client_nonce
[
32
])
{
static
int
encrypt_packet_buffer_aes_unauth
(
const
char
server_nonce
[
16
],
const
char
hidden_client_nonce
[
32
])
{
init_aes_unauth
(
server_nonce
,
hidden_client_nonce
,
AES_ENCRYPT
);
tgl_
init_aes_unauth
(
server_nonce
,
hidden_client_nonce
,
AES_ENCRYPT
);
return
pad_aes_encrypt
((
char
*
)
packet_buffer
,
(
packet_ptr
-
packet_buffer
)
*
4
,
(
char
*
)
encrypt_buffer
,
ENCRYPT_BUFFER_INTS
*
4
);
return
tgl_
pad_aes_encrypt
((
char
*
)
packet_buffer
,
(
packet_ptr
-
packet_buffer
)
*
4
,
(
char
*
)
encrypt_buffer
,
ENCRYPT_BUFFER_INTS
*
4
);
}
}
...
@@ -421,7 +419,7 @@ static int process_respq_answer (struct connection *c, char *packet, int len) {
...
@@ -421,7 +419,7 @@ static int process_respq_answer (struct connection *c, char *packet, int len) {
}
}
static
int
check_prime
(
BIGNUM
*
p
)
{
static
int
check_prime
(
BIGNUM
*
p
)
{
int
r
=
BN_is_prime
(
p
,
BN_prime_checks
,
0
,
BN_ctx
,
0
);
int
r
=
BN_is_prime
(
p
,
BN_prime_checks
,
0
,
tgl_state
.
BN_ctx
,
0
);
ensure
(
r
>=
0
);
ensure
(
r
>=
0
);
return
r
;
return
r
;
}
}
...
@@ -434,7 +432,7 @@ int tglmp_check_DH_params (BIGNUM *p, int g) {
...
@@ -434,7 +432,7 @@ int tglmp_check_DH_params (BIGNUM *p, int g) {
BN_init
(
&
dh_g
);
BN_init
(
&
dh_g
);
ensure
(
BN_set_word
(
&
dh_g
,
4
*
g
));
ensure
(
BN_set_word
(
&
dh_g
,
4
*
g
));
ensure
(
BN_mod
(
&
t
,
p
,
&
dh_g
,
BN_ctx
));
ensure
(
BN_mod
(
&
t
,
p
,
&
dh_g
,
tgl_state
.
BN_ctx
));
int
x
=
BN_get_word
(
&
t
);
int
x
=
BN_get_word
(
&
t
);
assert
(
x
>=
0
&&
x
<
4
*
g
);
assert
(
x
>=
0
&&
x
<
4
*
g
);
...
@@ -465,7 +463,7 @@ int tglmp_check_DH_params (BIGNUM *p, int g) {
...
@@ -465,7 +463,7 @@ int tglmp_check_DH_params (BIGNUM *p, int g) {
BIGNUM
b
;
BIGNUM
b
;
BN_init
(
&
b
);
BN_init
(
&
b
);
ensure
(
BN_set_word
(
&
b
,
2
));
ensure
(
BN_set_word
(
&
b
,
2
));
ensure
(
BN_div
(
&
t
,
0
,
p
,
&
b
,
BN_ctx
));
ensure
(
BN_div
(
&
t
,
0
,
p
,
&
b
,
tgl_state
.
BN_ctx
));
if
(
!
check_prime
(
&
t
))
{
return
-
1
;
}
if
(
!
check_prime
(
&
t
))
{
return
-
1
;
}
BN_free
(
&
b
);
BN_free
(
&
b
);
BN_free
(
&
t
);
BN_free
(
&
t
);
...
@@ -528,12 +526,12 @@ static int process_dh_answer (struct connection *c, char *packet, int len) {
...
@@ -528,12 +526,12 @@ static int process_dh_answer (struct connection *c, char *packet, int len) {
assert
(
*
(
int
*
)
(
packet
+
20
)
==
(
int
)
CODE_server_DH_params_ok
);
assert
(
*
(
int
*
)
(
packet
+
20
)
==
(
int
)
CODE_server_DH_params_ok
);
assert
(
!
memcmp
(
packet
+
24
,
nonce
,
16
));
assert
(
!
memcmp
(
packet
+
24
,
nonce
,
16
));
assert
(
!
memcmp
(
packet
+
40
,
server_nonce
,
16
));
assert
(
!
memcmp
(
packet
+
40
,
server_nonce
,
16
));
init_aes_unauth
(
server_nonce
,
new_nonce
,
AES_DECRYPT
);
tgl_
init_aes_unauth
(
server_nonce
,
new_nonce
,
AES_DECRYPT
);
in_ptr
=
(
int
*
)(
packet
+
56
);
in_ptr
=
(
int
*
)(
packet
+
56
);
in_end
=
(
int
*
)(
packet
+
len
);
in_end
=
(
int
*
)(
packet
+
len
);
int
l
=
prefetch_strlen
();
int
l
=
prefetch_strlen
();
assert
(
l
>
0
);
assert
(
l
>
0
);
l
=
pad_aes_decrypt
(
fetch_str
(
l
),
l
,
(
char
*
)
decrypt_buffer
,
DECRYPT_BUFFER_INTS
*
4
-
16
);
l
=
tgl_
pad_aes_decrypt
(
fetch_str
(
l
),
l
,
(
char
*
)
decrypt_buffer
,
DECRYPT_BUFFER_INTS
*
4
-
16
);
assert
(
in_ptr
==
in_end
);
assert
(
in_ptr
==
in_end
);
assert
(
l
>=
60
);
assert
(
l
>=
60
);
assert
(
decrypt_buffer
[
5
]
==
(
int
)
CODE_server_DH_inner_data
);
assert
(
decrypt_buffer
[
5
]
==
(
int
)
CODE_server_DH_inner_data
);
...
@@ -579,12 +577,12 @@ static int process_dh_answer (struct connection *c, char *packet, int len) {
...
@@ -579,12 +577,12 @@ static int process_dh_answer (struct connection *c, char *packet, int len) {
BIGNUM
*
y
=
BN_new
();
BIGNUM
*
y
=
BN_new
();
ensure_ptr
(
y
);
ensure_ptr
(
y
);
ensure
(
BN_mod_exp
(
y
,
&
dh_g
,
dh_power
,
&
dh_prime
,
BN_ctx
));
ensure
(
BN_mod_exp
(
y
,
&
dh_g
,
dh_power
,
&
dh_prime
,
tgl_state
.
BN_ctx
));
out_bignum
(
y
);
out_bignum
(
y
);
BN_free
(
y
);
BN_free
(
y
);
BN_init
(
&
auth_key_num
);
BN_init
(
&
auth_key_num
);
ensure
(
BN_mod_exp
(
&
auth_key_num
,
&
g_a
,
dh_power
,
&
dh_prime
,
BN_ctx
));
ensure
(
BN_mod_exp
(
&
auth_key_num
,
&
g_a
,
dh_power
,
&
dh_prime
,
tgl_state
.
BN_ctx
));
l
=
BN_num_bytes
(
&
auth_key_num
);
l
=
BN_num_bytes
(
&
auth_key_num
);
assert
(
l
>=
250
&&
l
<=
256
);
assert
(
l
>=
250
&&
l
<=
256
);
assert
(
BN_bn2bin
(
&
auth_key_num
,
(
unsigned
char
*
)
D
->
auth_key
));
assert
(
BN_bn2bin
(
&
auth_key_num
,
(
unsigned
char
*
)
D
->
auth_key
));
...
@@ -711,9 +709,9 @@ static int aes_encrypt_message (struct dc *DC, struct encrypted_message *enc) {
...
@@ -711,9 +709,9 @@ static int aes_encrypt_message (struct dc *DC, struct encrypted_message *enc) {
//printf ("enc_len is %d\n", enc_len);
//printf ("enc_len is %d\n", enc_len);
vlogprintf
(
E_DEBUG
,
"sending message with sha1 %08x
\n
"
,
*
(
int
*
)
sha1_buffer
);
vlogprintf
(
E_DEBUG
,
"sending message with sha1 %08x
\n
"
,
*
(
int
*
)
sha1_buffer
);
memcpy
(
enc
->
msg_key
,
sha1_buffer
+
4
,
16
);
memcpy
(
enc
->
msg_key
,
sha1_buffer
+
4
,
16
);
init_aes_auth
(
DC
->
auth_key
,
enc
->
msg_key
,
AES_ENCRYPT
);
tgl_
init_aes_auth
(
DC
->
auth_key
,
enc
->
msg_key
,
AES_ENCRYPT
);
//hexdump ((char *)enc, (char *)enc + enc_len + 24);
//hexdump ((char *)enc, (char *)enc + enc_len + 24);
return
pad_aes_encrypt
((
char
*
)
&
enc
->
server_salt
,
enc_len
,
(
char
*
)
&
enc
->
server_salt
,
MAX_MESSAGE_INTS
*
4
+
(
MINSZ
-
UNENCSZ
));
return
tgl_
pad_aes_encrypt
((
char
*
)
&
enc
->
server_salt
,
enc_len
,
(
char
*
)
&
enc
->
server_salt
,
MAX_MESSAGE_INTS
*
4
+
(
MINSZ
-
UNENCSZ
));
}
}
long
long
tglmp_encrypt_send_message
(
struct
connection
*
c
,
int
*
msg
,
int
msg_ints
,
int
useful
)
{
long
long
tglmp_encrypt_send_message
(
struct
connection
*
c
,
int
*
msg
,
int
msg_ints
,
int
useful
)
{
...
@@ -821,7 +819,7 @@ static void work_packed (struct connection *c, long long msg_id) {
...
@@ -821,7 +819,7 @@ static void work_packed (struct connection *c, long long msg_id) {
int
l
=
prefetch_strlen
();
int
l
=
prefetch_strlen
();
char
*
s
=
fetch_str
(
l
);
char
*
s
=
fetch_str
(
l
);
int
total_out
=
tinflate
(
s
,
l
,
buf
,
MAX_PACKED_SIZE
);
int
total_out
=
t
gl_
inflate
(
s
,
l
,
buf
,
MAX_PACKED_SIZE
);
int
*
end
=
in_ptr
;
int
*
end
=
in_ptr
;
int
*
eend
=
in_end
;
int
*
eend
=
in_end
;
//assert (total_out % 4 == 0);
//assert (total_out % 4 == 0);
...
@@ -933,8 +931,8 @@ static int process_rpc_message (struct connection *c UU, struct encrypted_messag
...
@@ -933,8 +931,8 @@ static int process_rpc_message (struct connection *c UU, struct encrypted_messag
struct
dc
*
DC
=
tgl_state
.
net_methods
->
get_dc
(
c
);
struct
dc
*
DC
=
tgl_state
.
net_methods
->
get_dc
(
c
);
assert
(
enc
->
auth_key_id
==
DC
->
auth_key_id
);
assert
(
enc
->
auth_key_id
==
DC
->
auth_key_id
);
assert
(
DC
->
auth_key_id
);
assert
(
DC
->
auth_key_id
);
init_aes_auth
(
DC
->
auth_key
+
8
,
enc
->
msg_key
,
AES_DECRYPT
);
tgl_
init_aes_auth
(
DC
->
auth_key
+
8
,
enc
->
msg_key
,
AES_DECRYPT
);
int
l
=
pad_aes_decrypt
((
char
*
)
&
enc
->
server_salt
,
len
-
UNENCSZ
,
(
char
*
)
&
enc
->
server_salt
,
len
-
UNENCSZ
);
int
l
=
tgl_
pad_aes_decrypt
((
char
*
)
&
enc
->
server_salt
,
len
-
UNENCSZ
,
(
char
*
)
&
enc
->
server_salt
,
len
-
UNENCSZ
);
assert
(
l
==
len
-
UNENCSZ
);
assert
(
l
==
len
-
UNENCSZ
);
//assert (enc->auth_key_id2 == enc->auth_key_id);
//assert (enc->auth_key_id2 == enc->auth_key_id);
assert
(
!
(
enc
->
msg_len
&
3
)
&&
enc
->
msg_len
>
0
&&
enc
->
msg_len
<=
len
-
MINSZ
&&
len
-
MINSZ
-
enc
->
msg_len
<=
12
);
assert
(
!
(
enc
->
msg_len
&
3
)
&&
enc
->
msg_len
>
0
&&
enc
->
msg_len
<=
len
-
MINSZ
&&
len
-
MINSZ
-
enc
->
msg_len
<=
12
);
...
@@ -1089,7 +1087,7 @@ static int rpc_close (struct connection *c) {
...
@@ -1089,7 +1087,7 @@ static int rpc_close (struct connection *c) {
#define RANDSEED_PASSWORD_FILENAME NULL
#define RANDSEED_PASSWORD_FILENAME NULL
#define RANDSEED_PASSWORD_LENGTH 0
#define RANDSEED_PASSWORD_LENGTH 0
void
tglmp_on_start
(
const
char
*
key
)
{
void
tglmp_on_start
(
const
char
*
key
)
{
prng_seed
(
RANDSEED_PASSWORD_FILENAME
,
RANDSEED_PASSWORD_LENGTH
);
tgl_
prng_seed
(
RANDSEED_PASSWORD_FILENAME
,
RANDSEED_PASSWORD_LENGTH
);
if
(
key
)
{
if
(
key
)
{
if
(
rsa_load_public_key
(
key
)
<
0
)
{
if
(
rsa_load_public_key
(
key
)
<
0
)
{
...
@@ -1103,7 +1101,7 @@ void tglmp_on_start (const char *key) {
...
@@ -1103,7 +1101,7 @@ void tglmp_on_start (const char *key) {
exit
(
1
);
exit
(
1
);
}
}
}
}
pk_fingerprint
=
compute_rsa_key_fingerprint
(
pubKey
);
pk_fingerprint
=
tgl_do_
compute_rsa_key_fingerprint
(
pubKey
);
}
}
//int auth_ok (void) {
//int auth_ok (void) {
...
...
mtproto-common.c
View file @
f3636ced
...
@@ -40,6 +40,7 @@
...
@@ -40,6 +40,7 @@
#include "mtproto-common.h"
#include "mtproto-common.h"
#include "include.h"
#include "include.h"
#include "tools.h"
#ifdef __MACH__
#ifdef __MACH__
#include <mach/clock.h>
#include <mach/clock.h>
...
@@ -47,12 +48,12 @@
...
@@ -47,12 +48,12 @@
#endif
#endif
int
__packet_buffer
[
PACKET_BUFFER_SIZE
],
*
packet_ptr
;
static
int
__packet_buffer
[
PACKET_BUFFER_SIZE
];
int
*
packet_buffer
=
__packet_buffer
+
16
;
int
*
tgl_packet_ptr
;
int
*
tgl_packet_buffer
=
__packet_buffer
+
16
;
long
long
rsa_encrypted_chunks
,
rsa_decrypted_chunks
;
static
long
long
rsa_encrypted_chunks
,
rsa_decrypted_chunks
;
BN_CTX
*
BN_ctx
;
//int verbosity;
//int verbosity;
static
int
get_random_bytes
(
unsigned
char
*
buf
,
int
n
)
{
static
int
get_random_bytes
(
unsigned
char
*
buf
,
int
n
)
{
...
@@ -105,9 +106,9 @@ static __inline__ unsigned long long rdtsc (void) {
...
@@ -105,9 +106,9 @@ static __inline__ unsigned long long rdtsc (void) {
}
}
#endif
#endif
void
prng_seed
(
const
char
*
password_filename
,
int
password_length
)
{
void
tgl_
prng_seed
(
const
char
*
password_filename
,
int
password_length
)
{
struct
timespec
T
;
struct
timespec
T
;
my_clock_gettime
(
CLOCK_REALTIME
,
&
T
);
tgl_
my_clock_gettime
(
CLOCK_REALTIME
,
&
T
);
RAND_add
(
&
T
,
sizeof
(
T
),
4
.
0
);
RAND_add
(
&
T
,
sizeof
(
T
),
4
.
0
);
#ifdef HAVE_RDTSC
#ifdef HAVE_RDTSC
unsigned
long
long
r
=
rdtsc
();
unsigned
long
long
r
=
rdtsc
();
...
@@ -140,11 +141,11 @@ void prng_seed (const char *password_filename, int password_length) {
...
@@ -140,11 +141,11 @@ void prng_seed (const char *password_filename, int password_length) {
tfree_secure
(
a
,
password_length
);
tfree_secure
(
a
,
password_length
);
}
}
}
}
BN_ctx
=
BN_CTX_new
();
tgl_state
.
BN_ctx
=
BN_CTX_new
();
ensure_ptr
(
BN_ctx
);
ensure_ptr
(
tgl_state
.
BN_ctx
);
}
}
int
serialize_bignum
(
BIGNUM
*
b
,
char
*
buffer
,
int
maxlen
)
{
int
tgl_
serialize_bignum
(
BIGNUM
*
b
,
char
*
buffer
,
int
maxlen
)
{
int
itslen
=
BN_num_bytes
(
b
);
int
itslen
=
BN_num_bytes
(
b
);
int
reqlen
;
int
reqlen
;
if
(
itslen
<
254
)
{
if
(
itslen
<
254
)
{
...
@@ -174,19 +175,19 @@ int serialize_bignum (BIGNUM *b, char *buffer, int maxlen) {
...
@@ -174,19 +175,19 @@ int serialize_bignum (BIGNUM *b, char *buffer, int maxlen) {
}
}
long
long
compute_rsa_key_fingerprint
(
RSA
*
key
)
{
long
long
tgl_do_
compute_rsa_key_fingerprint
(
RSA
*
key
)
{
static
char
tempbuff
[
4096
];
static
char
tempbuff
[
4096
];
static
unsigned
char
sha
[
20
];
static
unsigned
char
sha
[
20
];
assert
(
key
->
n
&&
key
->
e
);
assert
(
key
->
n
&&
key
->
e
);
int
l1
=
serialize_bignum
(
key
->
n
,
tempbuff
,
4096
);
int
l1
=
tgl_
serialize_bignum
(
key
->
n
,
tempbuff
,
4096
);
assert
(
l1
>
0
);
assert
(
l1
>
0
);
int
l2
=
serialize_bignum
(
key
->
e
,
tempbuff
+
l1
,
4096
-
l1
);
int
l2
=
tgl_
serialize_bignum
(
key
->
e
,
tempbuff
+
l1
,
4096
-
l1
);
assert
(
l2
>
0
&&
l1
+
l2
<=
4096
);
assert
(
l2
>
0
&&
l1
+
l2
<=
4096
);
SHA1
((
unsigned
char
*
)
tempbuff
,
l1
+
l2
,
sha
);
SHA1
((
unsigned
char
*
)
tempbuff
,
l1
+
l2
,
sha
);
return
*
(
long
long
*
)(
sha
+
12
);
return
*
(
long
long
*
)(
sha
+
12
);
}
}
void
out_cstring
(
const
char
*
str
,
long
len
)
{
void
tgl_
out_cstring
(
const
char
*
str
,
long
len
)
{
assert
(
len
>=
0
&&
len
<
(
1
<<
24
));
assert
(
len
>=
0
&&
len
<
(
1
<<
24
));
assert
((
char
*
)
packet_ptr
+
len
+
8
<
(
char
*
)
(
packet_buffer
+
PACKET_BUFFER_SIZE
));
assert
((
char
*
)
packet_ptr
+
len
+
8
<
(
char
*
)
(
packet_buffer
+
PACKET_BUFFER_SIZE
));
char
*
dest
=
(
char
*
)
packet_ptr
;
char
*
dest
=
(
char
*
)
packet_ptr
;
...
@@ -204,7 +205,7 @@ void out_cstring (const char *str, long len) {
...
@@ -204,7 +205,7 @@ void out_cstring (const char *str, long len) {
packet_ptr
=
(
int
*
)
dest
;
packet_ptr
=
(
int
*
)
dest
;
}
}
void
out_cstring_careful
(
const
char
*
str
,
long
len
)
{
void
tgl_
out_cstring_careful
(
const
char
*
str
,
long
len
)
{
assert
(
len
>=
0
&&
len
<
(
1
<<
24
));
assert
(
len
>=
0
&&
len
<
(
1
<<
24
));
assert
((
char
*
)
packet_ptr
+
len
+
8
<
(
char
*
)
(
packet_buffer
+
PACKET_BUFFER_SIZE
));
assert
((
char
*
)
packet_ptr
+
len
+
8
<
(
char
*
)
(
packet_buffer
+
PACKET_BUFFER_SIZE
));
char
*
dest
=
(
char
*
)
packet_ptr
;
char
*
dest
=
(
char
*
)
packet_ptr
;
...
@@ -229,16 +230,16 @@ void out_cstring_careful (const char *str, long len) {
...
@@ -229,16 +230,16 @@ void out_cstring_careful (const char *str, long len) {
}
}
void
out_data
(
const
void
*
data
,
long
len
)
{
void
tgl_
out_data
(
const
void
*
data
,
long
len
)
{
assert
(
len
>=
0
&&
len
<
(
1
<<
24
)
&&
!
(
len
&
3
));
assert
(
len
>=
0
&&
len
<
(
1
<<
24
)
&&
!
(
len
&
3
));
assert
((
char
*
)
packet_ptr
+
len
+
8
<
(
char
*
)
(
packet_buffer
+
PACKET_BUFFER_SIZE
));
assert
((
char
*
)
packet_ptr
+
len
+
8
<
(
char
*
)
(
packet_buffer
+
PACKET_BUFFER_SIZE
));
memcpy
(
packet_ptr
,
data
,
len
);
memcpy
(
packet_ptr
,
data
,
len
);
packet_ptr
+=
len
>>
2
;
packet_ptr
+=
len
>>
2
;
}
}
int
*
in_ptr
,
*
in_end
;
int
*
tgl_in_ptr
,
*
tgl_
in_end
;
int
fetch_bignum
(
BIGNUM
*
x
)
{
int
tgl_
fetch_bignum
(
BIGNUM
*
x
)
{
int
l
=
prefetch_strlen
();
int
l
=
prefetch_strlen
();
if
(
l
<
0
)
{
if
(
l
<
0
)
{
return
l
;
return
l
;
...
@@ -248,7 +249,7 @@ int fetch_bignum (BIGNUM *x) {
...
@@ -248,7 +249,7 @@ int fetch_bignum (BIGNUM *x) {
return
l
;
return
l
;
}
}
int
pad_rsa_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
E
)
{
int
tgl_
pad_rsa_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
E
)
{
int
pad
=
(
255000
-
from_len
-
32
)
%
255
+
32
;
int
pad
=
(
255000
-
from_len
-
32
)
%
255
+
32
;
int
chunks
=
(
from_len
+
pad
)
/
255
;
int
chunks
=
(
from_len
+
pad
)
/
255
;
int
bits
=
BN_num_bits
(
N
);
int
bits
=
BN_num_bits
(
N
);
...
@@ -263,7 +264,7 @@ int pad_rsa_encrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
...
@@ -263,7 +264,7 @@ int pad_rsa_encrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
rsa_encrypted_chunks
+=
chunks
;
rsa_encrypted_chunks
+=
chunks
;
for
(
i
=
0
;
i
<
chunks
;
i
++
)
{
for
(
i
=
0
;
i
<
chunks
;
i
++
)
{
BN_bin2bn
((
unsigned
char
*
)
from
,
255
,
&
x
);
BN_bin2bn
((
unsigned
char
*
)
from
,
255
,
&
x
);
assert
(
BN_mod_exp
(
&
y
,
&
x
,
E
,
N
,
BN_ctx
)
==
1
);
assert
(
BN_mod_exp
(
&
y
,
&
x
,
E
,
N
,
tgl_state
.
BN_ctx
)
==
1
);
unsigned
l
=
256
-
BN_num_bytes
(
&
y
);
unsigned
l
=
256
-
BN_num_bytes
(
&
y
);
assert
(
l
<=
256
);
assert
(
l
<=
256
);
memset
(
to
,
0
,
l
);
memset
(
to
,
0
,
l
);
...
@@ -275,7 +276,7 @@ int pad_rsa_encrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
...
@@ -275,7 +276,7 @@ int pad_rsa_encrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
return
chunks
*
256
;
return
chunks
*
256
;
}
}
int
pad_rsa_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
D
)
{
int
tgl_
pad_rsa_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
D
)
{
if
(
from_len
<
0
||
from_len
>
0x1000
||
(
from_len
&
0xff
))
{
if
(
from_len
<
0
||
from_len
>
0x1000
||
(
from_len
&
0xff
))
{
return
-
1
;
return
-
1
;
}
}
...
@@ -290,7 +291,7 @@ int pad_rsa_decrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
...
@@ -290,7 +291,7 @@ int pad_rsa_decrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
for
(
i
=
0
;
i
<
chunks
;
i
++
)
{
for
(
i
=
0
;
i
<
chunks
;
i
++
)
{
++
rsa_decrypted_chunks
;
++
rsa_decrypted_chunks
;
BN_bin2bn
((
unsigned
char
*
)
from
,
256
,
&
x
);
BN_bin2bn
((
unsigned
char
*
)
from
,
256
,
&
x
);
assert
(
BN_mod_exp
(
&
y
,
&
x
,
D
,
N
,
BN_ctx
)
==
1
);
assert
(
BN_mod_exp
(
&
y
,
&
x
,
D
,
N
,
tgl_state
.
BN_ctx
)
==
1
);
int
l
=
BN_num_bytes
(
&
y
);
int
l
=
BN_num_bytes
(
&
y
);
if
(
l
>
255
)
{
if
(
l
>
255
)
{
BN_free
(
&
x
);
BN_free
(
&
x
);
...
@@ -307,10 +308,10 @@ int pad_rsa_decrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
...
@@ -307,10 +308,10 @@ int pad_rsa_decrypt (char *from, int from_len, char *to, int size, BIGNUM *N, BI
return
chunks
*
255
;
return
chunks
*
255
;
}
}
unsigned
char
aes_key_raw
[
32
],
aes_iv
[
32
];
static
unsigned
char
aes_key_raw
[
32
],
aes_iv
[
32
];
AES_KEY
aes_key
;
static
AES_KEY
aes_key
;
void
init_aes_unauth
(
const
char
server_nonce
[
16
],
const
char
hidden_client_nonce
[
32
],
int
encrypt
)
{
void
tgl_
init_aes_unauth
(
const
char
server_nonce
[
16
],
const
char
hidden_client_nonce
[
32
],
int
encrypt
)
{
static
unsigned
char
buffer
[
64
],
hash
[
20
];
static
unsigned
char
buffer
[
64
],
hash
[
20
];
memcpy
(
buffer
,
hidden_client_nonce
,
32
);
memcpy
(
buffer
,
hidden_client_nonce
,
32
);
memcpy
(
buffer
+
32
,
server_nonce
,
16
);
memcpy
(
buffer
+
32
,
server_nonce
,
16
);
...
@@ -331,7 +332,7 @@ void init_aes_unauth (const char server_nonce[16], const char hidden_client_nonc
...
@@ -331,7 +332,7 @@ void init_aes_unauth (const char server_nonce[16], const char hidden_client_nonc
memset
(
aes_key_raw
,
0
,
sizeof
(
aes_key_raw
));
memset
(
aes_key_raw
,
0
,
sizeof
(
aes_key_raw
));
}
}
void
init_aes_auth
(
char
auth_key
[
192
],
char
msg_key
[
16
],
int
encrypt
)
{
void
tgl_
init_aes_auth
(
char
auth_key
[
192
],
char
msg_key
[
16
],
int
encrypt
)
{
static
unsigned
char
buffer
[
48
],
hash
[
20
];
static
unsigned
char
buffer
[
48
],
hash
[
20
];
// sha1_a = SHA1 (msg_key + substr (auth_key, 0, 32));
// sha1_a = SHA1 (msg_key + substr (auth_key, 0, 32));
// sha1_b = SHA1 (substr (auth_key, 32, 16) + msg_key + substr (auth_key, 48, 16));
// sha1_b = SHA1 (substr (auth_key, 32, 16) + msg_key + substr (auth_key, 48, 16));
...
@@ -371,7 +372,7 @@ void init_aes_auth (char auth_key[192], char msg_key[16], int encrypt) {
...
@@ -371,7 +372,7 @@ void init_aes_auth (char auth_key[192], char msg_key[16], int encrypt) {
memset
(
aes_key_raw
,
0
,
sizeof
(
aes_key_raw
));
memset
(
aes_key_raw
,
0
,
sizeof
(
aes_key_raw
));
}
}
int
pad_aes_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
)
{
int
tgl_
pad_aes_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
)
{
int
padded_size
=
(
from_len
+
15
)
&
-
16
;
int
padded_size
=
(
from_len
+
15
)
&
-
16
;
assert
(
from_len
>
0
&&
padded_size
<=
size
);
assert
(
from_len
>
0
&&
padded_size
<=
size
);
if
(
from_len
<
padded_size
)
{
if
(
from_len
<
padded_size
)
{
...
@@ -381,7 +382,7 @@ int pad_aes_encrypt (char *from, int from_len, char *to, int size) {
...
@@ -381,7 +382,7 @@ int pad_aes_encrypt (char *from, int from_len, char *to, int size) {
return
padded_size
;
return
padded_size
;
}
}
int
pad_aes_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
)
{
int
tgl_
pad_aes_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
)
{
if
(
from_len
<=
0
||
from_len
>
size
||
(
from_len
&
15
))
{
if
(
from_len
<=
0
||
from_len
>
size
||
(
from_len
&
15
))
{
return
-
1
;
return
-
1
;
}
}
...
...
mtproto-common.h
View file @
f3636ced
...
@@ -111,14 +111,17 @@ struct encrypted_message {
...
@@ -111,14 +111,17 @@ struct encrypted_message {
#pragma pack(pop)
#pragma pack(pop)
BN_CTX
*
BN_ctx
;
//
BN_CTX *BN_ctx;
void
prng_seed
(
const
char
*
password_filename
,
int
password_length
);
void
tgl_
prng_seed
(
const
char
*
password_filename
,
int
password_length
);
int
serialize_bignum
(
BIGNUM
*
b
,
char
*
buffer
,
int
maxlen
);
int
tgl_
serialize_bignum
(
BIGNUM
*
b
,
char
*
buffer
,
int
maxlen
);
long
long
compute_rsa_key_fingerprint
(
RSA
*
key
);
long
long
tgl_do_
compute_rsa_key_fingerprint
(
RSA
*
key
);
extern
int
*
packet_buffer
;
#define packet_buffer tgl_packet_buffer
extern
int
*
packet_ptr
;
#define packet_ptr tgl_packet_ptr
extern
int
*
tgl_packet_buffer
;
extern
int
*
tgl_packet_ptr
;
static
inline
void
out_ints
(
const
int
*
what
,
int
len
)
{
static
inline
void
out_ints
(
const
int
*
what
,
int
len
)
{
assert
(
packet_ptr
+
len
<=
packet_buffer
+
PACKET_BUFFER_SIZE
);
assert
(
packet_ptr
+
len
<=
packet_buffer
+
PACKET_BUFFER_SIZE
);
...
@@ -143,21 +146,28 @@ static inline void clear_packet (void) {
...
@@ -143,21 +146,28 @@ static inline void clear_packet (void) {
packet_ptr
=
packet_buffer
;
packet_ptr
=
packet_buffer
;
}
}
void
out_cstring
(
const
char
*
str
,
long
len
);
void
tgl_out_cstring
(
const
char
*
str
,
long
len
);
void
out_cstring_careful
(
const
char
*
str
,
long
len
);
void
tgl_out_cstring_careful
(
const
char
*
str
,
long
len
);
void
out_data
(
const
void
*
data
,
long
len
);
void
tgl_out_data
(
const
void
*
data
,
long
len
);
#define out_cstring tgl_out_cstring
#define out_cstring_careful tgl_out_cstring_careful
#define out_data tgl_out_data
static
inline
void
out_string
(
const
char
*
str
)
{
static
inline
void
out_string
(
const
char
*
str
)
{
out_cstring
(
str
,
strlen
(
str
));
out_cstring
(
str
,
strlen
(
str
));
}
}
static
inline
void
out_bignum
(
BIGNUM
*
n
)
{
static
inline
void
out_bignum
(
BIGNUM
*
n
)
{
int
l
=
serialize_bignum
(
n
,
(
char
*
)
packet_ptr
,
(
PACKET_BUFFER_SIZE
-
(
packet_ptr
-
packet_buffer
))
*
4
);
int
l
=
tgl_
serialize_bignum
(
n
,
(
char
*
)
packet_ptr
,
(
PACKET_BUFFER_SIZE
-
(
packet_ptr
-
packet_buffer
))
*
4
);
assert
(
l
>
0
);
assert
(
l
>
0
);
packet_ptr
+=
l
>>
2
;
packet_ptr
+=
l
>>
2
;
}
}
extern
int
*
in_ptr
,
*
in_end
;
#define in_ptr tgl_in_ptr
#define in_end tgl_in_end
extern
int
*
tgl_in_ptr
,
*
tgl_in_end
;
//void fetch_pts (void);
//void fetch_pts (void);
//void fetch_qts (void);
//void fetch_qts (void);
...
@@ -179,7 +189,6 @@ static inline int prefetch_strlen (void) {
...
@@ -179,7 +189,6 @@ static inline int prefetch_strlen (void) {
}
}
}
}
extern
int
verbosity
;
static
inline
char
*
fetch_str
(
int
len
)
{
static
inline
char
*
fetch_str
(
int
len
)
{
assert
(
len
>=
0
);
assert
(
len
>=
0
);
vlogprintf
(
E_DEBUG
+
3
,
"fetch_string: len = %d
\n
"
,
len
);
vlogprintf
(
E_DEBUG
+
3
,
"fetch_string: len = %d
\n
"
,
len
);
...
@@ -270,7 +279,8 @@ static inline long have_prefetch_ints (void) {
...
@@ -270,7 +279,8 @@ static inline long have_prefetch_ints (void) {
return
in_end
-
in_ptr
;
return
in_end
-
in_ptr
;
}
}
int
fetch_bignum
(
BIGNUM
*
x
);
int
tgl_fetch_bignum
(
BIGNUM
*
x
);
#define fetch_bignum tgl_fetch_bignum
static
inline
int
fetch_int
(
void
)
{
static
inline
int
fetch_int
(
void
)
{
assert
(
in_ptr
+
1
<=
in_end
);
assert
(
in_ptr
+
1
<=
in_end
);
...
@@ -335,18 +345,18 @@ static inline void fetch256 (void *buf) {
...
@@ -335,18 +345,18 @@ static inline void fetch256 (void *buf) {
//int get_random_bytes (unsigned char *buf, int n);
//int get_random_bytes (unsigned char *buf, int n);
int
pad_rsa_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
E
);
int
tgl_
pad_rsa_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
E
);
int
pad_rsa_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
D
);
int
tgl_
pad_rsa_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
,
BIGNUM
*
N
,
BIGNUM
*
D
);
extern
long
long
rsa_encrypted_chunks
,
rsa_decrypted_chunks
;
//
extern long long rsa_encrypted_chunks, rsa_decrypted_chunks;
extern
unsigned
char
aes_key_raw
[
32
],
aes_iv
[
32
];
//
extern unsigned char aes_key_raw[32], aes_iv[32];
extern
AES_KEY
aes_key
;
//
extern AES_KEY aes_key;
void
init_aes_unauth
(
const
char
server_nonce
[
16
],
const
char
hidden_client_nonce
[
32
],
int
encrypt
);
void
tgl_
init_aes_unauth
(
const
char
server_nonce
[
16
],
const
char
hidden_client_nonce
[
32
],
int
encrypt
);
void
init_aes_auth
(
char
auth_key
[
192
],
char
msg_key
[
16
],
int
encrypt
);
void
tgl_
init_aes_auth
(
char
auth_key
[
192
],
char
msg_key
[
16
],
int
encrypt
);
int
pad_aes_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
);
int
tgl_
pad_aes_encrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
);
int
pad_aes_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
);
int
tgl_
pad_aes_decrypt
(
char
*
from
,
int
from_len
,
char
*
to
,
int
size
);
/*
/*
static inline void hexdump_in (void) {
static inline void hexdump_in (void) {
hexdump (in_ptr, in_end);
hexdump (in_ptr, in_end);
...
@@ -360,5 +370,4 @@ static inline void hexdump_out (void) {
...
@@ -360,5 +370,4 @@ static inline void hexdump_out (void) {
#define CLOCK_REALTIME 0
#define CLOCK_REALTIME 0
#define CLOCK_MONOTONIC 1
#define CLOCK_MONOTONIC 1
#endif
#endif
void
my_clock_gettime
(
int
clock_id
,
struct
timespec
*
T
);
#endif
#endif
queries.c
View file @
f3636ced
...
@@ -220,7 +220,7 @@ void tglq_query_result (long long id UU) {
...
@@ -220,7 +220,7 @@ void tglq_query_result (long long id UU) {
fetch_int
();
fetch_int
();
int
l
=
prefetch_strlen
();
int
l
=
prefetch_strlen
();
char
*
s
=
fetch_str
(
l
);
char
*
s
=
fetch_str
(
l
);
int
total_out
=
tinflate
(
s
,
l
,
packed_buffer
,
MAX_PACKED_SIZE
);
int
total_out
=
t
gl_
inflate
(
s
,
l
,
packed_buffer
,
MAX_PACKED_SIZE
);
end
=
in_ptr
;
end
=
in_ptr
;
eend
=
in_end
;
eend
=
in_end
;
//assert (total_out % 4 == 0);
//assert (total_out % 4 == 0);
...
@@ -2468,7 +2468,7 @@ static struct query_methods send_encr_request_methods = {
...
@@ -2468,7 +2468,7 @@ static struct query_methods send_encr_request_methods = {
//int encr_root;
//int encr_root;
//unsigned char *encr_prime;
//unsigned char *encr_prime;
//int encr_param_version;
//int encr_param_version;
static
BN_CTX
*
ctx
;
//
static BN_CTX *ctx;
void
tgl_do_send_accept_encr_chat
(
struct
tgl_secret_chat
*
E
,
unsigned
char
*
random
,
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
struct
tgl_secret_chat
*
E
),
void
*
callback_extra
)
{
void
tgl_do_send_accept_encr_chat
(
struct
tgl_secret_chat
*
E
,
unsigned
char
*
random
,
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
struct
tgl_secret_chat
*
E
),
void
*
callback_extra
)
{
int
i
;
int
i
;
...
@@ -2493,15 +2493,15 @@ void tgl_do_send_accept_encr_chat (struct tgl_secret_chat *E, unsigned char *ran
...
@@ -2493,15 +2493,15 @@ void tgl_do_send_accept_encr_chat (struct tgl_secret_chat *E, unsigned char *ran
BIGNUM
*
g_a
=
BN_bin2bn
(
E
->
g_key
,
256
,
0
);
BIGNUM
*
g_a
=
BN_bin2bn
(
E
->
g_key
,
256
,
0
);
ensure_ptr
(
g_a
);
ensure_ptr
(
g_a
);
assert
(
tglmp_check_g
(
tgl_state
.
encr_prime
,
g_a
)
>=
0
);
assert
(
tglmp_check_g
(
tgl_state
.
encr_prime
,
g_a
)
>=
0
);
if
(
!
ctx
)
{
//
if (!ctx) {
ctx
=
BN_CTX_new
();
//
ctx = BN_CTX_new ();
ensure_ptr
(
ctx
);
//
ensure_ptr (ctx);
}
//
}
BIGNUM
*
p
=
BN_bin2bn
(
tgl_state
.
encr_prime
,
256
,
0
);
BIGNUM
*
p
=
BN_bin2bn
(
tgl_state
.
encr_prime
,
256
,
0
);
ensure_ptr
(
p
);
ensure_ptr
(
p
);
BIGNUM
*
r
=
BN_new
();
BIGNUM
*
r
=
BN_new
();
ensure_ptr
(
r
);
ensure_ptr
(
r
);
ensure
(
BN_mod_exp
(
r
,
g_a
,
b
,
p
,
ctx
));
ensure
(
BN_mod_exp
(
r
,
g_a
,
b
,
p
,
tgl_state
.
BN_
ctx
));
static
unsigned
char
kk
[
256
];
static
unsigned
char
kk
[
256
];
memset
(
kk
,
0
,
sizeof
(
kk
));
memset
(
kk
,
0
,
sizeof
(
kk
));
BN_bn2bin
(
r
,
kk
);
BN_bn2bin
(
r
,
kk
);
...
@@ -2520,7 +2520,7 @@ void tgl_do_send_accept_encr_chat (struct tgl_secret_chat *E, unsigned char *ran
...
@@ -2520,7 +2520,7 @@ void tgl_do_send_accept_encr_chat (struct tgl_secret_chat *E, unsigned char *ran
out_long
(
E
->
access_hash
);
out_long
(
E
->
access_hash
);
ensure
(
BN_set_word
(
g_a
,
tgl_state
.
encr_root
));
ensure
(
BN_set_word
(
g_a
,
tgl_state
.
encr_root
));
ensure
(
BN_mod_exp
(
r
,
g_a
,
b
,
p
,
ctx
));
ensure
(
BN_mod_exp
(
r
,
g_a
,
b
,
p
,
tgl_state
.
BN_
ctx
));
static
unsigned
char
buf
[
256
];
static
unsigned
char
buf
[
256
];
memset
(
buf
,
0
,
sizeof
(
buf
));
memset
(
buf
,
0
,
sizeof
(
buf
));
BN_bn2bin
(
r
,
buf
);
BN_bn2bin
(
r
,
buf
);
...
@@ -2540,17 +2540,13 @@ void tgl_do_create_keys_end (struct tgl_secret_chat *U) {
...
@@ -2540,17 +2540,13 @@ void tgl_do_create_keys_end (struct tgl_secret_chat *U) {
BIGNUM
*
g_b
=
BN_bin2bn
(
U
->
g_key
,
256
,
0
);
BIGNUM
*
g_b
=
BN_bin2bn
(
U
->
g_key
,
256
,
0
);
ensure_ptr
(
g_b
);
ensure_ptr
(
g_b
);
assert
(
tglmp_check_g
(
tgl_state
.
encr_prime
,
g_b
)
>=
0
);
assert
(
tglmp_check_g
(
tgl_state
.
encr_prime
,
g_b
)
>=
0
);
if
(
!
ctx
)
{
ctx
=
BN_CTX_new
();
ensure_ptr
(
ctx
);
}
BIGNUM
*
p
=
BN_bin2bn
(
tgl_state
.
encr_prime
,
256
,
0
);
BIGNUM
*
p
=
BN_bin2bn
(
tgl_state
.
encr_prime
,
256
,
0
);
ensure_ptr
(
p
);
ensure_ptr
(
p
);
BIGNUM
*
r
=
BN_new
();
BIGNUM
*
r
=
BN_new
();
ensure_ptr
(
r
);
ensure_ptr
(
r
);
BIGNUM
*
a
=
BN_bin2bn
((
void
*
)
U
->
key
,
256
,
0
);
BIGNUM
*
a
=
BN_bin2bn
((
void
*
)
U
->
key
,
256
,
0
);
ensure_ptr
(
a
);
ensure_ptr
(
a
);
ensure
(
BN_mod_exp
(
r
,
g_b
,
a
,
p
,
ctx
));
ensure
(
BN_mod_exp
(
r
,
g_b
,
a
,
p
,
tgl_state
.
BN_
ctx
));
unsigned
char
*
t
=
talloc
(
256
);
unsigned
char
*
t
=
talloc
(
256
);
memcpy
(
t
,
U
->
key
,
256
);
memcpy
(
t
,
U
->
key
,
256
);
...
@@ -2586,10 +2582,6 @@ void tgl_do_send_create_encr_chat (void *x, unsigned char *random, void (*callba
...
@@ -2586,10 +2582,6 @@ void tgl_do_send_create_encr_chat (void *x, unsigned char *random, void (*callba
for
(
i
=
0
;
i
<
256
;
i
++
)
{
for
(
i
=
0
;
i
<
256
;
i
++
)
{
random
[
i
]
^=
random_here
[
i
];
random
[
i
]
^=
random_here
[
i
];
}
}
if
(
!
ctx
)
{
ctx
=
BN_CTX_new
();
ensure_ptr
(
ctx
);
}
BIGNUM
*
a
=
BN_bin2bn
(
random
,
256
,
0
);
BIGNUM
*
a
=
BN_bin2bn
(
random
,
256
,
0
);
ensure_ptr
(
a
);
ensure_ptr
(
a
);
BIGNUM
*
p
=
BN_bin2bn
(
tgl_state
.
encr_prime
,
256
,
0
);
BIGNUM
*
p
=
BN_bin2bn
(
tgl_state
.
encr_prime
,
256
,
0
);
...
@@ -2603,7 +2595,7 @@ void tgl_do_send_create_encr_chat (void *x, unsigned char *random, void (*callba
...
@@ -2603,7 +2595,7 @@ void tgl_do_send_create_encr_chat (void *x, unsigned char *random, void (*callba
BIGNUM
*
r
=
BN_new
();
BIGNUM
*
r
=
BN_new
();
ensure_ptr
(
r
);
ensure_ptr
(
r
);
ensure
(
BN_mod_exp
(
r
,
g
,
a
,
p
,
ctx
));
ensure
(
BN_mod_exp
(
r
,
g
,
a
,
p
,
tgl_state
.
BN_
ctx
));
BN_clear_free
(
a
);
BN_clear_free
(
a
);
...
...
structures.c
View file @
f3636ced
...
@@ -68,7 +68,7 @@ static tgl_peer_t *Peers[TGL_MAX_PEER_NUM];
...
@@ -68,7 +68,7 @@ static tgl_peer_t *Peers[TGL_MAX_PEER_NUM];
char
*
create_print_name
(
tgl_peer_id_t
id
,
const
char
*
a1
,
const
char
*
a2
,
const
char
*
a3
,
const
char
*
a4
)
{
char
*
tgls_default_
create_print_name
(
tgl_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
;
static
char
buf
[
10000
];
static
char
buf
[
10000
];
...
...
structures.h
View file @
f3636ced
...
@@ -23,7 +23,7 @@
...
@@ -23,7 +23,7 @@
#include "tgl-layout.h"
#include "tgl-layout.h"
#include "tgl-fetch.h"
#include "tgl-fetch.h"
char
*
create_print_name
(
tgl_peer_id_t
id
,
const
char
*
a1
,
const
char
*
a2
,
const
char
*
a3
,
const
char
*
a4
);
char
*
tgls_default_
create_print_name
(
tgl_peer_id_t
id
,
const
char
*
a1
,
const
char
*
a2
,
const
char
*
a3
,
const
char
*
a4
);
void
tgls_free_user
(
struct
tgl_user
*
U
);
void
tgls_free_user
(
struct
tgl_user
*
U
);
...
...
tgl.c
View file @
f3636ced
...
@@ -5,6 +5,7 @@
...
@@ -5,6 +5,7 @@
#include "tgl.h"
#include "tgl.h"
#include "tools.h"
#include "tools.h"
#include "mtproto-client.h"
#include "mtproto-client.h"
#include "structures.h"
#include "net.h"
#include "net.h"
#include <event2/event.h>
#include <event2/event.h>
...
@@ -44,6 +45,9 @@ void tgl_init (void) {
...
@@ -44,6 +45,9 @@ void tgl_init (void) {
if
(
!
tgl_state
.
net_methods
)
{
if
(
!
tgl_state
.
net_methods
)
{
tgl_state
.
net_methods
=
&
tgl_conn_methods
;
tgl_state
.
net_methods
=
&
tgl_conn_methods
;
}
}
if
(
!
tgl_state
.
callback
.
create_print_name
)
{
tgl_state
.
callback
.
create_print_name
=
tgls_default_create_print_name
;
}
tglmp_on_start
(
tgl_state
.
rsa_key
);
tglmp_on_start
(
tgl_state
.
rsa_key
);
}
}
...
...
tgl.h
View file @
f3636ced
...
@@ -6,14 +6,15 @@
...
@@ -6,14 +6,15 @@
#define TGL_MAX_DC_NUM 100
#define TGL_MAX_DC_NUM 100
// JUST RANDOM STRING
#define TGL_BUILD "1828"
#define TGL_BUILD "1828"
#define TGL_VERSION "
0.9
-beta"
#define TGL_VERSION "
1.0
-beta"
// Do not modify this structure, unless you know what you do
struct
connection
;
struct
connection
;
struct
mtproto_methods
;
struct
mtproto_methods
;
struct
session
;
struct
session
;
struct
dc
;
struct
dc
;
struct
bingnum_ctx
;
#define TGL_UPDATE_CREATED 1
#define TGL_UPDATE_CREATED 1
#define TGL_UPDATE_DELETED 2
#define TGL_UPDATE_DELETED 2
...
@@ -31,6 +32,21 @@ struct dc;
...
@@ -31,6 +32,21 @@ struct dc;
#define TGL_UPDATE_MEMBERS 8192
#define TGL_UPDATE_MEMBERS 8192
#define TGL_UPDATE_ACCESS_HASH 16384
#define TGL_UPDATE_ACCESS_HASH 16384
struct
tgl_allocator
{
void
*
(
*
talloc
)(
size_t
size
);
void
*
(
*
trealloc
)(
void
*
ptr
,
size_t
old_size
,
size_t
size
);
void
*
(
*
talloc0
)(
size_t
size
);
char
*
(
*
tstrdup
)(
const
char
*
s
);
char
*
(
*
tstrndup
)(
const
char
*
s
,
size_t
n
);
void
(
*
tfree
)(
void
*
ptr
,
int
size
);
void
(
*
tfree_str
)(
void
*
ptr
);
void
(
*
tfree_secure
)(
void
*
ptr
,
int
size
);
int
(
*
tasprintf
)(
char
**
res
,
const
char
*
format
,
...)
__attribute__
((
format
(
printf
,
2
,
3
)));
int
(
*
tsnprintf
)(
char
*
buf
,
int
len
,
const
char
*
format
,
...)
__attribute__
((
format
(
printf
,
3
,
4
)));
void
(
*
tcheck
)(
void
);
void
(
*
texists
)(
void
*
ptr
,
int
size
);
};
struct
tgl_update_callback
{
struct
tgl_update_callback
{
void
(
*
new_msg
)(
struct
tgl_message
*
M
);
void
(
*
new_msg
)(
struct
tgl_message
*
M
);
void
(
*
marked_read
)(
int
num
,
struct
tgl_message
*
list
[]);
void
(
*
marked_read
)(
int
num
,
struct
tgl_message
*
list
[]);
...
@@ -59,6 +75,7 @@ struct tgl_update_callback {
...
@@ -59,6 +75,7 @@ struct tgl_update_callback {
void
(
*
secret_chat_update
)(
struct
tgl_secret_chat
*
C
,
unsigned
flags
);
void
(
*
secret_chat_update
)(
struct
tgl_secret_chat
*
C
,
unsigned
flags
);
void
(
*
msg_receive
)(
struct
tgl_message
*
M
);
void
(
*
msg_receive
)(
struct
tgl_message
*
M
);
void
(
*
our_id
)(
int
id
);
void
(
*
our_id
)(
int
id
);
char
*
(
*
create_print_name
)
(
tgl_peer_id_t
id
,
const
char
*
a1
,
const
char
*
a2
,
const
char
*
a3
,
const
char
*
a4
);
};
};
struct
tgl_net_methods
{
struct
tgl_net_methods
{
...
@@ -81,6 +98,7 @@ struct tgl_net_methods {
...
@@ -81,6 +98,7 @@ struct tgl_net_methods {
#define TGL_LOCK_DIFF 1
#define TGL_LOCK_DIFF 1
// Do not modify this structure, unless you know what you do
struct
tgl_state
{
struct
tgl_state
{
int
our_id
;
// ID of logged in user
int
our_id
;
// ID of logged in user
int
encr_root
;
int
encr_root
;
...
@@ -115,6 +133,9 @@ struct tgl_state {
...
@@ -115,6 +133,9 @@ struct tgl_state {
struct
event_base
*
ev_base
;
struct
event_base
*
ev_base
;
char
*
rsa_key
;
char
*
rsa_key
;
struct
bignum_ctx
*
BN_ctx
;
struct
tgl_allocator
allocator
;
};
};
extern
struct
tgl_state
tgl_state
;
extern
struct
tgl_state
tgl_state
;
...
...
tools.c
View file @
f3636ced
...
@@ -40,10 +40,10 @@
...
@@ -40,10 +40,10 @@
#define RES_PRE 8
#define RES_PRE 8
#define RES_AFTER 8
#define RES_AFTER 8
#define MAX_BLOCKS 1000000
#define MAX_BLOCKS 1000000
void
*
blocks
[
MAX_BLOCKS
];
static
void
*
blocks
[
MAX_BLOCKS
];
void
*
free_blocks
[
MAX_BLOCKS
];
static
void
*
free_blocks
[
MAX_BLOCKS
];
int
used_blocks
;
static
int
used_blocks
;
int
free_blocks_cnt
;
static
int
free_blocks_cnt
;
#endif
#endif
...
@@ -59,11 +59,6 @@ extern int verbosity;
...
@@ -59,11 +59,6 @@ extern int verbosity;
long
long
total_allocated_bytes
;
long
long
total_allocated_bytes
;
static
void
out_of_memory
(
void
)
{
fprintf
(
stderr
,
"Out of memory
\n
"
);
exit
(
1
);
}
int
tsnprintf
(
char
*
buf
,
int
len
,
const
char
*
format
,
...)
{
int
tsnprintf
(
char
*
buf
,
int
len
,
const
char
*
format
,
...)
{
va_list
ap
;
va_list
ap
;
va_start
(
ap
,
format
);
va_start
(
ap
,
format
);
...
@@ -201,21 +196,8 @@ char *tstrndup (const char *s, size_t n) {
...
@@ -201,21 +196,8 @@ char *tstrndup (const char *s, size_t n) {
#endif
#endif
}
}
void
ensure
(
int
r
)
{
if
(
!
r
)
{
logprintf
(
"Open SSL error
\n
"
);
ERR_print_errors_fp
(
stderr
);
assert
(
0
);
}
}
void
ensure_ptr
(
void
*
p
)
{
if
(
p
==
NULL
)
{
out_of_memory
();
}
}
int
tinflate
(
void
*
input
,
int
ilen
,
void
*
output
,
int
olen
)
{
int
t
gl_
inflate
(
void
*
input
,
int
ilen
,
void
*
output
,
int
olen
)
{
z_stream
strm
;
z_stream
strm
;
memset
(
&
strm
,
0
,
sizeof
(
strm
));
memset
(
&
strm
,
0
,
sizeof
(
strm
));
assert
(
inflateInit2
(
&
strm
,
16
+
MAX_WBITS
)
==
Z_OK
);
assert
(
inflateInit2
(
&
strm
,
16
+
MAX_WBITS
)
==
Z_OK
);
...
@@ -282,7 +264,7 @@ void texists (void *ptr, int size) {
...
@@ -282,7 +264,7 @@ void texists (void *ptr, int size) {
}
}
#endif
#endif
void
my_clock_gettime
(
int
clock_id
,
struct
timespec
*
T
)
{
void
tgl_
my_clock_gettime
(
int
clock_id
,
struct
timespec
*
T
)
{
#ifdef __MACH__
#ifdef __MACH__
// We are ignoring MONOTONIC and hope time doesn't go back too often
// We are ignoring MONOTONIC and hope time doesn't go back too often
clock_serv_t
cclock
;
clock_serv_t
cclock
;
...
@@ -299,7 +281,7 @@ void my_clock_gettime (int clock_id, struct timespec *T) {
...
@@ -299,7 +281,7 @@ void my_clock_gettime (int clock_id, struct timespec *T) {
double
tglt_get_double_time
(
void
)
{
double
tglt_get_double_time
(
void
)
{
struct
timespec
tv
;
struct
timespec
tv
;
my_clock_gettime
(
CLOCK_REALTIME
,
&
tv
);
tgl_
my_clock_gettime
(
CLOCK_REALTIME
,
&
tv
);
return
tv
.
tv_sec
+
1e-9
*
tv
.
tv_nsec
;
return
tv
.
tv_sec
+
1e-9
*
tv
.
tv_nsec
;
}
}
...
...
tools.h
View file @
f3636ced
...
@@ -19,6 +19,9 @@
...
@@ -19,6 +19,9 @@
#ifndef __TOOLS_H__
#ifndef __TOOLS_H__
#define __TOOLS_H__
#define __TOOLS_H__
#include <time.h>
#include <openssl/err.h>
#include <assert.h>
double
tglt_get_double_time
(
void
);
double
tglt_get_double_time
(
void
);
...
@@ -27,9 +30,28 @@ void *trealloc (void *ptr, size_t old_size, size_t size);
...
@@ -27,9 +30,28 @@ void *trealloc (void *ptr, size_t old_size, size_t size);
void
*
talloc0
(
size_t
size
);
void
*
talloc0
(
size_t
size
);
char
*
tstrdup
(
const
char
*
s
);
char
*
tstrdup
(
const
char
*
s
);
char
*
tstrndup
(
const
char
*
s
,
size_t
n
);
char
*
tstrndup
(
const
char
*
s
,
size_t
n
);
int
tinflate
(
void
*
input
,
int
ilen
,
void
*
output
,
int
olen
);
int
tgl_inflate
(
void
*
input
,
int
ilen
,
void
*
output
,
int
olen
);
void
ensure
(
int
r
);
//void ensure (int r);
void
ensure_ptr
(
void
*
p
);
//void ensure_ptr (void *p);
static
inline
void
out_of_memory
(
void
)
{
fprintf
(
stderr
,
"Out of memory
\n
"
);
exit
(
1
);
}
static
inline
void
ensure
(
int
r
)
{
if
(
!
r
)
{
fprintf
(
stderr
,
"Open SSL error
\n
"
);
ERR_print_errors_fp
(
stderr
);
assert
(
0
);
}
}
static
inline
void
ensure_ptr
(
void
*
p
)
{
if
(
p
==
NULL
)
{
out_of_memory
();
}
}
void
tfree
(
void
*
ptr
,
int
size
);
void
tfree
(
void
*
ptr
,
int
size
);
void
tfree_str
(
void
*
ptr
);
void
tfree_str
(
void
*
ptr
);
...
@@ -40,9 +62,11 @@ int tsnprintf (char *buf, int len, const char *format, ...) __attribute__ ((form
...
@@ -40,9 +62,11 @@ int tsnprintf (char *buf, int len, const char *format, ...) __attribute__ ((form
int
tasprintf
(
char
**
res
,
const
char
*
format
,
...)
__attribute__
((
format
(
printf
,
2
,
3
)));
int
tasprintf
(
char
**
res
,
const
char
*
format
,
...)
__attribute__
((
format
(
printf
,
2
,
3
)));
void
tglt_secure_random
(
void
*
s
,
int
l
);
void
tglt_secure_random
(
void
*
s
,
int
l
);
void
tgl_my_clock_gettime
(
int
clock_id
,
struct
timespec
*
T
);
#ifdef DEBUG
#ifdef DEBUG
void
tcheck
(
void
);
void
tcheck
(
void
);
void
texists
(
void
*
ptr
,
int
size
);
void
texists
(
void
*
ptr
,
int
size
);
#endif
#endif
#endif
#endif
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