diff options
author | llnulldisk <48621230+llnulldisk@users.noreply.github.com> | 2022-09-04 20:59:46 +0200 |
---|---|---|
committer | llnulldisk <48621230+llnulldisk@users.noreply.github.com> | 2022-09-04 20:59:46 +0200 |
commit | 5a72b4b1fc89d9b6033f929d9bf4f6e30d7f9698 (patch) | |
tree | 33fba0566f2bb1f378ca2d3de57fe63170312cca /src/Api.cpp | |
parent | 5492d26d21d09dc9cc3551f32a8eab7a2e783e3c (diff) |
Update to API 5.4
Diffstat (limited to 'src/Api.cpp')
-rw-r--r-- | src/Api.cpp | 50 |
1 files changed, 44 insertions, 6 deletions
diff --git a/src/Api.cpp b/src/Api.cpp index 9fdf290..ad9f544 100644 --- a/src/Api.cpp +++ b/src/Api.cpp @@ -1058,36 +1058,52 @@ string Api::exportChatInviteLink(std::int64_t chatId) const { ChatInviteLink::Ptr Api::createChatInviteLink(std::int64_t chatId, std::int32_t expireDate, - std::int32_t memberLimit) const { + std::int32_t memberLimit, + const std::string& name, + bool createsJoinRequest) const { vector<HttpReqArg> args; - args.reserve(3); + args.reserve(5); args.emplace_back("chat_id", chatId); + if (!name.empty()) { + args.emplace_back("name", name); + } if (expireDate != 0) { args.emplace_back("expire_date", expireDate); } if (memberLimit != 0) { args.emplace_back("member_limit", memberLimit); } + if (createsJoinRequest) { + args.emplace_back("createsJoinRequest", createsJoinRequest); + } return _tgTypeParser.parseJsonAndGetChatInviteLink(sendRequest("createChatInviteLink", args)); } ChatInviteLink::Ptr Api::editChatInviteLink(std::int64_t chatId, - std::string inviteLink, - std::int32_t expireDate, - std::int32_t memberLimit) const { + std::string inviteLink, + std::int32_t expireDate, + std::int32_t memberLimit, + const std::string& name, + bool createsJoinRequest) const { vector<HttpReqArg> args; - args.reserve(4); + args.reserve(6); args.emplace_back("chat_id", chatId); args.emplace_back("invite_link", inviteLink); + if (!name.empty()) { + args.emplace_back("name", name); + } if (expireDate != 0) { args.emplace_back("expire_date", expireDate); } if (memberLimit != 0) { args.emplace_back("member_limit", memberLimit); } + if (createsJoinRequest) { + args.emplace_back("createsJoinRequest", createsJoinRequest); + } return _tgTypeParser.parseJsonAndGetChatInviteLink(sendRequest("editChatInviteLink", args)); } @@ -1103,6 +1119,28 @@ ChatInviteLink::Ptr Api::revokeChatInviteLink(std::int64_t chatId, return _tgTypeParser.parseJsonAndGetChatInviteLink(sendRequest("revokeChatInviteLink", args)); } +bool Api::approveChatJoinRequest(std::int64_t chatId, + std::int64_t userId) const { + vector<HttpReqArg> args; + args.reserve(2); + + args.emplace_back("chat_id", chatId); + args.emplace_back("user_id", userId); + + return sendRequest("approveChatJoinRequest", args).get<bool>("", false); +} + +bool Api::declineChatJoinRequest(std::int64_t chatId, + std::int64_t userId) const { + vector<HttpReqArg> args; + args.reserve(2); + + args.emplace_back("chat_id", chatId); + args.emplace_back("user_id", userId); + + return sendRequest("declineChatJoinRequest", args).get<bool>("", false); +} + bool Api::setChatPhoto(std::int64_t chatId, const InputFile::Ptr photo) const { vector<HttpReqArg> args; args.reserve(2); |