Documentation ¶
Overview ¶
Gojenkins is a Jenkins Client in Go, that exposes the jenkins REST api in a more developer friendly way.
Gojenkins is a Jenkins Client in Go, that exposes the jenkins REST api in a more developer friendly way.
Index ¶
- Constants
- Variables
- type APIRequest
- type APIToken
- type APITokenGenerateResponse
- type Artifact
- type BasicAuth
- type Build
- func (b *Build) GetActions() []generalObj
- func (b *Build) GetAllFingerPrints(ctx context.Context) []*FingerPrint
- func (b *Build) GetArtifacts() []Artifact
- func (b *Build) GetBuildNumber() int64
- func (b *Build) GetCauses(ctx context.Context) ([]map[string]interface{}, error)
- func (b *Build) GetConsoleOutput(ctx context.Context) string
- func (b *Build) GetConsoleOutputFromIndex(ctx context.Context, startID int64) (consoleResponse, error)
- func (b *Build) GetCulprits() []Culprit
- func (b *Build) GetDownstreamBuilds(ctx context.Context) ([]*Build, error)
- func (b *Build) GetDownstreamJobNames(ctx context.Context) []string
- func (b *Build) GetDuration() float64
- func (b *Build) GetInjectedEnvVars(ctx context.Context) (map[string]string, error)
- func (b *Build) GetMatrixRuns(ctx context.Context) ([]*Build, error)
- func (b *Build) GetParameters() []parameter
- func (b *Build) GetResult() string
- func (b *Build) GetResultSet(ctx context.Context) (*TestResult, error)
- func (b *Build) GetRevision() string
- func (b *Build) GetRevisionBranch() string
- func (b *Build) GetTimestamp() time.Time
- func (b *Build) GetUpstreamBuild(ctx context.Context) (*Build, error)
- func (b *Build) GetUpstreamBuildNumber(ctx context.Context) (int64, error)
- func (b *Build) GetUpstreamJob(ctx context.Context) (*Job, error)
- func (b *Build) GetUrl() string
- func (b *Build) Info() *BuildResponse
- func (b *Build) IsGood(ctx context.Context) bool
- func (b *Build) IsRunning(ctx context.Context) bool
- func (b *Build) Poll(ctx context.Context, options ...interface{}) (int, error)
- func (b *Build) SetDescription(ctx context.Context, description string) error
- func (b *Build) Stop(ctx context.Context) (bool, error)
- type BuildResponse
- type BuildRevision
- type Builds
- type Computers
- type CredentialsManager
- func (cm CredentialsManager) Add(ctx context.Context, domain string, creds interface{}) error
- func (cm CredentialsManager) Delete(ctx context.Context, domain string, id string) error
- func (cm CredentialsManager) GetSingle(ctx context.Context, domain string, id string, creds interface{}) error
- func (cm CredentialsManager) List(ctx context.Context, domain string) ([]string, error)
- func (cm CredentialsManager) Update(ctx context.Context, domain string, id string, creds interface{}) error
- type Culprit
- type DockerServerCredentials
- type ErrAPIToken
- type ErrUser
- type Executor
- type ExecutorResponse
- type FileCredentials
- type FingerPrint
- func (f FingerPrint) GetInfo(ctx context.Context) (*FingerPrintResponse, error)
- func (f FingerPrint) Poll(ctx context.Context) (int, error)
- func (f FingerPrint) Valid(ctx context.Context) (bool, error)
- func (f FingerPrint) ValidateForBuild(ctx context.Context, filename string, build *Build) (bool, error)
- type FingerPrintResponse
- type Folder
- type FolderResponse
- type History
- type InnerJob
- type Jenkins
- func (j *Jenkins) BuildJob(ctx context.Context, name string, params map[string]string) (int64, error)
- func (j *Jenkins) CopyJob(ctx context.Context, copyFrom string, newName string) (*Job, error)
- func (j *Jenkins) CreateFolder(ctx context.Context, name string, parents ...string) (*Folder, error)
- func (j *Jenkins) CreateJob(ctx context.Context, config string, options ...interface{}) (*Job, error)
- func (j *Jenkins) CreateJobInFolder(ctx context.Context, config string, jobName string, parentIDs ...string) (*Job, error)
- func (j *Jenkins) CreateNode(ctx context.Context, name string, numExecutors int, description string, ...) (*Node, error)
- func (j *Jenkins) CreateUser(ctx context.Context, userName, password, fullName, email string) (User, error)
- func (j *Jenkins) CreateView(ctx context.Context, name string, viewType string) (*View, error)
- func (j *Jenkins) DeleteJob(ctx context.Context, name string) (bool, error)
- func (j *Jenkins) DeleteNode(ctx context.Context, name string) (bool, error)
- func (j *Jenkins) DeleteUser(ctx context.Context, userName string) error
- func (j *Jenkins) GenerateAPIToken(ctx context.Context, tokenName string) (APIToken, error)
- func (j *Jenkins) GetAllBuildIds(ctx context.Context, job string) ([]JobBuild, error)
- func (j *Jenkins) GetAllJobNames(ctx context.Context) ([]InnerJob, error)
- func (j *Jenkins) GetAllJobs(ctx context.Context) ([]*Job, error)
- func (j *Jenkins) GetAllNodes(ctx context.Context) ([]*Node, error)
- func (j *Jenkins) GetAllViews(ctx context.Context) ([]*View, error)
- func (j *Jenkins) GetArtifactData(ctx context.Context, id string) (*FingerPrintResponse, error)
- func (j *Jenkins) GetBuild(ctx context.Context, jobName string, number int64) (*Build, error)
- func (j *Jenkins) GetBuildFromQueueID(ctx context.Context, job *Job, queueid int64) (*Build, error)
- func (j *Jenkins) GetFolder(ctx context.Context, id string, parents ...string) (*Folder, error)
- func (j *Jenkins) GetJob(ctx context.Context, id string, parentIDs ...string) (*Job, error)
- func (j *Jenkins) GetJobObj(ctx context.Context, name string) *Job
- func (j *Jenkins) GetLabel(ctx context.Context, name string) (*Label, error)
- func (j *Jenkins) GetNode(ctx context.Context, name string) (*Node, error)
- func (j *Jenkins) GetPlugins(ctx context.Context, depth int) (*Plugins, error)
- func (j *Jenkins) GetQueue(ctx context.Context) (*Queue, error)
- func (j *Jenkins) GetQueueItem(ctx context.Context, id int64) (*Task, error)
- func (j *Jenkins) GetQueueUrl() string
- func (j *Jenkins) GetSubJob(ctx context.Context, parentId string, childId string) (*Job, error)
- func (j *Jenkins) GetView(ctx context.Context, name string) (*View, error)
- func (j *Jenkins) HasPlugin(ctx context.Context, name string) (*Plugin, error)
- func (j *Jenkins) Info(ctx context.Context) (*ExecutorResponse, error)
- func (j *Jenkins) Init(ctx context.Context) (*Jenkins, error)
- func (j *Jenkins) InstallPlugin(ctx context.Context, name string, version string) error
- func (j *Jenkins) Poll(ctx context.Context) (int, error)
- func (j *Jenkins) RenameJob(ctx context.Context, job string, name string) *Job
- func (j *Jenkins) RevokeAPIToken(ctx context.Context, tokenUuid string) error
- func (j *Jenkins) RevokeAllAPITokens(ctx context.Context) error
- func (j *Jenkins) SafeRestart(ctx context.Context) error
- func (j *Jenkins) UninstallPlugin(ctx context.Context, name string) error
- func (j *Jenkins) UpdateJob(ctx context.Context, job string, config string) *Job
- func (j *Jenkins) ValidateFingerPrint(ctx context.Context, id string) (bool, error)
- type Job
- func (j *Job) Copy(ctx context.Context, destinationName string) (*Job, error)
- func (j *Job) Create(ctx context.Context, config string, qr ...interface{}) (*Job, error)
- func (j *Job) Delete(ctx context.Context) (bool, error)
- func (j *Job) Disable(ctx context.Context) (bool, error)
- func (j *Job) Enable(ctx context.Context) (bool, error)
- func (j *Job) GetAllBuildIds(ctx context.Context) ([]JobBuild, error)
- func (j *Job) GetBuild(ctx context.Context, id int64) (*Build, error)
- func (j *Job) GetBuildsFields(ctx context.Context, fields []string, custom interface{}) error
- func (j *Job) GetConfig(ctx context.Context) (string, error)
- func (j *Job) GetDescription() string
- func (j *Job) GetDetails() *JobResponse
- func (j *Job) GetDownstreamJobs(ctx context.Context) ([]*Job, error)
- func (j *Job) GetDownstreamJobsMetadata() []InnerJob
- func (j *Job) GetFirstBuild(ctx context.Context) (*Build, error)
- func (j *Job) GetInnerJob(ctx context.Context, id string) (*Job, error)
- func (j *Job) GetInnerJobs(ctx context.Context) ([]*Job, error)
- func (j *Job) GetInnerJobsMetadata() []InnerJob
- func (j *Job) GetLastBuild(ctx context.Context) (*Build, error)
- func (j *Job) GetLastCompletedBuild(ctx context.Context) (*Build, error)
- func (j *Job) GetLastFailedBuild(ctx context.Context) (*Build, error)
- func (j *Job) GetLastStableBuild(ctx context.Context) (*Build, error)
- func (j *Job) GetLastSuccessfulBuild(ctx context.Context) (*Build, error)
- func (j *Job) GetName() string
- func (j *Job) GetParameters(ctx context.Context) ([]ParameterDefinition, error)
- func (job *Job) GetPipelineRun(ctx context.Context, id string) (pr *PipelineRun, err error)
- func (job *Job) GetPipelineRuns(ctx context.Context) (pr []PipelineRun, err error)
- func (j *Job) GetUpstreamJobs(ctx context.Context) ([]*Job, error)
- func (j *Job) GetUpstreamJobsMetadata() []InnerJob
- func (j *Job) HasQueuedBuild()
- func (j *Job) History(ctx context.Context) ([]*History, error)
- func (j *Job) Invoke(ctx context.Context, files []string, skipIfRunning bool, ...) (bool, error)
- func (j *Job) InvokeSimple(ctx context.Context, params map[string]string) (int64, error)
- func (j *Job) IsEnabled(ctx context.Context) (bool, error)
- func (j *Job) IsQueued(ctx context.Context) (bool, error)
- func (j *Job) IsRunning(ctx context.Context) (bool, error)
- func (j *Job) Poll(ctx context.Context) (int, error)
- func (j *Job) Rename(ctx context.Context, name string) (bool, error)
- func (j *Job) UpdateConfig(ctx context.Context, config string) error
- type JobBuild
- type JobResponse
- type Label
- type LabelNode
- type LabelResponse
- type LeveledLogger
- type LeveledLoggerImpl
- type MODE
- type Node
- func (n *Node) Delete(ctx context.Context) (bool, error)
- func (n *Node) Disconnect(ctx context.Context) (int, error)
- func (n *Node) GetLogText(ctx context.Context) (string, error)
- func (n *Node) GetName() string
- func (n *Node) Info(ctx context.Context) (*NodeResponse, error)
- func (n *Node) IsIdle(ctx context.Context) (bool, error)
- func (n *Node) IsJnlpAgent(ctx context.Context) (bool, error)
- func (n *Node) IsOnline(ctx context.Context) (bool, error)
- func (n *Node) IsTemporarilyOffline(ctx context.Context) (bool, error)
- func (n *Node) LaunchNodeBySSH(ctx context.Context) (int, error)
- func (n *Node) Poll(ctx context.Context) (int, error)
- func (n *Node) SetOffline(ctx context.Context, options ...interface{}) (bool, error)
- func (n *Node) SetOnline(ctx context.Context) (bool, error)
- func (n *Node) ToggleTemporarilyOffline(ctx context.Context, options ...interface{}) (bool, error)
- type NodeResponse
- type ParameterDefinition
- type PipelineArtifact
- type PipelineInputAction
- type PipelineNode
- type PipelineNodeLog
- type PipelineRun
- func (pr *PipelineRun) AbortInput(ctx context.Context) (bool, error)
- func (pr *PipelineRun) GetArtifacts(ctx context.Context) (artifacts []PipelineArtifact, err error)
- func (pr *PipelineRun) GetNode(ctx context.Context, id string) (node *PipelineNode, err error)
- func (pr *PipelineRun) GetPendingInputActions(ctx context.Context) (PIAs []PipelineInputAction, err error)
- func (pr *PipelineRun) ProceedInput(ctx context.Context) (bool, error)
- type Plugin
- type PluginResponse
- type Plugins
- type PrivateKey
- type PrivateKeyFile
- type Queue
- type Requester
- func (r *Requester) Do(ctx context.Context, ar *APIRequest, responseStruct interface{}, ...) (resp *http.Response, err error)
- func (r *Requester) Get(ctx context.Context, endpoint string, responseStruct interface{}, ...) (*http.Response, error)
- func (r *Requester) GetJSON(ctx context.Context, endpoint string, responseStruct interface{}, ...) (*http.Response, error)
- func (r *Requester) GetXML(ctx context.Context, endpoint string, responseStruct interface{}, ...) (*http.Response, error)
- func (r *Requester) Post(ctx context.Context, endpoint string, payload io.Reader, ...) (*http.Response, error)
- func (r *Requester) PostFiles(ctx context.Context, endpoint string, payload io.Reader, ...) (*http.Response, error)
- func (r *Requester) PostJSON(ctx context.Context, endpoint string, payload io.Reader, ...) (*http.Response, error)
- func (r *Requester) PostXML(ctx context.Context, endpoint string, xml string, responseStruct interface{}, ...) (*http.Response, error)
- func (r *Requester) ReadJSONResponse(response *http.Response, responseStruct interface{}) (*http.Response, error)
- func (r *Requester) ReadRawResponse(response *http.Response, responseStruct interface{}) (*http.Response, error)
- func (r *Requester) SetClient(client *http.Client) *Requester
- func (r *Requester) SetCrumb(ctx context.Context, ar *APIRequest) error
- type SSHCredentials
- type StringCredentials
- type Task
- type TestResult
- type User
- type UsernameCredentials
- type View
- func (v *View) AddJob(ctx context.Context, name string) (bool, error)
- func (v *View) DeleteJob(ctx context.Context, name string) (bool, error)
- func (v *View) GetDescription() string
- func (v *View) GetJobs() []InnerJob
- func (v *View) GetName() string
- func (v *View) GetUrl() string
- func (v *View) Poll(ctx context.Context) (int, error)
- type ViewData
- type ViewResponse
Constants ¶
const ( STATUS_FAIL = "FAIL" STATUS_ERROR = "ERROR" STATUS_ABORTED = "ABORTED" STATUS_REGRESSION = "REGRESSION" STATUS_SUCCESS = "SUCCESS" STATUS_FIXED = "FIXED" STATUS_PASSED = "PASSED" RESULT_STATUS_FAILURE = "FAILURE" RESULT_STATUS_FAILED = "FAILED" RESULT_STATUS_SKIPPED = "SKIPPED" STR_RE_SPLIT_VIEW = "(.*)/view/([^/]*)/?" )
const ClassUsernameCredentials = "com.cloudbees.plugins.credentials.impl.UsernamePasswordCredentialsImpl"
ClassUsernameCredentials is name if java class which implements credentials that store username-password pair
const KeySourceDirectEntryType = "com.cloudbees.jenkins.plugins.sshcredentials.impl.BasicSSHUserPrivateKey$DirectEntryPrivateKeySource"
KeySourceDirectEntryType is used when secret in provided directly as private key value
const KeySourceOnMasterType = "com.cloudbees.jenkins.plugins.sshcredentials.impl.BasicSSHUserPrivateKey$FileOnMasterPrivateKeySource"
KeySourceOnMasterType is used when private key value is path to file on jenkins master
Variables ¶
var ( LIST_VIEW = "hudson.model.ListView" NESTED_VIEW = "hudson.plugins.nested_view.NestedView" MY_VIEW = "hudson.model.MyView" DASHBOARD_VIEW = "hudson.plugins.view.dashboard.Dashboard" PIPELINE_VIEW = "au.com.centrumsystems.hudson.plugin.buildpipeline.BuildPipelineView" )
Functions ¶
This section is empty.
Types ¶
type APIRequest ¶
type APIRequest struct { Method string Endpoint string Payload io.Reader Headers http.Header Suffix string }
func NewAPIRequest ¶
func NewAPIRequest(method string, endpoint string, payload io.Reader) *APIRequest
func (*APIRequest) SetHeader ¶
func (ar *APIRequest) SetHeader(key string, value string) *APIRequest
type APIToken ¶
type APIToken struct { Jenkins *Jenkins Name string `json:"tokenName"` UUID string `json:"tokenUuid"` Value string `json:"tokenValue"` }
APIToken is a Jenkins API token to be created for the user instantiated with the Jenkins client
type APITokenGenerateResponse ¶
APITokenGenerateResponse is the response given by Jenkins when an API token is created
type Artifact ¶
Represents an Artifact
type Build ¶
type Build struct { Raw *BuildResponse Job *Job Jenkins *Jenkins Base string Depth int }
func (*Build) GetActions ¶
func (b *Build) GetActions() []generalObj
func (*Build) GetAllFingerPrints ¶
func (b *Build) GetAllFingerPrints(ctx context.Context) []*FingerPrint
func (*Build) GetArtifacts ¶
func (*Build) GetBuildNumber ¶
func (*Build) GetConsoleOutputFromIndex ¶
func (*Build) GetCulprits ¶
func (*Build) GetDownstreamBuilds ¶
func (*Build) GetDownstreamJobNames ¶
func (*Build) GetDuration ¶
func (*Build) GetInjectedEnvVars ¶
func (*Build) GetParameters ¶
func (b *Build) GetParameters() []parameter
func (*Build) GetResultSet ¶
func (b *Build) GetResultSet(ctx context.Context) (*TestResult, error)
func (*Build) GetRevision ¶
func (*Build) GetRevisionBranch ¶
func (*Build) GetTimestamp ¶
func (*Build) GetUpstreamBuild ¶
func (*Build) GetUpstreamBuildNumber ¶
func (*Build) Poll ¶
Poll for current data. Optional parameter - depth. More about depth here: https://wiki.jenkins-ci.org/display/JENKINS/Remote+access+API
func (*Build) SetDescription ¶
type BuildResponse ¶
type BuildResponse struct { Actions []generalObj Artifacts []struct { DisplayPath string `json:"displayPath"` FileName string `json:"fileName"` RelativePath string `json:"relativePath"` } `json:"artifacts"` Building bool `json:"building"` BuiltOn string `json:"builtOn"` ChangeSet struct { Items []struct { AffectedPaths []string `json:"affectedPaths"` Author struct { AbsoluteUrl string `json:"absoluteUrl"` FullName string `json:"fullName"` } `json:"author"` Comment string `json:"comment"` CommitID string `json:"commitId"` Date string `json:"date"` ID string `json:"id"` Msg string `json:"msg"` Paths []struct { EditType string `json:"editType"` File string `json:"file"` } `json:"paths"` Timestamp int64 `json:"timestamp"` } `json:"items"` Kind string `json:"kind"` Revisions []struct { Module string Revision int } `json:"revision"` } `json:"changeSet"` ChangeSets []struct { Items []struct { AffectedPaths []string `json:"affectedPaths"` Author struct { AbsoluteUrl string `json:"absoluteUrl"` FullName string `json:"fullName"` } `json:"author"` Comment string `json:"comment"` CommitID string `json:"commitId"` Date string `json:"date"` ID string `json:"id"` Msg string `json:"msg"` Paths []struct { EditType string `json:"editType"` File string `json:"file"` } `json:"paths"` Timestamp int64 `json:"timestamp"` } `json:"items"` Kind string `json:"kind"` Revisions []struct { Module string Revision int } `json:"revision"` } `json:"changeSets"` Culprits []Culprit `json:"culprits"` Description interface{} `json:"description"` Duration float64 `json:"duration"` EstimatedDuration float64 `json:"estimatedDuration"` Executor interface{} `json:"executor"` DisplayName string `json:"displayName"` FullDisplayName string `json:"fullDisplayName"` ID string `json:"id"` KeepLog bool `json:"keepLog"` Number int64 `json:"number"` QueueID int64 `json:"queueId"` Result string `json:"result"` Timestamp int64 `json:"timestamp"` URL string `json:"url"` MavenArtifacts interface{} `json:"mavenArtifacts"` MavenVersionUsed string `json:"mavenVersionUsed"` FingerPrint []FingerPrintResponse Runs []struct { Number int64 URL string } `json:"runs"` }
type BuildRevision ¶
type BuildRevision struct { SHA1 string `json:"SHA1"` Branch []branch `json:"branch"` }
type Builds ¶
type Builds struct { BuildNumber int64 `json:"buildNumber"` BuildResult interface{} `json:"buildResult"` Marked BuildRevision `json:"marked"` Revision BuildRevision `json:"revision"` }
type Computers ¶
type Computers struct { BusyExecutors int `json:"busyExecutors"` Computers []*NodeResponse `json:"computer"` DisplayName string `json:"displayName"` TotalExecutors int `json:"totalExecutors"` }
type CredentialsManager ¶
CredentialsManager is utility to control credential plugin Credentials declared by it can be used in jenkins jobs
func (CredentialsManager) Add ¶
func (cm CredentialsManager) Add(ctx context.Context, domain string, creds interface{}) error
Add credential to given domain, creds must be struct which is parsable to xml
func (CredentialsManager) GetSingle ¶
func (cm CredentialsManager) GetSingle(ctx context.Context, domain string, id string, creds interface{}) error
GetSingle searches for credential in given domain with given id, if credential is found it will be parsed as xml to creds parameter(creds must be pointer to struct)
type DockerServerCredentials ¶
type DockerServerCredentials struct { XMLName xml.Name `xml:"org.jenkinsci.plugins.docker.commons.credentials.DockerServerCredentials"` ID string `xml:"id"` Scope string `xml:"scope"` Username string `xml:"username"` Description string `xml:"description,omitempty"` ClientKey string `xml:"clientKey"` ClientCertificate string `xml:"clientCertificate"` ServerCaCertificate string `xml:"serverCaCertificate"` }
DockerServerCredentials store credentials for docker keys.
type ErrAPIToken ¶
type ErrAPIToken struct {
Message string
}
ErrAPIToken occurs when there is error creating or revoking API tokens
func (*ErrAPIToken) Error ¶
func (e *ErrAPIToken) Error() string
type ErrUser ¶
type ErrUser struct {
Message string
}
ErrUser occurs when there is error creating or revoking Jenkins users
type Executor ¶
type Executor struct { Raw *ExecutorResponse Jenkins *Jenkins }
type ExecutorResponse ¶
type ExecutorResponse struct { AssignedLabels []map[string]string `json:"assignedLabels"` Description interface{} `json:"description"` Jobs []InnerJob `json:"jobs"` Mode string `json:"mode"` NodeDescription string `json:"nodeDescription"` NodeName string `json:"nodeName"` NumExecutors int64 `json:"numExecutors"` OverallLoad struct{} `json:"overallLoad"` PrimaryView struct { Name string `json:"name"` URL string `json:"url"` } `json:"primaryView"` QuietingDown bool `json:"quietingDown"` SlaveAgentPort int64 `json:"slaveAgentPort"` UnlabeledLoad struct{} `json:"unlabeledLoad"` UseCrumbs bool `json:"useCrumbs"` UseSecurity bool `json:"useSecurity"` Views []ViewData `json:"views"` }
type FileCredentials ¶
type FileCredentials struct { XMLName xml.Name `xml:"org.jenkinsci.plugins.plaincredentials.impl.FileCredentialsImpl"` ID string `xml:"id"` Scope string `xml:"scope"` Description string `xml:"description"` Filename string `xml:"fileName"` SecretBytes string `xml:"secretBytes"` }
FileCredentials store a file "SecretBytes" is a base64 encoded file content
type FingerPrint ¶
type FingerPrint struct { Jenkins *Jenkins Base string Id string Raw *FingerPrintResponse }
func (FingerPrint) GetInfo ¶
func (f FingerPrint) GetInfo(ctx context.Context) (*FingerPrintResponse, error)
func (FingerPrint) ValidateForBuild ¶
type FingerPrintResponse ¶
type FingerPrintResponse struct { FileName string `json:"fileName"` Hash string `json:"hash"` Original struct { Name string Number int64 } `json:"original"` Timestamp int64 `json:"timestamp"` Usage []struct { Name string `json:"name"` Ranges struct { Ranges []struct { End int64 `json:"end"` Start int64 `json:"start"` } `json:"ranges"` } `json:"ranges"` } `json:"usage"` }
type Folder ¶
type Folder struct { Raw *FolderResponse Jenkins *Jenkins Base string }
type FolderResponse ¶
type Jenkins ¶
type Jenkins struct { Server string Version string Raw *ExecutorResponse Requester *Requester }
func CreateJenkins ¶
Creates a new Jenkins Instance Optional parameters are: client, username, password or token After creating an instance call init method.
func (*Jenkins) BuildJob ¶
func (j *Jenkins) BuildJob(ctx context.Context, name string, params map[string]string) (int64, error)
Invoke a job. First parameter job name, second parameter is optional Build parameters. Returns queue id
func (*Jenkins) CopyJob ¶
Create a copy of a job. First parameter Name of the job to copy from, Second parameter new job name.
func (*Jenkins) CreateFolder ¶
func (j *Jenkins) CreateFolder(ctx context.Context, name string, parents ...string) (*Folder, error)
Create a new folder This folder can be nested in other parent folders Example: jenkins.CreateFolder("newFolder", "grandparentFolder", "parentFolder")
func (*Jenkins) CreateJob ¶
func (j *Jenkins) CreateJob(ctx context.Context, config string, options ...interface{}) (*Job, error)
Create a new job from config File Method takes XML string as first parameter, and if the name is not specified in the config file takes name as string as second parameter e.g jenkins.CreateJob("<config></config>","newJobName")
func (*Jenkins) CreateJobInFolder ¶
func (j *Jenkins) CreateJobInFolder(ctx context.Context, config string, jobName string, parentIDs ...string) (*Job, error)
Create a new job in the folder Example: jenkins.CreateJobInFolder("<config></config>", "newJobName", "myFolder", "parentFolder")
func (*Jenkins) CreateNode ¶
func (j *Jenkins) CreateNode(ctx context.Context, name string, numExecutors int, description string, remoteFS string, label string, options ...interface{}) (*Node, error)
Create a new Node Can be JNLPLauncher or SSHLauncher Example : jenkins.CreateNode("nodeName", 1, "Description", "/var/lib/jenkins", "jdk8 docker", map[string]string{"method": "JNLPLauncher"}) By Default JNLPLauncher is created Multiple labels should be separated by blanks
func (*Jenkins) CreateUser ¶
func (j *Jenkins) CreateUser(ctx context.Context, userName, password, fullName, email string) (User, error)
CreateUser creates a new Jenkins account
func (*Jenkins) CreateView ¶
Create View First Parameter - name of the View Second parameter - Type Possible Types:
gojenkins.LIST_VIEW gojenkins.NESTED_VIEW gojenkins.MY_VIEW gojenkins.DASHBOARD_VIEW gojenkins.PIPELINE_VIEW
Example: jenkins.CreateView("newView",gojenkins.LIST_VIEW)
func (*Jenkins) DeleteNode ¶
Delete a Jenkins slave node
func (*Jenkins) DeleteUser ¶
DeleteUser deletes a Jenkins account
func (*Jenkins) GenerateAPIToken ¶
GenerateAPIToken creates a new API token for the Jenkins client user
func (*Jenkins) GetAllBuildIds ¶
Get all builds Numbers and URLS for a specific job. There are only build IDs here, To get all the other info of the build use jenkins.GetBuild(job,buildNumber) or job.GetBuild(buildNumber)
func (*Jenkins) GetAllJobNames ¶
Get Only Array of Job Names, Color, URL Does not query each single Job.
func (*Jenkins) GetAllJobs ¶
Get All Possible Job Objects. Each job will be queried.
func (*Jenkins) GetArtifactData ¶
Get Artifact data by Hash
func (*Jenkins) GetBuildFromQueueID ¶
A task in queue will be assigned a build number in a job after a few seconds. this function will return the build object.
func (*Jenkins) GetPlugins ¶
Returns the list of all plugins installed on the Jenkins server. You can supply depth parameter, to limit how much data is returned.
func (*Jenkins) GetQueueItem ¶
GetQueueItem returns a single queue Task
func (*Jenkins) GetQueueUrl ¶
func (*Jenkins) HasPlugin ¶
Check if the plugin is installed on the server. Depth level 1 is used. If you need to go deeper, you can use GetPlugins, and iterate through them.
func (*Jenkins) Info ¶
func (j *Jenkins) Info(ctx context.Context) (*ExecutorResponse, error)
Get Basic Information About Jenkins
func (*Jenkins) Init ¶
Init Method. Should be called after creating a Jenkins Instance. e.g jenkins,err := CreateJenkins("url").Init() HTTP Client is set here, Connection to jenkins is tested here.
func (*Jenkins) InstallPlugin ¶
InstallPlugin with given version and name
func (*Jenkins) RenameJob ¶
Rename a job. First parameter job old name, Second parameter job new name.
func (*Jenkins) RevokeAPIToken ¶
RevokeAPIToken revokes an API token
func (*Jenkins) RevokeAllAPITokens ¶
RevokeAllAPITokens revokes all API tokens for the Jenkins client user
func (*Jenkins) SafeRestart ¶
SafeRestart jenkins, restart will be done when there are no jobs running
func (*Jenkins) UninstallPlugin ¶
UninstallPlugin plugin otherwise returns error
type Job ¶
type Job struct { Raw *JobResponse Jenkins *Jenkins Base string }
func (*Job) GetAllBuildIds ¶
Returns All Builds with Number and URL
func (*Job) GetBuildsFields ¶
func (*Job) GetDescription ¶
func (*Job) GetDetails ¶
func (j *Job) GetDetails() *JobResponse
func (*Job) GetDownstreamJobs ¶
func (*Job) GetDownstreamJobsMetadata ¶
func (*Job) GetInnerJobsMetadata ¶
func (*Job) GetLastCompletedBuild ¶
func (*Job) GetLastFailedBuild ¶
func (*Job) GetLastStableBuild ¶
func (*Job) GetLastSuccessfulBuild ¶
func (*Job) GetParameters ¶
func (j *Job) GetParameters(ctx context.Context) ([]ParameterDefinition, error)
func (*Job) GetPipelineRun ¶
func (*Job) GetPipelineRuns ¶
func (job *Job) GetPipelineRuns(ctx context.Context) (pr []PipelineRun, err error)
func (*Job) GetUpstreamJobsMetadata ¶
func (*Job) HasQueuedBuild ¶
func (j *Job) HasQueuedBuild()
func (*Job) InvokeSimple ¶
type JobResponse ¶
type JobResponse struct { Class string `json:"_class"` Actions []generalObj Buildable bool `json:"buildable"` Builds []JobBuild Color string `json:"color"` ConcurrentBuild bool `json:"concurrentBuild"` Description string `json:"description"` DisplayName string `json:"displayName"` DisplayNameOrNull interface{} `json:"displayNameOrNull"` DownstreamProjects []InnerJob `json:"downstreamProjects"` FirstBuild JobBuild FullName string `json:"fullName"` FullDisplayName string `json:"fullDisplayName"` HealthReport []struct { Description string `json:"description"` IconClassName string `json:"iconClassName"` IconUrl string `json:"iconUrl"` Score int64 `json:"score"` } `json:"healthReport"` InQueue bool `json:"inQueue"` KeepDependencies bool `json:"keepDependencies"` LastBuild JobBuild `json:"lastBuild"` LastCompletedBuild JobBuild `json:"lastCompletedBuild"` LastFailedBuild JobBuild `json:"lastFailedBuild"` LastStableBuild JobBuild `json:"lastStableBuild"` LastSuccessfulBuild JobBuild `json:"lastSuccessfulBuild"` LastUnstableBuild JobBuild `json:"lastUnstableBuild"` LastUnsuccessfulBuild JobBuild `json:"lastUnsuccessfulBuild"` Name string `json:"name"` NextBuildNumber int64 `json:"nextBuildNumber"` Property []struct { ParameterDefinitions []ParameterDefinition `json:"parameterDefinitions"` } `json:"property"` QueueItem interface{} `json:"queueItem"` Scm struct{} `json:"scm"` UpstreamProjects []InnerJob `json:"upstreamProjects"` URL string `json:"url"` Jobs []InnerJob `json:"jobs"` PrimaryView *ViewData `json:"primaryView"` Views []ViewData `json:"views"` }
type Label ¶
type Label struct { Raw *LabelResponse Jenkins *Jenkins Base string }
type LabelResponse ¶
type LeveledLogger ¶
type LeveledLogger interface { Debug(format string, a ...interface{}) Info(format string, a ...interface{}) Warn(format string, a ...interface{}) Error(format string, a ...interface{}) }
Logger interface used by jenkins for loging
var Logger LeveledLogger
Main Logger
func NewLeveledLogger ¶
func NewLeveledLogger(debug, info, warn, err *log.Logger) LeveledLogger
type LeveledLoggerImpl ¶
type LeveledLoggerImpl struct {
// contains filtered or unexported fields
}
Simple implementation using golang log library
func (*LeveledLoggerImpl) Debug ¶
func (l *LeveledLoggerImpl) Debug(format string, a ...interface{})
func (*LeveledLoggerImpl) Error ¶
func (l *LeveledLoggerImpl) Error(format string, a ...interface{})
func (*LeveledLoggerImpl) Info ¶
func (l *LeveledLoggerImpl) Info(format string, a ...interface{})
func (*LeveledLoggerImpl) Warn ¶
func (l *LeveledLoggerImpl) Warn(format string, a ...interface{})
type Node ¶
type Node struct { Raw *NodeResponse Jenkins *Jenkins Base string }
func (*Node) IsTemporarilyOffline ¶
func (*Node) SetOffline ¶
type NodeResponse ¶
type NodeResponse struct { Class string `json:"_class"` Actions []interface{} `json:"actions"` DisplayName string `json:"displayName"` Executors []struct { CurrentExecutable struct { Number int `json:"number"` URL string `json:"url"` SubBuilds []struct { Abort bool `json:"abort"` Build interface{} `json:"build"` BuildNumber int `json:"buildNumber"` Duration string `json:"duration"` Icon string `json:"icon"` JobName string `json:"jobName"` ParentBuildNumber int `json:"parentBuildNumber"` ParentJobName string `json:"parentJobName"` PhaseName string `json:"phaseName"` Result string `json:"result"` Retry bool `json:"retry"` URL string `json:"url"` } `json:"subBuilds"` } `json:"currentExecutable"` } `json:"executors"` Icon string `json:"icon"` IconClassName string `json:"iconClassName"` Idle bool `json:"idle"` JnlpAgent bool `json:"jnlpAgent"` LaunchSupported bool `json:"launchSupported"` LoadStatistics struct{} `json:"loadStatistics"` ManualLaunchAllowed bool `json:"manualLaunchAllowed"` MonitorData struct { Hudson_NodeMonitors_ArchitectureMonitor interface{} `json:"hudson.node_monitors.ArchitectureMonitor"` Hudson_NodeMonitors_ClockMonitor interface{} `json:"hudson.node_monitors.ClockMonitor"` Hudson_NodeMonitors_DiskSpaceMonitor interface{} `json:"hudson.node_monitors.DiskSpaceMonitor"` Hudson_NodeMonitors_ResponseTimeMonitor struct { Average int64 `json:"average"` } `json:"hudson.node_monitors.ResponseTimeMonitor"` Hudson_NodeMonitors_SwapSpaceMonitor interface{} `json:"hudson.node_monitors.SwapSpaceMonitor"` Hudson_NodeMonitors_TemporarySpaceMonitor interface{} `json:"hudson.node_monitors.TemporarySpaceMonitor"` } `json:"monitorData"` NumExecutors int64 `json:"numExecutors"` Offline bool `json:"offline"` OfflineCause struct{} `json:"offlineCause"` OfflineCauseReason string `json:"offlineCauseReason"` OneOffExecutors []interface{} `json:"oneOffExecutors"` TemporarilyOffline bool `json:"temporarilyOffline"` }
type ParameterDefinition ¶
type PipelineArtifact ¶
type PipelineInputAction ¶
type PipelineNode ¶
type PipelineNode struct { Run *PipelineRun Base string URLs map[string]map[string]string `json:"_links"` ID string Name string Status string StartTime int64 `json:"startTimeMillis"` Duration int64 `json:"durationMillis"` StageFlowNodes []PipelineNode ParentNodes []int64 }
func (*PipelineNode) GetLog ¶
func (node *PipelineNode) GetLog(ctx context.Context) (log *PipelineNodeLog, err error)
type PipelineNodeLog ¶
type PipelineRun ¶
type PipelineRun struct { Job *Job Base string URLs map[string]map[string]string `json:"_links"` ID string Name string Status string StartTime int64 `json:"startTimeMillis"` EndTime int64 `json:"endTimeMillis"` Duration int64 `json:"durationMillis"` Stages []PipelineNode }
func (*PipelineRun) AbortInput ¶
func (pr *PipelineRun) AbortInput(ctx context.Context) (bool, error)
func (*PipelineRun) GetArtifacts ¶
func (pr *PipelineRun) GetArtifacts(ctx context.Context) (artifacts []PipelineArtifact, err error)
func (*PipelineRun) GetNode ¶
func (pr *PipelineRun) GetNode(ctx context.Context, id string) (node *PipelineNode, err error)
func (*PipelineRun) GetPendingInputActions ¶
func (pr *PipelineRun) GetPendingInputActions(ctx context.Context) (PIAs []PipelineInputAction, err error)
func (*PipelineRun) ProceedInput ¶
func (pr *PipelineRun) ProceedInput(ctx context.Context) (bool, error)
type Plugin ¶
type Plugin struct { Active bool `json:"active"` BackupVersion interface{} `json:"backupVersion"` Bundled bool `json:"bundled"` Deleted bool `json:"deleted"` Dependencies []struct { Optional string `json:"optional"` ShortName string `json:"shortname"` Version string `json:"version"` } `json:"dependencies"` Downgradable bool `json:"downgradable"` Enabled bool `json:"enabled"` HasUpdate bool `json:"hasUpdate"` LongName string `json:"longName"` Pinned bool `json:"pinned"` ShortName string `json:"shortName"` SupportsDynamicLoad string `json:"supportsDynamicLoad"` URL string `json:"url"` Version string `json:"version"` }
type PluginResponse ¶
type PluginResponse struct {
Plugins []Plugin `json:"plugins"`
}
type PrivateKey ¶
PrivateKey used in SSHCredentials type, type can be either: KeySourceDirectEntryType - then value should be text with secret KeySourceOnMasterType - then value should be path on master jenkins where secret is stored
type PrivateKeyFile ¶
type Requester ¶
type Requester struct { Base string BasicAuth *BasicAuth Client *http.Client CACert []byte SslVerify bool }
func (*Requester) ReadJSONResponse ¶
func (*Requester) ReadRawResponse ¶
type SSHCredentials ¶
type SSHCredentials struct { XMLName xml.Name `xml:"com.cloudbees.jenkins.plugins.sshcredentials.impl.BasicSSHUserPrivateKey"` ID string `xml:"id"` Scope string `xml:"scope"` Username string `xml:"username"` Description string `xml:"description,omitempty"` PrivateKeySource interface{} `xml:"privateKeySource"` Passphrase string `xml:"passphrase,omitempty"` }
SSHCredentials store credentials for ssh keys.
type StringCredentials ¶
type StringCredentials struct { XMLName xml.Name `xml:"org.jenkinsci.plugins.plaincredentials.impl.StringCredentialsImpl"` ID string `xml:"id"` Scope string `xml:"scope"` Description string `xml:"description"` Secret string `xml:"secret"` }
StringCredentials store only secret text
type Task ¶
func (*Task) GetParameters ¶
func (t *Task) GetParameters() []parameter
type TestResult ¶
type TestResult struct { Duration float64 `json:"duration"` Empty bool `json:"empty"` FailCount int64 `json:"failCount"` PassCount int64 `json:"passCount"` SkipCount int64 `json:"skipCount"` Suites []struct { Cases []struct { Age int64 `json:"age"` ClassName string `json:"className"` Duration float64 `json:"duration"` ErrorDetails interface{} `json:"errorDetails"` ErrorStackTrace interface{} `json:"errorStackTrace"` FailedSince int64 `json:"failedSince"` Name string `json:"name"` Skipped bool `json:"skipped"` SkippedMessage interface{} `json:"skippedMessage"` Status string `json:"status"` Stderr interface{} `json:"stderr"` Stdout interface{} `json:"stdout"` } `json:"cases"` Duration float64 `json:"duration"` ID interface{} `json:"id"` Name string `json:"name"` Stderr interface{} `json:"stderr"` Stdout interface{} `json:"stdout"` Timestamp interface{} `json:"timestamp"` } `json:"suites"` }
type UsernameCredentials ¶
type UsernameCredentials struct { XMLName xml.Name `xml:"com.cloudbees.plugins.credentials.impl.UsernamePasswordCredentialsImpl"` ID string `xml:"id"` Scope string `xml:"scope"` Description string `xml:"description"` Username string `xml:"username"` Password string `xml:"password"` }
UsernameCredentials struct representing credential for storing username-password pair