mirror of https://github.com/procxx/kepka.git
Remove mtproto/facade.h from main pch.
This commit is contained in:
parent
0c0c8f3584
commit
2577bedeac
|
@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#include "boxes/calendar_box.h"
|
#include "boxes/calendar_box.h"
|
||||||
|
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
#include "ui/widgets/buttons.h"
|
#include "ui/widgets/buttons.h"
|
||||||
#include "lang/lang_keys.h"
|
#include "lang/lang_keys.h"
|
||||||
#include "ui/effects/ripple_animation.h"
|
#include "ui/effects/ripple_animation.h"
|
||||||
|
|
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "boxes/abstract_box.h"
|
#include "boxes/abstract_box.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace Main {
|
namespace Main {
|
||||||
class Session;
|
class Session;
|
||||||
|
|
|
@ -19,6 +19,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "numbers.h"
|
#include "numbers.h"
|
||||||
#include "app.h"
|
#include "app.h"
|
||||||
#include "lang/lang_keys.h"
|
#include "lang/lang_keys.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "styles/style_layers.h"
|
#include "styles/style_layers.h"
|
||||||
#include "styles/style_boxes.h"
|
#include "styles/style_boxes.h"
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "boxes/abstract_box.h"
|
#include "boxes/abstract_box.h"
|
||||||
#include "base/timer.h"
|
#include "base/timer.h"
|
||||||
#include "ui/widgets/input_fields.h"
|
#include "ui/widgets/input_fields.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class InputField;
|
class InputField;
|
||||||
|
|
|
@ -11,6 +11,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "storage/storage_media_prepare.h"
|
#include "storage/storage_media_prepare.h"
|
||||||
#include "ui/wrap/slide_wrap.h"
|
#include "ui/wrap/slide_wrap.h"
|
||||||
#include "media/clip/media_clip_reader.h"
|
#include "media/clip/media_clip_reader.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace ChatHelpers {
|
namespace ChatHelpers {
|
||||||
class TabbedPanel;
|
class TabbedPanel;
|
||||||
|
|
|
@ -10,6 +10,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "boxes/abstract_box.h"
|
#include "boxes/abstract_box.h"
|
||||||
#include "base/unique_qptr.h"
|
#include "base/unique_qptr.h"
|
||||||
|
|
||||||
|
class RPCError;
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class FlatLabel;
|
class FlatLabel;
|
||||||
class LinkButton;
|
class LinkButton;
|
||||||
|
|
|
@ -14,6 +14,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "ui/widgets/buttons.h"
|
#include "ui/widgets/buttons.h"
|
||||||
#include "ui/widgets/input_fields.h"
|
#include "ui/widgets/input_fields.h"
|
||||||
#include "ui/toast/toast.h"
|
#include "ui/toast/toast.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "mainwindow.h"
|
#include "mainwindow.h"
|
||||||
#include "styles/style_layers.h"
|
#include "styles/style_layers.h"
|
||||||
#include "styles/style_boxes.h"
|
#include "styles/style_boxes.h"
|
||||||
|
|
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "boxes/abstract_box.h"
|
#include "boxes/abstract_box.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
template <typename Enum>
|
template <typename Enum>
|
||||||
|
|
|
@ -12,6 +12,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "base/timer.h"
|
#include "base/timer.h"
|
||||||
#include "ui/effects/animations.h"
|
#include "ui/effects/animations.h"
|
||||||
#include "ui/effects/round_checkbox.h"
|
#include "ui/effects/round_checkbox.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
enum class SendMenuType;
|
enum class SendMenuType;
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "boxes/abstract_box.h"
|
#include "boxes/abstract_box.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class UsernameInput;
|
class UsernameInput;
|
||||||
|
|
|
@ -13,6 +13,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "ui/rp_widget.h"
|
#include "ui/rp_widget.h"
|
||||||
#include "base/flags.h"
|
#include "base/flags.h"
|
||||||
#include "base/object_ptr.h"
|
#include "base/object_ptr.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace Main {
|
namespace Main {
|
||||||
class Session;
|
class Session;
|
||||||
|
|
|
@ -13,6 +13,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "ui/widgets/scroll_area.h"
|
#include "ui/widgets/scroll_area.h"
|
||||||
#include "ui/special_buttons.h"
|
#include "ui/special_buttons.h"
|
||||||
#include "api/api_single_message_search.h"
|
#include "api/api_single_message_search.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace Main {
|
namespace Main {
|
||||||
class Session;
|
class Session;
|
||||||
|
|
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "mtproto/auth_key.h"
|
#include "mtproto/auth_key.h"
|
||||||
|
#include "mtproto/mtp_instance.h"
|
||||||
#include "base/weak_ptr.h"
|
#include "base/weak_ptr.h"
|
||||||
|
|
||||||
namespace Main {
|
namespace Main {
|
||||||
|
|
|
@ -15,6 +15,10 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
|
|
||||||
class ApiWrap;
|
class ApiWrap;
|
||||||
|
|
||||||
|
namespace MTP {
|
||||||
|
class Instance;
|
||||||
|
} // namespace MTP
|
||||||
|
|
||||||
namespace Support {
|
namespace Support {
|
||||||
class Helper;
|
class Helper;
|
||||||
class Templates;
|
class Templates;
|
||||||
|
|
|
@ -13,6 +13,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "ui/effects/animations.h"
|
#include "ui/effects/animations.h"
|
||||||
#include "media/player/media_player_float.h"
|
#include "media/player/media_player_float.h"
|
||||||
#include "data/data_pts_waiter.h"
|
#include "data/data_pts_waiter.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
struct HistoryMessageMarkupButton;
|
struct HistoryMessageMarkupButton;
|
||||||
class MainWindow;
|
class MainWindow;
|
||||||
|
|
|
@ -14,6 +14,29 @@ extern "C" {
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
|
|
||||||
|
AuthKey::AuthKey(Type type, DcId dcId, const Data &data)
|
||||||
|
: _type(type)
|
||||||
|
, _dcId(dcId)
|
||||||
|
, _key(data) {
|
||||||
|
countKeyId();
|
||||||
|
}
|
||||||
|
|
||||||
|
AuthKey::AuthKey(const Data &data) : _type(Type::Local), _key(data) {
|
||||||
|
countKeyId();
|
||||||
|
}
|
||||||
|
|
||||||
|
AuthKey::Type AuthKey::type() const {
|
||||||
|
return _type;
|
||||||
|
}
|
||||||
|
|
||||||
|
int AuthKey::dcId() const {
|
||||||
|
return _dcId;
|
||||||
|
}
|
||||||
|
|
||||||
|
AuthKey::KeyId AuthKey::keyId() const {
|
||||||
|
return _keyId;
|
||||||
|
}
|
||||||
|
|
||||||
void AuthKey::prepareAES_oldmtp(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &aesIV, bool send) const {
|
void AuthKey::prepareAES_oldmtp(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &aesIV, bool send) const {
|
||||||
uint32 x = send ? 0 : 8;
|
uint32 x = send ? 0 : 8;
|
||||||
|
|
||||||
|
@ -72,6 +95,41 @@ void AuthKey::prepareAES(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &
|
||||||
memcpy(iv + 8 + 16, sha256_b + 24, 8);
|
memcpy(iv + 8 + 16, sha256_b + 24, 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const void *AuthKey::partForMsgKey(bool send) const {
|
||||||
|
return _key.data() + 88 + (send ? 0 : 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
void AuthKey::write(QDataStream &to) const {
|
||||||
|
to.writeRawData(reinterpret_cast<const char*>(_key.data()), _key.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
bytes::const_span AuthKey::data() const {
|
||||||
|
return _key;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool AuthKey::equals(const std::shared_ptr<AuthKey> &other) const {
|
||||||
|
return other ? (_key == other->_key) : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void AuthKey::FillData(Data &authKey, bytes::const_span computedAuthKey) {
|
||||||
|
auto computedAuthKeySize = computedAuthKey.size();
|
||||||
|
Assert(computedAuthKeySize <= kSize);
|
||||||
|
auto authKeyBytes = gsl::make_span(authKey);
|
||||||
|
if (computedAuthKeySize < kSize) {
|
||||||
|
bytes::set_with_const(authKeyBytes.subspan(0, kSize - computedAuthKeySize), gsl::byte());
|
||||||
|
bytes::copy(authKeyBytes.subspan(kSize - computedAuthKeySize), computedAuthKey);
|
||||||
|
} else {
|
||||||
|
bytes::copy(authKeyBytes, computedAuthKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AuthKey::countKeyId() {
|
||||||
|
auto sha1 = hashSha1(_key.data(), _key.size());
|
||||||
|
|
||||||
|
// Lower 64 bits = 8 bytes of 20 byte SHA1 hash.
|
||||||
|
_keyId = *reinterpret_cast<KeyId*>(sha1.data() + 12);
|
||||||
|
}
|
||||||
|
|
||||||
void aesIgeEncryptRaw(const void *src, void *dst, uint32 len, const void *key, const void *iv) {
|
void aesIgeEncryptRaw(const void *src, void *dst, uint32 len, const void *key, const void *iv) {
|
||||||
uchar aes_key[32], aes_iv[32];
|
uchar aes_key[32], aes_iv[32];
|
||||||
memcpy(aes_key, key, 32);
|
memcpy(aes_key, key, 32);
|
||||||
|
|
|
@ -7,9 +7,9 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "base/bytes.h"
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include "base/bytes.h"
|
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
|
|
||||||
|
@ -24,65 +24,29 @@ public:
|
||||||
ReadFromFile,
|
ReadFromFile,
|
||||||
Local,
|
Local,
|
||||||
};
|
};
|
||||||
AuthKey(Type type, DcId dcId, const Data &data) : _type(type), _dcId(dcId), _key(data) {
|
AuthKey(Type type, DcId dcId, const Data &data);
|
||||||
countKeyId();
|
explicit AuthKey(const Data &data);
|
||||||
}
|
|
||||||
AuthKey(const Data &data) : _type(Type::Local), _key(data) {
|
|
||||||
countKeyId();
|
|
||||||
}
|
|
||||||
|
|
||||||
AuthKey(const AuthKey &other) = delete;
|
AuthKey(const AuthKey &other) = delete;
|
||||||
AuthKey &operator=(const AuthKey &other) = delete;
|
AuthKey &operator=(const AuthKey &other) = delete;
|
||||||
|
|
||||||
Type type() const {
|
Type type() const;
|
||||||
return _type;
|
int dcId() const;
|
||||||
}
|
KeyId keyId() const;
|
||||||
|
|
||||||
int dcId() const {
|
|
||||||
return _dcId;
|
|
||||||
}
|
|
||||||
|
|
||||||
KeyId keyId() const {
|
|
||||||
return _keyId;
|
|
||||||
}
|
|
||||||
|
|
||||||
void prepareAES_oldmtp(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &aesIV, bool send) const;
|
void prepareAES_oldmtp(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &aesIV, bool send) const;
|
||||||
void prepareAES(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &aesIV, bool send) const;
|
void prepareAES(const MTPint128 &msgKey, MTPint256 &aesKey, MTPint256 &aesIV, bool send) const;
|
||||||
|
|
||||||
const void *partForMsgKey(bool send) const {
|
const void *partForMsgKey(bool send) const;
|
||||||
return _key.data() + 88 + (send ? 0 : 8);
|
|
||||||
}
|
|
||||||
|
|
||||||
void write(QDataStream &to) const {
|
void write(QDataStream &to) const;
|
||||||
to.writeRawData(reinterpret_cast<const char*>(_key.data()), _key.size());
|
bytes::const_span data() const;
|
||||||
}
|
bool equals(const std::shared_ptr<AuthKey> &other) const;
|
||||||
bytes::const_span data() const {
|
|
||||||
return _key;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool equals(const std::shared_ptr<AuthKey> &other) const {
|
static void FillData(Data &authKey, bytes::const_span computedAuthKey);
|
||||||
return other ? (_key == other->_key) : false;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void FillData(Data &authKey, bytes::const_span computedAuthKey) {
|
|
||||||
auto computedAuthKeySize = computedAuthKey.size();
|
|
||||||
Assert(computedAuthKeySize <= kSize);
|
|
||||||
auto authKeyBytes = gsl::make_span(authKey);
|
|
||||||
if (computedAuthKeySize < kSize) {
|
|
||||||
bytes::set_with_const(authKeyBytes.subspan(0, kSize - computedAuthKeySize), gsl::byte());
|
|
||||||
bytes::copy(authKeyBytes.subspan(kSize - computedAuthKeySize), computedAuthKey);
|
|
||||||
} else {
|
|
||||||
bytes::copy(authKeyBytes, computedAuthKey);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void countKeyId() {
|
void countKeyId();
|
||||||
auto sha1 = hashSha1(_key.data(), _key.size());
|
|
||||||
|
|
||||||
// Lower 64 bits = 8 bytes of 20 byte SHA1 hash.
|
|
||||||
_keyId = *reinterpret_cast<KeyId*>(sha1.data() + 12);
|
|
||||||
}
|
|
||||||
|
|
||||||
Type _type = Type::Generated;
|
Type _type = Type::Generated;
|
||||||
DcId _dcId = 0;
|
DcId _dcId = 0;
|
||||||
|
|
|
@ -9,6 +9,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
|
|
||||||
#include "mtproto/mtp_instance.h"
|
#include "mtproto/mtp_instance.h"
|
||||||
#include "mtproto/rpc_sender.h"
|
#include "mtproto/rpc_sender.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#include "mtproto/config_loader.h"
|
#include "mtproto/config_loader.h"
|
||||||
|
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "mtproto/dc_options.h"
|
#include "mtproto/dc_options.h"
|
||||||
#include "mtproto/mtp_instance.h"
|
#include "mtproto/mtp_instance.h"
|
||||||
#include "mtproto/special_config_request.h"
|
#include "mtproto/special_config_request.h"
|
||||||
|
|
|
@ -1187,7 +1187,7 @@ void ConnectionPrivate::connectToServer(bool afterConfig) {
|
||||||
if (_testConnections.empty()) {
|
if (_testConnections.empty()) {
|
||||||
if (_instance->isKeysDestroyer()) {
|
if (_instance->isKeysDestroyer()) {
|
||||||
LOG(("MTP Error: DC %1 options for not found for auth key destruction!").arg(_shiftedDcId));
|
LOG(("MTP Error: DC %1 options for not found for auth key destruction!").arg(_shiftedDcId));
|
||||||
emit _instance->keyDestroyed(_shiftedDcId);
|
_instance->checkIfKeyWasDestroyed(_shiftedDcId);
|
||||||
return;
|
return;
|
||||||
} else if (afterConfig) {
|
} else if (afterConfig) {
|
||||||
LOG(("MTP Error: DC %1 options for not found right after config load!").arg(_shiftedDcId));
|
LOG(("MTP Error: DC %1 options for not found right after config load!").arg(_shiftedDcId));
|
||||||
|
@ -2606,7 +2606,7 @@ void ConnectionPrivate::updateAuthKey() {
|
||||||
} else if (_instance->isKeysDestroyer()) {
|
} else if (_instance->isKeysDestroyer()) {
|
||||||
// We are here to destroy an old key, so we're done.
|
// We are here to destroy an old key, so we're done.
|
||||||
LOG(("MTP Error: No key %1 in updateAuthKey() for destroying.").arg(_shiftedDcId));
|
LOG(("MTP Error: No key %1 in updateAuthKey() for destroying.").arg(_shiftedDcId));
|
||||||
emit _instance->keyDestroyed(_shiftedDcId);
|
_instance->checkIfKeyWasDestroyed(_shiftedDcId);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3104,15 +3104,17 @@ void ConnectionPrivate::handleError(int errorCode) {
|
||||||
_waitForConnectedTimer.cancel();
|
_waitForConnectedTimer.cancel();
|
||||||
|
|
||||||
if (errorCode == -404) {
|
if (errorCode == -404) {
|
||||||
if (_instance->isKeysDestroyer()) {
|
if (_dcType == DcType::Cdn) {
|
||||||
LOG(("MTP Info: -404 error received on destroying key %1, assuming it is destroyed.").arg(_shiftedDcId));
|
|
||||||
emit _instance->keyDestroyed(_shiftedDcId);
|
|
||||||
return;
|
|
||||||
} else if (_dcType == DcType::Cdn) {
|
|
||||||
LOG(("MTP Info: -404 error received in CDN dc %1, assuming it was destroyed, recreating.").arg(_shiftedDcId));
|
LOG(("MTP Info: -404 error received in CDN dc %1, assuming it was destroyed, recreating.").arg(_shiftedDcId));
|
||||||
clearMessages();
|
clearMessages();
|
||||||
keyId = kRecreateKeyId;
|
keyId = kRecreateKeyId;
|
||||||
return restart();
|
return restart();
|
||||||
|
} else {
|
||||||
|
LOG(("MTP Info: -404 error received, informing instance."));
|
||||||
|
_instance->checkIfKeyWasDestroyed(_shiftedDcId);
|
||||||
|
if (_instance->isKeysDestroyer()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
MTP_LOG(_shiftedDcId, ("Restarting after error in connection, error code: %1...").arg(errorCode));
|
MTP_LOG(_shiftedDcId, ("Restarting after error in connection, error code: %1...").arg(errorCode));
|
||||||
|
|
|
@ -10,6 +10,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "mtproto/auth_key.h"
|
#include "mtproto/auth_key.h"
|
||||||
#include "mtproto/dc_options.h"
|
#include "mtproto/dc_options.h"
|
||||||
#include "mtproto/connection_abstract.h"
|
#include "mtproto/connection_abstract.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "base/openssl_help.h"
|
#include "base/openssl_help.h"
|
||||||
#include "base/timer.h"
|
#include "base/timer.h"
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,9 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "base/bytes.h"
|
#include "base/bytes.h"
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
|
|
||||||
|
class Instance;
|
||||||
|
|
||||||
namespace internal {
|
namespace internal {
|
||||||
|
|
||||||
struct ConnectionOptions;
|
struct ConnectionOptions;
|
||||||
|
|
|
@ -7,6 +7,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#include "mtproto/connection_resolving.h"
|
#include "mtproto/connection_resolving.h"
|
||||||
|
|
||||||
|
#include "mtproto/mtp_instance.h"
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
namespace internal {
|
namespace internal {
|
||||||
namespace {
|
namespace {
|
||||||
|
|
|
@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#include "mtproto/dc_options.h"
|
#include "mtproto/dc_options.h"
|
||||||
|
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "storage/serialize_common.h"
|
#include "storage/serialize_common.h"
|
||||||
#include "mtproto/connection_tcp.h"
|
#include "mtproto/connection_tcp.h"
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#include "mtproto/dedicated_file_loader.h"
|
#include "mtproto/dedicated_file_loader.h"
|
||||||
|
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "main/main_session.h"
|
#include "main/main_session.h"
|
||||||
#include "main/main_account.h" // Account::sessionChanges.
|
#include "main/main_account.h" // Account::sessionChanges.
|
||||||
#include "core/application.h"
|
#include "core/application.h"
|
||||||
|
|
|
@ -7,9 +7,9 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
*/
|
*/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
namespace MTP {
|
#include "mtproto/mtp_instance.h"
|
||||||
|
|
||||||
class Instance;
|
namespace MTP {
|
||||||
|
|
||||||
class WeakInstance : private QObject, private base::Subscriber {
|
class WeakInstance : private QObject, private base::Subscriber {
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -17,8 +17,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "mtproto/rsa_public_key.h"
|
#include "mtproto/rsa_public_key.h"
|
||||||
#include "storage/localstorage.h"
|
#include "storage/localstorage.h"
|
||||||
#include "calls/calls_instance.h"
|
#include "calls/calls_instance.h"
|
||||||
#include "main/main_account.h"
|
#include "main/main_session.h" // Session::Exists.
|
||||||
#include "main/main_session.h"
|
#include "main/main_account.h" // Account::configUpdated.
|
||||||
#include "apiwrap.h"
|
#include "apiwrap.h"
|
||||||
#include "core/application.h"
|
#include "core/application.h"
|
||||||
#include "lang/lang_instance.h"
|
#include "lang/lang_instance.h"
|
||||||
|
@ -26,7 +26,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "base/unixtime.h"
|
#include "base/unixtime.h"
|
||||||
#include "base/call_delayed.h"
|
#include "base/call_delayed.h"
|
||||||
#include "base/timer.h"
|
#include "base/timer.h"
|
||||||
#include "facades.h"
|
#include "facades.h" // Proxies list.
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -246,10 +246,6 @@ void Instance::Private::start(Config &&config) {
|
||||||
_deviceModel = std::move(config.deviceModel);
|
_deviceModel = std::move(config.deviceModel);
|
||||||
_systemVersion = std::move(config.systemVersion);
|
_systemVersion = std::move(config.systemVersion);
|
||||||
|
|
||||||
if (isKeysDestroyer()) {
|
|
||||||
_instance->connect(_instance, SIGNAL(keyDestroyed(qint32)), _instance, SLOT(onKeyDestroyed(qint32)), Qt::QueuedConnection);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto &key : config.keys) {
|
for (auto &key : config.keys) {
|
||||||
auto dcId = key->dcId();
|
auto dcId = key->dcId();
|
||||||
auto shiftedDcId = dcId;
|
auto shiftedDcId = dcId;
|
||||||
|
@ -1487,10 +1483,10 @@ void Instance::Private::performKeyDestroy(ShiftedDcId shiftedDcId) {
|
||||||
} break;
|
} break;
|
||||||
case mtpc_destroy_auth_key_none: LOG(("MTP Info: key %1 already destroyed.").arg(shiftedDcId)); break;
|
case mtpc_destroy_auth_key_none: LOG(("MTP Info: key %1 already destroyed.").arg(shiftedDcId)); break;
|
||||||
}
|
}
|
||||||
emit _instance->keyDestroyed(shiftedDcId);
|
_instance->checkIfKeyWasDestroyed(shiftedDcId);
|
||||||
}), rpcFail([this, shiftedDcId](const RPCError &error) {
|
}), rpcFail([this, shiftedDcId](const RPCError &error) {
|
||||||
LOG(("MTP Error: key %1 destruction resulted in error: %2").arg(shiftedDcId).arg(error.type()));
|
LOG(("MTP Error: key %1 destruction resulted in error: %2").arg(shiftedDcId).arg(error.type()));
|
||||||
emit _instance->keyDestroyed(shiftedDcId);
|
_instance->checkIfKeyWasDestroyed(shiftedDcId);
|
||||||
return true;
|
return true;
|
||||||
}), shiftedDcId);
|
}), shiftedDcId);
|
||||||
}
|
}
|
||||||
|
@ -1749,9 +1745,16 @@ void Instance::scheduleKeyDestroy(ShiftedDcId shiftedDcId) {
|
||||||
_private->scheduleKeyDestroy(shiftedDcId);
|
_private->scheduleKeyDestroy(shiftedDcId);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Instance::onKeyDestroyed(qint32 shiftedDcId) {
|
void Instance::checkIfKeyWasDestroyed(ShiftedDcId shiftedDcId) {
|
||||||
_private->completedKeyDestroy(shiftedDcId);
|
crl::on_main(this, [=] {
|
||||||
|
if (isKeysDestroyer()) {
|
||||||
|
LOG(("MTP Info: checkIfKeyWasDestroyed on destroying key %1, "
|
||||||
|
"assuming it is destroyed.").arg(shiftedDcId));
|
||||||
|
_private->completedKeyDestroy(shiftedDcId);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void Instance::sendRequest(
|
void Instance::sendRequest(
|
||||||
mtpRequestId requestId,
|
mtpRequestId requestId,
|
||||||
SecureRequest &&request,
|
SecureRequest &&request,
|
||||||
|
|
|
@ -173,6 +173,7 @@ public:
|
||||||
|
|
||||||
bool isKeysDestroyer() const;
|
bool isKeysDestroyer() const;
|
||||||
void scheduleKeyDestroy(ShiftedDcId shiftedDcId);
|
void scheduleKeyDestroy(ShiftedDcId shiftedDcId);
|
||||||
|
void checkIfKeyWasDestroyed(ShiftedDcId shiftedDcId);
|
||||||
|
|
||||||
void requestConfig();
|
void requestConfig();
|
||||||
void requestConfigIfOld();
|
void requestConfigIfOld();
|
||||||
|
@ -190,16 +191,12 @@ public slots:
|
||||||
signals:
|
signals:
|
||||||
void configLoaded();
|
void configLoaded();
|
||||||
void cdnConfigLoaded();
|
void cdnConfigLoaded();
|
||||||
void keyDestroyed(qint32 shiftedDcId);
|
|
||||||
void allKeysDestroyed();
|
void allKeysDestroyed();
|
||||||
void proxyDomainResolved(
|
void proxyDomainResolved(
|
||||||
QString host,
|
QString host,
|
||||||
QStringList ips,
|
QStringList ips,
|
||||||
qint64 expireAt);
|
qint64 expireAt);
|
||||||
|
|
||||||
private slots:
|
|
||||||
void onKeyDestroyed(qint32 shiftedDcId);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void sendRequest(
|
void sendRequest(
|
||||||
mtpRequestId requestId,
|
mtpRequestId requestId,
|
||||||
|
|
|
@ -8,6 +8,9 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "base/variant.h"
|
#include "base/variant.h"
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
#include "mtproto/mtp_instance.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
|
|
||||||
|
|
|
@ -120,7 +120,8 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "core/utils.h"
|
#include "core/utils.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include "mtproto/facade.h"
|
#include "scheme.h"
|
||||||
|
#include "mtproto/type_utils.h"
|
||||||
|
|
||||||
#include "ui/style/style_core.h"
|
#include "ui/style/style_core.h"
|
||||||
#include "styles/palette.h"
|
#include "styles/palette.h"
|
||||||
|
|
|
@ -11,6 +11,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "base/timer.h"
|
#include "base/timer.h"
|
||||||
#include "base/binary_guard.h"
|
#include "base/binary_guard.h"
|
||||||
#include "data/data_file_origin.h"
|
#include "data/data_file_origin.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
|
|
||||||
#include <QtNetwork/QNetworkReply>
|
#include <QtNetwork/QNetworkReply>
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "api/api_common.h"
|
#include "api/api_common.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
|
|
||||||
#include <QtCore/QTimer>
|
#include <QtCore/QTimer>
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "ui/widgets/buttons.h"
|
#include "ui/widgets/buttons.h"
|
||||||
#include "ui/effects/radial_animation.h"
|
#include "ui/effects/radial_animation.h"
|
||||||
#include "ui/ui_utility.h"
|
#include "ui/ui_utility.h"
|
||||||
|
#include "mtproto/facade.h"
|
||||||
#include "window/themes/window_theme.h"
|
#include "window/themes/window_theme.h"
|
||||||
#include "boxes/connection_box.h"
|
#include "boxes/connection_box.h"
|
||||||
#include "boxes/abstract_box.h"
|
#include "boxes/abstract_box.h"
|
||||||
|
|
Loading…
Reference in New Issue