Browse Source

A little cleanup

master
ViViDboarder 4 years ago
parent
commit
d87e00a4a1
  1. 3
      README.md
  2. 106
      gopush.go

3
README.md

@ -9,6 +9,7 @@ General usage:
gopush -token="yourapitokenfrompushbullet"
gopush "Whatever you want pushed"
```
Defaults to all devices, but you can also specify with `-d="Device name"`
Defaults to all devices, but you can also specify with `gopush -d="Device name"`. Can't remember your devices? `gopush -l` will list them.
I often use this combined with a bash or fish script (maybe I'll post later) to push me successes, failures, or results for long running commands.

106
gopush.go

@ -1,37 +1,39 @@
package main
import (
"errors"
"flag"
"fmt"
"io/ioutil"
"log"
"os"
"./goson"
"./pushbullet"
"github.com/ViViDboarder/gopush/goson"
"github.com/ViViDboarder/gopush/pushbullet"
)
type Options struct {
Token string
Message string
Device string
Push bool
List bool
SetActive bool
Token string
Message string
Device string
Push bool
List bool
}
var options = Options{}
func loadArgs() {
func loadArgs() (options Options, err error) {
options = Options{}
token := flag.String("token", "", "Your API Token")
activeDevice := flag.String("d", "", "Set default device")
listDevices := flag.Bool("l", false, "List devices")
flag.Parse()
options.Token = *token
options.Device = *activeDevice
options.List = *listDevices
if options.Device != "" {
options.SetActive = true
if options.List {
return
}
// Positional args
@ -39,8 +41,7 @@ func loadArgs() {
case 0:
data, err := ioutil.ReadAll(os.Stdin)
if err != nil {
// TODO: Make errors great again!
os.Exit(1)
return options, err
}
message := string(data)
if message == "" {
@ -61,60 +62,77 @@ func loadArgs() {
options.Push = true
break
}
return
}
func main() {
loadArgs()
func printDevices(devices []pushbullet.Device, activeDevice pushbullet.Device) {
fmt.Println("Devices:")
var prefix string
for _, device := range devices {
if device.Iden == activeDevice.Iden {
prefix = " *"
} else {
prefix = " "
}
config := goson.LoadConfig("gopush")
fmt.Println(prefix + device.Format())
}
}
var ok bool
func getToken(options Options, config goson.Config) (token string, err error) {
if options.Token != "" {
token = options.Token
config.Set("token", options.Token)
} else {
options.Token, ok = config.GetString("token")
var ok bool
token, ok = config.GetString("token")
if !ok {
fmt.Println("No token found")
os.Exit(1)
err = errors.New("No token found")
}
}
return
}
pb := pushbullet.New(options.Token)
func getDevice(options Options, config goson.Config) (device string) {
if options.Device == "" {
activeDeviceIden, ok := config.GetString("activeDeviceIden")
if ok {
options.Device = activeDeviceIden
device = activeDeviceIden
}
}
return
}
pb.SetActiveDevice(options.Device)
func persistDevice(activeDeviceIden string, config goson.Config) {
storedDeviceIden, ok := config.GetString("activeDeviceIden")
if activeDeviceIden != "" && ok && activeDeviceIden != storedDeviceIden {
config.Set("activeDeviceIden", activeDeviceIden)
}
}
if options.SetActive {
config.Set("activeDeviceIden", pb.ActiveDevice.Iden)
func main() {
options, err := loadArgs()
if err != nil {
log.Fatal(err)
}
config := goson.LoadConfig("gopush")
token, err := getToken(options, config)
if err != nil {
fmt.Println("Token required and not provided by config or command line")
log.Fatal(err)
}
device := getDevice(options, config)
pb := pushbullet.New(token)
pb.SetActiveDevice(device)
persistDevice(pb.ActiveDevice.Iden, config)
config.Write()
if options.Push {
pb.PushNote(options.Message)
} else if options.List {
devices := pb.GetDevices()
PrintDevices(devices, pb.ActiveDevice)
}
}
func PrintDevices(devices []pushbullet.Device, activeDevice pushbullet.Device) {
fmt.Println("Devices:")
var prefix string
for _, device := range devices {
if device.Iden == activeDevice.Iden {
prefix = " *"
} else {
prefix = " "
}
fmt.Println(prefix + device.Format())
printDevices(devices, pb.ActiveDevice)
}
}

Loading…
Cancel
Save