forked from chyroc/lark
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapi_application_version_list.go
254 lines (222 loc) · 17.7 KB
/
api_application_version_list.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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
// Code generated by lark_sdk_gen. DO NOT EDIT.
/**
* Copyright 2022 chyroc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package lark
import (
"context"
)
// GetApplicationVersionList 根据 app_id 获取对应应用版本列表。
//
// doc: https://open.feishu.cn/document/uAjLw4CM/ukTMukTMukTM/application-v6/application-app_version/list
// new doc: https://open.feishu.cn/document/server-docs/application-v6/application/list
func (r *ApplicationService) GetApplicationVersionList(ctx context.Context, request *GetApplicationVersionListReq, options ...MethodOptionFunc) (*GetApplicationVersionListResp, *Response, error) {
if r.cli.mock.mockApplicationGetApplicationVersionList != nil {
r.cli.Log(ctx, LogLevelDebug, "[lark] Application#GetApplicationVersionList mock enable")
return r.cli.mock.mockApplicationGetApplicationVersionList(ctx, request, options...)
}
req := &RawRequestReq{
Scope: "Application",
API: "GetApplicationVersionList",
Method: "GET",
URL: r.cli.openBaseURL + "/open-apis/application/v6/applications/:app_id/app_versions",
Body: request,
MethodOption: newMethodOption(options),
NeedTenantAccessToken: true,
}
resp := new(getApplicationVersionListResp)
response, err := r.cli.RawRequest(ctx, req, resp)
return resp.Data, response, err
}
// MockApplicationGetApplicationVersionList mock ApplicationGetApplicationVersionList method
func (r *Mock) MockApplicationGetApplicationVersionList(f func(ctx context.Context, request *GetApplicationVersionListReq, options ...MethodOptionFunc) (*GetApplicationVersionListResp, *Response, error)) {
r.mockApplicationGetApplicationVersionList = f
}
// UnMockApplicationGetApplicationVersionList un-mock ApplicationGetApplicationVersionList method
func (r *Mock) UnMockApplicationGetApplicationVersionList() {
r.mockApplicationGetApplicationVersionList = nil
}
// GetApplicationVersionListReq ...
type GetApplicationVersionListReq struct {
AppID string `path:"app_id" json:"-"` // 应用的 app_id, 需要查询其他应用版本信息时, 必须申请[获取应用版本信息](https://open.feishu.cn/document/ukTMukTMukTM/uQjN3QjL0YzN04CN2cDN)权限, 仅查询本应用版本信息时, 可填入 "me" 或者应用自身 app_id, 示例值: "cli_9b445f5258795107"
Lang string `query:"lang" json:"-"` // 应用信息的语言版本, 示例值: zh_cn, 可选值有: zh_cn: 中文, en_us: 英文, ja_jp: 日文, 最小长度: `1` 字符
PageSize *int64 `query:"page_size" json:"-"` // 分页大小, 示例值: 10, 默认值: `20`, 取值范围: `1` ~ `50`
PageToken *string `query:"page_token" json:"-"` // 分页标记, 第一次请求不填, 表示从头开始遍历;分页查询结果还有更多项时会同时返回新的 page_token, 下次遍历可采用该 page_token 获取查询结果, 示例值: new-e3c5a0627cdf0c2e057da7257b90376a
Order *int64 `query:"order" json:"-"` // 0: 按照时间倒序 1: 按照时间正序, 示例值: 0, 默认值: `0`
UserIDType *IDType `query:"user_id_type" json:"-"` // 用户 ID 类型, 示例值: open_id, 可选值有: open_id: 标识一个用户在某个应用中的身份。同一个用户在不同应用中的 Open ID 不同。[了解更多: 如何获取 Open ID](https://open.feishu.cn/document/uAjLw4CM/ugTN1YjL4UTN24CO1UjN/trouble-shooting/how-to-obtain-openid), union_id: 标识一个用户在某个应用开发商下的身份。同一用户在同一开发商下的应用中的 Union ID 是相同的, 在不同开发商下的应用中的 Union ID 是不同的。通过 Union ID, 应用开发商可以把同个用户在多个应用中的身份关联起来。[了解更多: 如何获取 Union ID?](https://open.feishu.cn/document/uAjLw4CM/ugTN1YjL4UTN24CO1UjN/trouble-shooting/how-to-obtain-union-id), user_id: 标识一个用户在某个租户内的身份。同一个用户在租户 A 和租户 B 内的 User ID 是不同的。在同一个租户内, 一个用户的 User ID 在所有应用(包括商店应用)中都保持一致。User ID 主要用于在不同的应用间打通用户数据。[了解更多: 如何获取 User ID?](https://open.feishu.cn/document/uAjLw4CM/ugTN1YjL4UTN24CO1UjN/trouble-shooting/how-to-obtain-user-id), 默认值: `open_id`, 当值为 `user_id`, 字段权限要求: 获取用户 user ID
}
// GetApplicationVersionListResp ...
type GetApplicationVersionListResp struct {
Items []*GetApplicationVersionListRespItem `json:"items,omitempty"` // 应用版本列表
PageToken string `json:"page_token,omitempty"` // 分页标记, 当 has_more 为 true 时, 会同时返回新的 page_token, 否则不返回 page_token
HasMore bool `json:"has_more,omitempty"` // 是否还有更多项
}
// GetApplicationVersionListRespItem ...
type GetApplicationVersionListRespItem struct {
AppID string `json:"app_id,omitempty"` // 应用 id
Version string `json:"version,omitempty"` // 在开发者后台填入的应用版本号
VersionID string `json:"version_id,omitempty"` // 唯一标识应用版本的 ID
AppName string `json:"app_name,omitempty"` // 应用默认名称
AvatarURL string `json:"avatar_url,omitempty"` // 应用头像 url
Description string `json:"description,omitempty"` // 应用默认描述
Scopes []*GetApplicationVersionListRespItemScope `json:"scopes,omitempty"` // 应用权限列表
BackHomeURL string `json:"back_home_url,omitempty"` // 后台主页地址
I18n []*GetApplicationVersionListRespItemI18n `json:"i18n,omitempty"` // 应用的国际化信息列表
CommonCategories []string `json:"common_categories,omitempty"` // 应用分类的国际化描述
Events []string `json:"events,omitempty"` // 应用已订阅开放平台事件列表
Status int64 `json:"status,omitempty"` // 版本状态, 可选值有: 0: 未知状态, 1: 审核通过, 2: 审核拒绝, 3: 审核中, 4: 未提交审核
CreateTime string `json:"create_time,omitempty"` // 版本创建时间(单位: s)
PublishTime string `json:"publish_time,omitempty"` // 版本发布时间(单位: s)
Ability *GetApplicationVersionListRespItemAbility `json:"ability,omitempty"` // 当前版本下应用开启的能力
Remark *GetApplicationVersionListRespItemRemark `json:"remark,omitempty"` // 跟随应用版本的信息
}
// GetApplicationVersionListRespItemAbility ...
type GetApplicationVersionListRespItemAbility struct {
Gadget *GetApplicationVersionListRespItemAbilityGadget `json:"gadget,omitempty"` // 小程序能力
WebApp *GetApplicationVersionListRespItemAbilityWebApp `json:"web_app,omitempty"` // 网页能力
Bot *GetApplicationVersionListRespItemAbilityBot `json:"bot,omitempty"` // 机器人能力
WorkplaceWidgets []*GetApplicationVersionListRespItemAbilityWorkplaceWidget `json:"workplace_widgets,omitempty"` // 小组件能力
Navigate *GetApplicationVersionListRespItemAbilityNavigate `json:"navigate,omitempty"` // 主导航小程序
CloudDoc *GetApplicationVersionListRespItemAbilityCloudDoc `json:"cloud_doc,omitempty"` // 云文档应用
DocsBlocks []*GetApplicationVersionListRespItemAbilityDocsBlock `json:"docs_blocks,omitempty"` // 云文档小组件
MessageAction *GetApplicationVersionListRespItemAbilityMessageAction `json:"message_action,omitempty"` // 消息快捷操作
PlusMenu *GetApplicationVersionListRespItemAbilityPlusMenu `json:"plus_menu,omitempty"` // 加号菜单
}
// GetApplicationVersionListRespItemAbilityBot ...
type GetApplicationVersionListRespItemAbilityBot struct {
CardRequestURL string `json:"card_request_url,omitempty"` // 消息卡片回调地址
}
// GetApplicationVersionListRespItemAbilityCloudDoc ...
type GetApplicationVersionListRespItemAbilityCloudDoc struct {
SpaceURL string `json:"space_url,omitempty"` // 云空间重定向 url
I18n []*GetApplicationVersionListRespItemAbilityCloudDocI18n `json:"i18n,omitempty"` // 国际化信息
IconURL string `json:"icon_url,omitempty"` // 图标链接
Mode int64 `json:"mode,omitempty"` // 云文档支持模式, 可选值有: 0: 未知, 1: 移动端
}
// GetApplicationVersionListRespItemAbilityCloudDocI18n ...
type GetApplicationVersionListRespItemAbilityCloudDocI18n struct {
I18nKey string `json:"i18n_key,omitempty"` // 国际化语言的 key, 可选值有: zh_cn: 中文, en_us: 英文, ja_jp: 日文
Name string `json:"name,omitempty"` // 云文档国际化名称
ReadDescription string `json:"read_description,omitempty"` // 云文档国际化读权限说明
WriteDescription string `json:"write_description,omitempty"` // 云文档国际化写权限说明
}
// GetApplicationVersionListRespItemAbilityDocsBlock ...
type GetApplicationVersionListRespItemAbilityDocsBlock struct {
BlockTypeID string `json:"block_type_id,omitempty"` // BlockTypeID
I18n []*GetApplicationVersionListRespItemAbilityDocsBlockI18n `json:"i18n,omitempty"` // block 的国际化信息
MobileIconURL string `json:"mobile_icon_url,omitempty"` // 移动端 icon 链接
PcIconURL string `json:"pc_icon_url,omitempty"` // pc 端口 icon 链接
}
// GetApplicationVersionListRespItemAbilityDocsBlockI18n ...
type GetApplicationVersionListRespItemAbilityDocsBlockI18n struct {
I18nKey string `json:"i18n_key,omitempty"` // 国际化语言的 key, 可选值有: zh_cn: 中文, en_us: 英文, ja_jp: 日文
Name string `json:"name,omitempty"` // 名称
}
// GetApplicationVersionListRespItemAbilityGadget ...
type GetApplicationVersionListRespItemAbilityGadget struct {
EnablePcMode int64 `json:"enable_pc_mode,omitempty"` // pc 支持的小程序模式, bit 位表示, 可选值有: 1: sidebar 模式, 2: pc 模式, 4: 主导航模式
SchemaURLs []string `json:"schema_urls,omitempty"` // schema url 列表
PcUseMobilePkg bool `json:"pc_use_mobile_pkg,omitempty"` // pc 端是否使用小程序版本
PcVersion string `json:"pc_version,omitempty"` // pc 的小程序版本号
MobileVersion string `json:"mobile_version,omitempty"` // 移动端小程序版本号
MobileMinLarkVersion string `json:"mobile_min_lark_version,omitempty"` // 移动端兼容的最低飞书版本
PcMinLarkVersion string `json:"pc_min_lark_version,omitempty"` // pc 端兼容的最低飞书版本
}
// GetApplicationVersionListRespItemAbilityMessageAction ...
type GetApplicationVersionListRespItemAbilityMessageAction struct {
PcAppLink string `json:"pc_app_link,omitempty"` // pc 端链接
MobileAppLink string `json:"mobile_app_link,omitempty"` // 移动端链接
I18n []*GetApplicationVersionListRespItemAbilityMessageActionI18n `json:"i18n,omitempty"` // 国际化信息
}
// GetApplicationVersionListRespItemAbilityMessageActionI18n ...
type GetApplicationVersionListRespItemAbilityMessageActionI18n struct {
I18nKey string `json:"i18n_key,omitempty"` // 国际化语言的 key, 可选值有: zh_cn: 中文, en_us: 英文, ja_jp: 日文
Name string `json:"name,omitempty"` // 国际化名称
}
// GetApplicationVersionListRespItemAbilityNavigate ...
type GetApplicationVersionListRespItemAbilityNavigate struct {
Pc *GetApplicationVersionListRespItemAbilityNavigatePc `json:"pc,omitempty"` // pc 端主导航信息
Mobile *GetApplicationVersionListRespItemAbilityNavigateMobile `json:"mobile,omitempty"` // 移动端主导航信息
}
// GetApplicationVersionListRespItemAbilityNavigateMobile ...
type GetApplicationVersionListRespItemAbilityNavigateMobile struct {
Version string `json:"version,omitempty"` // 主导航小程序版本号
ImageURL string `json:"image_url,omitempty"` // 默认图片 url
HoverImageURL string `json:"hover_image_url,omitempty"` // 选中态图片 url
}
// GetApplicationVersionListRespItemAbilityNavigatePc ...
type GetApplicationVersionListRespItemAbilityNavigatePc struct {
Version string `json:"version,omitempty"` // 主导航小程序版本号
ImageURL string `json:"image_url,omitempty"` // 默认图片 url
HoverImageURL string `json:"hover_image_url,omitempty"` // 选中态图片 url
}
// GetApplicationVersionListRespItemAbilityPlusMenu ...
type GetApplicationVersionListRespItemAbilityPlusMenu struct {
PcAppLink string `json:"pc_app_link,omitempty"` // pc 端链接
MobileAppLink string `json:"mobile_app_link,omitempty"` // 移动端链接
}
// GetApplicationVersionListRespItemAbilityWebApp ...
type GetApplicationVersionListRespItemAbilityWebApp struct {
PcURL string `json:"pc_url,omitempty"` // pc 端 url
MobileURL string `json:"mobile_url,omitempty"` // 移动端 url
}
// GetApplicationVersionListRespItemAbilityWorkplaceWidget ...
type GetApplicationVersionListRespItemAbilityWorkplaceWidget struct {
MinLarkVersion string `json:"min_lark_version,omitempty"` // 最低兼容飞书版本号
}
// GetApplicationVersionListRespItemI18n ...
type GetApplicationVersionListRespItemI18n struct {
I18nKey string `json:"i18n_key,omitempty"` // 国际化语言的 key, 可选值有: zh_cn: 中文, en_us: 英文, ja_jp: 日文
Name string `json:"name,omitempty"` // 应用国际化名称
Description string `json:"description,omitempty"` // 应用国际化描述(副标题)
HelpUse string `json:"help_use,omitempty"` // 国际化帮助文档链接
}
// GetApplicationVersionListRespItemRemark ...
type GetApplicationVersionListRespItemRemark struct {
Remark string `json:"remark,omitempty"` // 备注说明
UpdateRemark string `json:"update_remark,omitempty"` // 更新说明
Visibility *GetApplicationVersionListRespItemRemarkVisibility `json:"visibility,omitempty"` // 应用当前版本开发者编辑的可见性建议, 若开发者未编辑可见性建议, 则该字段无内容
}
// GetApplicationVersionListRespItemRemarkVisibility ...
type GetApplicationVersionListRespItemRemarkVisibility struct {
IsAll bool `json:"is_all,omitempty"` // 是否全员可见
VisibleList *GetApplicationVersionListRespItemRemarkVisibilityVisibleList `json:"visible_list,omitempty"` // 可见名单
InvisibleList *GetApplicationVersionListRespItemRemarkVisibilityInvisibleList `json:"invisible_list,omitempty"` // 不可见名单
}
// GetApplicationVersionListRespItemRemarkVisibilityInvisibleList ...
type GetApplicationVersionListRespItemRemarkVisibilityInvisibleList struct {
OpenIDs []string `json:"open_ids,omitempty"` // 不可见性成员 open_id 列表
DepartmentIDs []string `json:"department_ids,omitempty"` // 不可见性部门的 id 列表
GroupIDs []string `json:"group_ids,omitempty"` // 不可见性成员 group_id 列表
}
// GetApplicationVersionListRespItemRemarkVisibilityVisibleList ...
type GetApplicationVersionListRespItemRemarkVisibilityVisibleList struct {
OpenIDs []string `json:"open_ids,omitempty"` // 可见性成员 open_id 列表
DepartmentIDs []string `json:"department_ids,omitempty"` // 可见性部门的 id 列表
GroupIDs []string `json:"group_ids,omitempty"` // 可见性成员 group_id 列表
}
// GetApplicationVersionListRespItemScope ...
type GetApplicationVersionListRespItemScope struct {
Scope string `json:"scope,omitempty"` // 应用权限
Description string `json:"description,omitempty"` // 应用权限的国际化描述
Level int64 `json:"level,omitempty"` // 权限等级描述, 可选值有: 1: 普通权限, 2: 高级权限, 3: 超敏感权限, 0: 未知等级
}
// getApplicationVersionListResp ...
type getApplicationVersionListResp struct {
Code int64 `json:"code,omitempty"` // 错误码, 非 0 表示失败
Msg string `json:"msg,omitempty"` // 错误描述
Data *GetApplicationVersionListResp `json:"data,omitempty"`
Error *ErrorDetail `json:"error,omitempty"`
}