Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
jenkinsci
Jenkins Cli
提交
1e10cd45
J
Jenkins Cli
项目概览
jenkinsci
/
Jenkins Cli
通知
0
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
Jenkins Cli
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
1e10cd45
编写于
6月 27, 2019
作者:
LinuxSuRen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add queue as subcmd
上级
cda23f29
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
123 addition
and
0 deletion
+123
-0
app/cmd/queue.go
app/cmd/queue.go
+44
-0
client/queue.go
client/queue.go
+79
-0
未找到文件。
app/cmd/queue.go
0 → 100644
浏览文件 @
1e10cd45
package
cmd
import
(
"fmt"
"log"
"github.com/linuxsuren/jenkins-cli/client"
"github.com/spf13/cobra"
)
type
QueueOption
struct
{
OutputOption
}
var
queueOption
QueueOption
func
init
()
{
rootCmd
.
AddCommand
(
queueCmd
)
queueCmd
.
PersistentFlags
()
.
StringVarP
(
&
queueOption
.
Format
,
"output"
,
"o"
,
"json"
,
"Format the output"
)
}
var
queueCmd
=
&
cobra
.
Command
{
Use
:
"queue"
,
Short
:
"Print the queue of your Jenkins"
,
Long
:
`Print the queue of your Jenkins`
,
Run
:
func
(
cmd
*
cobra
.
Command
,
args
[]
string
)
{
jenkins
:=
getCurrentJenkins
()
jclient
:=
&
client
.
QueueClient
{}
jclient
.
URL
=
jenkins
.
URL
jclient
.
UserName
=
jenkins
.
UserName
jclient
.
Token
=
jenkins
.
Token
if
status
,
err
:=
jclient
.
Get
();
err
==
nil
{
var
data
[]
byte
if
data
,
err
=
Format
(
status
,
queueOption
.
Format
);
err
==
nil
{
fmt
.
Printf
(
"%s
\n
"
,
string
(
data
))
}
else
{
log
.
Fatal
(
err
)
}
}
else
{
log
.
Fatal
(
err
)
}
},
}
client/queue.go
0 → 100644
浏览文件 @
1e10cd45
package
client
import
(
"crypto/tls"
"encoding/json"
"fmt"
"io/ioutil"
"log"
"net/http"
)
type
QueueClient
struct
{
JenkinsCore
}
func
(
q
*
QueueClient
)
Get
()
(
status
*
JobQueue
,
err
error
)
{
api
:=
fmt
.
Sprintf
(
"%s/queue/api/json"
,
q
.
URL
)
var
(
req
*
http
.
Request
response
*
http
.
Response
)
req
,
err
=
http
.
NewRequest
(
"GET"
,
api
,
nil
)
if
err
==
nil
{
q
.
AuthHandle
(
req
)
}
else
{
return
}
tr
:=
&
http
.
Transport
{
TLSClientConfig
:
&
tls
.
Config
{
InsecureSkipVerify
:
true
},
}
client
:=
&
http
.
Client
{
Transport
:
tr
}
if
response
,
err
=
client
.
Do
(
req
);
err
==
nil
{
code
:=
response
.
StatusCode
var
data
[]
byte
data
,
err
=
ioutil
.
ReadAll
(
response
.
Body
)
if
code
==
200
{
if
err
==
nil
{
status
=
&
JobQueue
{}
err
=
json
.
Unmarshal
(
data
,
status
)
}
}
else
{
log
.
Fatal
(
string
(
data
))
}
}
else
{
log
.
Fatal
(
err
)
}
return
}
type
JobQueue
struct
{
Items
[]
QueueItem
}
type
QueueItem
struct
{
Blocked
bool
Buildable
bool
ID
int
Params
string
Pending
bool
Stuck
bool
URL
string
Why
string
BuildableStartMilliseconds
int64
InQueueSince
int64
Actions
[]
CauseAction
}
type
CauseAction
struct
{
Causes
[]
Cause
}
type
Cause
struct
{
UpstreamUrl
string
UpstreamProject
string
UpstreamBuild
int
ShortDescription
string
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录