2017-10-31 22:50:14 +05:00
|
|
|
// OpenSAPS - Open Slack API server for everyone.
|
|
|
|
//
|
|
|
|
// Copyright (c) 2017, Stanislav N. aka pztrn.
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
package telegrampusher
|
|
|
|
|
|
|
|
import (
|
|
|
|
// stdlib
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
"net/url"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
// local
|
2019-12-15 22:17:01 +05:00
|
|
|
configstruct "go.dev.pztrn.name/opensaps/config/struct"
|
|
|
|
slackmessage "go.dev.pztrn.name/opensaps/slack/message"
|
2017-10-31 22:50:14 +05:00
|
|
|
)
|
|
|
|
|
|
|
|
type TelegramConnection struct {
|
2019-03-05 18:32:34 +05:00
|
|
|
config configstruct.ConfigTelegram
|
2017-10-31 22:50:14 +05:00
|
|
|
}
|
|
|
|
|
2019-03-05 18:32:34 +05:00
|
|
|
func (tc *TelegramConnection) Initialize(connName string, cfg configstruct.ConfigTelegram) {
|
|
|
|
tc.config = cfg
|
2017-10-31 22:50:14 +05:00
|
|
|
}
|
|
|
|
|
|
|
|
func (tc *TelegramConnection) ProcessMessage(message slackmessage.SlackMessage) {
|
|
|
|
// Prepare message body.
|
2019-03-05 19:31:13 +05:00
|
|
|
messageData := c.SendToParser(message.Username, message)
|
|
|
|
|
|
|
|
messageToSend := messageData["message"].(string)
|
|
|
|
// We'll use HTML, so reformat links accordingly (if any).
|
|
|
|
linksRaw, linksFound := messageData["links"]
|
|
|
|
if linksFound {
|
|
|
|
links := linksRaw.([][]string)
|
|
|
|
for _, link := range links {
|
2019-03-06 05:08:00 +05:00
|
|
|
messageToSend = strings.Replace(messageToSend, link[0], `<a href="`+link[1]+`">`+link[2]+`</a>`, -1)
|
2017-10-31 22:50:14 +05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-05 19:31:13 +05:00
|
|
|
c.Log.Debugln("Crafted message:", messageToSend)
|
2017-10-31 22:50:14 +05:00
|
|
|
|
|
|
|
// Send message.
|
2019-03-05 19:31:13 +05:00
|
|
|
tc.SendMessage(messageToSend)
|
2017-10-31 22:50:14 +05:00
|
|
|
}
|
|
|
|
|
|
|
|
func (tc *TelegramConnection) SendMessage(message string) {
|
|
|
|
msgdata := url.Values{}
|
2019-03-05 18:32:34 +05:00
|
|
|
msgdata.Set("chat_id", tc.config.ChatID)
|
2017-10-31 22:50:14 +05:00
|
|
|
msgdata.Set("text", message)
|
|
|
|
msgdata.Set("parse_mode", "HTML")
|
|
|
|
|
2019-03-05 18:32:34 +05:00
|
|
|
// Are we should use proxy?
|
|
|
|
httpTransport := &http.Transport{}
|
2019-12-15 22:17:01 +05:00
|
|
|
|
2019-03-05 18:32:34 +05:00
|
|
|
if tc.config.Proxy.Enabled {
|
|
|
|
// Compose proxy URL.
|
|
|
|
proxyURL := "http://"
|
|
|
|
if tc.config.Proxy.User != "" {
|
|
|
|
proxyURL += tc.config.Proxy.User
|
|
|
|
if tc.config.Proxy.Password != "" {
|
|
|
|
proxyURL += ":" + tc.config.Proxy.Password
|
|
|
|
}
|
2019-12-15 22:17:01 +05:00
|
|
|
|
2019-03-05 18:32:34 +05:00
|
|
|
proxyURL += "@"
|
|
|
|
}
|
2019-12-15 22:17:01 +05:00
|
|
|
|
2019-03-05 18:32:34 +05:00
|
|
|
proxyURL += tc.config.Proxy.Address
|
|
|
|
|
|
|
|
proxyURLParsed, err := url.Parse(proxyURL)
|
|
|
|
if err != nil {
|
|
|
|
c.Log.Errorln("Error while constructing/parsing proxy URL:", err.Error())
|
|
|
|
} else {
|
|
|
|
httpTransport.Proxy = http.ProxyURL(proxyURLParsed)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
client := &http.Client{Transport: httpTransport}
|
2019-12-15 22:17:01 +05:00
|
|
|
botURL := fmt.Sprintf("https://api.telegram.org/bot%s/sendMessage", tc.config.BotID)
|
|
|
|
|
|
|
|
c.Log.Debugln("Bot URL:", botURL)
|
|
|
|
|
|
|
|
response, err := client.PostForm(botURL, msgdata)
|
2019-03-05 18:32:34 +05:00
|
|
|
if err != nil {
|
2019-12-15 22:17:01 +05:00
|
|
|
c.Log.Errorln("Error occurred while sending data to Telegram:", err.Error())
|
2019-03-05 18:32:34 +05:00
|
|
|
} else {
|
|
|
|
c.Log.Debugln("Status:", response.Status)
|
|
|
|
if response.StatusCode != 200 {
|
|
|
|
body := []byte{}
|
|
|
|
_, _ = response.Body.Read(body)
|
|
|
|
response.Body.Close()
|
|
|
|
c.Log.Debugln(body)
|
|
|
|
}
|
|
|
|
}
|
2017-10-31 22:50:14 +05:00
|
|
|
}
|
|
|
|
|
|
|
|
func (tc *TelegramConnection) Shutdown() {
|
|
|
|
// There is nothing we can do actually.
|
|
|
|
}
|