-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathavailable-types.go
732 lines (652 loc) · 34.8 KB
/
available-types.go
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
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
package telegram
import "io"
// User struct.
type User struct {
ID int64 `json:"id"`
IsBot bool `json:"is_bot"`
FirstName string `json:"first_name"`
LastName *string `json:"last_name,omitempty"`
Username *string `json:"username,omitempty"`
LanguageCode *string `json:"language_code,omitempty"`
CanJoinGroups *bool `json:"can_join_groups,omitempty"`
CanReadAllGroupMessages *bool `json:"can_read_all_group_messages,omitempty"`
SupportsInlineQueries *bool `json:"supports_inline_queries,omitempty"`
}
// Chat struct.
type Chat struct {
ID int64 `json:"id"`
Type ChatType `json:"type"`
Title *string `json:"title,omitempty"`
Username *string `json:"username,omitempty"`
FirstName *string `json:"first_name,omitempty"`
LastName *string `json:"last_name,omitempty"`
Photo *ChatPhoto `json:"photo,omitempty"`
Bio *string `json:"bio,omitempty"`
HasPrivateForwards *bool `json:"has_private_forwards,omitempty"`
Description *string `json:"description,omitempty"`
InviteLink *string `json:"invite_link,omitempty"`
PinnedMessage *Message `json:"pinned_message,omitempty"`
Permissions *ChatPermissions `json:"permissions,omitempty"`
SlowModeDelay *int `json:"slow_mode_delay,omitempty"`
MessageAutoDeleteTime *int `json:"message_auto_delete_time,omitempty"`
HasProtectedContent *bool `json:"has_protected_content,omitempty"`
StickerSetName *string `json:"sticker_set_name,omitempty"`
CanSetStickerSet *bool `json:"can_set_sticker_set,omitempty"`
LinkedChatID *int64 `json:"linked_chat_id,omitempty"`
Location *ChatLocation `json:"location,omitempty"`
}
// Message struct.
type Message struct {
MessageID int `json:"message_id"`
From *User `json:"from,omitempty"`
SenderChat *Chat `json:"sender_chat,omitempty"`
Date int `json:"date"`
Chat Chat `json:"chat"`
ForwardFrom *User `json:"forward_from,omitempty"`
ForwardFromChat *Chat `json:"forward_from_chat,omitempty"`
ForwardFromMessageID *int `json:"forward_from_message_id,omitempty"`
ForwardSignature *string `json:"forward_signature,omitempty"`
ForwardSenderName *string `json:"forward_sender_name,omitempty"`
ForwardDate *int `json:"forward_date,omitempty"`
IsAutomaticForward *bool `json:"is_automatic_forward,omitempty"`
ReplyToMessage *Message `json:"reply_to_message,omitempty"`
ViaBot *User `json:"via_bot,omitempty"`
EditDate *int `json:"edit_date,omitempty"`
HasProtectedContent *bool `json:"has_protected_content,omitempty"`
MediaGroupID *string `json:"media_group_id,omitempty"`
AuthorSignature *string `json:"author_signature,omitempty"`
Text *string `json:"text,omitempty"`
Entities []MessageEntity `json:"entities,omitempty"`
Animation *Animation `json:"animation,omitempty"`
Audio *Audio `json:"audio,omitempty"`
Document *Document `json:"document,omitempty"`
Photo []PhotoSize `json:"photo,omitempty"`
Sticker *Sticker `json:"sticker,omitempty"`
Video *Video `json:"video,omitempty"`
VideoNote *VideoNote `json:"video_note,omitempty"`
Voice *Voice `json:"voice,omitempty"`
Caption *string `json:"caption,omitempty"`
CaptionEntities []MessageEntity `json:"caption_entities,omitempty"`
Contact *Contact `json:"contact,omitempty"`
Dice *Dice `json:"dice,omitempty"`
Game *Game `json:"game,omitempty"`
Poll *Poll `json:"poll,omitempty"`
Venue *Venue `json:"venue,omitempty"`
Location *Location `json:"location,omitempty"`
NewChatMembers []User `json:"new_chat_members,omitempty"`
LeftChatMember *User `json:"left_chat_member,omitempty"`
NewChatTitle *string `json:"new_chat_title,omitempty"`
NewChatPhoto []PhotoSize `json:"new_chat_photo,omitempty"`
DeleteChatPhoto *bool `json:"delete_chat_photo,omitempty"`
GroupChatCreated *bool `json:"group_chat_created,omitempty"`
SupergroupChatCreated *bool `json:"supergroup_chat_created,omitempty"`
ChannelChatCreated *bool `json:"channel_chat_created,omitempty"`
MessageAutoDeleteTimerChanged *MessageAutoDeleteTimerChanged `json:"message_auto_delete_timer_changed,omitempty"`
MigrateToChatID *int64 `json:"migrate_to_chat_id,omitempty"`
MigrateFromChatID *int64 `json:"migrate_from_chat_id,omitempty"`
PinnedMessage *Message `json:"pinned_message,omitempty"`
Invoice *Invoice `json:"invoice,omitempty"`
SuccessfulPayment *SuccessfulPayment `json:"successful_payment,omitempty"`
ConnectedWebsite *string `json:"connected_website,omitempty"`
PassportData *PassportData `json:"passport_data,omitempty"`
ProximityAlertTriggered *ProximityAlertTriggered `json:"proximity_alert_triggered,omitempty"`
VoiceChatScheduled *VoiceChatScheduled `json:"voice_chat_scheduled,omitempty"` // Deprecated
VideoChatScheduled *VideoChatScheduled `json:"video_chat_scheduled,omitempty"`
VoiceChatStarted *VoiceChatStarted `json:"voice_chat_started,omitempty"` // Deprecated
VideoChatStarted *VideoChatStarted `json:"video_chat_started,omitempty"`
VoiceChatEnded *VoiceChatEnded `json:"voice_chat_ended,omitempty"` // Deprecated
VideoChatEnded *VideoChatEnded `json:"video_chat_ended,omitempty"`
VoiceChatParticipantsInvited *VoiceChatParticipantsInvited `json:"voice_chat_participants_invited,omitempty"` // Deprecated
VideoChatParticipantsInvited *VideoChatParticipantsInvited `json:"video_chat_participants_invited,omitempty"`
WebAppData *WebAppData `json:"web_app_data,omitempty"` // Optional. Service message: data sent by a Web App
ReplyMarkup *InlineKeyboardMarkup `json:"reply_markup,omitempty"`
}
// MessageID struct.
type MessageID struct {
MessageID int `json:"message_id"`
}
type MessageEntityType string
const (
MessageEntityTypeMention MessageEntityType = "mention"
MessageEntityTypeHashtag MessageEntityType = "hashtag"
MessageEntityTypeCashtag MessageEntityType = "cashtag"
MessageEntityTypeBotCommand MessageEntityType = "bot_command"
MessageEntityTypeURL MessageEntityType = "url"
MessageEntityTypeEmail MessageEntityType = "email"
MessageEntityTypePhoneNumber MessageEntityType = "phone_number"
MessageEntityTypeBold MessageEntityType = "bold"
MessageEntityTypeItalic MessageEntityType = "italic"
MessageEntityTypeUnderline MessageEntityType = "underline"
MessageEntityTypeStrikethrough MessageEntityType = "strikethrough"
MessageEntityTypeCode MessageEntityType = "code"
MessageEntityTypePre MessageEntityType = "pre"
MessageEntityTypeTextLink MessageEntityType = "text_link"
MessageEntityTypeTextMention MessageEntityType = "text_mention"
MessageEntityTypeSpoiler MessageEntityType = "spoiler"
)
// MessageEntity struct.
type MessageEntity struct {
Type MessageEntityType `json:"type"`
Offset int `json:"offset"`
Length int `json:"length"`
URL *string `json:"url,omitempty"`
User *User `json:"user,omitempty"`
Language string `json:"language,omitempty"`
}
// PhotoSize struct.
type PhotoSize struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Width int `json:"width"`
Height int `json:"height"`
FileSize *int `json:"file_size,omitempty"`
}
// Animation struct.
type Animation struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Width int `json:"width"`
Height int `json:"height"`
Duration int `json:"duration"`
Thumb *PhotoSize `json:"thumb,omitempty"`
Filename *string `json:"filename,omitempty"`
MimeType *string `json:"mime_type,omitempty"`
FileSize *int `json:"file_size,omitempty"`
}
// Audio struct.
type Audio struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Duration int `json:"duration"`
Performer *string `json:"performer,omitempty"`
Title *string `json:"title,omitempty"`
FileName *string `json:"file_name,omitempty"`
MimeType *string `json:"mime_type,omitempty"`
FileSize *int `json:"file_size,omitempty"`
Thumb *PhotoSize `json:"thumb,omitempty"`
}
// Document struct
type Document struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Thumb *PhotoSize `json:"thumb,omitempty"`
FileName *string `json:"file_name,omitempty"`
MimeType *string `json:"mime_type,omitempty"`
FileSize *int `json:"file_size,omitempty"`
}
// Video struct
type Video struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Width int `json:"width"`
Height int `json:"height"`
Duration int `json:"duration"`
Thumb *PhotoSize `json:"thumb,omitempty"`
FileName *string `json:"file_name,omitempty"`
MimeType *string `json:"mime_type,omitempty"`
FileSize *int `json:"file_size,omitempty"`
}
// Voice struct
type Voice struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Duration int `json:"duration"`
MimeType *string `json:"mime_type,omitempty"`
FileSize *int `json:"file_size,omitempty"`
}
// VideoNote struct
type VideoNote struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
Length int `json:"length"`
Duration int `json:"duration"`
Thumbs *PhotoSize `json:"thumbs,omitempty"`
FileSize *int `json:"file_size,omitempty"`
}
// Contact struct
type Contact struct {
PhoneNumber string `json:"phone_number"`
FirstName string `json:"first_name"`
LastName *string `json:"last_name,omitempty"`
UserID *int64 `json:"user_id,omitempty"`
VCard *string `json:"vcard,omitempty"`
}
// Dice struct
type Dice struct {
Emoji string `json:"emoji"`
Value int `json:"value"`
}
// PollOption struct
type PollOption struct {
Text string `json:"text"`
VoterCount int `json:"voter_count"`
}
// PollAnswer struct
type PollAnswer struct {
PollID string `json:"poll_id"`
User User `json:"user"`
OptionIDs []int `json:"option_ids"`
}
// Poll struct
type Poll struct {
ID string `json:"id"`
Question string `json:"question"`
Options []PollOption `json:"options"`
TotalVoterCount int `json:"total_voter_count"`
IsClosed bool `json:"is_closed"`
IsAnonymous bool `json:"is_anonymous"`
Type string `json:"type"`
AllowsMultipleAnswers bool `json:"allows_multiple_answers"`
CorrectOptionID *int `json:"correct_option_id,omitempty"`
Explanation *string `json:"explanation,omitempty"`
ExplanationEntities []MessageEntity `json:"explanation_entities,omitempty"`
OpenPeriod *int `json:"open_period,omitempty"`
CloseDate *int `json:"close_date,omitempty"`
}
// Location struct
type Location struct {
Longitude float32 `json:"longitude"`
Latitude float32 `json:"latitude"`
HorizontalAccuracy *float32 `json:"horizontal_accuracy,omitempty"`
LivePeriod *int `json:"live_period,omitempty"`
Heading *int `json:"heading,omitempty"`
ProximityAlertRadius *int `json:"proximity_alert_radius,omitempty"`
}
// Venue struct
type Venue struct {
Location Location `json:"location"`
Title string `json:"title"`
Address string `json:"address"`
FoursquareID *string `json:"foursquare_id,omitempty"`
FoursquareType *string `json:"foursquare_type,omitempty"`
GooglePlaceID *string `json:"google_place_id,omitempty"`
GooglePlaceType *string `json:"google_place_type,omitempty"`
}
// WebAppData describes data sent from a Web App to the bot.
type WebAppData struct {
Data string `json:"data"` // The data. Be aware that a bad client can send arbitrary data in this field.
ButtonText string `json:"button_text"` // Text of the web_app keyboard button from which the Web App was opened. Be aware that a bad client can send arbitrary data in this field.
}
// ProximityAlertTriggered struct
type ProximityAlertTriggered struct {
Traveler User `json:"traveler"`
Watcher User `json:"watcher"`
Distance int `json:"distance"`
}
// MessageAutoDeleteTimerChanged struct
type MessageAutoDeleteTimerChanged struct {
MessageAutoDeleteTime int `json:"message_auto_delete_time"`
}
// VoiceChatScheduled represents a service message about a voice chat scheduled in the chat.
// Deprecated
type VoiceChatScheduled struct {
StartDate int `json:"start_date"` // Point in time (Unix timestamp) when the voice chat is supposed to be started by a chat administrator
}
// VideoChatScheduled represents a service message about a voice chat scheduled in the chat.
type VideoChatScheduled struct {
StartDate int `json:"start_date"` // Point in time (Unix timestamp) when the voice chat is supposed to be started by a chat administrator
}
// VoiceChatStarted struct
// Deprecated
type VoiceChatStarted struct{}
// VideoChatStarted struct
type VideoChatStarted struct{}
// VoiceChatEnded struct
// Deprecated
type VoiceChatEnded struct {
Duration int `json:"duration"` // Voice chat duration; in seconds
}
// VideoChatEnded struct
type VideoChatEnded struct {
Duration int `json:"duration"` // Voice chat duration; in seconds
}
// VoiceChatParticipantsInvited struct
// Deprecated
type VoiceChatParticipantsInvited struct {
Users *[]User `json:"users,omitempty"`
}
// VideoChatParticipantsInvited struct
type VideoChatParticipantsInvited struct {
Users *[]User `json:"users,omitempty"`
}
// UserProfilePhotos struct
type UserProfilePhotos struct {
TotalCount int `json:"total_count"`
Photos [][]PhotoSize `json:"photos"`
}
// File struct
type File struct {
FileID string `json:"file_id"`
FileUniqueID string `json:"file_unique_id"`
FileSize *int `json:"file_size,omitempty"`
FilePath *string `json:"file_path,omitempty"`
}
// WebAppInfo struct
type WebAppInfo struct {
URL string `json:"url"` // An HTTPS URL of a Web App to be opened with additional data as specified in Initializing Web Apps (https://core.telegram.org/bots/webapps#initializing-web-apps)
}
// ReplyKeyboardMarkup struct
type ReplyKeyboardMarkup struct {
Keyboard [][]KeyboardButton `json:"keyboard"` // Array of button rows, each represented by an Array of KeyboardButton objects
ResizeKeyboard *bool `json:"resize_keyboard,omitempty"` // Optional. Requests clients to resize the keyboard vertically for optimal fit (e.g., make the keyboard smaller if there are just two rows of buttons). Defaults to false, in which case the custom keyboard is always of the same height as the app's standard keyboard.
OneTimeKeyboard *bool `json:"one_time_keyboard,omitempty"` // Optional. Requests clients to hide the keyboard as soon as it's been used. The keyboard will still be available, but clients will automatically display the usual letter-keyboard in the chat – the user can press a special button in the input field to see the custom keyboard again. Defaults to false.
InputFieldPlaceholder *string `json:"input_field_placeholder,omitempty"` // Optional. The placeholder to be shown in the input field when the keyboard is active; 1-64 characters
Selective *bool `json:"selective,omitempty"` // Optional. Use this parameter if you want to show the keyboard to specific users only. Targets: 1) users that are @mentioned in the text of the Message object; 2) if the bot's message is a reply (has reply_to_message_id), sender of the original message. Example: A user requests to change the bot's language, bot replies to the request with a keyboard to select the new language. Other users in the group don't see the keyboard.
}
// KeyboardButton struct
type KeyboardButton struct {
Text string `json:"text"`
RequestContact *bool `json:"request_contact,omitempty"`
RequestLocation *bool `json:"request_location,omitempty"`
RequestPoll *KeyboardButtonPollType `json:"request_poll,omitempty"`
WebApp *WebAppInfo `json:"web_app,omitempty"`
}
// KeyboardButtonPollType struct
type KeyboardButtonPollType struct {
Type *string `json:"type,omitempty"`
}
// ReplyKeyboardRemove struct
type ReplyKeyboardRemove struct {
RemoveKeyboard bool `json:"remove_keyboard"`
Selective *bool `json:"selective,omitempty"`
}
// InlineKeyboardMarkup struct
type InlineKeyboardMarkup struct {
InlineKeyboard [][]InlineKeyboardButton `json:"inline_keyboard"`
}
// InlineKeyboardButton struct
type InlineKeyboardButton struct {
Text string `json:"text"`
URL *string `json:"url,omitempty"`
LoginURL *LoginURL `json:"login_url,omitempty"`
CallbackData *string `json:"callback_data,omitempty"`
WebApp *WebAppInfo `json:"web_app,omitempty"`
SwitchInlineQuery *string `json:"switch_inline_query,omitempty"`
SwitchInlineQueryCurrentChat *string `json:"switch_inline_query_current_chat,omitempty"`
CallbackGame *CallbackGame `json:"callback_game,omitempty"`
Pay *bool `json:"pay,omitempty"`
}
// LoginURL struct
type LoginURL struct {
URL string `json:"url"`
ForwardText *string `json:"forward_text,omitempty"`
BotUsername *string `json:"bot_username,omitempty"`
RequestWriteAccess *bool `json:"request_write_access,omitempty"`
}
// CallbackQuery struct
type CallbackQuery struct {
ID string `json:"id"`
From User `json:"from"`
Message *Message `json:"message,omitempty"`
InlineMessageID *string `json:"inline_message_id,omitempty"`
ChatInstance *string `json:"chat_instance,omitempty"`
Data *string `json:"data,omitempty"`
GameShortName *string `json:"game_short_name,omitempty"`
}
// ForceReply struct
type ForceReply struct {
ForceReply bool `json:"force_reply"` // Shows reply interface to the user, as if they manually selected the bot's message and tapped 'Reply'
InputFieldPlaceholder *string `json:"input_field_placeholder,omitempty"` // Optional. The placeholder to be shown in the input field when the reply is active; 1-64 characters
Selective *bool `json:"selective,omitempty"` // Optional. Use this parameter if you want to force reply from specific users only. Targets: 1) users that are @mentioned in the text of the Message object; 2) if the bot's message is a reply (has reply_to_message_id), sender of the original message.
}
// ChatPhoto struct
type ChatPhoto struct {
SmallFileID string `json:"small_file_id"`
SmallFileUniqueID string `json:"small_file_unique_id"`
BigFileID string `json:"big_file_id"`
BigFileUniqueID string `json:"big_file_unique_id"`
}
// ChatInviteLink represents an invite link for a chat.
type ChatInviteLink struct {
InviteLink string `json:"invite_link"`
Creator User `json:"creator"`
CreatesJoinRequest User `json:"creates_join_request"`
IsPrimary bool `json:"is_primary"`
IsRevoked bool `json:"is_revoked"`
Name *string `json:"name"`
ExpireDate *int `json:"expire_date,omitempty"`
MemberLimit *int `json:"member_limit,omitempty"`
PendingJoinRequestCount *int `json:"pending_join_request_count,omitempty"`
}
// ChatAdministratorRights represents the rights of an administrator in a chat.
type ChatAdministratorRights struct {
IsAnonymous bool `json:"is_anonymous"` // True, if the user's presence in the chat is hidden
CanManageChat bool `json:"can_manage_chat"` // True, if the administrator can access the chat event log, chat statistics, message statistics in channels, see channel members, see anonymous administrators in supergroups and ignore slow mode. Implied by any other administrator privilege
CanDeleteMessages bool `json:"can_delete_messages"` // True, if the administrator can delete messages of other users
CanManageVideoChats bool `json:"can_manage_video_chats"` // True, if the administrator can manage video chats
CanRestrictMembers bool `json:"can_restrict_members"` // True, if the administrator can restrict, ban or unban chat members
CanPromoteMembers bool `json:"can_promote_members"` // True, if the administrator can add new administrators with a subset of their own privileges or demote administrators that they have promoted, directly or indirectly (promoted by administrators that were appointed by the user)
CanChangeInfo bool `json:"can_change_info"` // True, if the user is allowed to change the chat title, photo and other settings
CanInviteUsers bool `json:"can_invite_users"` // True, if the user is allowed to invite new users to the chat
CanPostMessages bool `json:"can_post_messages"` // Optional. True, if the administrator can post in the channel; channels only
CanEditMessages bool `json:"can_edit_messages"` // Optional. True, if the administrator can edit messages of other users and can pin messages; channels only
CanPinMessages bool `json:"can_pin_messages"` // Optional. True, if the user is allowed to pin messages; groups and supergroups only
CanManageTopics bool `json:"can_manage_topics"` // Optional. True, if the user is allowed to create, rename, close, and reopen forum topics; supergroups only
}
// ChatMember contains information about one member of a chat. Currently, the following 6 types of chat members are supported:
// * ChatMemberOwner
// * ChatMemberAdministrator
// * ChatMemberMember
// * ChatMemberRestricted
// * ChatMemberLeft
// * ChatMemberBanned
type ChatMember interface{}
// ChatMemberOwner represents a chat member that owns the chat and has all administrator privileges.
type ChatMemberOwner struct {
Status string `json:"status"`
User User `json:"user"`
IsAnonymous bool `json:"is_anonymous,omitempty"`
CustomTitle *string `json:"custom_title,omitempty"`
}
// ChatMemberAdministrator represents a chat member that has some additional privileges.
type ChatMemberAdministrator struct {
Status string `json:"status"`
User User `json:"user"`
CanBeEdited bool `json:"can_be_edited,omitempty"`
IsAnonymous bool `json:"is_anonymous,omitempty"`
CanManageChat bool `json:"can_manage_chat,omitempty"`
CanDeleteMessages bool `json:"can_delete_messages,omitempty"`
CanManageVoiceChats bool `json:"can_manage_voice_chats,omitempty"` // deprecated
CanManageVideoChats bool `json:"can_manage_video_chats,omitempty"`
CanRestrictMembers bool `json:"can_restrict_members,omitempty"`
CanPromoteMembers bool `json:"can_promote_members,omitempty"`
CanChangeInfo bool `json:"can_change_info,omitempty"`
CanInviteUsers bool `json:"can_invite_users,omitempty"`
CanPostMessages *bool `json:"can_post_messages,omitempty"`
CanEditMessages *bool `json:"can_edit_messages,omitempty"`
CanPinMessages *bool `json:"can_pin_messages,omitempty"`
CustomTitle *string `json:"custom_title,omitempty"`
}
// ChatMemberMember represents a chat member that has no additional privileges or restrictions.
type ChatMemberMember struct {
Status string `json:"status"`
User User `json:"user"`
}
// ChatMemberRestricted represents a chat member that is under certain restrictions in the chat. Supergroups only.
type ChatMemberRestricted struct {
Status string `json:"status"`
User User `json:"user"`
IsMember bool `json:"is_member,omitempty"`
CanChangeInfo bool `json:"can_change_info,omitempty"`
CanInviteUsers bool `json:"can_invite_users,omitempty"`
CanPinMessages bool `json:"can_pin_messages,omitempty"`
CanSendMessages bool `json:"can_send_messages,omitempty"`
CanSendMediaMessages bool `json:"can_send_media_messages,omitempty"`
CanSendPolls bool `json:"can_send_polls,omitempty"`
CanSendOtherMessages bool `json:"can_send_other_messages,omitempty"`
CanAddWebPagePreviews bool `json:"can_add_web_page_previews,omitempty"`
UntilDate int `json:"until_date,omitempty"`
}
// ChatMemberLeft represents a chat member that isn't currently a member of the chat, but may join it themselves.
type ChatMemberLeft struct {
Status string `json:"status"`
User User `json:"user"`
}
// ChatMemberBanned represents a chat member that was banned in the chat and can't return to the chat or view chat messages.
type ChatMemberBanned struct {
Status string `json:"status"`
User User `json:"user"`
UntilDate int `json:"until_date,omitempty"`
}
// ChatMemberUpdated represents changes in the status of a chat member.
type ChatMemberUpdated struct {
Chat Chat `json:"chat"`
From User `json:"from"`
Date int `json:"date"`
OldChatMember ChatMember `json:"old_chat_member"`
NewChatMember ChatMember `json:"new_chat_member"`
InviteLink *ChatInviteLink `json:"invite_link,omitempty"`
}
// ChatJoinRequest represents a join request sent to a chat.
type ChatJoinRequest struct {
Chat Chat `json:"chat"`
From User `json:"from"`
Date int `json:"date"`
Bio *string `json:"bio,omitempty"`
InviteLink *ChatInviteLink `json:"invite_link,omitempty"`
}
// ChatPermissions struct
type ChatPermissions struct {
CanSendMessages *bool `json:"can_send_messages,omitempty"`
CanSendMediaMessages *bool `json:"can_send_media_messages,omitempty"`
CanSendPolls *bool `json:"can_send_polls,omitempty"`
CanSendOtherMessages *bool `json:"can_send_other_messages,omitempty"`
CanAddWebPagePreviews *bool `json:"can_add_web_page_previews,omitempty"`
CanChangeInfo *bool `json:"can_change_info,omitempty"`
CanInviteUsers *bool `json:"can_invite_users,omitempty"`
CanPinMessages *bool `json:"can_pin_messages,omitempty"`
}
// ChatLocation struct
type ChatLocation struct {
Location Location `json:"location"`
Address string `json:"address"`
}
// BotCommand struct
type BotCommand struct {
Command string `json:"command"`
Description string `json:"description"`
}
// BotCommandScope represents the scope to which bot commands are applied. Currently, the following 7 scopes are supported:
// * BotCommandScopeDefault
// * BotCommandScopeAllPrivateChats
// * BotCommandScopeAllGroupChats
// * BotCommandScopeAllChatAdministrators
// * BotCommandScopeChat
// * BotCommandScopeChatAdministrators
// * BotCommandScopeChatMember
type BotCommandScope interface{}
// BotCommandScopeDefault represents the default scope of bot commands. Default commands are used if no commands with a narrower scope are specified for the user.
type BotCommandScopeDefault struct {
Type string `json:"type"` // Scope type, must be default
}
// BotCommandScopeAllPrivateChats represents the scope of bot commands, covering all private chats.
type BotCommandScopeAllPrivateChats struct {
Type string `json:"type"` // Scope type, must be all_private_chats
}
// BotCommandScopeAllGroupChats represents the scope of bot commands, covering all group and supergroup chats.
type BotCommandScopeAllGroupChats struct {
Type string `json:"type"` // Scope type, must be all_group_chats
}
// BotCommandScopeAllChatAdministrators represents the scope of bot commands, covering all group and supergroup chat administrators.
type BotCommandScopeAllChatAdministrators struct {
Type string `json:"type"` // Scope type, must be all_chat_administrators
}
// BotCommandScopeChat represents the scope of bot commands, covering specific chat.
type BotCommandScopeChat struct {
Type string `json:"type"` // Scope type, must be chat
ChatID interface{} `json:"chat_id"` // Unique identifier for the target chat or username of the target supergroup (in the format @supergroupusername)
}
// BotCommandScopeChatAdministrators represents the scope of bot commands, covering all administrators of a specific group or supergroup chat.
type BotCommandScopeChatAdministrators struct {
Type string `json:"type"` // Scope type, must be chat_administrators
ChatID interface{} `json:"chat_id"` // Unique identifier for the target chat or username of the target supergroup (in the format @supergroupusername)
}
// BotCommandScopeChatMember represents the scope of bot commands, covering a specific member of a group or supergroup chat.
type BotCommandScopeChatMember struct {
Type string `json:"type"` // Scope type, must be chat_member
ChatID interface{} `json:"chat_id"` // Unique identifier for the target chat or username of the target supergroup (in the format @supergroupusername)
UserID int `json:"user_id"` // Unique identifier of the target user
}
// MenuButton describes the bot's menu button in a private chat. It should be one of
//
// - MenuButtonCommands
// - MenuButtonWebApp
// - MenuButtonDefault
//
// If a menu button other than MenuButtonDefault is set for a private chat, then it is applied in the chat. Otherwise the default menu button is applied. By default, the menu button opens the list of bot commands.
type MenuButton interface{}
// MenuButtonCommands represents a menu button, which opens the bot's list of commands.
type MenuButtonCommands struct {
Type string `json:"type"`
}
// MenuButtonWebApp represents a menu button, which launches a Web App.
type MenuButtonWebApp struct {
Type string `json:"type"`
Text string `json:"text"`
WebApp WebAppInfo `json:"web_app"`
}
// MenuButtonDefault describes that no specific value for the menu button was set.
type MenuButtonDefault struct {
Type string `json:"type"`
}
// ResponseParameters struct
type ResponseParameters struct {
MigrateToChatID *int64 `json:"migrate_to_chat_id,omitempty"`
RetryAfter *int `json:"retry_after,omitempty"`
}
// InputMedia interface
type InputMedia interface{}
// InputMediaPhoto struct
type InputMediaPhoto struct {
Type string `json:"type"`
Media string `json:"media"`
Caption *string `json:"caption,omitempty"`
ParseMode *string `json:"parse_mode,omitempty"`
}
// InputMediaVideo struct
type InputMediaVideo struct {
Type string `json:"type"`
Media string `json:"media"`
Thumb interface{} `json:"thumb,omitempty"`
Caption *string `json:"caption,omitempty"`
ParseMode *string `json:"parse_mode,omitempty"`
Width *int `json:"width,omitempty"`
Height *int `json:"height,omitempty"`
Duration *int `json:"duration,omitempty"`
SupportsStreaming *bool `json:"supports_streaming,omitempty"`
}
// InputMediaAnimation struct
type InputMediaAnimation struct {
Type string `json:"type"`
Media string `json:"media"`
Thumb interface{} `json:"thumb,omitempty"`
Caption *string `json:"caption,omitempty"`
ParseMode *string `json:"parse_mode,omitempty"`
Width *int `json:"width,omitempty"`
Height *int `json:"height,omitempty"`
Duration *int `json:"duration,omitempty"`
}
// InputMediaAudio struct
type InputMediaAudio struct {
Type string `json:"type"`
Media string `json:"media"`
Thumb interface{} `json:"thumb,omitempty"`
Caption *string `json:"caption,omitempty"`
ParseMode *string `json:"parse_mode,omitempty"`
Duration *int `json:"duration,omitempty"`
Performer *string `json:"performer,omitempty"`
Title *string `json:"title,omitempty"`
}
// InputMediaDocument struct
type InputMediaDocument struct {
Type string `json:"type"`
Media string `json:"media"`
Thumb interface{} `json:"thumb,omitempty"`
Caption *string `json:"caption,omitempty"`
ParseMode *string `json:"parse_mode,omitempty"`
DisableContentTypeDetection *bool `json:"disable_content_type_detection,omitempty"`
}
// InputFile interface
type InputFile interface {
io.Reader
}