Update itctl to use api
This commit is contained in:
		
							
								
								
									
										14
									
								
								api/notify.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								api/notify.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| package api | ||||
|  | ||||
| import "go.arsenm.dev/itd/internal/types" | ||||
|  | ||||
| func (c *Client) Notify(title string, body string) error { | ||||
| 	_, err := c.request(types.Request{ | ||||
| 		Type: types.ReqTypeNotify, | ||||
| 		Data: types.ReqDataNotify{ | ||||
| 			Title: title, | ||||
| 			Body: body, | ||||
| 		}, | ||||
| 	}) | ||||
| 	return err | ||||
| } | ||||
| @@ -19,15 +19,11 @@ | ||||
| package firmware | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/cheggaaa/pb/v3" | ||||
| 	"github.com/mitchellh/mapstructure" | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| ) | ||||
|  | ||||
| @@ -36,47 +32,34 @@ type DFUProgress struct { | ||||
| 	Total    int64 `mapstructure:"total"` | ||||
| } | ||||
|  | ||||
|  | ||||
| // upgradeCmd represents the upgrade command | ||||
| var upgradeCmd = &cobra.Command{ | ||||
| 	Use:     "upgrade", | ||||
| 	Short:   "Upgrade InfiniTime firmware using files or archive", | ||||
| 	Aliases: []string{"upg"}, | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		var data types.ReqDataFwUpgrade | ||||
| 		var upgType api.UpgradeType | ||||
| 		var files []string | ||||
| 		// Get relevant data struct | ||||
| 		if viper.GetString("archive") != "" { | ||||
| 			// Get archive data struct | ||||
| 			data = types.ReqDataFwUpgrade{ | ||||
| 				Type:  types.UpgradeTypeArchive, | ||||
| 				Files: []string{viper.GetString("archive")}, | ||||
| 			} | ||||
| 			upgType = types.UpgradeTypeArchive | ||||
| 			files = []string{viper.GetString("archive")} | ||||
| 		} else if viper.GetString("initPkt") != "" && viper.GetString("firmware") != "" { | ||||
| 			// Get files data struct | ||||
| 			data = types.ReqDataFwUpgrade{ | ||||
| 				Type:  types.UpgradeTypeFiles, | ||||
| 				Files: []string{viper.GetString("initPkt"), viper.GetString("firmware")}, | ||||
| 			} | ||||
| 			upgType = types.UpgradeTypeFiles | ||||
| 			files = []string{viper.GetString("initPkt"), viper.GetString("firmware")} | ||||
| 		} else { | ||||
| 			cmd.Usage() | ||||
| 			log.Warn().Msg("Upgrade command requires either archive or init packet and firmware.") | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| 		// Encode response into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeFwUpgrade, | ||||
| 			Data: data, | ||||
| 		}) | ||||
| 		progress, err := client.FirmwareUpgrade(upgType, files...) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 			log.Fatal().Err(err).Msg("Error initiating DFU") | ||||
| 		} | ||||
|  | ||||
| 		// Create progress bar template | ||||
| @@ -84,23 +67,7 @@ var upgradeCmd = &cobra.Command{ | ||||
| 		// Start full bar at 0 total | ||||
| 		bar := pb.ProgressBarTemplate(barTmpl).Start(0) | ||||
| 		// Create new scanner of connection | ||||
| 		scanner := bufio.NewScanner(conn) | ||||
| 		for scanner.Scan() { | ||||
| 			var res types.Response | ||||
| 			// Decode scanned line into response struct | ||||
| 			err = json.Unmarshal(scanner.Bytes(), &res) | ||||
| 			if err != nil { | ||||
| 				log.Fatal().Err(err).Msg("Error decoding JSON response") | ||||
| 			} | ||||
| 			if res.Error { | ||||
| 				log.Fatal().Msg(res.Message) | ||||
| 			} | ||||
| 			var event DFUProgress | ||||
| 			// Decode response data into progress struct | ||||
| 			err = mapstructure.Decode(res.Value, &event) | ||||
| 			if err != nil { | ||||
| 				log.Fatal().Err(err).Msg("Error decoding response data") | ||||
| 			} | ||||
| 		for event := range progress { | ||||
| 			// Set total bytes in progress bar | ||||
| 			bar.SetTotal(event.Total) | ||||
| 			// Set amount of bytes received in progress bar | ||||
| @@ -112,9 +79,6 @@ var upgradeCmd = &cobra.Command{ | ||||
| 		} | ||||
| 		// Finish progress bar | ||||
| 		bar.Finish() | ||||
| 		if scanner.Err() != nil { | ||||
| 			log.Fatal().Err(scanner.Err()).Msg("Error while scanning output") | ||||
| 		} | ||||
| 	}, | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -19,15 +19,12 @@ | ||||
| package firmware | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // versionCmd represents the version command | ||||
| @@ -36,40 +33,14 @@ var versionCmd = &cobra.Command{ | ||||
| 	Aliases: []string{"ver"}, | ||||
| 	Short:   "Get firmware version of InfiniTime", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		version, err := client.Version() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeFwVersion, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 			log.Fatal().Err(err).Msg("Error getting firmware version") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Decode line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 		} | ||||
|  | ||||
| 		// Print returned value | ||||
| 		fmt.Println(res.Value) | ||||
| 		fmt.Println(version) | ||||
| 	}, | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -19,15 +19,12 @@ | ||||
| package get | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // addressCmd represents the address command | ||||
| @@ -36,40 +33,14 @@ var addressCmd = &cobra.Command{ | ||||
| 	Aliases: []string{"addr"}, | ||||
| 	Short:   "Get InfiniTime's bluetooth address", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
| 		 | ||||
| 		address, err := client.Address() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeBtAddress, | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 			log.Fatal().Err(err).Msg("Error getting bluetooth address") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Decode line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 		} | ||||
|  | ||||
| 		// Print returned value | ||||
| 		fmt.Println(res.Value) | ||||
| 		fmt.Println(address) | ||||
| 	}, | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -19,15 +19,12 @@ | ||||
| package get | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // batteryCmd represents the batt command | ||||
| @@ -36,40 +33,15 @@ var batteryCmd = &cobra.Command{ | ||||
| 	Aliases: []string{"batt"}, | ||||
| 	Short:   "Get battery level from InfiniTime", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeBattLevel, | ||||
| 		}) | ||||
| 		battLevel, err := client.BatteryLevel() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Deocde line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 			log.Fatal().Err(err).Msg("Error getting battery level") | ||||
| 		} | ||||
|  | ||||
| 		// Print returned percentage | ||||
| 		fmt.Printf("%d%%\n", int(res.Value.(float64))) | ||||
| 		fmt.Printf("%d%%\n", battLevel) | ||||
| 	}, | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -19,15 +19,12 @@ | ||||
| package get | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // heartCmd represents the heart command | ||||
| @@ -35,40 +32,15 @@ var heartCmd = &cobra.Command{ | ||||
| 	Use:   "heart", | ||||
| 	Short: "Get heart rate from InfiniTime", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeHeartRate, | ||||
| 		}) | ||||
| 		heartRate, err := client.HeartRate() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Decode line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 			log.Fatal().Err(err).Msg("Error getting heart rate") | ||||
| 		} | ||||
|  | ||||
| 		// Print returned BPM | ||||
| 		fmt.Printf("%d BPM\n", int(res.Value.(float64))) | ||||
| 		fmt.Printf("%d BPM\n", heartRate) | ||||
| 	}, | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -19,16 +19,12 @@ | ||||
| package get | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/mitchellh/mapstructure" | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // steps.goCmd represents the steps.go command | ||||
| @@ -36,42 +32,11 @@ var motionCmd = &cobra.Command{ | ||||
| 	Use:   "motion", | ||||
| 	Short: "Get motion values from InfiniTime", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeMotion, | ||||
| 		}) | ||||
| 		motionVals, err := client.Motion() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Decode line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		var motionVals types.MotionValues | ||||
| 		err = mapstructure.Decode(res.Value, &motionVals) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding motion values") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 			log.Fatal().Err(err).Msg("Error getting motion values") | ||||
| 		} | ||||
|  | ||||
| 		if viper.GetBool("shell") { | ||||
|   | ||||
| @@ -19,15 +19,12 @@ | ||||
| package get | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // steps.goCmd represents the steps.go command | ||||
| @@ -35,40 +32,15 @@ var stepsCmd = &cobra.Command{ | ||||
| 	Use:   "steps", | ||||
| 	Short: "Get step count from InfiniTime", | ||||
| 	Run: func(cmd *cobra.Command, args []string) { | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeStepCount, | ||||
| 		}) | ||||
| 		stepCount, err := client.StepCount() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Decode line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 			log.Fatal().Err(err).Msg("Error getting step count") | ||||
| 		} | ||||
|  | ||||
| 		// Print returned BPM | ||||
| 		fmt.Printf("%d Steps\n", int(res.Value.(float64))) | ||||
| 		fmt.Printf("%d Steps\n", stepCount) | ||||
| 	}, | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -19,15 +19,11 @@ | ||||
| package notify | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"encoding/json" | ||||
| 	"net" | ||||
|  | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| 	"go.arsenm.dev/itd/cmd/itctl/root" | ||||
| 	"go.arsenm.dev/itd/internal/types" | ||||
| ) | ||||
|  | ||||
| // notifyCmd represents the notify command | ||||
| @@ -41,40 +37,11 @@ var notifyCmd = &cobra.Command{ | ||||
| 			log.Fatal().Msg("Command notify requires two arguments") | ||||
| 		} | ||||
|  | ||||
| 		// Connect to itd UNIX socket | ||||
| 		conn, err := net.Dial("unix", viper.GetString("sockPath")) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error dialing socket. Is itd running?") | ||||
| 		} | ||||
| 		defer conn.Close() | ||||
| 		client := viper.Get("client").(*api.Client) | ||||
|  | ||||
| 		// Encode request into connection | ||||
| 		err = json.NewEncoder(conn).Encode(types.Request{ | ||||
| 			Type: types.ReqTypeNotify, | ||||
| 			Data: types.ReqDataNotify{ | ||||
| 				Title: args[0], | ||||
| 				Body:  args[1], | ||||
| 			}, | ||||
| 		}) | ||||
| 		err := client.Notify(args[0], args[1]) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error making request") | ||||
| 		} | ||||
|  | ||||
| 		// Read one line from connection | ||||
| 		line, _, err := bufio.NewReader(conn).ReadLine() | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error reading line from connection") | ||||
| 		} | ||||
|  | ||||
| 		var res types.Response | ||||
| 		// Decode line into response | ||||
| 		err = json.Unmarshal(line, &res) | ||||
| 		if err != nil { | ||||
| 			log.Fatal().Err(err).Msg("Error decoding JSON data") | ||||
| 		} | ||||
|  | ||||
| 		if res.Error { | ||||
| 			log.Fatal().Msg(res.Message) | ||||
| 			log.Fatal().Err(err).Msg("Error sending notification") | ||||
| 		} | ||||
| 	}, | ||||
| } | ||||
|   | ||||
| @@ -20,8 +20,10 @@ package root | ||||
|  | ||||
| import ( | ||||
| 	"github.com/abiosoft/ishell" | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/spf13/cobra" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"go.arsenm.dev/itd/api" | ||||
| ) | ||||
|  | ||||
| // RootCmd represents the base command when called without any subcommands | ||||
| @@ -61,18 +63,25 @@ var RootCmd = &cobra.Command{ | ||||
| // Execute adds all child commands to the root command and sets flags appropriately. | ||||
| // This is called by main.main(). It only needs to happen once to the rootCmd. | ||||
| func Execute() { | ||||
| 	client, err := api.New(viper.GetString("sockPath")) | ||||
| 	if err != nil { | ||||
| 		log.Fatal().Err(err).Msg("Error connecting to socket. Is itd running?") | ||||
| 	} | ||||
| 	defer client.Close() | ||||
| 	viper.Set("client", client) | ||||
| 	RootCmd.CompletionOptions.DisableDefaultCmd = true | ||||
| 	cobra.CheckErr(RootCmd.Execute()) | ||||
|  | ||||
| } | ||||
|  | ||||
| func init() { | ||||
| 	// Register flag for socket path | ||||
| 	RootCmd.Flags().StringP("socket-path", "s", "", "Path to itd socket") | ||||
| 	RootCmd.Flags().StringP("socket-path", "s", api.DefaultAddr, "Path to itd socket") | ||||
|  | ||||
| 	// Bind flag and environment variable to viper key | ||||
| 	viper.BindPFlag("sockPath", RootCmd.Flags().Lookup("socket-path")) | ||||
| 	viper.BindEnv("sockPath", "ITCTL_SOCKET_PATH") | ||||
|  | ||||
| 	// Set default value for socket path | ||||
| 	viper.SetDefault("sockPath", "/tmp/itd/socket") | ||||
| 	viper.SetDefault("sockPath", api.DefaultAddr) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user