mirror of https://github.com/procxx/kepka.git
Remove mtproto/session.h from precompiled header.
This commit is contained in:
parent
fa3a76b3d8
commit
ddf4a36bdc
|
@ -750,23 +750,24 @@ void AddBotToGroupBoxController::shareBotGame(not_null<PeerData*> chat) {
|
||||||
if (!weak) {
|
if (!weak) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto history = App::historyLoaded(chat);
|
const auto history = App::historyLoaded(chat);
|
||||||
auto afterRequestId = history ? history->sendRequestId : 0;
|
const auto randomId = rand_value<uint64>();
|
||||||
auto randomId = rand_value<uint64>();
|
const auto requestId = MTP::send(
|
||||||
auto gameShortName = bot->botInfo->shareGameShortName;
|
MTPmessages_SendMedia(
|
||||||
auto inputGame = MTP_inputGameShortName(
|
MTP_flags(0),
|
||||||
bot->inputUser,
|
chat->input,
|
||||||
MTP_string(gameShortName));
|
MTP_int(0),
|
||||||
auto request = MTPmessages_SendMedia(
|
MTP_inputMediaGame(
|
||||||
MTP_flags(0),
|
MTP_inputGameShortName(
|
||||||
chat->input,
|
bot->inputUser,
|
||||||
MTP_int(0),
|
MTP_string(bot->botInfo->shareGameShortName))),
|
||||||
MTP_inputMediaGame(inputGame),
|
MTP_long(randomId),
|
||||||
MTP_long(randomId),
|
MTPnullMarkup),
|
||||||
MTPnullMarkup);
|
App::main()->rpcDone(&MainWidget::sentUpdatesReceived),
|
||||||
auto done = App::main()->rpcDone(&MainWidget::sentUpdatesReceived);
|
App::main()->rpcFail(&MainWidget::sendMessageFail),
|
||||||
auto fail = App::main()->rpcFail(&MainWidget::sendMessageFail);
|
0,
|
||||||
auto requestId = MTP::send(request, done, fail, 0, 0, afterRequestId);
|
0,
|
||||||
|
history ? history->sendRequestId : 0);
|
||||||
if (history) {
|
if (history) {
|
||||||
history->sendRequestId = requestId;
|
history->sendRequestId = requestId;
|
||||||
}
|
}
|
||||||
|
@ -778,9 +779,9 @@ void AddBotToGroupBoxController::shareBotGame(not_null<PeerData*> chat) {
|
||||||
return lng_bot_sure_share_game(lt_user, App::peerName(chat));
|
return lng_bot_sure_share_game(lt_user, App::peerName(chat));
|
||||||
}
|
}
|
||||||
return lng_bot_sure_share_game_group(lt_group, chat->name);
|
return lng_bot_sure_share_game_group(lt_group, chat->name);
|
||||||
};
|
}();
|
||||||
Ui::show(
|
Ui::show(
|
||||||
Box<ConfirmBox>(confirmText(), send),
|
Box<ConfirmBox>(confirmText, std::move(send)),
|
||||||
LayerOption::KeepOther);
|
LayerOption::KeepOther);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -799,17 +800,16 @@ void AddBotToGroupBoxController::addBotToGroup(not_null<PeerData*> chat) {
|
||||||
}
|
}
|
||||||
if (auto &info = bot->botInfo) {
|
if (auto &info = bot->botInfo) {
|
||||||
if (!info->startGroupToken.isEmpty()) {
|
if (!info->startGroupToken.isEmpty()) {
|
||||||
auto request = MTPmessages_StartBot(
|
MTP::send(
|
||||||
bot->inputUser,
|
MTPmessages_StartBot(
|
||||||
chat->input,
|
bot->inputUser,
|
||||||
MTP_long(rand_value<uint64>()),
|
chat->input,
|
||||||
MTP_string(info->startGroupToken));
|
MTP_long(rand_value<uint64>()),
|
||||||
auto done = App::main()->rpcDone(
|
MTP_string(info->startGroupToken)),
|
||||||
&MainWidget::sentUpdatesReceived);
|
App::main()->rpcDone(&MainWidget::sentUpdatesReceived),
|
||||||
auto fail = App::main()->rpcFail(
|
App::main()->rpcFail(
|
||||||
&MainWidget::addParticipantFail,
|
&MainWidget::addParticipantFail,
|
||||||
{ bot, chat });
|
{ bot, chat }));
|
||||||
MTP::send(request, done, fail);
|
|
||||||
} else {
|
} else {
|
||||||
App::main()->addParticipants(
|
App::main()->addParticipants(
|
||||||
chat,
|
chat,
|
||||||
|
|
|
@ -57,7 +57,11 @@ void ConfigLoader::load() {
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequestId ConfigLoader::sendRequest(ShiftedDcId shiftedDcId) {
|
mtpRequestId ConfigLoader::sendRequest(ShiftedDcId shiftedDcId) {
|
||||||
return _instance->send(MTPhelp_GetConfig(), _doneHandler, _failHandler, shiftedDcId);
|
return _instance->send(
|
||||||
|
MTPhelp_GetConfig(),
|
||||||
|
base::duplicate(_doneHandler),
|
||||||
|
base::duplicate(_failHandler),
|
||||||
|
shiftedDcId);
|
||||||
}
|
}
|
||||||
|
|
||||||
DcId ConfigLoader::specialToRealDcId(DcId specialDcId) {
|
DcId ConfigLoader::specialToRealDcId(DcId specialDcId) {
|
||||||
|
@ -146,16 +150,24 @@ void ConfigLoader::sendSpecialRequest() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto weak = base::make_weak(this);
|
const auto weak = base::make_weak(this);
|
||||||
auto index = rand_value<uint32>() % uint32(_specialEndpoints.size());
|
const auto index = rand_value<uint32>() % _specialEndpoints.size();
|
||||||
auto endpoint = _specialEndpoints.begin() + index;
|
const auto endpoint = _specialEndpoints.begin() + index;
|
||||||
_specialEnumCurrent = specialToRealDcId(endpoint->dcId);
|
_specialEnumCurrent = specialToRealDcId(endpoint->dcId);
|
||||||
_instance->dcOptions()->constructAddOne(_specialEnumCurrent, MTPDdcOption::Flag::f_tcpo_only, endpoint->ip, endpoint->port);
|
_instance->dcOptions()->constructAddOne(
|
||||||
_specialEnumRequest = _instance->send(MTPhelp_GetConfig(), rpcDone([weak](const MTPConfig &result) {
|
_specialEnumCurrent,
|
||||||
if (const auto strong = weak.get()) {
|
MTPDdcOption::Flag::f_tcpo_only,
|
||||||
strong->specialConfigLoaded(result);
|
endpoint->ip,
|
||||||
}
|
endpoint->port);
|
||||||
}), _failHandler, _specialEnumCurrent);
|
_specialEnumRequest = _instance->send(
|
||||||
|
MTPhelp_GetConfig(),
|
||||||
|
rpcDone([weak](const MTPConfig &result) {
|
||||||
|
if (const auto strong = weak.get()) {
|
||||||
|
strong->specialConfigLoaded(result);
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
base::duplicate(_failHandler),
|
||||||
|
_specialEnumCurrent);
|
||||||
_triedSpecialEndpoints.push_back(*endpoint);
|
_triedSpecialEndpoints.push_back(*endpoint);
|
||||||
_specialEndpoints.erase(endpoint);
|
_specialEndpoints.erase(endpoint);
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
*/
|
*/
|
||||||
#include "mtproto/connection.h"
|
#include "mtproto/connection.h"
|
||||||
|
|
||||||
|
#include "mtproto/session.h"
|
||||||
#include "mtproto/rsa_public_key.h"
|
#include "mtproto/rsa_public_key.h"
|
||||||
#include "mtproto/rpc_sender.h"
|
#include "mtproto/rpc_sender.h"
|
||||||
#include "mtproto/dc_options.h"
|
#include "mtproto/dc_options.h"
|
||||||
|
@ -1637,7 +1638,9 @@ ConnectionPrivate::HandleResult ConnectionPrivate::handleOneReceived(const mtpPr
|
||||||
mtpRequestId requestId = wasSent(resendId);
|
mtpRequestId requestId = wasSent(resendId);
|
||||||
if (requestId) {
|
if (requestId) {
|
||||||
LOG(("Message Error: bad message notification received, msgId %1, error_code %2, fatal: clearing callbacks").arg(data.vbad_msg_id.v).arg(errorCode));
|
LOG(("Message Error: bad message notification received, msgId %1, error_code %2, fatal: clearing callbacks").arg(data.vbad_msg_id.v).arg(errorCode));
|
||||||
_instance->clearCallbacksDelayed(RPCCallbackClears(1, RPCCallbackClear(requestId, -errorCode)));
|
_instance->clearCallbacksDelayed(RPCCallbackClears(
|
||||||
|
1,
|
||||||
|
RPCCallbackClear(requestId, -errorCode)));
|
||||||
} else {
|
} else {
|
||||||
DEBUG_LOG(("Message Error: such message was not sent recently %1").arg(resendId));
|
DEBUG_LOG(("Message Error: such message was not sent recently %1").arg(resendId));
|
||||||
}
|
}
|
||||||
|
@ -2177,7 +2180,9 @@ void ConnectionPrivate::requestsAcked(const QVector<MTPlong> &ids, bool byRespon
|
||||||
clearedAcked.reserve(ackedCount - MTPIdsBufferSize);
|
clearedAcked.reserve(ackedCount - MTPIdsBufferSize);
|
||||||
while (ackedCount-- > MTPIdsBufferSize) {
|
while (ackedCount-- > MTPIdsBufferSize) {
|
||||||
mtpRequestIdsMap::iterator i(wereAcked.begin());
|
mtpRequestIdsMap::iterator i(wereAcked.begin());
|
||||||
clearedAcked.push_back(RPCCallbackClear(i.key(), RPCError::TimeoutError));
|
clearedAcked.push_back(RPCCallbackClear(
|
||||||
|
i.key(),
|
||||||
|
RPCError::TimeoutError));
|
||||||
wereAcked.erase(i);
|
wereAcked.erase(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,6 +71,14 @@ public:
|
||||||
static mtpRequest prepare(uint32 requestSize, uint32 maxSize = 0);
|
static mtpRequest prepare(uint32 requestSize, uint32 maxSize = 0);
|
||||||
static void padding(mtpRequest &request);
|
static void padding(mtpRequest &request);
|
||||||
|
|
||||||
|
template <typename TRequest>
|
||||||
|
static mtpRequest serialize(const TRequest &request) {
|
||||||
|
const auto requestSize = request.innerLength() >> 2;
|
||||||
|
auto serialized = prepare(requestSize);
|
||||||
|
request.write(*serialized);
|
||||||
|
return serialized;
|
||||||
|
}
|
||||||
|
|
||||||
static uint32 messageSize(const mtpRequest &request) {
|
static uint32 messageSize(const mtpRequest &request) {
|
||||||
if (request->size() < 9) return 0;
|
if (request->size() < 9) return 0;
|
||||||
return 4 + (request.innerLength() >> 2); // 2: msg_id, 1: seq_no, q: message_length
|
return 4 + (request.innerLength() >> 2); // 2: msg_id, 1: seq_no, q: message_length
|
||||||
|
|
|
@ -20,9 +20,8 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
*/
|
*/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "mtproto/type_utils.h"
|
|
||||||
#include "mtproto/session.h"
|
|
||||||
#include "core/single_timer.h"
|
#include "core/single_timer.h"
|
||||||
|
#include "mtproto/type_utils.h"
|
||||||
#include "mtproto/mtp_instance.h"
|
#include "mtproto/mtp_instance.h"
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
|
@ -193,12 +192,23 @@ inline QString dctransport(ShiftedDcId shiftedDcId = 0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename TRequest>
|
template <typename TRequest>
|
||||||
inline mtpRequestId send(const TRequest &request, RPCResponseHandler callbacks = RPCResponseHandler(), ShiftedDcId dcId = 0, TimeMs msCanWait = 0, mtpRequestId after = 0) {
|
inline mtpRequestId send(
|
||||||
|
const TRequest &request,
|
||||||
|
RPCResponseHandler &&callbacks = {},
|
||||||
|
ShiftedDcId dcId = 0,
|
||||||
|
TimeMs msCanWait = 0,
|
||||||
|
mtpRequestId after = 0) {
|
||||||
return MainInstance()->send(request, std::move(callbacks), dcId, msCanWait, after);
|
return MainInstance()->send(request, std::move(callbacks), dcId, msCanWait, after);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename TRequest>
|
template <typename TRequest>
|
||||||
inline mtpRequestId send(const TRequest &request, RPCDoneHandlerPtr onDone, RPCFailHandlerPtr onFail = RPCFailHandlerPtr(), ShiftedDcId dcId = 0, TimeMs msCanWait = 0, mtpRequestId after = 0) {
|
inline mtpRequestId send(
|
||||||
|
const TRequest &request,
|
||||||
|
RPCDoneHandlerPtr &&onDone,
|
||||||
|
RPCFailHandlerPtr &&onFail = nullptr,
|
||||||
|
ShiftedDcId dcId = 0,
|
||||||
|
TimeMs msCanWait = 0,
|
||||||
|
mtpRequestId after = 0) {
|
||||||
return MainInstance()->send(request, std::move(onDone), std::move(onFail), dcId, msCanWait, after);
|
return MainInstance()->send(request, std::move(onDone), std::move(onFail), dcId, msCanWait, after);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -226,31 +236,4 @@ inline int32 state(mtpRequestId requestId) { // < 0 means waiting for such count
|
||||||
return MainInstance()->state(requestId);
|
return MainInstance()->state(requestId);
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
template <typename TRequest>
|
|
||||||
mtpRequestId Session::send(const TRequest &request, RPCResponseHandler callbacks, TimeMs msCanWait, bool needsLayer, bool toMainDC, mtpRequestId after) {
|
|
||||||
mtpRequestId requestId = 0;
|
|
||||||
try {
|
|
||||||
uint32 requestSize = request.innerLength() >> 2;
|
|
||||||
mtpRequest reqSerialized(mtpRequestData::prepare(requestSize));
|
|
||||||
request.write(*reqSerialized);
|
|
||||||
|
|
||||||
DEBUG_LOG(("MTP Info: adding request to toSendMap, msCanWait %1").arg(msCanWait));
|
|
||||||
|
|
||||||
reqSerialized->msDate = getms(true); // > 0 - can send without container
|
|
||||||
reqSerialized->needsLayer = needsLayer;
|
|
||||||
if (after) reqSerialized->after = getRequest(after);
|
|
||||||
requestId = storeRequest(reqSerialized, callbacks);
|
|
||||||
|
|
||||||
sendPrepared(reqSerialized, msCanWait);
|
|
||||||
} catch (Exception &e) {
|
|
||||||
requestId = 0;
|
|
||||||
requestPrepareFailed(callbacks.onFail, e);
|
|
||||||
}
|
|
||||||
if (requestId) registerRequest(requestId, toMainDC ? -getDcWithShift() : getDcWithShift());
|
|
||||||
return requestId;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace MTP
|
} // namespace MTP
|
||||||
|
|
|
@ -20,6 +20,7 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
*/
|
*/
|
||||||
#include "mtproto/mtp_instance.h"
|
#include "mtproto/mtp_instance.h"
|
||||||
|
|
||||||
|
#include "mtproto/session.h"
|
||||||
#include "mtproto/dc_options.h"
|
#include "mtproto/dc_options.h"
|
||||||
#include "mtproto/dcenter.h"
|
#include "mtproto/dcenter.h"
|
||||||
#include "mtproto/config_loader.h"
|
#include "mtproto/config_loader.h"
|
||||||
|
@ -71,12 +72,15 @@ public:
|
||||||
std::shared_ptr<internal::Dcenter> getDcById(ShiftedDcId shiftedDcId);
|
std::shared_ptr<internal::Dcenter> getDcById(ShiftedDcId shiftedDcId);
|
||||||
void unpaused();
|
void unpaused();
|
||||||
|
|
||||||
void queueQuittingConnection(std::unique_ptr<internal::Connection> connection);
|
void queueQuittingConnection(
|
||||||
|
std::unique_ptr<internal::Connection> &&connection);
|
||||||
void connectionFinished(internal::Connection *connection);
|
void connectionFinished(internal::Connection *connection);
|
||||||
|
|
||||||
void registerRequest(mtpRequestId requestId, int32 dcWithShift);
|
void registerRequest(mtpRequestId requestId, int32 dcWithShift);
|
||||||
void unregisterRequest(mtpRequestId requestId);
|
void unregisterRequest(mtpRequestId requestId);
|
||||||
mtpRequestId storeRequest(mtpRequest &request, const RPCResponseHandler &parser);
|
mtpRequestId storeRequest(
|
||||||
|
mtpRequest &request,
|
||||||
|
RPCResponseHandler &&callbacks);
|
||||||
mtpRequest getRequest(mtpRequestId requestId);
|
mtpRequest getRequest(mtpRequestId requestId);
|
||||||
void clearCallbacks(mtpRequestId requestId, int32 errorCode = RPCError::NoError); // 0 - do not toggle onError callback
|
void clearCallbacks(mtpRequestId requestId, int32 errorCode = RPCError::NoError); // 0 - do not toggle onError callback
|
||||||
void clearCallbacksDelayed(const RPCCallbackClears &requestIds);
|
void clearCallbacksDelayed(const RPCCallbackClears &requestIds);
|
||||||
|
@ -127,6 +131,7 @@ private:
|
||||||
bool exportFail(const RPCError &error, mtpRequestId requestId);
|
bool exportFail(const RPCError &error, mtpRequestId requestId);
|
||||||
bool onErrorDefault(mtpRequestId requestId, const RPCError &error);
|
bool onErrorDefault(mtpRequestId requestId, const RPCError &error);
|
||||||
|
|
||||||
|
void logoutGuestDcs();
|
||||||
bool logoutGuestDone(mtpRequestId requestId);
|
bool logoutGuestDone(mtpRequestId requestId);
|
||||||
|
|
||||||
void configLoadDone(const MTPConfig &result);
|
void configLoadDone(const MTPConfig &result);
|
||||||
|
@ -452,9 +457,14 @@ void Instance::Private::reInitConnection(DcId dcId) {
|
||||||
getSession(dcId)->notifyLayerInited(false);
|
getSession(dcId)->notifyLayerInited(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Instance::Private::logout(RPCDoneHandlerPtr onDone, RPCFailHandlerPtr onFail) {
|
void Instance::Private::logout(
|
||||||
_instance->send(MTPauth_LogOut(), onDone, onFail);
|
RPCDoneHandlerPtr onDone,
|
||||||
|
RPCFailHandlerPtr onFail) {
|
||||||
|
_instance->send(MTPauth_LogOut(), std::move(onDone), std::move(onFail));
|
||||||
|
logoutGuestDcs();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Instance::Private::logoutGuestDcs() {
|
||||||
auto dcIds = std::vector<DcId>();
|
auto dcIds = std::vector<DcId>();
|
||||||
{
|
{
|
||||||
QReadLocker lock(&_keysForWriteLock);
|
QReadLocker lock(&_keysForWriteLock);
|
||||||
|
@ -566,7 +576,8 @@ void Instance::Private::unpaused() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Instance::Private::queueQuittingConnection(std::unique_ptr<internal::Connection> connection) {
|
void Instance::Private::queueQuittingConnection(
|
||||||
|
std::unique_ptr<internal::Connection> &&connection) {
|
||||||
_quittingConnections.insert(std::move(connection));
|
_quittingConnections.insert(std::move(connection));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -690,18 +701,20 @@ void Instance::Private::unregisterRequest(mtpRequestId requestId) {
|
||||||
_requestsByDc.erase(requestId);
|
_requestsByDc.erase(requestId);
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequestId Instance::Private::storeRequest(mtpRequest &request, const RPCResponseHandler &parser) {
|
mtpRequestId Instance::Private::storeRequest(
|
||||||
mtpRequestId res = reqid();
|
mtpRequest &request,
|
||||||
request->requestId = res;
|
RPCResponseHandler &&callbacks) {
|
||||||
if (parser.onDone || parser.onFail) {
|
const auto requestId = reqid();
|
||||||
|
request->requestId = requestId;
|
||||||
|
if (callbacks.onDone || callbacks.onFail) {
|
||||||
QMutexLocker locker(&_parserMapLock);
|
QMutexLocker locker(&_parserMapLock);
|
||||||
_parserMap.emplace(res, parser);
|
_parserMap.emplace(requestId, std::move(callbacks));
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
QWriteLocker locker(&_requestMapLock);
|
QWriteLocker locker(&_requestMapLock);
|
||||||
_requestMap.emplace(res, request);
|
_requestMap.emplace(requestId, request);
|
||||||
}
|
}
|
||||||
return res;
|
return requestId;
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequest Instance::Private::getRequest(mtpRequestId requestId) {
|
mtpRequest Instance::Private::getRequest(mtpRequestId requestId) {
|
||||||
|
@ -1378,7 +1391,8 @@ void Instance::unpaused() {
|
||||||
_private->unpaused();
|
_private->unpaused();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Instance::queueQuittingConnection(std::unique_ptr<internal::Connection> connection) {
|
void Instance::queueQuittingConnection(
|
||||||
|
std::unique_ptr<internal::Connection> &&connection) {
|
||||||
_private->queueQuittingConnection(std::move(connection));
|
_private->queueQuittingConnection(std::move(connection));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1414,8 +1428,10 @@ void Instance::registerRequest(mtpRequestId requestId, ShiftedDcId dcWithShift)
|
||||||
_private->registerRequest(requestId, dcWithShift);
|
_private->registerRequest(requestId, dcWithShift);
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequestId Instance::storeRequest(mtpRequest &request, const RPCResponseHandler &parser) {
|
mtpRequestId Instance::storeRequest(
|
||||||
return _private->storeRequest(request, parser);
|
mtpRequest &request,
|
||||||
|
RPCResponseHandler &&callbacks) {
|
||||||
|
return _private->storeRequest(request, std::move(callbacks));
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequest Instance::getRequest(mtpRequestId requestId) {
|
mtpRequest Instance::getRequest(mtpRequestId requestId) {
|
||||||
|
@ -1442,10 +1458,6 @@ bool Instance::rpcErrorOccured(mtpRequestId requestId, const RPCFailHandlerPtr &
|
||||||
return _private->rpcErrorOccured(requestId, onFail, err);
|
return _private->rpcErrorOccured(requestId, onFail, err);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal::Session *Instance::getSession(ShiftedDcId shiftedDcId) {
|
|
||||||
return _private->getSession(shiftedDcId);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Instance::isKeysDestroyer() const {
|
bool Instance::isKeysDestroyer() const {
|
||||||
return _private->isKeysDestroyer();
|
return _private->isKeysDestroyer();
|
||||||
}
|
}
|
||||||
|
@ -1458,6 +1470,30 @@ void Instance::onKeyDestroyed(qint32 shiftedDcId) {
|
||||||
_private->completedKeyDestroy(shiftedDcId);
|
_private->completedKeyDestroy(shiftedDcId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mtpRequestId Instance::send(
|
||||||
|
mtpRequest &&request,
|
||||||
|
RPCResponseHandler &&callbacks,
|
||||||
|
ShiftedDcId dcId,
|
||||||
|
TimeMs msCanWait,
|
||||||
|
mtpRequestId after) {
|
||||||
|
if (const auto session = _private->getSession(dcId)) {
|
||||||
|
return session->send(
|
||||||
|
mtpRequestData::serialize(request),
|
||||||
|
std::move(callbacks),
|
||||||
|
msCanWait,
|
||||||
|
true,
|
||||||
|
!dcId,
|
||||||
|
after);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Instance::sendAnything(ShiftedDcId dcId, TimeMs msCanWait) {
|
||||||
|
if (const auto session = _private->getSession(dcId)) {
|
||||||
|
session->sendAnything(msCanWait);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Instance::~Instance() {
|
Instance::~Instance() {
|
||||||
_private->prepareToDestroy();
|
_private->prepareToDestroy();
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,14 +22,16 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include "mtproto/rpc_sender.h"
|
||||||
|
|
||||||
namespace MTP {
|
namespace MTP {
|
||||||
namespace internal {
|
namespace internal {
|
||||||
class Dcenter;
|
class Dcenter;
|
||||||
|
class Session;
|
||||||
|
class Connection;
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
|
||||||
class DcOptions;
|
class DcOptions;
|
||||||
class Session;
|
|
||||||
class AuthKey;
|
class AuthKey;
|
||||||
using AuthKeyPtr = std::shared_ptr<AuthKey>;
|
using AuthKeyPtr = std::shared_ptr<AuthKey>;
|
||||||
using AuthKeysList = std::vector<AuthKeyPtr>;
|
using AuthKeysList = std::vector<AuthKeyPtr>;
|
||||||
|
@ -70,23 +72,37 @@ public:
|
||||||
not_null<DcOptions*> dcOptions();
|
not_null<DcOptions*> dcOptions();
|
||||||
|
|
||||||
template <typename TRequest>
|
template <typename TRequest>
|
||||||
mtpRequestId send(const TRequest &request, RPCResponseHandler callbacks = RPCResponseHandler(), ShiftedDcId dcId = 0, TimeMs msCanWait = 0, mtpRequestId after = 0) {
|
mtpRequestId send(
|
||||||
if (auto session = getSession(dcId)) {
|
const TRequest &request,
|
||||||
return session->send(request, callbacks, msCanWait, true, !dcId, after);
|
RPCResponseHandler &&callbacks = {},
|
||||||
}
|
ShiftedDcId dcId = 0,
|
||||||
return 0;
|
TimeMs msCanWait = 0,
|
||||||
|
mtpRequestId after = 0) {
|
||||||
|
return send(
|
||||||
|
mtpRequestData::serialize(request),
|
||||||
|
std::move(callbacks),
|
||||||
|
dcId,
|
||||||
|
msCanWait,
|
||||||
|
after);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename TRequest>
|
template <typename TRequest>
|
||||||
mtpRequestId send(const TRequest &request, RPCDoneHandlerPtr onDone, RPCFailHandlerPtr onFail = RPCFailHandlerPtr(), int32 dc = 0, TimeMs msCanWait = 0, mtpRequestId after = 0) {
|
mtpRequestId send(
|
||||||
return send(request, RPCResponseHandler(onDone, onFail), dc, msCanWait, after);
|
const TRequest &request,
|
||||||
|
RPCDoneHandlerPtr &&onDone,
|
||||||
|
RPCFailHandlerPtr &&onFail = nullptr,
|
||||||
|
ShiftedDcId dc = 0,
|
||||||
|
TimeMs msCanWait = 0,
|
||||||
|
mtpRequestId after = 0) {
|
||||||
|
return send(
|
||||||
|
request,
|
||||||
|
RPCResponseHandler(std::move(onDone), std::move(onFail)),
|
||||||
|
dc,
|
||||||
|
msCanWait,
|
||||||
|
after);
|
||||||
}
|
}
|
||||||
|
|
||||||
void sendAnything(ShiftedDcId dcId = 0, TimeMs msCanWait = 0) {
|
void sendAnything(ShiftedDcId dcId = 0, TimeMs msCanWait = 0);
|
||||||
if (auto session = getSession(dcId)) {
|
|
||||||
session->sendAnything(msCanWait);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void restart();
|
void restart();
|
||||||
void restart(ShiftedDcId shiftedDcId);
|
void restart(ShiftedDcId shiftedDcId);
|
||||||
|
@ -103,7 +119,7 @@ public:
|
||||||
std::shared_ptr<internal::Dcenter> getDcById(ShiftedDcId shiftedDcId);
|
std::shared_ptr<internal::Dcenter> getDcById(ShiftedDcId shiftedDcId);
|
||||||
void unpaused();
|
void unpaused();
|
||||||
|
|
||||||
void queueQuittingConnection(std::unique_ptr<internal::Connection> connection);
|
void queueQuittingConnection(std::unique_ptr<internal::Connection> &&connection);
|
||||||
|
|
||||||
void setUpdatesHandler(RPCDoneHandlerPtr onDone);
|
void setUpdatesHandler(RPCDoneHandlerPtr onDone);
|
||||||
void setGlobalFailHandler(RPCFailHandlerPtr onFail);
|
void setGlobalFailHandler(RPCFailHandlerPtr onFail);
|
||||||
|
@ -115,7 +131,9 @@ public:
|
||||||
void onSessionReset(ShiftedDcId dcWithShift);
|
void onSessionReset(ShiftedDcId dcWithShift);
|
||||||
|
|
||||||
void registerRequest(mtpRequestId requestId, ShiftedDcId dcWithShift);
|
void registerRequest(mtpRequestId requestId, ShiftedDcId dcWithShift);
|
||||||
mtpRequestId storeRequest(mtpRequest &request, const RPCResponseHandler &parser);
|
mtpRequestId storeRequest(
|
||||||
|
mtpRequest &request,
|
||||||
|
RPCResponseHandler &&callbacks);
|
||||||
mtpRequest getRequest(mtpRequestId requestId);
|
mtpRequest getRequest(mtpRequestId requestId);
|
||||||
void clearCallbacksDelayed(const RPCCallbackClears &requestIds);
|
void clearCallbacksDelayed(const RPCCallbackClears &requestIds);
|
||||||
|
|
||||||
|
@ -147,7 +165,12 @@ private slots:
|
||||||
void onKeyDestroyed(qint32 shiftedDcId);
|
void onKeyDestroyed(qint32 shiftedDcId);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
internal::Session *getSession(ShiftedDcId shiftedDcId);
|
mtpRequestId send(
|
||||||
|
mtpRequest &&request,
|
||||||
|
RPCResponseHandler &&callbacks,
|
||||||
|
ShiftedDcId dcId,
|
||||||
|
TimeMs msCanWait,
|
||||||
|
mtpRequestId after);
|
||||||
|
|
||||||
class Private;
|
class Private;
|
||||||
const std::unique_ptr<Private> _private;
|
const std::unique_ptr<Private> _private;
|
||||||
|
|
|
@ -98,9 +98,10 @@ public:
|
||||||
using RPCFailHandlerPtr = std::shared_ptr<RPCAbstractFailHandler>;
|
using RPCFailHandlerPtr = std::shared_ptr<RPCAbstractFailHandler>;
|
||||||
|
|
||||||
struct RPCResponseHandler {
|
struct RPCResponseHandler {
|
||||||
RPCResponseHandler() {
|
RPCResponseHandler() = default;
|
||||||
}
|
RPCResponseHandler(RPCDoneHandlerPtr &&done, RPCFailHandlerPtr &&fail)
|
||||||
RPCResponseHandler(const RPCDoneHandlerPtr &ondone, const RPCFailHandlerPtr &onfail) : onDone(ondone), onFail(onfail) {
|
: onDone(std::move(done))
|
||||||
|
, onFail(std::move(fail)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
RPCDoneHandlerPtr onDone;
|
RPCDoneHandlerPtr onDone;
|
||||||
|
@ -108,10 +109,6 @@ struct RPCResponseHandler {
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline RPCResponseHandler rpcCb(const RPCDoneHandlerPtr &onDone = RPCDoneHandlerPtr(), const RPCFailHandlerPtr &onFail = RPCFailHandlerPtr()) {
|
|
||||||
return RPCResponseHandler(onDone, onFail);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename TReturn>
|
template <typename TReturn>
|
||||||
class RPCDoneHandlerBare : public RPCAbstractDoneHandler { // done(from, end)
|
class RPCDoneHandlerBare : public RPCAbstractDoneHandler { // done(from, end)
|
||||||
using CallbackType = TReturn (*)(const mtpPrime *, const mtpPrime *);
|
using CallbackType = TReturn (*)(const mtpPrime *, const mtpPrime *);
|
||||||
|
|
|
@ -252,7 +252,13 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequestId send() {
|
mtpRequestId send() {
|
||||||
auto id = MainInstance()->send(_request, takeOnDone(), takeOnFail(), takeDcId(), takeCanWait(), takeAfter());
|
const auto id = MainInstance()->send(
|
||||||
|
_request,
|
||||||
|
takeOnDone(),
|
||||||
|
takeOnFail(),
|
||||||
|
takeDcId(),
|
||||||
|
takeCanWait(),
|
||||||
|
takeAfter());
|
||||||
registerRequest(id);
|
registerRequest(id);
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
|
@ -141,8 +141,10 @@ void Session::registerRequest(mtpRequestId requestId, ShiftedDcId dcWithShift) {
|
||||||
return _instance->registerRequest(requestId, dcWithShift);
|
return _instance->registerRequest(requestId, dcWithShift);
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequestId Session::storeRequest(mtpRequest &request, const RPCResponseHandler &parser) {
|
mtpRequestId Session::storeRequest(
|
||||||
return _instance->storeRequest(request, parser);
|
mtpRequest &request,
|
||||||
|
RPCResponseHandler &&callbacks) {
|
||||||
|
return _instance->storeRequest(request, std::move(callbacks));
|
||||||
}
|
}
|
||||||
|
|
||||||
mtpRequest Session::getRequest(mtpRequestId requestId) {
|
mtpRequest Session::getRequest(mtpRequestId requestId) {
|
||||||
|
@ -153,23 +155,6 @@ bool Session::rpcErrorOccured(mtpRequestId requestId, const RPCFailHandlerPtr &o
|
||||||
return _instance->rpcErrorOccured(requestId, onFail, err);
|
return _instance->rpcErrorOccured(requestId, onFail, err);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::requestPrepareFailed(
|
|
||||||
const RPCFailHandlerPtr &onFail,
|
|
||||||
Exception &e) {
|
|
||||||
CrashReports::SetAnnotation("RequestException", QString::fromLatin1(e.what()));
|
|
||||||
Unexpected("Exception in Session::send()");
|
|
||||||
|
|
||||||
const auto requestId = 0;
|
|
||||||
const auto error = rpcClientError(
|
|
||||||
"NO_REQUEST_ID",
|
|
||||||
QString(
|
|
||||||
"send() failed to queue request, exception: %1"
|
|
||||||
).arg(
|
|
||||||
e.what()
|
|
||||||
));
|
|
||||||
rpcErrorOccured(requestId, onFail, error);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Session::restart() {
|
void Session::restart() {
|
||||||
if (_killed) {
|
if (_killed) {
|
||||||
DEBUG_LOG(("Session Error: can't restart a killed session"));
|
DEBUG_LOG(("Session Error: can't restart a killed session"));
|
||||||
|
@ -255,7 +240,9 @@ void Session::needToResumeAndSend() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::sendPong(quint64 msgId, quint64 pingId) {
|
void Session::sendPong(quint64 msgId, quint64 pingId) {
|
||||||
send(MTP_pong(MTP_long(msgId), MTP_long(pingId)));
|
send(mtpRequestData::serialize(MTPPong(MTP_pong(
|
||||||
|
MTP_long(msgId),
|
||||||
|
MTP_long(pingId)))));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::sendMsgsStateInfo(quint64 msgId, QByteArray data) {
|
void Session::sendMsgsStateInfo(quint64 msgId, QByteArray data) {
|
||||||
|
@ -267,7 +254,8 @@ void Session::sendMsgsStateInfo(quint64 msgId, QByteArray data) {
|
||||||
auto dst = gsl::as_writeable_bytes(gsl::make_span(&info[0], info.size()));
|
auto dst = gsl::as_writeable_bytes(gsl::make_span(&info[0], info.size()));
|
||||||
base::copy_bytes(dst, src);
|
base::copy_bytes(dst, src);
|
||||||
}
|
}
|
||||||
send(MTPMsgsStateInfo(MTP_msgs_state_info(MTP_long(msgId), MTP_string(std::move(info)))));
|
send(mtpRequestData::serialize(MTPMsgsStateInfo(
|
||||||
|
MTP_msgs_state_info(MTP_long(msgId), MTP_string(std::move(info))))));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::checkRequestsByTimer() {
|
void Session::checkRequestsByTimer() {
|
||||||
|
@ -425,13 +413,17 @@ mtpRequestId Session::resend(quint64 msgId, qint64 msCanWait, bool forceContaine
|
||||||
QWriteLocker locker(data.haveSentMutex());
|
QWriteLocker locker(data.haveSentMutex());
|
||||||
mtpRequestMap &haveSent(data.haveSentMap());
|
mtpRequestMap &haveSent(data.haveSentMap());
|
||||||
|
|
||||||
mtpRequestMap::iterator i = haveSent.find(msgId);
|
auto i = haveSent.find(msgId);
|
||||||
if (i == haveSent.end()) {
|
if (i == haveSent.end()) {
|
||||||
if (sendMsgStateInfo) {
|
if (sendMsgStateInfo) {
|
||||||
char cantResend[2] = {1, 0};
|
char cantResend[2] = {1, 0};
|
||||||
DEBUG_LOG(("Message Info: cant resend %1, request not found").arg(msgId));
|
DEBUG_LOG(("Message Info: cant resend %1, request not found").arg(msgId));
|
||||||
|
|
||||||
return send(MTP_msgs_state_info(MTP_long(msgId), MTP_string(std::string(cantResend, cantResend + 1))));
|
auto info = std::string(cantResend, cantResend + 1);
|
||||||
|
return send(mtpRequestData::serialize(MTPMsgsStateInfo(
|
||||||
|
MTP_msgs_state_info(
|
||||||
|
MTP_long(msgId),
|
||||||
|
MTP_string(std::move(info))))));
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -480,6 +472,30 @@ void Session::resendAll() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mtpRequestId Session::send(
|
||||||
|
mtpRequest &&request,
|
||||||
|
RPCResponseHandler &&callbacks,
|
||||||
|
TimeMs msCanWait,
|
||||||
|
bool needsLayer,
|
||||||
|
bool toMainDC,
|
||||||
|
mtpRequestId after) {
|
||||||
|
DEBUG_LOG(("MTP Info: adding request to toSendMap, msCanWait %1").arg(msCanWait));
|
||||||
|
|
||||||
|
request->msDate = getms(true); // > 0 - can send without container
|
||||||
|
request->needsLayer = needsLayer;
|
||||||
|
if (after) {
|
||||||
|
request->after = getRequest(after);
|
||||||
|
}
|
||||||
|
const auto requestId = storeRequest(request, std::move(callbacks));
|
||||||
|
Assert(requestId != 0);
|
||||||
|
|
||||||
|
const auto signedDcId = toMainDC ? -getDcWithShift() : getDcWithShift();
|
||||||
|
sendPrepared(request, msCanWait);
|
||||||
|
registerRequest(requestId, signedDcId);
|
||||||
|
|
||||||
|
return requestId;
|
||||||
|
}
|
||||||
|
|
||||||
void Session::sendPrepared(const mtpRequest &request, TimeMs msCanWait, bool newRequest) { // returns true, if emit of needToSend() is needed
|
void Session::sendPrepared(const mtpRequest &request, TimeMs msCanWait, bool newRequest) { // returns true, if emit of needToSend() is needed
|
||||||
{
|
{
|
||||||
QWriteLocker locker(data.toSendMutex());
|
QWriteLocker locker(data.toSendMutex());
|
||||||
|
|
|
@ -311,16 +311,25 @@ public:
|
||||||
void destroyKey();
|
void destroyKey();
|
||||||
void notifyLayerInited(bool wasInited);
|
void notifyLayerInited(bool wasInited);
|
||||||
|
|
||||||
template <typename TRequest>
|
|
||||||
mtpRequestId send(const TRequest &request, RPCResponseHandler callbacks = RPCResponseHandler(), TimeMs msCanWait = 0, bool needsLayer = false, bool toMainDC = false, mtpRequestId after = 0); // send mtp request
|
|
||||||
|
|
||||||
void ping();
|
void ping();
|
||||||
void cancel(mtpRequestId requestId, mtpMsgId msgId);
|
void cancel(mtpRequestId requestId, mtpMsgId msgId);
|
||||||
int32 requestState(mtpRequestId requestId) const;
|
int32 requestState(mtpRequestId requestId) const;
|
||||||
int32 getState() const;
|
int32 getState() const;
|
||||||
QString transport() const;
|
QString transport() const;
|
||||||
|
|
||||||
void sendPrepared(const mtpRequest &request, TimeMs msCanWait = 0, bool newRequest = true); // nulls msgId and seqNo in request, if newRequest = true
|
mtpRequestId send(
|
||||||
|
mtpRequest &&request,
|
||||||
|
RPCResponseHandler &&callbacks = {},
|
||||||
|
TimeMs msCanWait = 0,
|
||||||
|
bool needsLayer = false,
|
||||||
|
bool toMainDC = false,
|
||||||
|
mtpRequestId after = 0);
|
||||||
|
|
||||||
|
// Nulls msgId and seqNo in request, if newRequest = true.
|
||||||
|
void sendPrepared(
|
||||||
|
const mtpRequest &request,
|
||||||
|
TimeMs msCanWait = 0,
|
||||||
|
bool newRequest = true);
|
||||||
|
|
||||||
~Session();
|
~Session();
|
||||||
|
|
||||||
|
@ -353,10 +362,11 @@ private:
|
||||||
void createDcData();
|
void createDcData();
|
||||||
|
|
||||||
void registerRequest(mtpRequestId requestId, ShiftedDcId dcWithShift);
|
void registerRequest(mtpRequestId requestId, ShiftedDcId dcWithShift);
|
||||||
mtpRequestId storeRequest(mtpRequest &request, const RPCResponseHandler &parser);
|
mtpRequestId storeRequest(
|
||||||
|
mtpRequest &request,
|
||||||
|
RPCResponseHandler &&callbacks);
|
||||||
mtpRequest getRequest(mtpRequestId requestId);
|
mtpRequest getRequest(mtpRequestId requestId);
|
||||||
bool rpcErrorOccured(mtpRequestId requestId, const RPCFailHandlerPtr &onFail, const RPCError &err);
|
bool rpcErrorOccured(mtpRequestId requestId, const RPCFailHandlerPtr &onFail, const RPCError &err);
|
||||||
void requestPrepareFailed(const RPCFailHandlerPtr &onFail, Exception &e);
|
|
||||||
|
|
||||||
not_null<Instance*> _instance;
|
not_null<Instance*> _instance;
|
||||||
std::unique_ptr<Connection> _connection;
|
std::unique_ptr<Connection> _connection;
|
||||||
|
|
Loading…
Reference in New Issue