Refactor to start removing global variables

This commit is contained in:
Mickael Remond 2019-07-27 18:06:55 -07:00
parent a3867dd0b3
commit 7ab6c3a62d
No known key found for this signature in database
GPG key ID: E6F6045D79965AA3
2 changed files with 66 additions and 64 deletions

View file

@ -22,60 +22,76 @@ var cmd = &cobra.Command{
Use: "sendxmpp <recipient,> [message]", Use: "sendxmpp <recipient,> [message]",
Example: `sendxmpp to@chat.sum7.eu "Hello World!"`, Example: `sendxmpp to@chat.sum7.eu "Hello World!"`,
Args: cobra.ExactArgs(2), Args: cobra.ExactArgs(2),
Run: func(cmd *cobra.Command, args []string) { Run: sendxmpp,
receiver := strings.Split(args[0], ",") }
msgText := args[1]
var err error func sendxmpp(cmd *cobra.Command, args []string) {
client, err := xmpp.NewClient(xmpp.Config{ receiver := strings.Split(args[0], ",")
Jid: viper.GetString("jid"), msgText := args[1]
Address: viper.GetString("addr"),
Password: viper.GetString("password"),
}, xmpp.NewRouter())
if err != nil { var err error
log.Errorf("error when starting xmpp client: %s", err) client, err := xmpp.NewClient(xmpp.Config{
Jid: viper.GetString("jid"),
Address: viper.GetString("addr"),
Password: viper.GetString("password"),
}, xmpp.NewRouter())
if err != nil {
log.Errorf("error when starting xmpp client: %s", err)
return
}
wg := sync.WaitGroup{}
wg.Add(1)
// FIXME: Remove global variables
var mucsToLeave []*xmpp.Jid
cm := xmpp.NewStreamManager(client, func(c xmpp.Sender) {
defer wg.Done()
log.Info("client connected")
if isMUCRecipient {
for _, muc := range receiver {
jid, err := xmpp.NewJid(muc)
if err != nil {
log.WithField("muc", muc).Errorf("skipping invalid muc jid: %w", err)
continue
}
jid.Resource = "sendxmpp"
if err := joinMUC(c, jid); err != nil {
log.WithField("muc", muc).Errorf("error joining muc: %w", err)
continue
}
mucsToLeave = append(mucsToLeave, jid)
}
}
if msgText != "-" {
send(c, receiver, msgText)
return return
} }
wg := sync.WaitGroup{} scanner := bufio.NewScanner(os.Stdin)
wg.Add(1) for scanner.Scan() {
send(c, receiver, scanner.Text())
}
cm := xmpp.NewStreamManager(client, func(c xmpp.Sender) { if err := scanner.Err(); err != nil {
defer wg.Done() log.Errorf("error on reading stdin: %s", err)
}
})
go func() {
err := cm.Run()
log.Panic("closed connection:", err)
wg.Done()
}()
log.Info("client connected") wg.Wait()
if isMUCRecipient { leaveMUCs(client, mucsToLeave)
for _, muc := range receiver {
joinMUC(c, muc, "sendxmpp")
}
}
if msgText != "-" {
send(c, receiver, msgText)
return
}
scanner := bufio.NewScanner(os.Stdin)
for scanner.Scan() {
send(c, receiver, scanner.Text())
}
if err := scanner.Err(); err != nil {
log.Errorf("error on reading stdin: %s", err)
}
})
go func() {
err := cm.Run()
log.Panic("closed connection:", err)
wg.Done()
}()
wg.Wait()
leaveMUCs(client)
},
} }
func init() { func init() {

View file

@ -7,33 +7,19 @@ import (
"gosrc.io/xmpp/stanza" "gosrc.io/xmpp/stanza"
) )
// FIXME: Remove global variables func joinMUC(c xmpp.Sender, toJID *xmpp.Jid) error {
var mucsToLeave []string return c.Send(stanza.Presence{Attrs: stanza.Attrs{To: toJID.Full()},
func joinMUC(c xmpp.Sender, to, nick string) error {
toJID, err := xmpp.NewJid(to)
if err != nil {
return err
}
toJID.Resource = nick
jid := toJID.Full()
mucsToLeave = append(mucsToLeave, jid)
return c.Send(stanza.Presence{Attrs: stanza.Attrs{To: jid},
Extensions: []stanza.PresExtension{ Extensions: []stanza.PresExtension{
stanza.MucPresence{ stanza.MucPresence{
History: stanza.History{MaxStanzas: stanza.NewNullableInt(0)}, History: stanza.History{MaxStanzas: stanza.NewNullableInt(0)},
}}, }},
}) })
} }
func leaveMUCs(c xmpp.Sender) { func leaveMUCs(c xmpp.Sender, mucsToLeave []*xmpp.Jid) {
for _, muc := range mucsToLeave { for _, muc := range mucsToLeave {
if err := c.Send(stanza.Presence{Attrs: stanza.Attrs{ if err := c.Send(stanza.Presence{Attrs: stanza.Attrs{
To: muc, To: muc.Full(),
Type: stanza.PresenceTypeUnavailable, Type: stanza.PresenceTypeUnavailable,
}}); err != nil { }}); err != nil {
log.WithField("muc", muc).Errorf("error on leaving muc: %s", err) log.WithField("muc", muc).Errorf("error on leaving muc: %s", err)