Commit 4c0071cf authored by Thomas Wentzel's avatar Thomas Wentzel

Got into a situation where telegram would crash upon startup, since...

Got into a situation where telegram would crash upon startup, since fetch_encrypted_message_file would end up being called with a message_media of type CODE_decrypted_message_media_document.
parent 49f1321f
...@@ -1482,15 +1482,29 @@ void fetch_encrypted_message_file (struct message_media *M) { ...@@ -1482,15 +1482,29 @@ void fetch_encrypted_message_file (struct message_media *M) {
if (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 != CODE_decrypted_message_media_photo && M->type != CODE_decrypted_message_media_video);
} else { } else {
assert (M->type == CODE_decrypted_message_media_photo || M->type == CODE_decrypted_message_media_video); assert (M->type == CODE_decrypted_message_media_document || M->type == CODE_decrypted_message_media_photo || M->type == CODE_decrypted_message_media_video);
M->encr_photo.id = fetch_long ();
M->encr_photo.access_hash = fetch_long (); switch (M->type) {
fetch_int (); case CODE_decrypted_message_media_document:
//assert (M->encr_photo.size == fetch_int ()); // Not at all sure these entries are correct.
//M->encr_photo.size = fetch_int (); // Why it is not the same? // Especially since values are not fetched into structures rigidly for photo and video.
M->encr_photo.dc_id = fetch_int (); M->encr_document.id = fetch_long();
M->encr_photo.key_fingerprint = fetch_int (); M->encr_document.access_hash = fetch_long();
M->encr_document.dc_id = fetch_int();
M->encr_document.size = fetch_int();
M->encr_document.key_fingerprint = fetch_int();
break;
case CODE_decrypted_message_media_photo:
case CODE_decrypted_message_media_video:
M->encr_photo.id = fetch_long ();
M->encr_photo.access_hash = fetch_long ();
fetch_int ();
//assert (M->encr_photo.size == fetch_int ());
//M->encr_photo.size = fetch_int (); // Why it is not the same?
M->encr_photo.dc_id = fetch_int ();
M->encr_photo.key_fingerprint = fetch_int ();
break;
}
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment