-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathchat_admin.go
More file actions
192 lines (156 loc) · 4.73 KB
/
Copy pathchat_admin.go
File metadata and controls
192 lines (156 loc) · 4.73 KB
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
package botapi
import (
"context"
"github.com/gotd/td/tg"
)
// errNotInPrivateChat is returned by chat-management methods invoked on a
// private (user) chat where they do not apply.
func errNotInPrivateChat() *Error {
return &Error{Code: 400, Description: "Bad Request: method is not available in private chats"}
}
// chatAdmin is the subset of peer operations shared by basic groups and
// channels/supergroups. peers.Chat and peers.Channel both implement it; users
// do not.
type chatAdmin interface {
SetTitle(ctx context.Context, title string) error
SetDescription(ctx context.Context, about string) error
Leave(ctx context.Context) error
}
// resolveChatAdmin resolves a ChatID to the shared admin operations, rejecting
// private chats.
func (b *Bot) resolveChatAdmin(ctx context.Context, chat ChatID) (chatAdmin, error) {
p, err := b.resolvePeer(ctx, chat)
if err != nil {
return nil, err
}
a, ok := p.(chatAdmin)
if !ok {
return nil, errNotInPrivateChat()
}
return a, nil
}
// SetChatTitle changes the title of a chat. The bot must be an administrator
// with the appropriate rights.
func (b *Bot) SetChatTitle(ctx context.Context, chat ChatID, title string) error {
a, err := b.resolveChatAdmin(ctx, chat)
if err != nil {
return err
}
if err := a.SetTitle(ctx, title); err != nil {
return asAPIError(err)
}
return nil
}
// SetChatDescription changes the description of a chat.
func (b *Bot) SetChatDescription(ctx context.Context, chat ChatID, description string) error {
a, err := b.resolveChatAdmin(ctx, chat)
if err != nil {
return err
}
if err := a.SetDescription(ctx, description); err != nil {
return asAPIError(err)
}
return nil
}
// LeaveChat makes the bot leave a group, supergroup or channel.
func (b *Bot) LeaveChat(ctx context.Context, chat ChatID) error {
a, err := b.resolveChatAdmin(ctx, chat)
if err != nil {
return err
}
if err := a.Leave(ctx); err != nil {
return asAPIError(err)
}
return nil
}
// PinChatMessage pins a message in a chat. By default it notifies members; pass
// Silent to pin quietly.
func (b *Bot) PinChatMessage(ctx context.Context, chat ChatID, messageID int, opts ...SendOption) error {
var cfg sendConfig
for _, o := range opts {
o(&cfg)
}
peer, err := b.resolveInputPeer(ctx, chat)
if err != nil {
return err
}
if _, err := b.raw.MessagesUpdatePinnedMessage(ctx, &tg.MessagesUpdatePinnedMessageRequest{
Peer: peer,
ID: messageID,
Silent: cfg.silent,
}); err != nil {
return asAPIError(err)
}
return nil
}
// UnpinChatMessage unpins the message with the given id in a chat.
func (b *Bot) UnpinChatMessage(ctx context.Context, chat ChatID, messageID int) error {
peer, err := b.resolveInputPeer(ctx, chat)
if err != nil {
return err
}
if _, err := b.raw.MessagesUpdatePinnedMessage(ctx, &tg.MessagesUpdatePinnedMessageRequest{
Peer: peer,
ID: messageID,
Unpin: true,
}); err != nil {
return asAPIError(err)
}
return nil
}
// UnpinAllChatMessages clears the list of pinned messages in a chat.
func (b *Bot) UnpinAllChatMessages(ctx context.Context, chat ChatID) error {
peer, err := b.resolveInputPeer(ctx, chat)
if err != nil {
return err
}
if _, err := b.raw.MessagesUnpinAllMessages(ctx, &tg.MessagesUnpinAllMessagesRequest{
Peer: peer,
}); err != nil {
return asAPIError(err)
}
return nil
}
// SetChatPermissions sets the default permissions for all non-administrator
// members of a supergroup. permissions is an allow-list.
func (b *Bot) SetChatPermissions(ctx context.Context, chat ChatID, permissions ChatPermissions) error {
peer, err := b.resolveInputPeer(ctx, chat)
if err != nil {
return err
}
if _, err := b.raw.MessagesEditChatDefaultBannedRights(ctx, &tg.MessagesEditChatDefaultBannedRightsRequest{
Peer: peer,
BannedRights: permissions.toBannedRights(0),
}); err != nil {
return asAPIError(err)
}
return nil
}
// SetChatStickerSet sets the group sticker set for a supergroup.
func (b *Bot) SetChatStickerSet(ctx context.Context, chat ChatID, stickerSetName string) error {
channel, err := b.resolveChannel(ctx, chat)
if err != nil {
return err
}
if _, err := b.raw.ChannelsSetStickers(ctx, &tg.ChannelsSetStickersRequest{
Channel: channel,
Stickerset: &tg.InputStickerSetShortName{ShortName: stickerSetName},
}); err != nil {
return asAPIError(err)
}
return nil
}
// DeleteChatStickerSet removes the group sticker set from a supergroup.
func (b *Bot) DeleteChatStickerSet(ctx context.Context, chat ChatID) error {
channel, err := b.resolveChannel(ctx, chat)
if err != nil {
return err
}
if _, err := b.raw.ChannelsSetStickers(ctx, &tg.ChannelsSetStickersRequest{
Channel: channel,
Stickerset: &tg.InputStickerSetEmpty{},
}); err != nil {
return asAPIError(err)
}
return nil
}