|
|
@@ -2,6 +2,7 @@ package cmd
|
|
|
|
|
|
import (
|
|
|
"errors"
|
|
|
+ "fmt"
|
|
|
"github.com/urfave/cli/v2"
|
|
|
"heckel.io/ntfy/client"
|
|
|
"strings"
|
|
|
@@ -9,17 +10,19 @@ import (
|
|
|
|
|
|
var cmdPublish = &cli.Command{
|
|
|
Name: "publish",
|
|
|
- Aliases: []string{"pub", "send", "push", "trigger"},
|
|
|
+ Aliases: []string{"pub", "send", "trigger"},
|
|
|
Usage: "Send message via a ntfy server",
|
|
|
- UsageText: "ntfy send [OPTIONS..] TOPIC MESSAGE",
|
|
|
+ UsageText: "ntfy send [OPTIONS..] TOPIC [MESSAGE]",
|
|
|
Action: execPublish,
|
|
|
Flags: []cli.Flag{
|
|
|
+ &cli.StringFlag{Name: "config", Aliases: []string{"c"}, Usage: "client config file"},
|
|
|
&cli.StringFlag{Name: "title", Aliases: []string{"t"}, Usage: "message title"},
|
|
|
&cli.StringFlag{Name: "priority", Aliases: []string{"p"}, Usage: "priority of the message (1=min, 2=low, 3=default, 4=high, 5=max)"},
|
|
|
- &cli.StringFlag{Name: "tags", Aliases: []string{"ta"}, Usage: "comma separated list of tags and emojis"},
|
|
|
- &cli.StringFlag{Name: "delay", Aliases: []string{"at", "in"}, Usage: "delay/schedule message"},
|
|
|
+ &cli.StringFlag{Name: "tags", Aliases: []string{"tag", "T"}, Usage: "comma separated list of tags and emojis"},
|
|
|
+ &cli.StringFlag{Name: "delay", Aliases: []string{"at", "in", "D"}, Usage: "delay/schedule message"},
|
|
|
&cli.BoolFlag{Name: "no-cache", Aliases: []string{"C"}, Usage: "do not cache message server-side"},
|
|
|
&cli.BoolFlag{Name: "no-firebase", Aliases: []string{"F"}, Usage: "do not forward message to Firebase"},
|
|
|
+ &cli.BoolFlag{Name: "quiet", Aliases: []string{"q"}, Usage: "do print message"},
|
|
|
},
|
|
|
Description: `Publish a message to a ntfy server.
|
|
|
|
|
|
@@ -33,12 +36,19 @@ Examples:
|
|
|
ntfy trigger mywebhook # Sending without message, useful for webhooks
|
|
|
|
|
|
Please also check out the docs on publishing messages. Especially for the --tags and --delay options,
|
|
|
-it has incredibly useful information: https://ntfy.sh/docs/publish/.`,
|
|
|
+it has incredibly useful information: https://ntfy.sh/docs/publish/.
|
|
|
+
|
|
|
+The default config file for all client commands is /etc/ntfy/client.yml (if root user),
|
|
|
+or ~/.config/ntfy/client.yml for all other users.`,
|
|
|
}
|
|
|
|
|
|
func execPublish(c *cli.Context) error {
|
|
|
if c.NArg() < 1 {
|
|
|
- return errors.New("topic missing")
|
|
|
+ return errors.New("must specify topic, type 'ntfy publish --help' for help")
|
|
|
+ }
|
|
|
+ conf, err := loadConfig(c)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
}
|
|
|
title := c.String("title")
|
|
|
priority := c.String("priority")
|
|
|
@@ -46,6 +56,7 @@ func execPublish(c *cli.Context) error {
|
|
|
delay := c.String("delay")
|
|
|
noCache := c.Bool("no-cache")
|
|
|
noFirebase := c.Bool("no-firebase")
|
|
|
+ quiet := c.Bool("quiet")
|
|
|
topic := c.Args().Get(0)
|
|
|
message := ""
|
|
|
if c.NArg() > 1 {
|
|
|
@@ -70,10 +81,13 @@ func execPublish(c *cli.Context) error {
|
|
|
if noFirebase {
|
|
|
options = append(options, client.WithNoFirebase())
|
|
|
}
|
|
|
- conf, err := loadConfig(c)
|
|
|
+ cl := client.New(conf)
|
|
|
+ m, err := cl.Publish(topic, message, options...)
|
|
|
if err != nil {
|
|
|
return err
|
|
|
}
|
|
|
- cl := client.New(conf)
|
|
|
- return cl.Publish(topic, message, options...)
|
|
|
+ if !quiet {
|
|
|
+ fmt.Fprintln(c.App.Writer, strings.TrimSpace(m.Raw))
|
|
|
+ }
|
|
|
+ return nil
|
|
|
}
|