-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapi_label.go
172 lines (145 loc) · 5.95 KB
/
api_label.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
package tapd
import (
"context"
"net/http"
)
// LabelColor is a type for label colors.
type LabelColor string
const (
LabelColor1 LabelColor = "1"
LabelColor2 LabelColor = "2"
LabelColor3 LabelColor = "3"
LabelColor4 LabelColor = "4"
)
type (
// Label represents a label.
Label struct {
ID string `json:"id,omitempty"`
WorkspaceID string `json:"workspace_id,omitempty"`
Name string `json:"name,omitempty"`
Color LabelColor `json:"color,omitempty"`
Category string `json:"category,omitempty"`
Creator string `json:"creator,omitempty"`
Modifier string `json:"modifier,omitempty"`
Created string `json:"created,omitempty"`
Modified string `json:"modified,omitempty"`
ColorValue string `json:"color_value,omitempty"`
}
LabelPool struct {
LabelPool *Label `json:"LabelPool"`
}
)
// LabelService handles communication with the label related methods of the Tapd API.
// Tapd API docs: https://open.tapd.cn/document/api-doc/API%E6%96%87%E6%A1%A3/api_reference/label/index.html
type LabelService struct {
client *Client
}
// -----------------------------------------------------------------------------
// 获取自定义标签
// -----------------------------------------------------------------------------
type GetLabelsRequest struct {
WorkspaceID *int `url:"workspace_id,omitempty"` // [必选]项目ID
ID *Multi[int] `url:"id,omitempty"` // [可选]id 支持多ID查询
Name *string `url:"name,omitempty"` // [可选]标签名称 支持模糊匹配
Creator *string `url:"creator,omitempty"` // [可选]创建人
Created *string `url:"created,omitempty"` // [可选]创建时间 支持时间查询
Limit *int `url:"limit,omitempty"` // [可选]设置返回数量限制,默认为30
Page *int `url:"page,omitempty"` // [可选]返回当前数量限制下第N页的数据,默认为1(第一页)
Order *Order `url:"order,omitempty"` // [可选]排序规则,规则:字段名 ASC或者DESC,然后 urlencode 如按创建时间逆序
}
// GetLabels 获取自定义标签
// https://open.tapd.cn/document/api-doc/API%E6%96%87%E6%A1%A3/api_reference/label/query_label.html
func (s *LabelService) GetLabels(
ctx context.Context, request *GetLabelsRequest, opts ...RequestOption,
) ([]*Label, *Response, error) {
req, err := s.client.NewRequest(ctx, http.MethodGet, "label", request, opts)
if err != nil {
return nil, nil, err
}
var items []*LabelPool
resp, err := s.client.Do(req, &items)
if err != nil {
return nil, resp, err
}
labels := make([]*Label, 0, len(items))
for _, item := range items {
labels = append(labels, item.LabelPool)
}
return labels, resp, nil
}
// -----------------------------------------------------------------------------
// 获取标签数量
// -----------------------------------------------------------------------------
type GetLabelCountRequest struct {
WorkspaceID *int `url:"workspace_id,omitempty"` // [必选]项目ID
ID *Multi[int] `url:"id,omitempty"` // [可选]id 支持多ID查询
Name *string `url:"name,omitempty"` // [可选]标签名称 支持模糊匹配
Creator *string `url:"creator,omitempty"` // [可选]创建人
Created *string `url:"created,omitempty"` // [可选]创建时间 支持时间查询
}
// GetLabelsCount 获取标签数量
// https://open.tapd.cn/document/api-doc/API%E6%96%87%E6%A1%A3/api_reference/label/count_label.html
func (s *LabelService) GetLabelsCount(
ctx context.Context, request *GetLabelCountRequest, opts ...RequestOption,
) (int, *Response, error) {
req, err := s.client.NewRequest(ctx, http.MethodGet, "label/count", request, opts)
if err != nil {
return 0, nil, err
}
var response CountResponse
resp, err := s.client.Do(req, &response)
if err != nil {
return 0, resp, err
}
return response.Count, resp, nil
}
// -----------------------------------------------------------------------------
// 创建标签
// -----------------------------------------------------------------------------
type CreateLabelRequest struct {
WorkspaceID *int `json:"workspace_id"` // [必选]项目ID
Name *string `json:"name"` // [必选]标签名称
Color *LabelColor `json:"color"` // 标签颜色
Creator *string `json:"creator"` // 创建人
}
// CreateLabel 创建标签
// https://open.tapd.cn/document/api-doc/API%E6%96%87%E6%A1%A3/api_reference/label/add_label.html
func (s *LabelService) CreateLabel(
ctx context.Context, request *CreateLabelRequest, opts ...RequestOption,
) (*Label, *Response, error) {
req, err := s.client.NewRequest(ctx, http.MethodPost, "label", request, opts)
if err != nil {
return nil, nil, err
}
var response LabelPool
resp, err := s.client.Do(req, &response)
if err != nil {
return nil, resp, err
}
return response.LabelPool, resp, nil
}
// -----------------------------------------------------------------------------
// 更新标签
// -----------------------------------------------------------------------------
type UpdateLabelRequest struct {
ID *int `json:"id"` // [必选]ID
WorkspaceID *int `json:"workspace_id"` // [必选]项目ID
Color *LabelColor `json:"color"` // 标签颜色
Modifier *string `json:"modifier"` // 更新人
}
// UpdateLabel 更新标签
// https://open.tapd.cn/document/api-doc/API%E6%96%87%E6%A1%A3/api_reference/label/update_label.html
func (s *LabelService) UpdateLabel(
ctx context.Context, request *UpdateLabelRequest, opts ...RequestOption,
) (*Label, *Response, error) {
req, err := s.client.NewRequest(ctx, http.MethodPost, "label", request, opts)
if err != nil {
return nil, nil, err
}
var response LabelPool
resp, err := s.client.Do(req, &response)
if err != nil {
return nil, resp, err
}
return response.LabelPool, resp, nil
}