1
0
mirror of https://github.com/taigrr/wtf synced 2025-01-18 04:03:14 -08:00

Added simple jenkins module that enables watching jenkins views build status

This commit is contained in:
DavidB 2018-06-09 20:49:12 +03:00
parent 5e13618813
commit eb547136cf
5 changed files with 169 additions and 0 deletions

64
jenkins/client.go Normal file
View File

@ -0,0 +1,64 @@
package jenkins
import (
"bytes"
"encoding/json"
"io"
"io/ioutil"
"net/http"
"net/url"
"strings"
)
func Create(jenkinsURL string, username string, apiKey string) (*View, error) {
const apiSuffix = "api/json?pretty=true"
parsedSuffix, err := url.Parse(apiSuffix)
if err != nil {
return &View{}, err
}
parsedJenkinsURL, err := url.Parse(ensureLastSlash(jenkinsURL))
if err != nil {
return &View{}, err
}
jenkinsAPIURL := parsedJenkinsURL.ResolveReference(parsedSuffix)
req, err := http.NewRequest("GET", jenkinsAPIURL.String(), nil)
req.SetBasicAuth(username, apiKey)
httpClient := &http.Client{}
resp, err := httpClient.Do(req)
if err != nil {
return &View{}, err
}
view := &View{}
parseJson(view, resp.Body)
return view, nil
}
func ensureLastSlash(URL string) string {
return strings.TrimRight(URL, "/") + "/"
}
/* -------------------- Unexported Functions -------------------- */
func parseJson(obj interface{}, text io.Reader) {
jsonStream, err := ioutil.ReadAll(text)
if err != nil {
panic(err)
}
decoder := json.NewDecoder(bytes.NewReader(jsonStream))
for {
if err := decoder.Decode(obj); err == io.EOF {
break
} else if err != nil {
panic(err)
}
}
}

8
jenkins/job.go Normal file
View File

@ -0,0 +1,8 @@
package jenkins
type Job struct {
Class string `json:"_class"`
Name string `json:"name"`
Url string `json:"url"`
Color string `json:"color"`
}

10
jenkins/view.go Normal file
View File

@ -0,0 +1,10 @@
package jenkins
type View struct {
Class string `json:"_class"`
Description string `json:"description"`
Jobs []Job `json:"jobs"`
Name string `json:"name"`
Property []string `json:"property"`
url string `json:"url"`
}

83
jenkins/widget.go Normal file
View File

@ -0,0 +1,83 @@
package jenkins
import (
"fmt"
"github.com/olebedev/config"
"github.com/senorprogrammer/wtf/wtf"
"os"
)
// Config is a pointer to the global config object
var Config *config.Config
type Widget struct {
wtf.TextWidget
}
func NewWidget() *Widget {
widget := Widget{
TextWidget: wtf.NewTextWidget("Jenkins", "jenkins", false),
}
return &widget
}
/* -------------------- Exported Functions -------------------- */
func (widget *Widget) Refresh() {
if widget.Disabled() {
return
}
view, err := Create(Config.UString("wtf.mods.jenkins.url"),
Config.UString("wtf.mods.jenkins.user"), os.Getenv("WTF_JENKINS_API_KEY"))
widget.UpdateRefreshedAt()
widget.View.Clear()
if err != nil {
widget.View.SetWrap(true)
widget.View.SetTitle(fmt.Sprintf(" %s ", widget.Name))
fmt.Fprintf(widget.View, "%v", err)
} else {
widget.View.SetWrap(false)
widget.View.SetTitle(
fmt.Sprintf(
" %s: [green] ",
widget.Name,
),
)
fmt.Fprintf(widget.View, "%s", widget.contentFrom(view))
}
}
/* -------------------- Unexported Functions -------------------- */
func (widget *Widget) contentFrom(view *View) string {
str := fmt.Sprintf(" [red]%s[white]\n", view.Name);
for _, job := range view.Jobs {
str = str + fmt.Sprintf(
" [%s]%-6s[white]\n",
widget.jobColor(&job),
job.Name,
)
}
return str
}
func (widget *Widget) jobColor(job *Job) string {
var color string
switch job.Color {
case "blue":
color = "green"
case "red":
color = "red"
default:
color = "white"
}
return color
}

4
wtf.go
View File

@ -23,6 +23,7 @@ import (
"github.com/senorprogrammer/wtf/gspreadsheets" "github.com/senorprogrammer/wtf/gspreadsheets"
"github.com/senorprogrammer/wtf/help" "github.com/senorprogrammer/wtf/help"
"github.com/senorprogrammer/wtf/ipinfo" "github.com/senorprogrammer/wtf/ipinfo"
"github.com/senorprogrammer/wtf/jenkins"
"github.com/senorprogrammer/wtf/jira" "github.com/senorprogrammer/wtf/jira"
"github.com/senorprogrammer/wtf/newrelic" "github.com/senorprogrammer/wtf/newrelic"
"github.com/senorprogrammer/wtf/opsgenie" "github.com/senorprogrammer/wtf/opsgenie"
@ -191,6 +192,8 @@ func addWidget(app *tview.Application, pages *tview.Pages, widgetName string) {
Widgets = append(Widgets, gspreadsheets.NewWidget()) Widgets = append(Widgets, gspreadsheets.NewWidget())
case "ipinfo": case "ipinfo":
Widgets = append(Widgets, ipinfo.NewWidget()) Widgets = append(Widgets, ipinfo.NewWidget())
case "jenkins":
Widgets = append(Widgets, jenkins.NewWidget())
case "jira": case "jira":
Widgets = append(Widgets, jira.NewWidget()) Widgets = append(Widgets, jira.NewWidget())
case "newrelic": case "newrelic":
@ -232,6 +235,7 @@ func makeWidgets(app *tview.Application, pages *tview.Pages) {
github.Config = Config github.Config = Config
gspreadsheets.Config = Config gspreadsheets.Config = Config
ipinfo.Config = Config ipinfo.Config = Config
jenkins.Config = Config
jira.Config = Config jira.Config = Config
newrelic.Config = Config newrelic.Config = Config
opsgenie.Config = Config opsgenie.Config = Config