-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
update.ts
132 lines (129 loc) · 5.52 KB
/
update.ts
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
import type { ChosenInlineResult, InlineQuery } from "./inline.ts";
import type {
Chat,
ChatJoinRequest,
ChatMemberUpdated,
User,
} from "./manage.ts";
import type { CallbackQuery } from "./markup.ts";
import type {
CommonMessageBundle,
Message,
Poll,
PollAnswer,
} from "./message.ts";
import type { PreCheckoutQuery, ShippingQuery } from "./payment.ts";
/** Internal namespace used to make some message types more accurate */
export declare namespace Update {
/** Internal type holding properties that updates in channels share. */
export interface Channel {
chat: Chat.ChannelChat;
author_signature?: string;
from?: never;
}
/** Internal type holding properties that updates outside of channels share. */
export interface NonChannel {
chat: Exclude<Chat, Chat.ChannelChat>;
author_signature?: never;
from: User;
}
/** Internal type holding properties that updates about new messages share. */
export interface New {
edit_date?: never;
}
/** Internal type holding properties that updates about edited messages share. */
export interface Edited {
/** Date the message was last edited in Unix time */
edit_date: number;
forward_from?: never;
forward_from_chat?: never;
forward_from_message_id?: never;
forward_signature?: never;
forward_sender_name?: never;
forward_date?: never;
}
export interface AbstractUpdate {
/** The update's unique identifier. Update identifiers start from a certain positive number and increase sequentially. This ID becomes especially handy if you're using webhooks, since it allows you to ignore repeated updates or to restore the correct update sequence, should they get out of order. If there are no new updates for at least a week, then identifier of the next update will be chosen randomly instead of sequentially. */
update_id: number;
}
export interface MessageUpdate<M extends Message = Message>
extends AbstractUpdate {
/** New incoming message of any kind - text, photo, sticker, etc. */
message: New & NonChannel & M;
}
export interface EditedMessageUpdate<
M extends CommonMessageBundle = CommonMessageBundle,
> extends AbstractUpdate {
/** New version of a message that is known to the bot and was edited */
edited_message: Edited & NonChannel & M;
}
export interface ChannelPostUpdate<M extends Message = Message>
extends AbstractUpdate {
/** New incoming channel post of any kind - text, photo, sticker, etc. */
channel_post: New & Channel & M;
}
export interface EditedChannelPostUpdate<
M extends CommonMessageBundle = CommonMessageBundle,
> extends AbstractUpdate {
/** New version of a channel post that is known to the bot and was edited */
edited_channel_post: Edited & Channel & M;
}
export interface InlineQueryUpdate extends AbstractUpdate {
/** New incoming inline query */
inline_query: InlineQuery;
}
export interface ChosenInlineResultUpdate extends AbstractUpdate {
/** The result of an inline query that was chosen by a user and sent to their chat partner. Please see our documentation on the feedback collecting for details on how to enable these updates for your bot. */
chosen_inline_result: ChosenInlineResult;
}
export interface CallbackQueryUpdate<C extends CallbackQuery = CallbackQuery>
extends AbstractUpdate {
/** New incoming callback query */
callback_query: C;
}
export interface ShippingQueryUpdate extends AbstractUpdate {
/** New incoming shipping query. Only for invoices with flexible price */
shipping_query: ShippingQuery;
}
export interface PreCheckoutQueryUpdate extends AbstractUpdate {
/** New incoming pre-checkout query. Contains full information about checkout */
pre_checkout_query: PreCheckoutQuery;
}
export interface PollUpdate extends AbstractUpdate {
/** New poll state. Bots receive only updates about stopped polls and polls, which are sent by the bot */
poll: Poll;
}
export interface PollAnswerUpdate extends AbstractUpdate {
/** A user changed their answer in a non-anonymous poll. Bots receive new votes only in polls that were sent by the bot itself. */
poll_answer: PollAnswer;
}
export interface MyChatMemberUpdate extends AbstractUpdate {
/** The bot's chat member status was updated in a chat. For private chats, this update is received only when the bot is blocked or unblocked by the user. */
my_chat_member: ChatMemberUpdated;
}
export interface ChatMemberUpdate extends AbstractUpdate {
/** A chat member's status was updated in a chat. The bot must be an administrator in the chat and must explicitly specify “chat_member” in the list of allowed_updates to receive these updates. */
chat_member: ChatMemberUpdated;
}
export interface ChatJoinRequestUpdate extends AbstractUpdate {
/** A request to join the chat has been sent. The bot must have the can_invite_users administrator right in the chat to receive these updates. */
chat_join_request: ChatJoinRequest;
}
}
/** This object represents an incoming update.
At most one of the optional parameters can be present in any given update. */
export type Update =
| Update.CallbackQueryUpdate
| Update.ChannelPostUpdate
| Update.ChatMemberUpdate
| Update.ChosenInlineResultUpdate
| Update.EditedChannelPostUpdate
| Update.EditedMessageUpdate
| Update.InlineQueryUpdate
| Update.MessageUpdate
| Update.MyChatMemberUpdate
| Update.PreCheckoutQueryUpdate
| Update.PollAnswerUpdate
| Update.PollUpdate
| Update.ShippingQueryUpdate
| Update.ChatJoinRequestUpdate;