mirror of
https://github.com/tucnak/telebot
synced 2024-11-11 01:10:39 +00:00
More refactoring, API rethinking.
This commit is contained in:
parent
3cf300d59d
commit
a8671a839d
302
bot.go
302
bot.go
@ -209,62 +209,12 @@ func (b *Bot) SendChatAction(recipient Recipient, action ChatAction) error {
|
|||||||
"action": string(action),
|
"action": string(action),
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("sendChatAction", params)
|
respJSON, err := b.sendCommand("sendChatAction", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
return extractOkResponse(respJSON)
|
||||||
Ok bool
|
|
||||||
Description string
|
|
||||||
}
|
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
|
||||||
if err != nil {
|
|
||||||
return errors.Wrap(err, "bad response json")
|
|
||||||
}
|
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
|
||||||
return errors.Errorf("api error: %s", responseRecieved.Description)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Respond publishes a set of responses for an inline query.
|
|
||||||
// This function is deprecated in favor of AnswerInlineQuery.
|
|
||||||
func (b *Bot) Respond(query Query, results []Result) error {
|
|
||||||
params := map[string]string{
|
|
||||||
"inline_query_id": query.ID,
|
|
||||||
}
|
|
||||||
|
|
||||||
if res, err := json.Marshal(results); err == nil {
|
|
||||||
params["results"] = string(res)
|
|
||||||
} else {
|
|
||||||
b.debug(errors.Wrapf(err, "failed to respond to \"%s\"", query.Text))
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("answerInlineQuery", params)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
var responseRecieved struct {
|
|
||||||
Ok bool
|
|
||||||
Description string
|
|
||||||
}
|
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
|
||||||
if err != nil {
|
|
||||||
return errors.Wrap(err, "bad response json")
|
|
||||||
}
|
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
|
||||||
return errors.Errorf("api error: %s", responseRecieved.Description)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// AnswerInlineQuery sends a response for a given inline query. A query can
|
// AnswerInlineQuery sends a response for a given inline query. A query can
|
||||||
@ -273,26 +223,12 @@ func (b *Bot) Respond(query Query, results []Result) error {
|
|||||||
func (b *Bot) AnswerInlineQuery(query *Query, response *QueryResponse) error {
|
func (b *Bot) AnswerInlineQuery(query *Query, response *QueryResponse) error {
|
||||||
response.QueryID = query.ID
|
response.QueryID = query.ID
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("answerInlineQuery", response)
|
respJSON, err := b.sendCommand("answerInlineQuery", response)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
return extractOkResponse(respJSON)
|
||||||
Ok bool
|
|
||||||
Description string
|
|
||||||
}
|
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
|
||||||
if err != nil {
|
|
||||||
return errors.Wrap(err, "bad response json")
|
|
||||||
}
|
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
|
||||||
return errors.Errorf("api error: %s", responseRecieved.Description)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// AnswerCallbackQuery sends a response for a given callback query. A callback can
|
// AnswerCallbackQuery sends a response for a given callback query. A callback can
|
||||||
@ -301,57 +237,44 @@ func (b *Bot) AnswerInlineQuery(query *Query, response *QueryResponse) error {
|
|||||||
func (b *Bot) AnswerCallbackQuery(callback *Callback, response *CallbackResponse) error {
|
func (b *Bot) AnswerCallbackQuery(callback *Callback, response *CallbackResponse) error {
|
||||||
response.CallbackID = callback.ID
|
response.CallbackID = callback.ID
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("answerCallbackQuery", response)
|
respJSON, err := b.sendCommand("answerCallbackQuery", response)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
return extractOkResponse(respJSON)
|
||||||
Ok bool
|
|
||||||
Description string
|
|
||||||
}
|
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
|
||||||
if err != nil {
|
|
||||||
return errors.Wrap(err, "bad response json")
|
|
||||||
}
|
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
|
||||||
return errors.Errorf("api error: %s", responseRecieved.Description)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetFile returns full file object including File.FilePath, which allow you to load file from Telegram
|
// GetFile returns full file object including File.FilePath, which allow you to load file from Telegram
|
||||||
//
|
//
|
||||||
// Usually File objects does not contain any FilePath so you need to perform additional request
|
// Usually File objects does not contain any FilePath so you need to perform additional request
|
||||||
func (b *Bot) GetFile(fileID string) (File, error) {
|
func (b *Bot) GetFile(fileID string) (*File, error) {
|
||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"file_id": fileID,
|
"file_id": fileID,
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("getFile", params)
|
|
||||||
|
respJSON, err := b.sendCommand("getFile", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return File{}, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Result File
|
Result *File
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return File{}, errors.Wrap(err, "bad response json")
|
return nil, errors.Wrap(err, "bad response json")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return File{}, errors.Errorf("api error: %s", responseRecieved.Description)
|
return nil, errors.Errorf("api error: %s", resp.Description)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return responseRecieved.Result, nil
|
return resp.Result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// LeaveChat makes bot leave a group, supergroup or channel.
|
// LeaveChat makes bot leave a group, supergroup or channel.
|
||||||
@ -359,27 +282,13 @@ func (b *Bot) LeaveChat(recipient Recipient) error {
|
|||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"chat_id": recipient.Destination(),
|
"chat_id": recipient.Destination(),
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("leaveChat", params)
|
|
||||||
|
respJSON, err := b.sendCommand("leaveChat", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
return extractOkResponse(respJSON)
|
||||||
Ok bool
|
|
||||||
Description string
|
|
||||||
Result bool
|
|
||||||
}
|
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
|
||||||
if err != nil {
|
|
||||||
return errors.Wrap(err, "bad response json")
|
|
||||||
}
|
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
|
||||||
return errors.Errorf("api error: %s", responseRecieved.Description)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetChat get up to date information about the chat.
|
// GetChat get up to date information about the chat.
|
||||||
@ -388,31 +297,32 @@ func (b *Bot) LeaveChat(recipient Recipient) error {
|
|||||||
// current username of a user, group or channel, etc.
|
// current username of a user, group or channel, etc.
|
||||||
//
|
//
|
||||||
// Returns a Chat object on success.
|
// Returns a Chat object on success.
|
||||||
func (b *Bot) GetChat(recipient Recipient) (Chat, error) {
|
func (b *Bot) GetChat(recipient Recipient) (*Chat, error) {
|
||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"chat_id": recipient.Destination(),
|
"chat_id": recipient.Destination(),
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("getChat", params)
|
|
||||||
|
respJSON, err := b.sendCommand("getChat", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return Chat{}, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Result Chat
|
Result *Chat
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return Chat{}, errors.Wrap(err, "bad response json")
|
return nil, errors.Wrap(err, "bad response json")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return Chat{}, errors.Errorf("api error: %s", responseRecieved.Description)
|
return nil, errors.Errorf("api error: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return responseRecieved.Result, nil
|
return resp.Result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetChatAdministrators return list of administrators in a chat.
|
// GetChatAdministrators return list of administrators in a chat.
|
||||||
@ -426,27 +336,28 @@ func (b *Bot) GetChatAdministrators(recipient Recipient) ([]ChatMember, error) {
|
|||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"chat_id": recipient.Destination(),
|
"chat_id": recipient.Destination(),
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("getChatAdministrators", params)
|
|
||||||
|
respJSON, err := b.sendCommand("getChatAdministrators", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []ChatMember{}, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Result []ChatMember
|
Result []ChatMember
|
||||||
Description string `json:"description"`
|
Description string `json:"description"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []ChatMember{}, errors.Wrap(err, "bad response json")
|
return nil, errors.Wrap(err, "bad response json")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return []ChatMember{}, errors.Errorf("api error: %s", responseRecieved.Description)
|
return nil, errors.Errorf("api error: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return responseRecieved.Result, nil
|
return resp.Result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetChatMembersCount return the number of members in a chat.
|
// GetChatMembersCount return the number of members in a chat.
|
||||||
@ -456,88 +367,95 @@ func (b *Bot) GetChatMembersCount(recipient Recipient) (int, error) {
|
|||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"chat_id": recipient.Destination(),
|
"chat_id": recipient.Destination(),
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("getChatMembersCount", params)
|
|
||||||
|
respJSON, err := b.sendCommand("getChatMembersCount", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Result int
|
Result int
|
||||||
Description string `json:"description"`
|
Description string `json:"description"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, errors.Wrap(err, "bad response json")
|
return 0, errors.Wrap(err, "bad response json")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return 0, errors.Errorf("api error: %s", responseRecieved.Description)
|
return 0, errors.Errorf("api error: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return responseRecieved.Result, nil
|
return resp.Result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetUserProfilePhotos return list of profile pictures for a user.
|
// GetUserProfilePhotos return list of profile pictures for a user.
|
||||||
//
|
//
|
||||||
// Returns a UserProfilePhotos object.
|
// Returns a list[photos][sizes].
|
||||||
func (b *Bot) GetUserProfilePhotos(recipient Recipient) (UserProfilePhotos, error) {
|
func (b *Bot) GetUserProfilePhotos(recipient Recipient) ([][]Photo, error) {
|
||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"user_id": recipient.Destination(),
|
"user_id": recipient.Destination(),
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("getUserProfilePhotos", params)
|
|
||||||
|
respJSON, err := b.sendCommand("getUserProfilePhotos", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return UserProfilePhotos{}, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Result UserProfilePhotos
|
Result struct {
|
||||||
|
Count int `json:"total_count"`
|
||||||
|
Photos [][]Photo `json:"photos"`
|
||||||
|
}
|
||||||
|
|
||||||
Description string `json:"description"`
|
Description string `json:"description"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return UserProfilePhotos{}, errors.Wrap(err, "bad response json")
|
return nil, errors.Wrap(err, "bad response json")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return UserProfilePhotos{}, errors.Errorf("api error: %s", responseRecieved.Description)
|
return nil, errors.Errorf("api error: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return responseRecieved.Result, nil
|
return resp.Result.Photos, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetChatMember return information about a member of a chat.
|
// GetChatMember return information about a member of a chat.
|
||||||
//
|
//
|
||||||
// Returns a ChatMember object on success.
|
// Returns a ChatMember object on success.
|
||||||
func (b *Bot) GetChatMember(recipient Recipient, user User) (ChatMember, error) {
|
func (b *Bot) GetChatMember(recipient Recipient, user User) (*ChatMember, error) {
|
||||||
params := map[string]string{
|
params := map[string]string{
|
||||||
"chat_id": recipient.Destination(),
|
"chat_id": recipient.Destination(),
|
||||||
"user_id": user.Destination(),
|
"user_id": user.Destination(),
|
||||||
}
|
}
|
||||||
responseJSON, err := b.sendCommand("getChatMember", params)
|
|
||||||
|
respJSON, err := b.sendCommand("getChatMember", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ChatMember{}, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Result ChatMember
|
Result *ChatMember
|
||||||
Description string `json:"description"`
|
Description string `json:"description"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ChatMember{}, errors.Wrap(err, "bad response json")
|
return nil, errors.Wrap(err, "bad response json")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return ChatMember{}, errors.Errorf("api error: %s", responseRecieved.Description)
|
return nil, errors.Errorf("api error: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return responseRecieved.Result, nil
|
return resp.Result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetFileDirectURL returns direct url for files using FileId which you can get from File object
|
// GetFileDirectURL returns direct url for files using FileId which you can get from File object
|
||||||
@ -563,27 +481,27 @@ func (b *Bot) EditMessageText(recipient Recipient, messageID int, message string
|
|||||||
embedSendOptions(params, sendOptions)
|
embedSendOptions(params, sendOptions)
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("editMessageText", params)
|
respJSON, err := b.sendCommand("editMessageText", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Message Message `json:"result"`
|
Message Message `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return nil, fmt.Errorf("telebot: %s", responseRecieved.Description)
|
return nil, fmt.Errorf("telebot: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &responseRecieved.Message, err
|
return &resp.Message, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -600,27 +518,27 @@ func (b *Bot) EditInlineMessageText(messageID string, message string, sendOption
|
|||||||
embedSendOptions(params, sendOptions)
|
embedSendOptions(params, sendOptions)
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("editMessageText", params)
|
respJSON, err := b.sendCommand("editMessageText", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Message Message `json:"result"`
|
Message Message `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return nil, fmt.Errorf("telebot: %s", responseRecieved.Description)
|
return nil, fmt.Errorf("telebot: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &responseRecieved.Message, err
|
return &resp.Message, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -642,27 +560,27 @@ func (b *Bot) EditMessageCaption(recipient Recipient, messageID int, caption str
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("editMessageCaption", params)
|
respJSON, err := b.sendCommand("editMessageCaption", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Message Message `json:"result"`
|
Message Message `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return nil, fmt.Errorf("telebot: %s", responseRecieved.Description)
|
return nil, fmt.Errorf("telebot: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &responseRecieved.Message, err
|
return &resp.Message, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -683,27 +601,27 @@ func (b *Bot) EditInlineMessageCaption(messageID string, caption string, inlineK
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("editMessageCaption", params)
|
respJSON, err := b.sendCommand("editMessageCaption", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Message Message `json:"result"`
|
Message Message `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return nil, fmt.Errorf("telebot: %s", responseRecieved.Description)
|
return nil, fmt.Errorf("telebot: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &responseRecieved.Message, err
|
return &resp.Message, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -724,27 +642,27 @@ func (b *Bot) EditMessageReplyMarkup(recipient Recipient, messageID int, inlineK
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("editMessageReplyMarkup", params)
|
respJSON, err := b.sendCommand("editMessageReplyMarkup", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Message Message `json:"result"`
|
Message Message `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return nil, fmt.Errorf("telebot: %s", responseRecieved.Description)
|
return nil, fmt.Errorf("telebot: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &responseRecieved.Message, err
|
return &resp.Message, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -764,26 +682,26 @@ func (b *Bot) EditInlineMessageReplyMarkup(messageID string, caption string, inl
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
responseJSON, err := b.sendCommand("editMessageReplyMarkup", params)
|
respJSON, err := b.sendCommand("editMessageReplyMarkup", params)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var responseRecieved struct {
|
var resp struct {
|
||||||
Ok bool
|
Ok bool
|
||||||
Description string
|
Description string
|
||||||
Message Message `json:"result"`
|
Message Message `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
err = json.Unmarshal(responseJSON, &responseRecieved)
|
err = json.Unmarshal(respJSON, &resp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !responseRecieved.Ok {
|
if !resp.Ok {
|
||||||
return nil, fmt.Errorf("telebot: %s", responseRecieved.Description)
|
return nil, fmt.Errorf("telebot: %s", resp.Description)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &responseRecieved.Message, err
|
return &resp.Message, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
14
telebot.go
14
telebot.go
@ -36,8 +36,10 @@ const (
|
|||||||
UploadingVideo ChatAction = "upload_video"
|
UploadingVideo ChatAction = "upload_video"
|
||||||
UploadingAudio ChatAction = "upload_audio"
|
UploadingAudio ChatAction = "upload_audio"
|
||||||
UploadingDocument ChatAction = "upload_document"
|
UploadingDocument ChatAction = "upload_document"
|
||||||
|
UploadingVNote ChatAction = "upload_video_note"
|
||||||
RecordingVideo ChatAction = "record_video"
|
RecordingVideo ChatAction = "record_video"
|
||||||
RecordingAudio ChatAction = "record_audio"
|
RecordingAudio ChatAction = "record_audio"
|
||||||
|
RecordingVNote ChatAction = "record_video_note"
|
||||||
FindingLocation ChatAction = "find_location"
|
FindingLocation ChatAction = "find_location"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -76,3 +78,15 @@ const (
|
|||||||
ChatSuperGroup ChatType = "supergroup"
|
ChatSuperGroup ChatType = "supergroup"
|
||||||
ChatChannel ChatType = "channel"
|
ChatChannel ChatType = "channel"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// MemberStatus is one's chat status
|
||||||
|
type MemberStatus string
|
||||||
|
|
||||||
|
const (
|
||||||
|
Creator MemberStatus = "creator"
|
||||||
|
Administrator MemberStatus = "administrator"
|
||||||
|
Member MemberStatus = "member"
|
||||||
|
Restricted MemberStatus = "restricted"
|
||||||
|
Left MemberStatus = "left"
|
||||||
|
Kicked MemberStatus = "kicked"
|
||||||
|
)
|
||||||
|
26
types.go
26
types.go
@ -267,15 +267,23 @@ type CallbackResponse struct {
|
|||||||
|
|
||||||
// ChatMember object represents information about a single chat member.
|
// ChatMember object represents information about a single chat member.
|
||||||
type ChatMember struct {
|
type ChatMember struct {
|
||||||
User User `json:"user"`
|
User *User `json:"user"`
|
||||||
Status string `json:"status"`
|
Status MemberStatus `json:"status"`
|
||||||
}
|
|
||||||
|
|
||||||
// UserProfilePhotos object represent a user's profile pictures.
|
// Due for banned/restricted, Unixtime.
|
||||||
type UserProfilePhotos struct {
|
Until int64 `json:"until_date,omitempty"`
|
||||||
// Total number of profile pictures the target user has.
|
|
||||||
Count int `json:"total_count"`
|
|
||||||
|
|
||||||
// Requested profile pictures (in up to 4 sizes each).
|
CanBeEdited bool `json:"can_be_edited,omitempty"`
|
||||||
Photos [][]Photo `json:"photos"`
|
CanChangeInfo bool `json:"can_change_info,omitempty"`
|
||||||
|
CanPostMessages bool `json:"can_post_messages,omitempty"`
|
||||||
|
CanEditMessages bool `json:"can_edit_messages,omitempty"`
|
||||||
|
CanDeleteMessages bool `json:"can_delete_messages,omitempty"`
|
||||||
|
CanInviteUsers bool `json:"can_invite_users,omitempty"`
|
||||||
|
CanRestrictMembers bool `json:"can_restrict_members,omitempty"`
|
||||||
|
CanPinMessages bool `json:"can_pin_messages,omitempty"`
|
||||||
|
CanPromoteMembers bool `json:"can_promote_members,omitempty"`
|
||||||
|
CanSendMessages bool `json:"can_send_messages,omitempty"`
|
||||||
|
CanSendMedia bool `json:"can_send_media_messages,omitempty"`
|
||||||
|
CanSendOther bool `json:"can_send_other_messages,omitempty"`
|
||||||
|
CanAddPreviews bool `json:"can_add_web_page_previews,omitempty"`
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user