hook2xmpp/xmpp.go

90 lines
2.0 KiB
Go
Raw Normal View History

2019-06-25 03:26:53 +02:00
package main
import (
"github.com/bdlm/log"
"gosrc.io/xmpp"
"gosrc.io/xmpp/stanza"
2019-06-25 03:26:53 +02:00
)
var mucs []string
2019-07-15 23:49:56 +02:00
func notify(c xmpp.Sender, text string) {
msg := stanza.Message{
Attrs: stanza.Attrs{Type: stanza.MessageTypeGroupchat},
2019-06-25 03:26:53 +02:00
Body: text,
}
for _, muc := range config.StartupNotifyMuc {
msg.To = muc
2019-07-15 23:49:56 +02:00
if err := c.Send(msg); err != nil {
log.WithFields(map[string]interface{}{
"muc": muc,
"msg": text,
}).Errorf("error on startup notify: %s", err)
}
2019-06-25 03:26:53 +02:00
}
msg.Type = stanza.MessageTypeChat
2019-06-25 03:26:53 +02:00
for _, user := range config.StartupNotifyUser {
msg.To = user
2019-07-15 23:49:56 +02:00
if err := c.Send(msg); err != nil {
log.WithFields(map[string]interface{}{
"user": user,
"msg": text,
}).Errorf("error on startup notify: %s", err)
}
2019-06-25 03:26:53 +02:00
}
log.Infof("notify: %s", text)
}
2019-07-15 23:49:56 +02:00
func joinMUC(c xmpp.Sender, to, nick string) error {
2019-06-25 03:26:53 +02:00
toJID, err := xmpp.NewJid(to)
if err != nil {
return err
}
toJID.Resource = nick
jid := toJID.Full()
mucs = append(mucs, jid)
2019-07-15 23:49:56 +02:00
return c.Send(stanza.Presence{Attrs: stanza.Attrs{To: jid},
Extensions: []stanza.PresExtension{
stanza.MucPresence{
History: stanza.History{MaxStanzas: stanza.NewNullableInt(0)},
2019-06-25 03:26:53 +02:00
}},
})
}
2019-07-15 23:49:56 +02:00
func postStartup(c xmpp.Sender) {
2019-06-25 03:26:53 +02:00
for _, muc := range config.StartupNotifyMuc {
2019-07-15 23:49:56 +02:00
if err := joinMUC(c, muc, config.Nickname); err != nil {
log.WithField("muc", muc).Errorf("error on joining muc: %s", err)
}
2019-06-25 03:26:53 +02:00
}
for _, hooks := range config.Hooks {
for _, hook := range hooks {
for _, muc := range hook.NotifyMuc {
2019-07-15 23:49:56 +02:00
if err := joinMUC(c, muc, config.Nickname); err != nil {
log.WithField("muc", muc).Errorf("error on joining muc: %s", err)
}
2019-06-25 03:26:53 +02:00
}
}
}
2019-07-15 23:49:56 +02:00
notify(c, "started hock2xmpp")
2019-06-25 03:26:53 +02:00
}
2019-07-15 23:49:56 +02:00
func closeXMPP(c xmpp.Sender) {
notify(c, "stopped of hock2xmpp")
2019-06-25 03:26:53 +02:00
for _, muc := range mucs {
2019-07-15 23:49:56 +02:00
if err := c.Send(stanza.Presence{Attrs: stanza.Attrs{
2019-06-25 03:26:53 +02:00
To: muc,
Type: stanza.PresenceTypeUnavailable,
}}); err != nil {
log.WithField("muc", muc).Errorf("error on leaving muc: %s", err)
}
2019-06-25 03:26:53 +02:00
}
}