Compare commits
2 Commits
7c7b06e893
...
4ea3545ea7
Author | SHA1 | Date | |
---|---|---|---|
4ea3545ea7 | |||
8df5b1d779 |
@ -19,6 +19,7 @@ type Flags struct {
|
||||
}
|
||||
|
||||
type Command struct {
|
||||
Name string
|
||||
Func func(CmdArgs) int
|
||||
Flags *flag.FlagSet
|
||||
}
|
||||
|
@ -25,7 +25,7 @@ func LsCmd(args CmdArgs) int {
|
||||
selector := args.Flags.String("selector")
|
||||
lights, err := c.ListLights(selector)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
fmt.Printf("fatal: %s\n", err)
|
||||
return 1
|
||||
}
|
||||
PrintLights(lights)
|
||||
|
@ -47,7 +47,7 @@ func main() {
|
||||
|
||||
cmd, ok := lumecmd.GetCommand(command)
|
||||
if !ok {
|
||||
fmt.Println("ERROR")
|
||||
fmt.Printf("lume: '%s' is not lume command. See 'lume' --help.'\n", command)
|
||||
os.Exit(1)
|
||||
}
|
||||
fs := cmd.Flags
|
||||
|
86
cmd/setstate.go
Normal file
86
cmd/setstate.go
Normal file
@ -0,0 +1,86 @@
|
||||
package lumecmd
|
||||
|
||||
import (
|
||||
"flag"
|
||||
"fmt"
|
||||
|
||||
"git.kill0.net/chill9/go-lifx"
|
||||
)
|
||||
|
||||
func init() {
|
||||
var cmdName string = "set-state"
|
||||
|
||||
fs := flag.NewFlagSet(cmdName, flag.ExitOnError)
|
||||
|
||||
selector := fs.String("selector", "all", "Set the selector")
|
||||
fs.StringVar(selector, "s", "all", "Set the selector")
|
||||
|
||||
power := fs.String("power", "", "power state")
|
||||
fs.StringVar(power, "p", "", "power state")
|
||||
|
||||
color := fs.String("color", "", "color state")
|
||||
fs.StringVar(color, "c", "", "color state")
|
||||
|
||||
brightness := fs.String("brightness", "", "brightness state")
|
||||
fs.StringVar(brightness, "b", "", "brightness state")
|
||||
|
||||
duration := fs.Float64("duration", 1.0, "duration state")
|
||||
fs.Float64Var(duration, "d", 1.0, "duration state")
|
||||
|
||||
infrared := fs.String("infrared", "", "infrared state")
|
||||
fs.StringVar(infrared, "i", "", "infrared state")
|
||||
|
||||
fast := fs.Bool("fast", false, "fast state")
|
||||
fs.BoolVar(fast, "f", false, "fast state")
|
||||
|
||||
RegisterCommand(cmdName, Command{
|
||||
Func: SetStateCmd,
|
||||
Flags: fs,
|
||||
})
|
||||
}
|
||||
|
||||
func SetStateCmd(args CmdArgs) int {
|
||||
c := args.Client
|
||||
state := lifx.State{}
|
||||
selector := args.Flags.String("selector")
|
||||
|
||||
power := args.Flags.String("power")
|
||||
if power != "" {
|
||||
state.Power = power
|
||||
}
|
||||
|
||||
color := args.Flags.String("color")
|
||||
if color != "" {
|
||||
state.Color = lifx.NamedColor(color)
|
||||
}
|
||||
|
||||
brightnessFlag := args.Flags.String("brightness")
|
||||
if brightnessFlag != "" {
|
||||
brightness := args.Flags.Float64("brightness")
|
||||
state.Brightness = brightness
|
||||
}
|
||||
|
||||
duration := args.Flags.Float64("duration")
|
||||
state.Duration = duration
|
||||
|
||||
infraredFlag := args.Flags.String("infrared")
|
||||
if infraredFlag != "" {
|
||||
infrared := args.Flags.Float64("infrared")
|
||||
state.Infrared = infrared
|
||||
}
|
||||
|
||||
fast := args.Flags.Bool("fast")
|
||||
state.Fast = fast
|
||||
|
||||
r, err := c.SetState(selector, state)
|
||||
if err != nil {
|
||||
fmt.Printf("fatal: %s\n", err)
|
||||
return 1
|
||||
}
|
||||
|
||||
if !fast {
|
||||
PrintResults(r.Results)
|
||||
}
|
||||
|
||||
return 0
|
||||
}
|
@ -24,7 +24,7 @@ func ToggleCmd(args CmdArgs) int {
|
||||
selector := args.Flags.String("selector")
|
||||
r, err := c.Toggle(selector, duration)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
fmt.Printf("fatal: %s\n", err)
|
||||
return 1
|
||||
}
|
||||
PrintResults(r.Results)
|
||||
|
@ -3,7 +3,7 @@ package lifx
|
||||
import (
|
||||
//"crypto/tls"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"errors"
|
||||
"net/http"
|
||||
"time"
|
||||
)
|
||||
@ -97,7 +97,7 @@ func NewApiError(resp *http.Response) error {
|
||||
if err = json.NewDecoder(resp.Body).Decode(&s); err != nil {
|
||||
return err
|
||||
}
|
||||
return fmt.Errorf("fatal: %s", s.Error)
|
||||
return errors.New(s.Error)
|
||||
}
|
||||
|
||||
func IsApiError(resp *http.Response) bool {
|
||||
@ -120,6 +120,10 @@ func (c *Client) SetState(selector string, state State) (*Response, error) {
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
if IsApiError(resp) {
|
||||
return nil, NewApiError(resp)
|
||||
}
|
||||
|
||||
if state.Fast && resp.StatusCode == http.StatusAccepted {
|
||||
return nil, nil
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user