/* This file is part of Telegram Desktop, the official desktop version of Telegram messaging app, see https://telegram.org Telegram Desktop is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. It is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. In addition, as a special exception, the copyright holders give permission to link the code of portions of this program with the OpenSSL library. Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE Copyright (c) 2014-2016 John Preston, https://desktop.telegram.org */ #pragma once class ApiWrap : public QObject, public RPCSender { Q_OBJECT public: ApiWrap(QObject *parent); void init(); using RequestMessageDataCallback = SharedCallback; void requestMessageData(ChannelData *channel, MsgId msgId, std_::unique_ptr callback); void requestFullPeer(PeerData *peer); void requestPeer(PeerData *peer); void requestPeers(const QList &peers); void requestLastParticipants(ChannelData *peer, bool fromStart = true); void requestBots(ChannelData *peer); void processFullPeer(PeerData *peer, const MTPmessages_ChatFull &result); void processFullPeer(PeerData *peer, const MTPUserFull &result); void requestSelfParticipant(ChannelData *channel); void kickParticipant(PeerData *peer, UserData *user); void requestWebPageDelayed(WebPageData *page); void clearWebPageRequest(WebPageData *page); void clearWebPageRequests(); void scheduleStickerSetRequest(uint64 setId, uint64 access); void requestStickerSets(); void joinChannel(ChannelData *channel); void leaveChannel(ChannelData *channel); void blockUser(UserData *user); void unblockUser(UserData *user); void exportInviteLink(PeerData *peer); void requestNotifySetting(PeerData *peer); ~ApiWrap(); signals: void fullPeerUpdated(PeerData *peer); public slots: void resolveMessageDatas(); void resolveWebPages(); void delayedRequestParticipantsCount(); private: void updatesReceived(const MTPUpdates &updates); void gotMessageDatas(ChannelData *channel, const MTPmessages_Messages &result, mtpRequestId req); struct MessageDataRequest { MessageDataRequest() : req(0) { } typedef SharedCallback::Ptr CallbackPtr; typedef QList Callbacks; mtpRequestId req; Callbacks callbacks; }; typedef QMap MessageDataRequests; MessageDataRequests _messageDataRequests; typedef QMap ChannelMessageDataRequests; ChannelMessageDataRequests _channelMessageDataRequests; SingleDelayedCall *_messageDataResolveDelayed; typedef QVector MessageIds; MessageIds collectMessageIds(const MessageDataRequests &requests); MessageDataRequests *messageDataRequests(ChannelData *channel, bool onlyExisting = false); void gotChatFull(PeerData *peer, const MTPmessages_ChatFull &result, mtpRequestId req); void gotUserFull(PeerData *peer, const MTPUserFull &result, mtpRequestId req); bool gotPeerFullFailed(PeerData *peer, const RPCError &err); typedef QMap PeerRequests; PeerRequests _fullPeerRequests; void gotChat(PeerData *peer, const MTPmessages_Chats &result); void gotUser(PeerData *peer, const MTPVector &result); void gotChats(const MTPmessages_Chats &result); void gotUsers(const MTPVector &result); bool gotPeerFailed(PeerData *peer, const RPCError &err); PeerRequests _peerRequests; void lastParticipantsDone(ChannelData *peer, const MTPchannels_ChannelParticipants &result, mtpRequestId req); bool lastParticipantsFail(ChannelData *peer, const RPCError &error, mtpRequestId req); PeerRequests _participantsRequests, _botsRequests; typedef QPair KickRequest; typedef QMap KickRequests; void kickParticipantDone(KickRequest kick, const MTPUpdates &updates, mtpRequestId req); bool kickParticipantFail(KickRequest kick, const RPCError &error, mtpRequestId req); KickRequests _kickRequests; void gotSelfParticipant(ChannelData *channel, const MTPchannels_ChannelParticipant &result); bool gotSelfParticipantFail(ChannelData *channel, const RPCError &error); typedef QMap SelfParticipantRequests; SelfParticipantRequests _selfParticipantRequests; void gotWebPages(ChannelData *channel, const MTPmessages_Messages &result, mtpRequestId req); typedef QMap WebPagesPending; WebPagesPending _webPagesPending; SingleTimer _webPagesTimer; QMap > _stickerSetRequests; void gotStickerSet(uint64 setId, const MTPmessages_StickerSet &result); bool gotStickerSetFail(uint64 setId, const RPCError &error); QMap _channelAmInRequests; void channelAmInUpdated(ChannelData *channel); void channelAmInDone(ChannelData *channel, const MTPUpdates &updates); bool channelAmInFail(ChannelData *channel, const RPCError &error); QMap _blockRequests; void blockDone(UserData *user, const MTPBool &result); void unblockDone(UserData *user, const MTPBool &result); bool blockFail(UserData *user, const RPCError &error); QMap _exportInviteRequests; void exportInviteDone(PeerData *peer, const MTPExportedChatInvite &result); bool exportInviteFail(PeerData *peer, const RPCError &error); QMap _notifySettingRequests; void notifySettingDone(MTPInputNotifyPeer peer, const MTPPeerNotifySettings &settings); PeerData *notifySettingReceived(MTPInputNotifyPeer peer, const MTPPeerNotifySettings &settings); bool notifySettingFail(PeerData *peer, const RPCError &error); };