2019-07-09 05:01:12 +03:00
|
|
|
//
|
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2019
|
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#include "td/mtproto/ProxySecret.h"
|
|
|
|
|
|
|
|
#include "td/utils/base64.h"
|
|
|
|
#include "td/utils/misc.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
namespace mtproto {
|
|
|
|
|
|
|
|
Result<ProxySecret> ProxySecret::from_link(Slice encoded_secret) {
|
|
|
|
auto r_decoded = hex_decode(encoded_secret);
|
|
|
|
if (r_decoded.is_error()) {
|
|
|
|
r_decoded = base64url_decode(encoded_secret);
|
|
|
|
}
|
|
|
|
if (r_decoded.is_error()) {
|
|
|
|
return Status::Error(400, "Wrong proxy secret");
|
|
|
|
}
|
|
|
|
return from_binary(r_decoded.ok());
|
|
|
|
}
|
|
|
|
|
|
|
|
Result<ProxySecret> ProxySecret::from_binary(Slice raw_unchecked_secret) {
|
|
|
|
if (raw_unchecked_secret.size() == 16 ||
|
|
|
|
(raw_unchecked_secret.size() == 17 && static_cast<unsigned char>(raw_unchecked_secret[0]) == 0xdd) ||
|
2019-07-11 23:42:59 +03:00
|
|
|
(raw_unchecked_secret.size() >= 18 && static_cast<unsigned char>(raw_unchecked_secret[0]) == 0xee)) {
|
2019-07-09 05:01:12 +03:00
|
|
|
return from_raw(raw_unchecked_secret);
|
|
|
|
}
|
|
|
|
if (raw_unchecked_secret.size() < 16) {
|
|
|
|
return Status::Error(400, "Wrong proxy secret");
|
|
|
|
}
|
|
|
|
return Status::Error(400, "Unsupported proxy secret");
|
|
|
|
}
|
|
|
|
|
|
|
|
string ProxySecret::get_encoded_secret() const {
|
|
|
|
if (emulate_tls()) {
|
|
|
|
return base64url_encode(secret_);
|
|
|
|
}
|
|
|
|
return buffer_to_hex(secret_);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace mtproto
|
|
|
|
} // namespace td
|