2019-06-25 03:26:53 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/bdlm/log"
|
|
|
|
"gosrc.io/xmpp"
|
2019-06-28 00:43:47 +02:00
|
|
|
"gosrc.io/xmpp/stanza"
|
2019-06-25 03:26:53 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var client *xmpp.Client
|
|
|
|
var mucs []string
|
|
|
|
|
|
|
|
func notify(text string) {
|
2019-06-28 00:43:47 +02:00
|
|
|
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-06-28 00:43:47 +02:00
|
|
|
if err := client.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
|
|
|
}
|
|
|
|
|
2019-06-28 00:43:47 +02:00
|
|
|
msg.Type = stanza.MessageTypeChat
|
2019-06-25 03:26:53 +02:00
|
|
|
for _, user := range config.StartupNotifyUser {
|
|
|
|
msg.To = user
|
2019-06-28 00:43:47 +02:00
|
|
|
if err := client.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)
|
|
|
|
}
|
|
|
|
|
|
|
|
func joinMUC(to, nick string) error {
|
|
|
|
|
|
|
|
toJID, err := xmpp.NewJid(to)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
toJID.Resource = nick
|
|
|
|
jid := toJID.Full()
|
|
|
|
|
|
|
|
mucs = append(mucs, jid)
|
|
|
|
|
2019-06-28 00:43:47 +02:00
|
|
|
return client.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
|
|
|
}},
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func postStartup(c xmpp.StreamClient) {
|
|
|
|
for _, muc := range config.StartupNotifyMuc {
|
2019-06-28 00:43:47 +02:00
|
|
|
if err := joinMUC(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-06-28 00:43:47 +02:00
|
|
|
if err := joinMUC(muc, config.Nickname); err != nil {
|
|
|
|
log.WithField("muc", muc).Errorf("error on joining muc: %s", err)
|
|
|
|
}
|
2019-06-25 03:26:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
notify("started hock2xmpp")
|
|
|
|
}
|
|
|
|
|
|
|
|
func closeXMPP() {
|
|
|
|
notify("stopped of hock2xmpp")
|
|
|
|
|
|
|
|
for _, muc := range mucs {
|
2019-06-28 00:43:47 +02:00
|
|
|
if err := client.Send(stanza.Presence{Attrs: stanza.Attrs{
|
2019-06-25 03:26:53 +02:00
|
|
|
To: muc,
|
2019-06-28 00:43:47 +02:00
|
|
|
Type: stanza.PresenceTypeUnavailable,
|
|
|
|
}}); err != nil {
|
|
|
|
log.WithField("muc", muc).Errorf("error on leaving muc: %s", err)
|
|
|
|
}
|
2019-06-25 03:26:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|