mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-04 02:30:45 +00:00
* Squashed 'tools/' changes from e9e7e6b..db5efc0db5efc0Merge pull request #28 from weaveworks/mike/add-image-tag5312c40Import image-tag script into build tools so it can be shared7e850f8Fix logs pathdda9785Update deploy apif2f4e5bFix the wcloud client3925eb6Merge pull request #27 from weaveworks/wcloud-events77355b9Lintd9a1c6cAdd wcloud events, update flags and error nicely when there is no config git-subtree-dir: tools git-subtree-split:db5efc0537* Remove ./image-tag and use ./tools/image-tag instead image-tag is now shared code from the build-tools repo
204 lines
3.8 KiB
Go
204 lines
3.8 KiB
Go
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"flag"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/olekukonko/tablewriter"
|
|
"gopkg.in/yaml.v2"
|
|
)
|
|
|
|
func env(key, def string) string {
|
|
if val, ok := os.LookupEnv(key); ok {
|
|
return val
|
|
}
|
|
return def
|
|
}
|
|
|
|
var (
|
|
token = env("SERVICE_TOKEN", "")
|
|
baseURL = env("BASE_URL", "https://cloud.weave.works")
|
|
)
|
|
|
|
func usage() {
|
|
fmt.Println(`Usage:
|
|
deploy <image>:<version> Deploy image to your configured env
|
|
list List recent deployments
|
|
config (<filename>) Get (or set) the configured env
|
|
logs <deploy> Show lots for the given deployment`)
|
|
}
|
|
|
|
func main() {
|
|
if len(os.Args) <= 1 {
|
|
usage()
|
|
os.Exit(1)
|
|
}
|
|
|
|
c := NewClient(token, baseURL)
|
|
|
|
switch os.Args[1] {
|
|
case "deploy":
|
|
deploy(c, os.Args[2:])
|
|
case "list":
|
|
list(c, os.Args[2:])
|
|
case "config":
|
|
config(c, os.Args[2:])
|
|
case "logs":
|
|
logs(c, os.Args[2:])
|
|
case "events":
|
|
events(c, os.Args[2:])
|
|
case "help":
|
|
usage()
|
|
default:
|
|
usage()
|
|
}
|
|
}
|
|
|
|
func deploy(c Client, args []string) {
|
|
if len(args) != 1 {
|
|
usage()
|
|
return
|
|
}
|
|
parts := strings.SplitN(args[0], ":", 2)
|
|
if len(parts) < 2 {
|
|
usage()
|
|
return
|
|
}
|
|
deployment := Deployment{
|
|
ImageName: parts[0],
|
|
Version: parts[1],
|
|
}
|
|
if err := c.Deploy(deployment); err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
func list(c Client, args []string) {
|
|
var (
|
|
flags = flag.NewFlagSet("", flag.ContinueOnError)
|
|
since = flags.Duration("since", 7*24*time.Hour, "How far back to fetch results")
|
|
)
|
|
if err := flags.Parse(args); err != nil {
|
|
usage()
|
|
return
|
|
}
|
|
through := time.Now()
|
|
from := through.Add(-*since)
|
|
deployments, err := c.GetDeployments(from.Unix(), through.Unix())
|
|
if err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
table := tablewriter.NewWriter(os.Stdout)
|
|
table.SetHeader([]string{"Created", "ID", "Image", "Version", "State"})
|
|
table.SetBorder(false)
|
|
table.SetColumnSeparator(" ")
|
|
for _, deployment := range deployments {
|
|
table.Append([]string{
|
|
deployment.CreatedAt.Format(time.RFC822),
|
|
deployment.ID,
|
|
deployment.ImageName,
|
|
deployment.Version,
|
|
deployment.State,
|
|
})
|
|
}
|
|
table.Render()
|
|
}
|
|
|
|
func events(c Client, args []string) {
|
|
var (
|
|
flags = flag.NewFlagSet("", flag.ContinueOnError)
|
|
since = flags.Duration("since", 7*24*time.Hour, "How far back to fetch results")
|
|
)
|
|
if err := flags.Parse(args); err != nil {
|
|
usage()
|
|
return
|
|
}
|
|
through := time.Now()
|
|
from := through.Add(-*since)
|
|
events, err := c.GetEvents(from.Unix(), through.Unix())
|
|
if err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
fmt.Println("events: ", string(events))
|
|
}
|
|
|
|
func loadConfig(filename string) (*Config, error) {
|
|
extension := filepath.Ext(filename)
|
|
var config Config
|
|
buf, err := ioutil.ReadFile(filename)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if extension == ".yaml" || extension == ".yml" {
|
|
if err := yaml.Unmarshal(buf, &config); err != nil {
|
|
return nil, err
|
|
}
|
|
} else {
|
|
if err := json.NewDecoder(bytes.NewReader(buf)).Decode(&config); err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
return &config, nil
|
|
}
|
|
|
|
func config(c Client, args []string) {
|
|
if len(args) > 1 {
|
|
usage()
|
|
return
|
|
}
|
|
|
|
if len(args) == 1 {
|
|
config, err := loadConfig(args[0])
|
|
if err != nil {
|
|
fmt.Println("Error reading config:", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
if err := c.SetConfig(config); err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
} else {
|
|
config, err := c.GetConfig()
|
|
if err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
buf, err := yaml.Marshal(config)
|
|
if err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
fmt.Println(string(buf))
|
|
}
|
|
}
|
|
|
|
func logs(c Client, args []string) {
|
|
if len(args) != 1 {
|
|
usage()
|
|
return
|
|
}
|
|
|
|
output, err := c.GetLogs(args[0])
|
|
if err != nil {
|
|
fmt.Println(err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
fmt.Println(string(output))
|
|
}
|