mirror of
https://salsa.debian.org/mdosch/feed-to-muc.git
synced 2024-11-22 22:18:39 +01:00
Cleaned up merging gone wild.
This commit is contained in:
parent
95129fda2c
commit
ba3e4a7f67
1 changed files with 0 additions and 245 deletions
245
main.go
245
main.go
|
@ -103,248 +103,3 @@ func main() {
|
||||||
time.Sleep(config.RefreshTime * time.Second)
|
time.Sleep(config.RefreshTime * time.Second)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
<<<<<<< HEAD
|
|
||||||
|
|
||||||
// Send a ping every 30 seconds after last successful ping to check if the MUC is still available.
|
|
||||||
func pingMUC(client *xmpp.Client, botJid string, muc string, mucNick string) {
|
|
||||||
for {
|
|
||||||
time.Sleep(30 * time.Second)
|
|
||||||
|
|
||||||
// Send ping to own MUC participant to check we are still joined.
|
|
||||||
id, err = client.RawInformation(botJid, muc+"/"+mucNick, sid.Id(),
|
|
||||||
"get", "<ping xmlns='urn:xmpp:ping'/>")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Can't send MUC self ping: ", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
pingSent = time.Now()
|
|
||||||
pingReceived = false
|
|
||||||
|
|
||||||
// Check for result IQ as long as there was no reply yet.
|
|
||||||
for (time.Since(pingSent).Seconds() < 10.0) && !pingReceived {
|
|
||||||
time.Sleep(1 * time.Second)
|
|
||||||
if pingReceived {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
// Quit if no ping reply was received.
|
|
||||||
if !pingReceived {
|
|
||||||
log.Fatal("MUC not available.")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Send a ping to the server every 30 seconds to check if the connection is still alive.
|
|
||||||
func pingServer(client *xmpp.Client, server string, botJid string) {
|
|
||||||
for {
|
|
||||||
time.Sleep(30 * time.Second)
|
|
||||||
|
|
||||||
// Send ping to server to check if connection still exists.
|
|
||||||
err := client.PingC2S(botJid, strings.Split(server, ":")[0])
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Client2Server ping failed:", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func processStanzas(client *xmpp.Client, muc string, mucNick string, feeds []string, quiet bool, contact string) {
|
|
||||||
for { // Receive stanzas. ToDo: Receive stanzas continiously without 30s delay.
|
|
||||||
stanza, err := client.Recv()
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed receiving Stanzas:", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check stanzas, maybe we want to reply.
|
|
||||||
switch v := stanza.(type) {
|
|
||||||
// Reply to requests for source and feeds.
|
|
||||||
case xmpp.Chat:
|
|
||||||
var command string
|
|
||||||
|
|
||||||
// Check for room mention of the bots nick if the the message type is groupchat.
|
|
||||||
if v.Type == "groupchat" {
|
|
||||||
// Leave if option quiet is set.
|
|
||||||
if quiet {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
// Get first word of the message and transform it to lower case.
|
|
||||||
mention := strings.ToLower(strings.Split(v.Text, " ")[0])
|
|
||||||
|
|
||||||
// If it is not the bots nick remove one trailing character as
|
|
||||||
// a lot of clients append `:` or `,` to mentions.
|
|
||||||
if mention != strings.ToLower(mucNick) {
|
|
||||||
mentionLength := len(mention)
|
|
||||||
// Leave if mentionLength is <= 0
|
|
||||||
if mentionLength <= 0 {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
mention = mention[:mentionLength-1]
|
|
||||||
// Leave if the message is not addressed to the bot.
|
|
||||||
if mention != strings.ToLower(mucNick) {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// As the first word is the mention of the bots nickname, the command is
|
|
||||||
// the second word in a groupchat message.
|
|
||||||
command = strings.ToLower(strings.Split(v.Text, " ")[1])
|
|
||||||
// If the message type is chat (e.g. private message), the command is the
|
|
||||||
// first word.
|
|
||||||
} else if v.Type == "chat" {
|
|
||||||
command = strings.ToLower(strings.Split(v.Text, " ")[0])
|
|
||||||
} else {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check for the command.
|
|
||||||
switch command {
|
|
||||||
|
|
||||||
// Reply with a short summary of available commands for `help`.
|
|
||||||
case "help":
|
|
||||||
|
|
||||||
reply := "The following commands are available:\n" +
|
|
||||||
"\"contact\": Show contact for this bot.\n" +
|
|
||||||
"\"feeds\": List feeds I'm following.\n" +
|
|
||||||
"\"ping\": Sends back a pong.\n" +
|
|
||||||
"\"source\": Show source code URL."
|
|
||||||
|
|
||||||
if v.Type == "groupchat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: muc,
|
|
||||||
Type: "groupchat", Text: strings.Split(v.Remote, "/")[1] + ": " + reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to MUC:", err)
|
|
||||||
}
|
|
||||||
} else if v.Type == "chat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: v.Remote,
|
|
||||||
Type: "chat", Text: reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to ", v.Remote, ": ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reply with repo address for `source`.
|
|
||||||
case "source":
|
|
||||||
|
|
||||||
reply := "My source can be found at " +
|
|
||||||
"https://salsa.debian.org/mdosch-guest/feed-to-muc"
|
|
||||||
|
|
||||||
if v.Type == "groupchat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: muc,
|
|
||||||
Type: "groupchat", Text: strings.Split(v.Remote, "/")[1] + ": " + reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to MUC:", err)
|
|
||||||
}
|
|
||||||
} else if v.Type == "chat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: v.Remote,
|
|
||||||
Type: "chat", Text: reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to ", v.Remote, ": ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Reply with the list of monitored feeds for `feeds`.
|
|
||||||
case "feeds":
|
|
||||||
var feedList string
|
|
||||||
for _, feed := range feeds {
|
|
||||||
// Add next feed element and a newline.
|
|
||||||
feedList = feedList + feed + "\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
reply := "Feeds I'm following:\n" + feedList
|
|
||||||
|
|
||||||
if v.Type == "groupchat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: muc,
|
|
||||||
Type: "groupchat", Text: strings.Split(v.Remote, "/")[1] + ": " + reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to MUC:", err)
|
|
||||||
}
|
|
||||||
} else if v.Type == "chat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: v.Remote,
|
|
||||||
Type: "chat", Text: reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to ", v.Remote, ": ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
case "ping":
|
|
||||||
|
|
||||||
reply := "pong"
|
|
||||||
|
|
||||||
if v.Type == "groupchat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: muc,
|
|
||||||
Type: "groupchat", Text: strings.Split(v.Remote, "/")[1] + ": " + reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to MUC:", err)
|
|
||||||
}
|
|
||||||
} else if v.Type == "chat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: v.Remote,
|
|
||||||
Type: "chat", Text: reply})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to ", v.Remote, ": ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
case "contact":
|
|
||||||
|
|
||||||
if contact == "" {
|
|
||||||
contact = "Sorry, no contact information provided."
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.Type == "groupchat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: muc,
|
|
||||||
Type: "groupchat", Text: strings.Split(v.Remote, "/")[1] + ": " + contact})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to MUC:", err)
|
|
||||||
}
|
|
||||||
} else if v.Type == "chat" {
|
|
||||||
_, err = client.Send(xmpp.Chat{Remote: v.Remote,
|
|
||||||
Type: "chat", Text: contact})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed sending message to ", v.Remote, ": ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reply to pings and disco queries.
|
|
||||||
case xmpp.IQ:
|
|
||||||
if (v.Type == "error") && (v.ID == id) {
|
|
||||||
log.Fatal("MUC not available.")
|
|
||||||
}
|
|
||||||
|
|
||||||
if (v.Type == "result") && (v.ID == id) {
|
|
||||||
pingReceived = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if v.Type == "get" {
|
|
||||||
// Reply to disco#info requests according to https://xmpp.org/extensions/xep-0030.html.
|
|
||||||
if strings.Contains(string(v.Query),
|
|
||||||
"<query xmlns='http://jabber.org/protocol/disco#info'/>") {
|
|
||||||
_, err := client.RawInformation(client.JID(), v.From, v.ID,
|
|
||||||
"result", "<query xmlns='http://jabber.org/protocol/disco#info'>"+
|
|
||||||
"<identity category='client' type='bot' name='feedbot'/>"+
|
|
||||||
"<feature var='http://jabber.org/protocol/disco#info'/></query>")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed to reply to disco#info:", err)
|
|
||||||
}
|
|
||||||
} else if strings.Contains(string(v.Query), "<ping xmlns='urn:xmpp:ping'/>") {
|
|
||||||
// Reply to pings.
|
|
||||||
_, err := client.RawInformation(client.JID(), v.From, v.ID, "result", "")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed to reply to ping:", err)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Send error replies for all other IQs.
|
|
||||||
_, err := client.RawInformation(client.JID(), v.From, v.ID, "error",
|
|
||||||
"<error type='cancel'><service-unavailable "+
|
|
||||||
"xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/></error>")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal("Error: Failed to send error IQ:", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
=======
|
|
||||||
>>>>>>> 62dfe9d... Distributed the code on several files to get a better overview.
|
|
||||||
|
|
Loading…
Reference in a new issue