break up into packages
parent
5efe73b3ca
commit
d48544ff0b
@ -0,0 +1,21 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"git.xbudex.com/buddy/open-hardware-monitor/lib/app"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := app.New()
|
||||||
|
handleErr(a.RunClient(os.Args))
|
||||||
|
}
|
||||||
|
|
||||||
|
func handleErr(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Fprintf(os.Stderr, "%s\n", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"git.xbudex.com/buddy/open-hardware-monitor/lib/app"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := app.New()
|
||||||
|
handleErr(a.RunMetrics(os.Args))
|
||||||
|
}
|
||||||
|
|
||||||
|
func handleErr(err error) {
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Fprintf(os.Stderr, "%s\n", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
module git.xbudex.com/buddy/open-hardware-monitor
|
||||||
|
|
||||||
|
go 1.13
|
||||||
|
|
||||||
|
require github.com/urfave/cli v1.22.1
|
@ -0,0 +1,12 @@
|
|||||||
|
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
|
||||||
|
github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d h1:U+s90UTSYgptZMwQh2aRr3LuazLJIa+Pg3Kc1ylSYVY=
|
||||||
|
github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU=
|
||||||
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
|
github.com/russross/blackfriday/v2 v2.0.1 h1:lPqVAte+HuHNfhJ/0LC98ESWRz8afy9tM/0RK8m9o+Q=
|
||||||
|
github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
|
||||||
|
github.com/shurcooL/sanitized_anchor_name v1.0.0 h1:PdmoCO6wvbs+7yrJyMORt4/BmY5IYyJwS/kOiWx8mHo=
|
||||||
|
github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc=
|
||||||
|
github.com/urfave/cli v1.22.1 h1:+mkCCcOFKPnCmVYVcURKps1Xe+3zP90gSYGNfRkjoIY=
|
||||||
|
github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0=
|
||||||
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
|
gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
@ -0,0 +1,98 @@
|
|||||||
|
package app
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"git.xbudex.com/buddy/open-hardware-monitor/lib/client"
|
||||||
|
"github.com/urfave/cli"
|
||||||
|
)
|
||||||
|
|
||||||
|
// App context
|
||||||
|
type App struct {
|
||||||
|
cli *cli.App
|
||||||
|
client *client.Client
|
||||||
|
out io.Writer
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
// FlagHost flag for host
|
||||||
|
FlagHost = cli.StringFlag{
|
||||||
|
Name: "host",
|
||||||
|
EnvVar: "OHWM_HOST",
|
||||||
|
Value: "127.0.0.1:8085",
|
||||||
|
Usage: "open hardware monitor host [OSHW_HOST]",
|
||||||
|
}
|
||||||
|
|
||||||
|
// FlagScheme flag for host
|
||||||
|
FlagScheme = cli.StringFlag{
|
||||||
|
Name: "scheme",
|
||||||
|
EnvVar: "OHWM_SCHEME",
|
||||||
|
Value: "http",
|
||||||
|
Usage: "open hardware monitor scheme (http/https)",
|
||||||
|
}
|
||||||
|
|
||||||
|
// FlagPath flag for path url
|
||||||
|
FlagPath = cli.StringFlag{
|
||||||
|
Name: "path",
|
||||||
|
EnvVar: "OHWM_PATH",
|
||||||
|
Value: "/data.json",
|
||||||
|
Usage: "open hardware monitor path (ie /data.json)",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
// New returns instance of an app
|
||||||
|
func New() *App {
|
||||||
|
cliapp := cli.NewApp()
|
||||||
|
app := &App{
|
||||||
|
out: os.Stdout,
|
||||||
|
cli: cliapp,
|
||||||
|
}
|
||||||
|
app.cli.Flags = []cli.Flag{
|
||||||
|
FlagHost,
|
||||||
|
FlagScheme,
|
||||||
|
FlagPath,
|
||||||
|
}
|
||||||
|
app.cli.Before = app.before
|
||||||
|
return app
|
||||||
|
}
|
||||||
|
|
||||||
|
// Before sets up app
|
||||||
|
func (a *App) before(ctx *cli.Context) error {
|
||||||
|
a.client = &client.Client{
|
||||||
|
URL: url.URL{
|
||||||
|
Scheme: ctx.String("scheme"),
|
||||||
|
Host: ctx.String("host"),
|
||||||
|
Path: ctx.String("path"),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *App) clientAction(_ *cli.Context) error {
|
||||||
|
node, err := a.client.Fetch()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fmt.Fprint(a.out, node.String())
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *App) actionMetrics(_ *cli.Context) error {
|
||||||
|
fmt.Fprintln(a.out, "todo")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// RunClient runs client action
|
||||||
|
func (a *App) RunClient(args []string) error {
|
||||||
|
a.cli.Action = a.clientAction
|
||||||
|
return a.cli.Run(args)
|
||||||
|
}
|
||||||
|
|
||||||
|
// RunMetrics runs metrics server
|
||||||
|
func (a *App) RunMetrics(args []string) error {
|
||||||
|
a.cli.Action = a.actionMetrics
|
||||||
|
return a.cli.Run(args)
|
||||||
|
}
|
@ -0,0 +1,73 @@
|
|||||||
|
package client
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Client for open hardware monitor
|
||||||
|
type Client struct {
|
||||||
|
Timeout time.Duration
|
||||||
|
URL url.URL
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fetch requests
|
||||||
|
func (c *Client) Fetch() (*Node, error) {
|
||||||
|
client := http.Client{Timeout: c.Timeout}
|
||||||
|
resp, err := client.Get(c.URL.String())
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
return c.Decode(resp.Body)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Decode json
|
||||||
|
func (c *Client) Decode(r io.Reader) (*Node, error) {
|
||||||
|
node := &Node{}
|
||||||
|
decoder := json.NewDecoder(r)
|
||||||
|
if err := decoder.Decode(node); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return node, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Node from data
|
||||||
|
type Node struct {
|
||||||
|
ID int `json:"id"`
|
||||||
|
ImageURL string
|
||||||
|
Max string
|
||||||
|
Min string
|
||||||
|
Text string
|
||||||
|
Value string
|
||||||
|
Children []Node
|
||||||
|
}
|
||||||
|
|
||||||
|
func (n *Node) String() string {
|
||||||
|
return n.stringify(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (n *Node) stringify(indent int) string {
|
||||||
|
prefix := ""
|
||||||
|
for i := 0; i < indent; i++ {
|
||||||
|
prefix += " "
|
||||||
|
}
|
||||||
|
|
||||||
|
ret := prefix + n.Text
|
||||||
|
if n.Value != "" {
|
||||||
|
ret += ": " + n.Value
|
||||||
|
}
|
||||||
|
if n.Max != "" && n.Min != "" && n.Max != "-" && n.Min != "-" {
|
||||||
|
ret += fmt.Sprintf(" (%s - %s)", n.Min, n.Max)
|
||||||
|
}
|
||||||
|
ret += "\n"
|
||||||
|
for _, child := range n.Children {
|
||||||
|
ret += child.stringify(indent + 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret
|
||||||
|
}
|
@ -1,103 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/json"
|
|
||||||
"flag"
|
|
||||||
"fmt"
|
|
||||||
"log"
|
|
||||||
"net/http"
|
|
||||||
"net/url"
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
if err := run(); err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const (
|
|
||||||
hostDefault = "127.0.0.1:8085"
|
|
||||||
hostDesc = "open hardware monitor host [OSHW_HOST]"
|
|
||||||
)
|
|
||||||
|
|
||||||
func run() error {
|
|
||||||
conifg := getConfig()
|
|
||||||
node, err := fetchNode(conifg.host)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
fmt.Printf("%s", node)
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
type config struct {
|
|
||||||
host string
|
|
||||||
}
|
|
||||||
|
|
||||||
func getConfig() *config {
|
|
||||||
c := config{}
|
|
||||||
host := os.Getenv("OHWM_HOST")
|
|
||||||
hostFlag := flag.String("host", hostDefault, hostDesc)
|
|
||||||
flag.Parse()
|
|
||||||
if *hostFlag != hostDefault {
|
|
||||||
host = *hostFlag
|
|
||||||
}
|
|
||||||
if host == "" {
|
|
||||||
host = hostDefault
|
|
||||||
}
|
|
||||||
c.host = host
|
|
||||||
return &c
|
|
||||||
}
|
|
||||||
|
|
||||||
func fetchNode(host string) (*node, error) {
|
|
||||||
client := http.Client{Timeout: time.Second}
|
|
||||||
u := url.URL{Scheme: "http", Host: host, Path: "/data.json"}
|
|
||||||
resp, err := client.Get(u.String())
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
node := &node{}
|
|
||||||
decoder := json.NewDecoder(resp.Body)
|
|
||||||
if err := decoder.Decode(node); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return node, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
type node struct {
|
|
||||||
ID int `json:"id"`
|
|
||||||
ImageURL string
|
|
||||||
Max string
|
|
||||||
Min string
|
|
||||||
Text string
|
|
||||||
Value string
|
|
||||||
Children []node
|
|
||||||
}
|
|
||||||
|
|
||||||
func (n *node) String() string {
|
|
||||||
return n.stringify(0)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (n *node) stringify(indent int) string {
|
|
||||||
prefix := ""
|
|
||||||
for i := 0; i < indent; i++ {
|
|
||||||
prefix += " "
|
|
||||||
}
|
|
||||||
|
|
||||||
ret := prefix + n.Text
|
|
||||||
if n.Value != "" {
|
|
||||||
ret += ": " + n.Value
|
|
||||||
}
|
|
||||||
if n.Max != "" && n.Min != "" && n.Max != "-" && n.Min != "-" {
|
|
||||||
ret += fmt.Sprintf(" (%s - %s)", n.Min, n.Max)
|
|
||||||
}
|
|
||||||
ret += "\n"
|
|
||||||
for _, child := range n.Children {
|
|
||||||
ret += child.stringify(indent + 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret
|
|
||||||
}
|
|
Loading…
Reference in New Issue