代码拉取完成,页面将自动刷新
package jenkins
import (
"bytes"
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strconv"
"strings"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
)
var (
ErrNotFound = errors.New("Not Found")
ErrCreateJobFail = errors.New("Create Job fail")
ErrUpdateJobFail = errors.New("Update Job fail")
ErrStopJobFail = errors.New("Stop Job fail")
ErrDeleteBuildFail = errors.New("Delete Build fail")
ErrBuildJobFail = errors.New("Build Job fail")
ErrGetBuildInfoFail = errors.New("Get Build Info fail")
ErrGetJobInfoFail = errors.New("Get Job Info fail")
)
type Client struct {
API string
User string
Token string
CrumbHeader string
CrumbBody string
}
func New(api string, user string, token string) (*Client, error) {
c := &Client{
API: api,
User: user,
Token: token,
}
if err := c.getCSRF(); err != nil {
return nil, err
}
return c, nil
}
func (c *Client) getCSRF() error {
getCrumbURL, err := url.Parse(c.API + GetCrumbURI)
if err != nil {
return err
}
req, _ := http.NewRequest(http.MethodGet, getCrumbURL.String(), nil)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
data, _ := ioutil.ReadAll(resp.Body)
Crumbs := strings.Split(string(data), ":")
if len(Crumbs) != 2 {
return errors.New("error get crumbs from jenkins")
}
c.CrumbHeader = Crumbs[0]
c.CrumbBody = Crumbs[1]
return nil
}
//deleteBuild deletes the last build of a job
func (c *Client) deleteBuild(jobname string, buildNumber int) error {
deleteBuildURI := fmt.Sprintf(DeleteBuildURI, jobname, buildNumber)
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + deleteBuildURI)
if err != nil {
return err
}
req, _ := http.NewRequest(http.MethodPost, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return ErrDeleteBuildFail
}
return nil
}
func (c *Client) execScript(script string) (string, error) {
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + ScriptURI)
if err != nil {
return "", err
}
v := url.Values{}
v.Add("script", script)
req, _ := http.NewRequest(http.MethodPost, targetURL.String(), bytes.NewBufferString(v.Encode()))
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return "", err
}
defer resp.Body.Close()
data, err := ioutil.ReadAll(resp.Body)
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return string(data), fmt.Errorf("jenkins run script fail,response code is :%v", resp.StatusCode)
}
return string(data), nil
}
func (c *Client) createJob(jobname string, content []byte) error {
createJobURL, err := url.Parse(c.API + CreateJobURI)
if err != nil {
return err
}
qry := createJobURL.Query()
qry.Add("name", jobname)
createJobURL.RawQuery = qry.Encode()
//send request part
req, _ := http.NewRequest(http.MethodPost, createJobURL.String(), bytes.NewReader(content))
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.Header.Set("Content-Type", "application/xml")
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
data, _ := ioutil.ReadAll(resp.Body)
logrus.Debug(string(data))
return fmt.Errorf("create job get response:%v", resp.StatusCode)
}
return nil
}
func (c *Client) updateJob(jobname string, content []byte) error {
updateJobURI := fmt.Sprintf(UpdateJobURI, jobname)
updateJobURL, err := url.Parse(c.API + updateJobURI)
if err != nil {
return err
}
//send request part
req, _ := http.NewRequest(http.MethodPost, updateJobURL.String(), bytes.NewReader(content))
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.Header.Set("Content-Type", "application/xml")
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
data, _ := ioutil.ReadAll(resp.Body)
logrus.Debug(string(data))
return fmt.Errorf("update job get response:%v", resp.StatusCode)
}
return nil
}
func (c *Client) buildJob(jobname string, params map[string]string) (string, error) {
buildURI := fmt.Sprintf(JenkinsJobBuildURI, jobname)
var targetURL *url.URL
targetURL, err := url.Parse(c.API + buildURI)
if err != nil {
return "", err
}
req, _ := http.NewRequest(http.MethodPost, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return "", err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return "", ErrBuildJobFail
}
logrus.Debugf("job queue is %s", resp.Header.Get("location"))
return "", nil
}
func (c *Client) getBuildInfo(jobname string) (*BuildInfo, error) {
buildInfoURI := fmt.Sprintf(JenkinsBuildInfoURI, jobname)
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + buildInfoURI)
if err != nil {
return nil, err
}
req, _ := http.NewRequest(http.MethodPost, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
if resp.StatusCode == 404 {
return nil, ErrNotFound
}
return nil, ErrGetBuildInfoFail
}
buildInfo := &BuildInfo{}
respBytes, err := ioutil.ReadAll(resp.Body)
err = json.Unmarshal(respBytes, buildInfo)
if err != nil {
return nil, err
}
return buildInfo, nil
}
func (c *Client) getJobInfo(jobname string) (*JobInfo, error) {
jobInfoURI := fmt.Sprintf(JenkinsJobInfoURI, jobname)
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + jobInfoURI)
if err != nil {
return nil, err
}
req, _ := http.NewRequest(http.MethodGet, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
if resp.StatusCode == 404 {
return nil, ErrNotFound
}
return nil, ErrGetJobInfoFail
}
jobInfo := &JobInfo{}
respBytes, err := ioutil.ReadAll(resp.Body)
err = json.Unmarshal(respBytes, jobInfo)
if err != nil {
return nil, err
}
return jobInfo, nil
}
func (c *Client) getBuildRawOutput(jobname string, buildNumber int, startLine int) (string, error) {
buildRawOutputURI := fmt.Sprintf(JenkinsBuildLogURI, jobname, buildNumber)
if startLine > 0 {
buildRawOutputURI += "&startLine=" + strconv.Itoa(startLine)
}
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + buildRawOutputURI)
if err != nil {
return "", err
}
req, _ := http.NewRequest(http.MethodGet, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return "", err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return "", ErrGetJobInfoFail
}
respBytes, err := ioutil.ReadAll(resp.Body)
return string(respBytes), nil
}
func (c *Client) stopJob(jobname string, buildNumber int) error {
stopJobURI := fmt.Sprintf(StopJobURI, jobname, buildNumber)
targetURL, err := url.Parse(c.API + stopJobURI)
if err != nil {
return err
}
req, _ := http.NewRequest(http.MethodPost, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return ErrStopJobFail
}
return nil
}
func (c *Client) cancelQueueItem(id int) error {
cancelQueueItemURI := fmt.Sprintf(CancelQueueItemURI, id)
targetURL, err := url.Parse(c.API + cancelQueueItemURI)
if err != nil {
return err
}
req, _ := http.NewRequest(http.MethodPost, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{
CheckRedirect: func(req *http.Request, via []*http.Request) error {
//no redirect
return http.ErrUseLastResponse
},
}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return ErrStopJobFail
}
return nil
}
func (c *Client) getWFBuildInfo(jobname string) (*WFBuildInfo, error) {
buildInfoURI := fmt.Sprintf(JenkinsWFBuildInfoURI, jobname)
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + buildInfoURI)
if err != nil {
return nil, err
}
req, _ := http.NewRequest(http.MethodGet, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return nil, ErrGetBuildInfoFail
}
buildInfo := &WFBuildInfo{}
respBytes, err := ioutil.ReadAll(resp.Body)
err = json.Unmarshal(respBytes, buildInfo)
if err != nil {
return nil, err
}
return buildInfo, nil
}
func (c *Client) getWFNodeInfo(jobname string, nodeID string) (*WFNodeInfo, error) {
nodeInfoURI := fmt.Sprintf(JenkinsWFNodeInfoURI, jobname, nodeID)
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + nodeInfoURI)
if err != nil {
return nil, err
}
req, _ := http.NewRequest(http.MethodGet, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return nil, errors.New("Error get jenkins node info")
}
nodeInfo := &WFNodeInfo{}
respBytes, err := ioutil.ReadAll(resp.Body)
err = json.Unmarshal(respBytes, nodeInfo)
if err != nil {
return nil, err
}
return nodeInfo, nil
}
func (c *Client) getWFNodeLog(jobname string, nodeID string) (*WFNodeLog, error) {
nodeLogURI := fmt.Sprintf(JenkinsWFNodeLogURI, jobname, nodeID)
var targetURL *url.URL
var err error
targetURL, err = url.Parse(c.API + nodeLogURI)
if err != nil {
return nil, err
}
req, _ := http.NewRequest(http.MethodGet, targetURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return nil, errors.New("Error get jenkins node log")
}
nodeLog := &WFNodeLog{}
respBytes, err := ioutil.ReadAll(resp.Body)
err = json.Unmarshal(respBytes, nodeLog)
if err != nil {
return nil, err
}
return nodeLog, nil
}
func (c *Client) createCredential(content []byte) error {
setCredURL, err := url.Parse(c.API + JenkinsSetCredURI)
if err != nil {
return err
}
req, _ := http.NewRequest(http.MethodPost, setCredURL.String(), bytes.NewReader(content))
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
return errors.New("create credential fail")
}
return nil
}
func (c *Client) getCredential(credentialID string) error {
getCredURI := fmt.Sprintf(JenkinsGetCredURI, credentialID)
getCredURL, err := url.Parse(c.API + getCredURI)
if err != nil {
return err
}
req, _ := http.NewRequest(http.MethodGet, getCredURL.String(), nil)
req.Header.Add(c.CrumbHeader, c.CrumbBody)
req.SetBasicAuth(c.User, c.Token)
client := http.Client{}
resp, err := client.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode < 200 || resp.StatusCode >= 400 {
if resp.StatusCode == 404 {
return ErrNotFound
}
return fmt.Errorf("Error create credential - got status code %v", resp.StatusCode)
}
return nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。