forked from jshiffer/go-xmpp
improve authentification
This commit is contained in:
parent
6aa942dd58
commit
0fb90abcf7
@ -13,6 +13,8 @@ import (
|
|||||||
"gosrc.io/xmpp"
|
"gosrc.io/xmpp"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var configFile = ""
|
||||||
|
|
||||||
var jid = ""
|
var jid = ""
|
||||||
var password = ""
|
var password = ""
|
||||||
|
|
||||||
@ -20,8 +22,9 @@ var receiverMUC = false
|
|||||||
var stdIn = false
|
var stdIn = false
|
||||||
|
|
||||||
var cmd = &cobra.Command{
|
var cmd = &cobra.Command{
|
||||||
Use: "sendxmpp",
|
Use: "sendxmpp <recieve,> [message]",
|
||||||
Args: cobra.MinimumNArgs(1),
|
Example: `sendxmpp to@chat.sum7.eu "Hello World!"`,
|
||||||
|
Args: cobra.RangeArgs(1, 2),
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
receiver := strings.Split(args[0], ",")
|
receiver := strings.Split(args[0], ",")
|
||||||
msgText := ""
|
msgText := ""
|
||||||
@ -35,19 +38,23 @@ var cmd = &cobra.Command{
|
|||||||
|
|
||||||
var err error
|
var err error
|
||||||
client, err := xmpp.NewClient(xmpp.Config{
|
client, err := xmpp.NewClient(xmpp.Config{
|
||||||
Jid: jid,
|
Jid: viper.GetString("jid"),
|
||||||
Password: password,
|
Password: viper.GetString("password"),
|
||||||
}, xmpp.NewRouter())
|
}, xmpp.NewRouter())
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Panicf("error on startup xmpp client: %s", err)
|
log.Errorf("error on startup xmpp client: %s", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
wg := sync.WaitGroup{}
|
wg := sync.WaitGroup{}
|
||||||
wg.Add(1)
|
wg.Add(1)
|
||||||
|
|
||||||
cm := xmpp.NewStreamManager(client, func(c xmpp.Sender) {
|
cm := xmpp.NewStreamManager(client, func(c xmpp.Sender) {
|
||||||
|
defer wg.Done()
|
||||||
|
|
||||||
log.Info("client connected")
|
log.Info("client connected")
|
||||||
|
|
||||||
if receiverMUC {
|
if receiverMUC {
|
||||||
for _, muc := range receiver {
|
for _, muc := range receiver {
|
||||||
joinMUC(c, muc, "sendxmpp")
|
joinMUC(c, muc, "sendxmpp")
|
||||||
@ -56,7 +63,6 @@ var cmd = &cobra.Command{
|
|||||||
|
|
||||||
if !stdIn {
|
if !stdIn {
|
||||||
send(c, receiver, msgText)
|
send(c, receiver, msgText)
|
||||||
wg.Done()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,11 +74,11 @@ var cmd = &cobra.Command{
|
|||||||
if err := scanner.Err(); err != nil {
|
if err := scanner.Err(); err != nil {
|
||||||
log.Errorf("error on reading stdin: %s", err)
|
log.Errorf("error on reading stdin: %s", err)
|
||||||
}
|
}
|
||||||
wg.Done()
|
|
||||||
})
|
})
|
||||||
go func() {
|
go func() {
|
||||||
err := cm.Run()
|
err := cm.Run()
|
||||||
log.Panic("closed connection:", err)
|
log.Panic("closed connection:", err)
|
||||||
|
wg.Done()
|
||||||
}()
|
}()
|
||||||
|
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
@ -82,14 +88,35 @@ var cmd = &cobra.Command{
|
|||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
cmd.Flags().StringVarP(&jid, "jid", "", "", "using jid (required)")
|
cobra.OnInitialize(initConfig)
|
||||||
viper.BindPFlag("jid", cmd.Flags().Lookup("jid"))
|
cmd.PersistentFlags().StringVar(&configFile, "config", "", "config file (default is ~/.config/fluxxmpp.yml)")
|
||||||
// cmd.MarkFlagRequired("jid")
|
|
||||||
|
|
||||||
cmd.Flags().StringVarP(&password, "password", "", "", "using password for your jid (required)")
|
cmd.Flags().StringP("jid", "", "", "using jid (required)")
|
||||||
|
viper.BindPFlag("jid", cmd.Flags().Lookup("jid"))
|
||||||
|
|
||||||
|
cmd.Flags().StringP("password", "", "", "using password for your jid (required)")
|
||||||
viper.BindPFlag("password", cmd.Flags().Lookup("password"))
|
viper.BindPFlag("password", cmd.Flags().Lookup("password"))
|
||||||
// cmd.MarkFlagRequired("password")
|
|
||||||
|
|
||||||
cmd.Flags().BoolVarP(&stdIn, "stdin", "i", false, "read from stdin instatt of 2. argument")
|
cmd.Flags().BoolVarP(&stdIn, "stdin", "i", false, "read from stdin instatt of 2. argument")
|
||||||
cmd.Flags().BoolVarP(&receiverMUC, "muc", "m", false, "reciever is a muc (join it before sending messages)")
|
cmd.Flags().BoolVarP(&receiverMUC, "muc", "m", false, "reciever is a muc (join it before sending messages)")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// initConfig reads in config file and ENV variables if set.
|
||||||
|
func initConfig() {
|
||||||
|
if configFile != "" {
|
||||||
|
viper.SetConfigFile(configFile)
|
||||||
|
}
|
||||||
|
|
||||||
|
viper.SetConfigName("fluxxmpp")
|
||||||
|
viper.AddConfigPath("/etc/")
|
||||||
|
viper.AddConfigPath("$HOME/.config")
|
||||||
|
viper.AddConfigPath(".")
|
||||||
|
|
||||||
|
viper.SetEnvPrefix("FLUXXMPP")
|
||||||
|
viper.AutomaticEnv()
|
||||||
|
|
||||||
|
// If a config file is found, read it in.
|
||||||
|
if err := viper.ReadInConfig(); err != nil {
|
||||||
|
log.Warnf("no configuration found (somebody could read your password from progress argument list): %s", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user