Minor Slice usage improvements.

GitOrigin-RevId: 44ceed78dfc3ec459a0c40b6863d1d6ffd863a64
This commit is contained in:
levlam 2018-11-06 23:25:09 +03:00
parent d78a1d0a33
commit 69d9173dcd
2 changed files with 3 additions and 4 deletions

View File

@ -166,7 +166,7 @@ Status AuthKeyHandshake::on_server_dh_params(Slice message, Callback *connection
size_t dh_inner_data_size = answer.size() - pad - 20; size_t dh_inner_data_size = answer.size() - pad - 20;
UInt<160> answer_real_sha1; UInt<160> answer_real_sha1;
sha1(Slice(answer.ubegin() + 20, dh_inner_data_size), answer_real_sha1.raw); sha1(answer.substr(20, dh_inner_data_size), answer_real_sha1.raw);
if (answer_sha1 != answer_real_sha1) { if (answer_sha1 != answer_real_sha1) {
return Status::Error("SHA1 mismatch"); return Status::Error("SHA1 mismatch");
} }
@ -196,7 +196,7 @@ Status AuthKeyHandshake::on_server_dh_params(Slice message, Callback *connection
as<int32>(encrypted_data.begin() + 20) = data.get_id(); as<int32>(encrypted_data.begin() + 20) = data.get_id();
auto real_size = tl_store_unsafe(data, encrypted_data.ubegin() + 20 + 4); auto real_size = tl_store_unsafe(data, encrypted_data.ubegin() + 20 + 4);
CHECK(real_size + 4 == data_size); CHECK(real_size + 4 == data_size);
sha1(Slice(encrypted_data.ubegin() + 20, data_size), encrypted_data.ubegin()); sha1(encrypted_data.substr(20, data_size), encrypted_data.ubegin());
Random::secure_bytes(encrypted_data.ubegin() + encrypted_data_size, Random::secure_bytes(encrypted_data.ubegin() + encrypted_data_size,
encrypted_data_size_with_pad - encrypted_data_size); encrypted_data_size_with_pad - encrypted_data_size);
tmp_KDF(server_nonce, new_nonce, &tmp_aes_key, &tmp_aes_iv); tmp_KDF(server_nonce, new_nonce, &tmp_aes_key, &tmp_aes_iv);

View File

@ -130,8 +130,7 @@ void AbridgedTransport::write_prepare_inplace(BufferWriter *message, bool quick_
} }
void AbridgedTransport::init_output_stream(ChainBufferWriter *stream) { void AbridgedTransport::init_output_stream(ChainBufferWriter *stream) {
const uint8 magic = 0xef; stream->append("\xef");
stream->append(Slice(&magic, 1));
} }
void ObfuscatedTransport::init(ChainBufferReader *input, ChainBufferWriter *output) { void ObfuscatedTransport::init(ChainBufferReader *input, ChainBufferWriter *output) {