Merge branch 'master' of github.com:youaresofunny/got

pull/281/head
Sergey Parshukov 6 years ago
commit b2775f9bda
No known key found for this signature in database
GPG Key ID: 9D0FB8D5E702923A
  1. 3
      configs.go
  2. 9
      helpers.go
  3. 12
      types.go

@ -178,6 +178,9 @@ func (edit BaseEdit) values() (url.Values, error) {
} }
if edit.ReplyMarkup != nil { if edit.ReplyMarkup != nil {
if len(edit.ReplyMarkup.InlineKeyboard) == 0 {
edit.ReplyMarkup.InlineKeyboard = make([][]InlineKeyboardButton, 0)
}
data, err := json.Marshal(edit.ReplyMarkup) data, err := json.Marshal(edit.ReplyMarkup)
if err != nil { if err != nil {
return v, err return v, err

@ -722,6 +722,15 @@ func NewInlineKeyboardButtonURL(text, url string) InlineKeyboardButton {
} }
} }
// NewInlineKeyboardButtonLoginURL creates an inline keyboard button with text
// which allows user to login into provided LoginURL.
func NewInlineKeyboardButtonLoginURL(text string, loginURL *LoginURL) InlineKeyboardButton {
return InlineKeyboardButton{
Text: text,
LoginURL: loginURL,
}
}
// NewInlineKeyboardButtonSwitch creates an inline keyboard button with // NewInlineKeyboardButtonSwitch creates an inline keyboard button with
// text which allows the user to switch to a chat or return to a chat. // text which allows the user to switch to a chat or return to a chat.
func NewInlineKeyboardButtonSwitch(text, sw string) InlineKeyboardButton { func NewInlineKeyboardButtonSwitch(text, sw string) InlineKeyboardButton {

@ -171,6 +171,9 @@ type Message struct {
Invoice *Invoice `json:"invoice"` // optional Invoice *Invoice `json:"invoice"` // optional
SuccessfulPayment *SuccessfulPayment `json:"successful_payment"` // optional SuccessfulPayment *SuccessfulPayment `json:"successful_payment"` // optional
PassportData *PassportData `json:"passport_data,omitempty"` // optional PassportData *PassportData `json:"passport_data,omitempty"` // optional
ConnectedWebsite *string `json:"connected_website,omitempty"` // optional
ReplyMarkup *InlineKeyboardMarkup `json:"reply_markup,omitempty"` // optional
AuthorSignature string `json:"author_signature,omitempty"` // optional
} }
// Time converts the message timestamp into a Time. // Time converts the message timestamp into a Time.
@ -473,6 +476,7 @@ type InlineKeyboardMarkup struct {
type InlineKeyboardButton struct { type InlineKeyboardButton struct {
Text string `json:"text"` Text string `json:"text"`
URL *string `json:"url,omitempty"` // optional URL *string `json:"url,omitempty"` // optional
LoginURL *LoginURL `json:"login_url,omitempty"` // optional
CallbackData *string `json:"callback_data,omitempty"` // optional CallbackData *string `json:"callback_data,omitempty"` // optional
SwitchInlineQuery *string `json:"switch_inline_query,omitempty"` // optional SwitchInlineQuery *string `json:"switch_inline_query,omitempty"` // optional
SwitchInlineQueryCurrentChat *string `json:"switch_inline_query_current_chat,omitempty"` // optional SwitchInlineQueryCurrentChat *string `json:"switch_inline_query_current_chat,omitempty"` // optional
@ -572,6 +576,14 @@ type WebhookInfo struct {
LastErrorMessage string `json:"last_error_message"` // optional LastErrorMessage string `json:"last_error_message"` // optional
} }
// LoginURL contains fields that allows user to login to webpage
type LoginURL struct {
URL string `json:"url"`
ForwardText *string `json:"forward_text,omitempty"`
BotUsername *string `json:"bot_username,omitempty"`
RequestWriteAcces *bool `json:"request_write_access,omitempty"`
}
// IsSet returns true if a webhook is currently set. // IsSet returns true if a webhook is currently set.
func (info WebhookInfo) IsSet() bool { func (info WebhookInfo) IsSet() bool {
return info.URL != "" return info.URL != ""