add default-user, default-password, and default-command options to client.yml config
This commit is contained in:
parent
28975e9433
commit
8956837443
3 changed files with 43 additions and 8 deletions
|
@ -12,8 +12,11 @@ const (
|
||||||
|
|
||||||
// Config is the config struct for a Client
|
// Config is the config struct for a Client
|
||||||
type Config struct {
|
type Config struct {
|
||||||
DefaultHost string `yaml:"default-host"`
|
DefaultHost string `yaml:"default-host"`
|
||||||
Subscribe []struct {
|
DefaultUser string `yaml:"default-user"`
|
||||||
|
DefaultPassword string `yaml:"default-password"`
|
||||||
|
DefaultCommand string `yaml:"default-command"`
|
||||||
|
Subscribe []struct {
|
||||||
Topic string `yaml:"topic"`
|
Topic string `yaml:"topic"`
|
||||||
User string `yaml:"user"`
|
User string `yaml:"user"`
|
||||||
Password string `yaml:"password"`
|
Password string `yaml:"password"`
|
||||||
|
@ -25,8 +28,11 @@ type Config struct {
|
||||||
// NewConfig creates a new Config struct for a Client
|
// NewConfig creates a new Config struct for a Client
|
||||||
func NewConfig() *Config {
|
func NewConfig() *Config {
|
||||||
return &Config{
|
return &Config{
|
||||||
DefaultHost: DefaultBaseURL,
|
DefaultHost: DefaultBaseURL,
|
||||||
Subscribe: nil,
|
DefaultUser: "",
|
||||||
|
DefaultPassword: "",
|
||||||
|
DefaultCommand: "",
|
||||||
|
Subscribe: nil,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,9 @@ func TestConfig_Load(t *testing.T) {
|
||||||
filename := filepath.Join(t.TempDir(), "client.yml")
|
filename := filepath.Join(t.TempDir(), "client.yml")
|
||||||
require.Nil(t, os.WriteFile(filename, []byte(`
|
require.Nil(t, os.WriteFile(filename, []byte(`
|
||||||
default-host: http://localhost
|
default-host: http://localhost
|
||||||
|
default-user: phil
|
||||||
|
default-password: mypass
|
||||||
|
default-command: 'echo "Got the message: $message"'
|
||||||
subscribe:
|
subscribe:
|
||||||
- topic: no-command-with-auth
|
- topic: no-command-with-auth
|
||||||
user: phil
|
user: phil
|
||||||
|
@ -22,12 +25,16 @@ subscribe:
|
||||||
command: notify-send -i /usr/share/ntfy/logo.png "Important" "$m"
|
command: notify-send -i /usr/share/ntfy/logo.png "Important" "$m"
|
||||||
if:
|
if:
|
||||||
priority: high,urgent
|
priority: high,urgent
|
||||||
|
- topic: defaults
|
||||||
`), 0600))
|
`), 0600))
|
||||||
|
|
||||||
conf, err := client.LoadConfig(filename)
|
conf, err := client.LoadConfig(filename)
|
||||||
require.Nil(t, err)
|
require.Nil(t, err)
|
||||||
require.Equal(t, "http://localhost", conf.DefaultHost)
|
require.Equal(t, "http://localhost", conf.DefaultHost)
|
||||||
require.Equal(t, 3, len(conf.Subscribe))
|
require.Equal(t, "phil", conf.DefaultUser)
|
||||||
|
require.Equal(t, "mypass", conf.DefaultPassword)
|
||||||
|
require.Equal(t, `echo "Got the message: $message"`, conf.DefaultCommand)
|
||||||
|
require.Equal(t, 4, len(conf.Subscribe))
|
||||||
require.Equal(t, "no-command-with-auth", conf.Subscribe[0].Topic)
|
require.Equal(t, "no-command-with-auth", conf.Subscribe[0].Topic)
|
||||||
require.Equal(t, "", conf.Subscribe[0].Command)
|
require.Equal(t, "", conf.Subscribe[0].Command)
|
||||||
require.Equal(t, "phil", conf.Subscribe[0].User)
|
require.Equal(t, "phil", conf.Subscribe[0].User)
|
||||||
|
@ -37,4 +44,5 @@ subscribe:
|
||||||
require.Equal(t, "alerts", conf.Subscribe[2].Topic)
|
require.Equal(t, "alerts", conf.Subscribe[2].Topic)
|
||||||
require.Equal(t, `notify-send -i /usr/share/ntfy/logo.png "Important" "$m"`, conf.Subscribe[2].Command)
|
require.Equal(t, `notify-send -i /usr/share/ntfy/logo.png "Important" "$m"`, conf.Subscribe[2].Command)
|
||||||
require.Equal(t, "high,urgent", conf.Subscribe[2].If["priority"])
|
require.Equal(t, "high,urgent", conf.Subscribe[2].If["priority"])
|
||||||
|
require.Equal(t, "defaults", conf.Subscribe[3].Topic)
|
||||||
}
|
}
|
||||||
|
|
|
@ -175,11 +175,32 @@ func doSubscribe(c *cli.Context, cl *client.Client, conf *client.Config, topic,
|
||||||
for filter, value := range s.If {
|
for filter, value := range s.If {
|
||||||
topicOptions = append(topicOptions, client.WithFilter(filter, value))
|
topicOptions = append(topicOptions, client.WithFilter(filter, value))
|
||||||
}
|
}
|
||||||
if s.User != "" && s.Password != "" {
|
var user, password string
|
||||||
topicOptions = append(topicOptions, client.WithBasicAuth(s.User, s.Password))
|
if s.User != "" {
|
||||||
|
user = s.User
|
||||||
|
} else if conf.DefaultUser != "" {
|
||||||
|
user = conf.DefaultUser
|
||||||
|
} else {
|
||||||
|
user = ""
|
||||||
|
}
|
||||||
|
if s.Password != "" {
|
||||||
|
password = s.Password
|
||||||
|
} else if conf.DefaultPassword != "" {
|
||||||
|
password = conf.DefaultPassword
|
||||||
|
} else {
|
||||||
|
password = ""
|
||||||
|
}
|
||||||
|
if user != "" && password != "" {
|
||||||
|
topicOptions = append(topicOptions, client.WithBasicAuth(user, password))
|
||||||
}
|
}
|
||||||
subscriptionID := cl.Subscribe(s.Topic, topicOptions...)
|
subscriptionID := cl.Subscribe(s.Topic, topicOptions...)
|
||||||
cmds[subscriptionID] = s.Command
|
if s.Command != "" {
|
||||||
|
cmds[subscriptionID] = s.Command
|
||||||
|
} else if conf.DefaultCommand != "" {
|
||||||
|
cmds[subscriptionID] = conf.DefaultCommand
|
||||||
|
} else {
|
||||||
|
cmds[subscriptionID] = ""
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if topic != "" {
|
if topic != "" {
|
||||||
subscriptionID := cl.Subscribe(topic, options...)
|
subscriptionID := cl.Subscribe(topic, options...)
|
||||||
|
|
Loading…
Reference in a new issue