summaryrefslogtreecommitdiff
path: root/include/tgbot/Api.h
blob: 55a09cb905d8e236e1085ebca97ce0d19bba6865 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
/*
 * Copyright (c) 2015 Oleg Morozenkov
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

#ifndef TGBOT_CPP_API_H
#define TGBOT_CPP_API_H

#include <string>
#include <vector>

#include <boost/property_tree/ptree.hpp>

#include "tgbot/net/HttpReqArg.h"
#include "tgbot/types/User.h"
#include "tgbot/types/Message.h"
#include "tgbot/types/GenericReply.h"
#include "tgbot/types/InputFile.h"
#include "tgbot/types/UserProfilePhotos.h"
#include "tgbot/types/Update.h"
#include "tgbot/types/InlineQueryResult.h"
#include "tgbot/types/Venue.h"
#include "tgbot/types/WebhookInfo.h"

namespace TgBot {

class Bot;

/**
 * This class executes telegram api methods. Telegram docs: <https://core.telegram.org/bots/api#available-methods>
 * @ingroup general
 */
class Api {

typedef std::shared_ptr<std::vector<std::string>> StringArrayPtr;

friend class Bot;

public:
	Api(const std::string& token);

	/**
	 * A simple method for testing your bot's auth token.
	 * @return Basic information about the bot in form of a User object.
	 */
	User::Ptr getMe() const;

	/**
	 * Use this method to send text messages.
	 * @param chatId Unique identifier for the target chat.
	 * @param text Text of the message to be sent.
	 * @param disableWebPagePreview Optional. Disables link previews for links in this message.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param parseMode Optional. Set it to "Markdown" or "HTML" if you want Telegram apps to show bold, italic, fixed-width text or inline URLs in your bot's message.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendMessage(int64_t chatId, const std::string& text, bool disableWebPagePreview = false, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), const std::string& parseMode = "", bool disableNotification = false) const;

	/**
	 * Use this method to forward messages of any kind.
	 * @param chatId Unique identifier for the target chat.
	 * @param fromChatId Unique identifier for the chat where the original message was sent — User or GroupChat id.
	 * @param messageId Unique message identifier.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr forwardMessage(int64_t chatId, int64_t fromChatId, int32_t messageId, bool disableNotification = false) const;

	/**
	 * Use this method to send photos.
	 * @param chatId Unique identifier for the target chat.
	 * @param photo Photo to send.
	 * @param caption Optional. Photo caption.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendPhoto(int64_t chatId, const InputFile::Ptr& photo, const std::string& caption = "", int32_t replyToMessageId = 0,
	                       const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send photos.
	 * @param chatId Unique identifier for the target chat.
	 * @param photo Photo to send. Id of the photo that is already on the Telegram servers.
	 * @param caption Optional. Photo caption.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendPhoto(int64_t chatId, const std::string& photoId, const std::string& caption = "", int32_t replyToMessageId = 0,
	                       const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. For this to work, your audio must be in an .ogg file encoded with OPUS (other formats may be sent as Document).
	 * @param chatId Unique identifier for the target chat.
	 * @param audio Audio to send.
	 * @param caption Audio caption, 0-200 characters
	 * @param duration Duration of sent audio in seconds.
	 * @param performer Performer
	 * @param title Track name
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendAudio(int64_t chatId, const InputFile::Ptr& audio, const std::string &caption = "", int32_t duration = 0,
	                       const std::string& performer = "", const std::string& title = "", int32_t replyToMessageId = 0,
	                       const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message. For this to work, your audio must be in an .ogg file encoded with OPUS (other formats may be sent as Document).
	 * @param chatId Unique identifier for the target chat.
	 * @param audio Id of the audio that is already on the Telegram servers.
	 * @param caption Audio caption, 0-200 characters
	 * @param duration Duration of sent audio in seconds.
	 * @param performer Performer
	 * @param title Track name
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendAudio(int64_t chatId, const std::string& audioId, const std::string &caption = "", int32_t duration = 0,
	                       const std::string& performer = "", const std::string& title = "", int32_t replyToMessageId = 0,
	                       const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send general files.
	 * @param chatId Unique identifier for the target chat.
	 * @param document Document to send.
	 * @param caption Document caption (may also be used when resending documents by file_id), 0-200 characters
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendDocument(int64_t chatId, const InputFile::Ptr& document, const std::string &caption = "", int32_t replyToMessageId = 0,
	                          const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send general files.
	 * @param chatId Unique identifier for the target chat.
	 * @param document Id of the document that is already on the Telegram servers.
	 * @param caption Document caption (may also be used when resending documents by file_id), 0-200 characters
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendDocument(int64_t chatId, const std::string& documentId, const std::string &caption = "", int32_t replyToMessageId = 0,
	                          const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send .webp stickers.
	 * @param chatId Unique identifier for the target chat.
	 * @param sticker Sticker to send.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendSticker(int64_t chatId, const InputFile::Ptr& sticker, int32_t replyToMessageId = 0,
	                         const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send .webp stickers.
	 * @param chatId Unique identifier for the target chat.
	 * @param sticker Id of the sticker that is already on the Telegram servers.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendSticker(int64_t chatId, const std::string& stickerId, int32_t replyToMessageId = 0,
	                         const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document).
	 * @param chatId Unique identifier for the target chat.
	 * @param video Video to send.
	 * @param duration Duration of sent video in seconds
	 * @param width Video width
	 * @param height Video height
	 * @param caption Video caption (may also be used when resending videos by file_id), 0-200 characters
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. An object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendVideo(int64_t chatId, const InputFile::Ptr& video, int32_t duration = 0, int32_t width = 0, int32_t height = 0, const std::string &caption = "",
						   int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document).
	 * @param chatId Unique identifier for the target chat.
	 * @param video Id of the video that is already on the Telegram servers.
	 * @param duration Duration of sent video in seconds
	 * @param width Video width
	 * @param height Video height
	 * @param caption Video caption (may also be used when resending videos by file_id), 0-200 characters
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendVideo(int64_t chatId, const std::string& videoId, int32_t duration = 0, int32_t width = 0, int32_t height = 0, const std::string &caption = "",
						   int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message.
	 * @param chatId Unique identifier for the target chat.
	 * @param voice Audio file to send.
	 * @param caption Voice message caption, 0-200 characters
	 * @param duration Duration of send audio in seconds.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendVoice(int64_t chatId, const InputFile::Ptr& voice, const std::string &caption = "", int duration = 0, int32_t replyToMessageId = 0,
	                      const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send audio files, if you want Telegram clients to display the file as a playable voice message.
	 * @param chatId Unique identifier for the target chat.
	 * @param voiceId Id of the voice that is already on the Telegram servers.
	 * @param caption Voice message caption, 0-200 characters
	 * @param duration Duration of send audio in seconds.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendVoice(int64_t chatId, const std::string& voiceId, const std::string &caption = "", int duration = 0, int32_t replyToMessageId = 0,
	                       const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send point on the map.
	 * @param chatId Unique identifier for the target chat.
	 * @param latitude Latitude of location.
	 * @param longitude Longitude of location.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendLocation(int64_t chatId, float latitude, float longitude, int32_t replyToMessageId = 0,
	                          const GenericReply::Ptr& replyMarkup = GenericReply::Ptr(), bool disableNotification = false) const;

	/**
	 * Use this method to send information about a venue. On success, the sent Message is returned.
	 * @param chatId Unique identifier for the target chat.
	 * @param latitude Latitude of location.
	 * @param longitude Longitude of location.
	 * @param title Name of the venue.
	 * @param address Address of the venue.
	 * @param foursquare_id Foursquare identifier of the venue.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendVenue(int64_t chatId, float latitude, float longitude, std::string title, std::string address, std::string foursquareId = "",
	                       bool disableNotification = false, int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const;

	/**
	 * Use this method to send phone contacts. On success, the sent Message is returned.
	 * @param chatId Unique identifier for the target chat.
	 * @param phoneNumber Contact's phone number.
	 * @param firstName Contact's first name.
	 * @param lastName Contact's last name.
	 * @param disableNotification Optional. Sends the message silenty.
	 * @param replyToMessageId Optional. If the message is a reply, ID of the original message.
	 * @param replyMarkup Optional. Additional interface options. A object for a custom reply keyboard, instructions to hide keyboard or to force a reply from the user.
	 * @return On success, the sent message is returned.
	 */
	Message::Ptr sendContact(int64_t chatId, std::string phoneNumber, std::string firstName, std::string lastName = "", bool disableNotification = false,
							int32_t replyToMessageId = 0, const GenericReply::Ptr& replyMarkup = GenericReply::Ptr()) const;

	/**
	 * Use this method when you need to tell the user that something is happening on the bot's side. The status is set for 5 seconds or less (when a message arrives from your bot, Telegram clients clear its typing status).
	 * Example: The ImageBot needs some time to process a request and upload the image. Instead of sending a text message along the lines of “Retrieving image, please wait…”, the bot may use sendChatAction with action = upload_photo. The user will see a “sending photo” status for the bot.
	 * We only recommend using this method when a response from the bot will take a noticeable amount of time to arrive.
	 * @param chatId Unique identifier for the target chat.
	 * @param action Type of action to broadcast. Choose one, depending on what the user is about to receive: typing for text messages, upload_photo for photos, record_video or upload_video for videos, record_audio or upload_audio for audio files, upload_document for general files, find_location for location data.
	 */
	void sendChatAction(int64_t chatId, const std::string& action) const;

	/**
	 * Use this method to get a list of profile pictures for a user.
	 * @param userId Unique identifier of the target user.
	 * @param offset Optional. Sequential number of the first photo to be returned. By default, all photos are returned.
	 * @param limit Optional. Limits the number of photos to be retrieved. Values between 1—100 are accepted. Defaults to 100.
	 * @return A UserProfilePhotos object.
	 */
	UserProfilePhotos::Ptr getUserProfilePhotos(int32_t userId, int32_t offset = 0, int32_t limit = 100) const;

	/**
	 * Use this method to receive incoming updates using long polling.
	 * This method will not work if an outgoing webhook is set up.
	 * In order to avoid getting duplicate updates, recalculate offset after each server response.
	 * @param offset Optional. Identifier of the first update to be returned. Must be greater by one than the highest among the identifiers of previously received updates. By default, updates starting with the earliest unconfirmed update are returned. An update is considered confirmed as soon as getUpdates is called with an offset higher than its update_id.
	 * @param limit Optional. Limits the number of updates to be retrieved. Values between 1—100 are accepted. Defaults to 100.
	 * @param timeout Optional. Timeout in seconds for long polling. Defaults to 0, i.e. usual short polling.
	 * @return An Array of Update objects
	 */
	std::vector<Update::Ptr> getUpdates(int32_t offset = 0, int32_t limit = 100, int32_t timeout = 0) const;

	/**
	 * Use this method to specify a url and receive incoming updates via an outgoing webhook. Whenever there is an update for the bot, we will send an HTTPS POST request to the specified url, containing a JSON-serialized Update. In case of an unsuccessful request, we will give up after a reasonable amount of attempts.
	 * If you'd like to make sure that the Webhook request comes from Telegram, we recommend using a secret path in the URL, e.g. www.example.com/<token>. Since nobody else knows your bot‘s token, you can be pretty sure it’s us.
	 * You will not be able to receive updates using getUpdates for as long as an outgoing webhook is set up.
	 * We currently do not support self-signed certificates.
	 * Ports currently supported for Webhooks: 443, 80, 88, 8443.
	 * @param url Optional. HTTPS url to send updates to. Use an empty string to remove webhook integration.
	 */
	void setWebhook(const std::string& url = "", const InputFile::Ptr& certificate = nullptr, int32_t maxConnection = 40, const StringArrayPtr &allowedUpdates = nullptr) const;

	/**
	 * Use this method to remove webhook integration if you decide to switch back to getUpdates.
	 * Returns True on success. Requires no parameters.
	 */
	bool deleteWebhook() const;

	/**
	 * Use this method to get current webhook status. 
	 * Requires no parameters. On success, returns a WebhookInfo object.
	 * If the bot is using getUpdates, will return an object with the url field empty.
	 */
	WebhookInfo::Ptr getWebhookInfo() const;

	/**
	 * Use this method to send answers to an inline query.
	 * No mode that 50 results per query are allowed.
	 * @param inlineQueryId Unique identifier for the answered query.
	 * @param results Array of results for the inline query.
	 * @param cacheTime The maximum amount of time in seconds that the result of the inline query may be cached on the server. Defaults to 300.
	 * @param isPersonal Pass True, if results may be cached on the server side only for the user that sent the query. By default, results may be returned to any user who sends the same query.
	 * @param nextOffset Pass the offset that a client should send in the next query with the same text to receive more results. Pass an empty string if there are no more results or if you don‘t support pagination. Offset length can’t exceed 64 bytes.
	 */
	void answerInlineQuery(const std::string& inlineQueryId, const std::vector<InlineQueryResult::Ptr>& results,
							int32_t cacheTime=300, bool isPersonal=false, const std::string& nextOffset="") const;

	/**
	 * Use this method to kick a user from a group or a supergroup.
	 * @param chatId Unique identifier for the target group.
	 * @param userId Unique identifier of the target user.
	 */
	void kickChatMember(int64_t chatId, int32_t userId) const;

	/**
	 * Use this method to unban a previously kicked user in a supergroup.
	 * @param chatId Unique identifier for the target group.
	 * @param userId Unique identifier of the target user.
	 */
	void unbanChatMember(int64_t chatId, int32_t userId) const;

private:
	boost::property_tree::ptree sendRequest(const std::string& method, const std::vector<HttpReqArg>& args = std::vector<HttpReqArg>()) const;

	const std::string _token;
};

}

#endif //TGBOT_CPP_API_H