Kaynağa Gözat

Telegram: add the possibility to disable buttons

Closes #2093
Jany 2 yıl önce
ebeveyn
işleme
e0e8a99abe

+ 7 - 0
internal/database/migrations.go

@@ -776,4 +776,11 @@ var migrations = []func(tx *sql.Tx) error{
 		_, err = tx.Exec(sql)
 		return err
 	},
+	func(tx *sql.Tx) (err error) {
+		sql := `
+			ALTER TABLE integrations ADD COLUMN telegram_bot_disable_buttons bool default 'f';
+		`
+		_, err = tx.Exec(sql)
+		return err
+	},
 }

+ 1 - 0
internal/integration/integration.go

@@ -354,6 +354,7 @@ func PushEntries(feed *model.Feed, entries model.Entries, userIntegrations *mode
 					userIntegrations.TelegramBotTopicID,
 					userIntegrations.TelegramBotDisableWebPagePreview,
 					userIntegrations.TelegramBotDisableNotification,
+					userIntegrations.TelegramBotDisableButtons,
 				); err != nil {
 					slog.Error("Unable to send entry to Telegram",
 						slog.Int64("user_id", userIntegrations.UserID),

+ 12 - 10
internal/integration/telegrambot/telegrambot.go

@@ -9,7 +9,7 @@ import (
 	"miniflux.app/v2/internal/model"
 )
 
-func PushEntry(feed *model.Feed, entry *model.Entry, botToken, chatID string, topicID *int64, disableWebPagePreview, disableNotification bool) error {
+func PushEntry(feed *model.Feed, entry *model.Entry, botToken, chatID string, topicID *int64, disableWebPagePreview, disableNotification bool, disableButtons bool) error {
 	textTemplate := `<b><a href=%q>%s</a></b> - <a href=%q>%s</a>`
 	formattedText := fmt.Sprintf(
 		textTemplate,
@@ -31,18 +31,20 @@ func PushEntry(feed *model.Feed, entry *model.Entry, botToken, chatID string, to
 		message.MessageThreadID = *topicID
 	}
 
-	var markupRow []*InlineKeyboardButton
+	if !disableButtons {
+		var markupRow []*InlineKeyboardButton
 
-	minifluxURLButton := InlineKeyboardButton{Text: "Go to article", URL: entry.URL}
-	markupRow = append(markupRow, &minifluxURLButton)
+		minifluxURLButton := InlineKeyboardButton{Text: "Go to article", URL: entry.URL}
+		markupRow = append(markupRow, &minifluxURLButton)
 
-	if entry.CommentsURL != "" {
-		commentButton := InlineKeyboardButton{Text: "Comments", URL: entry.CommentsURL}
-		markupRow = append(markupRow, &commentButton)
-	}
+		if entry.CommentsURL != "" {
+			commentButton := InlineKeyboardButton{Text: "Comments", URL: entry.CommentsURL}
+			markupRow = append(markupRow, &commentButton)
+		}
 
-	message.ReplyMarkup = &InlineKeyboard{}
-	message.ReplyMarkup.InlineKeyboard = append(message.ReplyMarkup.InlineKeyboard, markupRow)
+		message.ReplyMarkup = &InlineKeyboard{}
+		message.ReplyMarkup.InlineKeyboard = append(message.ReplyMarkup.InlineKeyboard, markupRow)
+	}
 
 	client := NewClient(botToken, chatID)
 	_, err := client.SendMessage(message)

+ 1 - 0
internal/locale/translations/de_DE.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Artikel in Linkding speichern",
     "form.integration.linkding_endpoint": "Linkding API-Endpunkt",
     "form.integration.linkding_api_key": "Linkding API-Schlüssel",

+ 1 - 0
internal/locale/translations/el_EL.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Αποθήκευση άρθρων στο Linkding",
     "form.integration.linkding_endpoint": "Τελικό σημείο Linkding API",
     "form.integration.linkding_api_key": "Κλειδί API Linkding",

+ 1 - 0
internal/locale/translations/en_US.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Save entries to Linkding",
     "form.integration.linkding_endpoint": "Linkding API Endpoint",
     "form.integration.linkding_api_key": "Linkding API key",

+ 1 - 0
internal/locale/translations/es_ES.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Enviar artículos a Linkding",
     "form.integration.linkding_endpoint": "Acceso API de Linkding",
     "form.integration.linkding_api_key": "Clave de API de Linkding",

+ 1 - 0
internal/locale/translations/fi_FI.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Tallenna artikkelit Linkkiin",
     "form.integration.linkding_endpoint": "Linkding API-päätepiste",
     "form.integration.linkding_api_key": "Linkding API-avain",

+ 1 - 0
internal/locale/translations/fr_FR.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Identifiant du sujet (Topic ID)",
     "form.integration.telegram_bot_disable_web_page_preview": "Désactiver l'aperçu de la page Web",
     "form.integration.telegram_bot_disable_notification": "Désactiver les notifications",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Sauvegarder les articles vers Linkding",
     "form.integration.linkding_endpoint": "URL de l'API de Linkding",
     "form.integration.linkding_api_key": "Clé d'API de Linkding",

+ 1 - 0
internal/locale/translations/hi_IN.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "लिंक्डिन में विषयवस्तु सहेजें",
     "form.integration.linkding_endpoint": "लिंकिंग एपीआई समापन बिंदु",
     "form.integration.linkding_api_key": "लिंकिंग एपीआई कुंजी",

+ 1 - 0
internal/locale/translations/id_ID.json

@@ -379,6 +379,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Simpan artikel ke Linkding",
     "form.integration.linkding_endpoint": "Titik URL API Linkding",
     "form.integration.linkding_api_key": "Kunci API Linkding",

+ 1 - 0
internal/locale/translations/it_IT.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Salva gli articoli su Linkding",
     "form.integration.linkding_endpoint": "Endpoint dell'API di Linkding",
     "form.integration.linkding_api_key": "API key dell'account Linkding",

+ 1 - 0
internal/locale/translations/ja_JP.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Linkding に記事を保存する",
     "form.integration.linkding_endpoint": "Linkding の API Endpoint",
     "form.integration.linkding_api_key": "Linkding の API key",

+ 1 - 0
internal/locale/translations/nl_NL.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Opslaan naar Linkding",
     "form.integration.linkding_endpoint": "Linkding URL",
     "form.integration.linkding_api_key": "Linkding API-sleutel",

+ 1 - 0
internal/locale/translations/pl_PL.json

@@ -384,6 +384,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Zapisz artykuły do Linkding",
     "form.integration.linkding_endpoint": "Linkding URL",
     "form.integration.linkding_api_key": "Linkding API key",

+ 1 - 0
internal/locale/translations/pt_BR.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Salvar itens no Linkding",
     "form.integration.linkding_endpoint": "Endpoint de API do Linkding",
     "form.integration.linkding_api_key": "Chave de API do Linkding",

+ 1 - 0
internal/locale/translations/ru_RU.json

@@ -384,6 +384,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Сохранять статьи в Linkding",
     "form.integration.linkding_endpoint": "Конечная точка Linkding API",
     "form.integration.linkding_api_key": "API-ключ Linkding",

+ 1 - 0
internal/locale/translations/tr_TR.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "Makaleleri Linkding'e kaydet",
     "form.integration.linkding_endpoint": "Linkding API Uç Noktası",
     "form.integration.linkding_api_key": "Linkding API Anahtarı",

+ 2 - 1
internal/locale/translations/uk_UA.json

@@ -384,6 +384,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.telegram_chat_id": "ID чату",
     "form.integration.linkding_activate": "Зберігати статті до Linkding",
     "form.integration.linkding_endpoint": "Linkding API Endpoint",
@@ -441,4 +442,4 @@
         "%d роки тому",
         "%d років тому"
     ]
-}
+}

+ 1 - 0
internal/locale/translations/zh_CN.json

@@ -379,6 +379,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.telegram_chat_id": "聊天ID",
     "form.integration.linkding_activate": "保存文章到 Linkding",
     "form.integration.linkding_endpoint": "Linkding API 端点",

+ 1 - 0
internal/locale/translations/zh_TW.json

@@ -382,6 +382,7 @@
     "form.integration.telegram_topic_id": "Topic ID",
     "form.integration.telegram_bot_disable_web_page_preview": "Disable web page preview",
     "form.integration.telegram_bot_disable_notification": "Disable notification",
+    "form.integration.telegram_bot_disable_buttons": "Disable buttons",
     "form.integration.linkding_activate": "儲存文章到 Linkding",
     "form.integration.linkding_endpoint": "Linkding API 端點",
     "form.integration.linkding_api_key": "Linkding API 金鑰",

+ 1 - 0
internal/model/integration.go

@@ -47,6 +47,7 @@ type Integration struct {
 	TelegramBotTopicID               *int64
 	TelegramBotDisableWebPagePreview bool
 	TelegramBotDisableNotification   bool
+	TelegramBotDisableButtons        bool
 	LinkdingEnabled                  bool
 	LinkdingURL                      string
 	LinkdingAPIKey                   string

+ 37 - 33
internal/storage/integration.go

@@ -151,6 +151,7 @@ func (s *Storage) Integration(userID int64) (*model.Integration, error) {
 			telegram_bot_topic_id,
 			telegram_bot_disable_web_page_preview,
 			telegram_bot_disable_notification,
+			telegram_bot_disable_buttons,
 			linkding_enabled,
 			linkding_url,
 			linkding_api_key,
@@ -223,6 +224,7 @@ func (s *Storage) Integration(userID int64) (*model.Integration, error) {
 		&integration.TelegramBotTopicID,
 		&integration.TelegramBotDisableWebPagePreview,
 		&integration.TelegramBotDisableNotification,
+		&integration.TelegramBotDisableButtons,
 		&integration.LinkdingEnabled,
 		&integration.LinkdingURL,
 		&integration.LinkdingAPIKey,
@@ -295,40 +297,41 @@ func (s *Storage) UpdateIntegration(integration *model.Integration) error {
 			telegram_bot_topic_id=$30,
 			telegram_bot_disable_web_page_preview=$31,
 			telegram_bot_disable_notification=$32,
-			espial_enabled=$33,
-			espial_url=$34,
-			espial_api_key=$35,
-			espial_tags=$36,
-			linkding_enabled=$37,
-			linkding_url=$38,
-			linkding_api_key=$39,
-			linkding_tags=$40,
-			linkding_mark_as_unread=$41,
-			matrix_bot_enabled=$42,
-			matrix_bot_user=$43,
-			matrix_bot_password=$44,
-			matrix_bot_url=$45,
-			matrix_bot_chat_id=$46,
-			notion_enabled=$47,
-			notion_token=$48,
-			notion_page_id=$49,
-			readwise_enabled=$50,
-			readwise_api_key=$51,
-			apprise_enabled=$52,
-			apprise_url=$53,
-			apprise_services_url=$54,
-			shiori_enabled=$55,
-			shiori_url=$56,
-			shiori_username=$57,
-			shiori_password=$58,
-			shaarli_enabled=$59,
-			shaarli_url=$60,
-			shaarli_api_secret=$61,
-			webhook_enabled=$62,
-			webhook_url=$63,
-			webhook_secret=$64
+			telegram_bot_disable_buttons=$33,
+			espial_enabled=$34,
+			espial_url=$35,
+			espial_api_key=$36,
+			espial_tags=$37,
+			linkding_enabled=$38,
+			linkding_url=$39,
+			linkding_api_key=$40,
+			linkding_tags=$41,
+			linkding_mark_as_unread=$42,
+			matrix_bot_enabled=$43,
+			matrix_bot_user=$44,
+			matrix_bot_password=$45,
+			matrix_bot_url=$46,
+			matrix_bot_chat_id=$47,
+			notion_enabled=$48,
+			notion_token=$49,
+			notion_page_id=$50,
+			readwise_enabled=$51,
+			readwise_api_key=$52,
+			apprise_enabled=$53,
+			apprise_url=$54,
+			apprise_services_url=$55,
+			shiori_enabled=$56,
+			shiori_url=$57,
+			shiori_username=$58,
+			shiori_password=$59,
+			shaarli_enabled=$60,
+			shaarli_url=$61,
+			shaarli_api_secret=$62,
+			webhook_enabled=$63,
+			webhook_url=$64,
+			webhook_secret=$65
 		WHERE
-			user_id=$65
+			user_id=$66
 	`
 	_, err := s.db.Exec(
 		query,
@@ -364,6 +367,7 @@ func (s *Storage) UpdateIntegration(integration *model.Integration) error {
 		integration.TelegramBotTopicID,
 		integration.TelegramBotDisableWebPagePreview,
 		integration.TelegramBotDisableNotification,
+		integration.TelegramBotDisableButtons,
 		integration.EspialEnabled,
 		integration.EspialURL,
 		integration.EspialAPIKey,

+ 4 - 0
internal/template/templates/views/integrations.html

@@ -339,6 +339,10 @@
                 <input type="checkbox" name="telegram_bot_disable_notification" value="1" {{ if .form.TelegramBotDisableNotification }}checked{{ end }}> {{ t "form.integration.telegram_bot_disable_notification" }}
             </label>
 
+            <label>
+                <input type="checkbox" name="telegram_bot_disable_buttons" value="1" {{ if .form.TelegramBotDisableButtons }}checked{{ end }}> {{ t "form.integration.telegram_bot_disable_buttons" }}
+            </label>
+
             <div class="buttons">
                 <button type="submit" class="button button-primary" data-label-loading="{{ t "form.submit.saving" }}">{{ t "action.update" }}</button>
             </div>

+ 3 - 0
internal/ui/form/integration.go

@@ -53,6 +53,7 @@ type IntegrationForm struct {
 	TelegramBotTopicID               *int64
 	TelegramBotDisableWebPagePreview bool
 	TelegramBotDisableNotification   bool
+	TelegramBotDisableButtons        bool
 	LinkdingEnabled                  bool
 	LinkdingURL                      string
 	LinkdingAPIKey                   string
@@ -119,6 +120,7 @@ func (i IntegrationForm) Merge(integration *model.Integration) {
 	integration.TelegramBotTopicID = i.TelegramBotTopicID
 	integration.TelegramBotDisableWebPagePreview = i.TelegramBotDisableWebPagePreview
 	integration.TelegramBotDisableNotification = i.TelegramBotDisableNotification
+	integration.TelegramBotDisableButtons = i.TelegramBotDisableButtons
 	integration.LinkdingEnabled = i.LinkdingEnabled
 	integration.LinkdingURL = i.LinkdingURL
 	integration.LinkdingAPIKey = i.LinkdingAPIKey
@@ -187,6 +189,7 @@ func NewIntegrationForm(r *http.Request) *IntegrationForm {
 		TelegramBotTopicID:               optionalInt64Field(r.FormValue("telegram_bot_topic_id")),
 		TelegramBotDisableWebPagePreview: r.FormValue("telegram_bot_disable_web_page_preview") == "1",
 		TelegramBotDisableNotification:   r.FormValue("telegram_bot_disable_notification") == "1",
+		TelegramBotDisableButtons:        r.FormValue("telegram_bot_disable_buttons") == "1",
 		LinkdingEnabled:                  r.FormValue("linkding_enabled") == "1",
 		LinkdingURL:                      r.FormValue("linkding_url"),
 		LinkdingAPIKey:                   r.FormValue("linkding_api_key"),

+ 1 - 0
internal/ui/integration_show.go

@@ -67,6 +67,7 @@ func (h *handler) showIntegrationPage(w http.ResponseWriter, r *http.Request) {
 		TelegramBotTopicID:               integration.TelegramBotTopicID,
 		TelegramBotDisableWebPagePreview: integration.TelegramBotDisableWebPagePreview,
 		TelegramBotDisableNotification:   integration.TelegramBotDisableNotification,
+		TelegramBotDisableButtons:        integration.TelegramBotDisableButtons,
 		LinkdingEnabled:                  integration.LinkdingEnabled,
 		LinkdingURL:                      integration.LinkdingURL,
 		LinkdingAPIKey:                   integration.LinkdingAPIKey,