diff --git a/api.go b/api.go new file mode 100644 index 0000000..2a400fb --- /dev/null +++ b/api.go @@ -0,0 +1,65 @@ +package main + +import ( + "encoding/json" + "fmt" + "net/http" + "os" +) + +type Project struct { + ProjectBody GenericBody `json:"project"` +} + +type GenericBody struct { + Id int `json:"id"` + Name string `json:"name"` + Note string `json:"note"` +} + +type Service struct { + ServiceBody GenericBody `json:"service"` +} + +func apiGetProjects() (projects []Project) { + client := &http.Client{} + req := buildGetRequest("/projects.json") + res, err := client.Do(req) + if err != nil { + _, _ = fmt.Fprintln(os.Stderr, err) + } + + defer res.Body.Close() + err = json.NewDecoder(res.Body).Decode(&projects) + if err != nil { + _, _ = fmt.Fprintln(os.Stderr, err) + } + return projects +} + +func buildGetRequest(path string) *http.Request { + url := fmt.Sprintf("%s%s", configGetApiUrl(), path) + req, err := http.NewRequest("GET", url, nil) + if err != nil { + _, _ = fmt.Fprintln(os.Stderr, err) + } + req.Header.Add("X-MiteApiKey", configGetApiKey()) + + return req +} + +func apiGetServices() (services []Service) { + client := &http.Client{} + req := buildGetRequest("/services.json") + res, err := client.Do(req) + if err != nil { + _, _ = fmt.Fprintln(os.Stderr, err) + } + + defer res.Body.Close() + err = json.NewDecoder(res.Body).Decode(&services) + if err != nil { + _, _ = fmt.Fprintln(os.Stderr, err) + } + return services +} diff --git a/cmd-list.go b/cmd-list.go index 74f18f1..9026e8d 100644 --- a/cmd-list.go +++ b/cmd-list.go @@ -1,12 +1,13 @@ package main import ( - "fmt" + "github.com/cheynewallace/tabby" "github.com/spf13/cobra" ) func init() { listCommand.AddCommand(listProjectsCommand) + listCommand.AddCommand(listServicesCommand) rootCmd.AddCommand(listCommand) } @@ -22,9 +23,28 @@ var listProjectsCommand = &cobra.Command{ Use: "projects", Short: "list projects", Run: func(cmd *cobra.Command, args []string) { - url := configGetApiUrl() - key := configGetApiKey() - // do get request - fmt.Println(url, key) + projects := apiGetProjects() + t := tabby.New() + t.AddHeader("id", "name", "notes") + for _, project := range projects { + p := project.ProjectBody + t.AddLine(p.Id, p.Name, p.Note) + } + t.Print() + }, +} + +var listServicesCommand = &cobra.Command{ + Use: "services", + Short: "list services", + Run: func(cmd *cobra.Command, args []string) { + services := apiGetServices() + t := tabby.New() + t.AddHeader("id", "name", "notes") + for _, project := range services { + s := project.ServiceBody + t.AddLine(s.Id, s.Name, s.Note) + } + t.Print() }, } diff --git a/config.go b/config.go index 0928e2a..992617b 100644 --- a/config.go +++ b/config.go @@ -9,11 +9,11 @@ import ( ) func configGetApiUrl() string { - configGet("api.url") + return configGet("api.url") } func configGetApiKey() string { - configGet("api.key") + return configGet("api.key") } func configGet(key string) string { diff --git a/go.mod b/go.mod index a05ac19..5605f5e 100644 --- a/go.mod +++ b/go.mod @@ -1,8 +1,10 @@ module github.com/phiros/mite-go require ( + github.com/BurntSushi/toml v0.3.1 // indirect + github.com/cheynewallace/tabby v1.1.0 + github.com/inconshreveable/mousetrap v1.0.0 // indirect github.com/mitchellh/go-homedir v1.1.0 github.com/spf13/cobra v0.0.3 github.com/spf13/viper v1.3.1 - rsc.io/quote v1.5.2 ) diff --git a/go.sum b/go.sum index 5547c72..00f95f8 100644 --- a/go.sum +++ b/go.sum @@ -1,12 +1,19 @@ +github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ= +github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8= +github.com/cheynewallace/tabby v1.1.0 h1:XtG/ZanoIvNZHfe0cClhWLzD/16GGF9UD7mMdWwYnCQ= +github.com/cheynewallace/tabby v1.1.0/go.mod h1:Pba/6cUL8uYqvOc9RkyvFbHGrQ9wShyrn6/S/1OYVys= github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= +github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/fsnotify/fsnotify v1.4.7 h1:IXs+QLmnXW2CcXuY+8Mzv/fWEsPGWxqefPtCP5CnV9I= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= +github.com/inconshreveable/mousetrap v1.0.0 h1:Z8tu5sraLXCXIcARxBp/8cbvlwVa7Z1NHg9XEKhtSvM= +github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= github.com/magiconair/properties v1.8.0 h1:LLgXmsheXeRoUOBOjtwPQCWIYqM/LU1ayDtDePerRcY= github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y= @@ -15,6 +22,7 @@ github.com/mitchellh/mapstructure v1.1.2 h1:fmNYVwqnSfB9mZU6OS2O6GsXM+wcskZDuKQz github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/pelletier/go-toml v1.2.0 h1:T5zMGML61Wp+FlcbWjRDT7yAxhJNAiPPLOFECq181zc= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= +github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/spf13/afero v1.1.2 h1:m8/z1t7/fwjysjQRYbP0RD+bUIF/8tJwPdEZsI83ACI= github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ= @@ -28,20 +36,16 @@ github.com/spf13/pflag v1.0.3 h1:zPAT6CGy6wXeQ7NtTnaTerfKOsV6V6F8agHXFiazDkg= github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/spf13/viper v1.3.1 h1:5+8j8FTpnFV4nEImW/ofkzEt8VoOiLXxdYIDsB73T38= github.com/spf13/viper v1.3.1/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s= +github.com/stretchr/testify v1.2.2 h1:bSDNvY7ZPG5RlJ8otE/7V6gMiyenm9RtJ7IUVIAoJ1w= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0= github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q= golang.org/x/crypto v0.0.0-20181203042331-505ab145d0a9/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= golang.org/x/sys v0.0.0-20181205085412-a5c9d58dba9a h1:1n5lsVfiQW3yfsRGu98756EH1YthsFqr/5mxHduZW2A= golang.org/x/sys v0.0.0-20181205085412-a5c9d58dba9a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c h1:qgOY6WgZOaTkIIMiVjBQcw93ERBE4m30iBm00nkL0i8= -golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.0 h1:g61tztE5qeGQ89tm6NTjjM9VPIm088od1l6aSorWRWg= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/yaml.v2 v2.2.2 h1:ZCJp+EgiOT7lHqUV2J862kp8Qj64Jo6az82+3Td9dZw= gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -rsc.io/quote v1.5.2 h1:w5fcysjrx7yqtD/aO+QwRjYZOKnaM9Uh2b40tElTs3Y= -rsc.io/quote v1.5.2/go.mod h1:LzX7hefJvL54yjefDEDHNONDjII0t9xZLPXsUe+TKr0= -rsc.io/sampler v1.3.0 h1:7uVkIFmeBqHfdjD+gZwtXXI+RODJ2Wc4O7MPEh/QiW4= -rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA=