diff --git a/api_corehr_bp_list.go b/api_corehr_bp_list.go new file mode 100644 index 00000000..8765a10e --- /dev/null +++ b/api_corehr_bp_list.go @@ -0,0 +1,84 @@ +// 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" +) + +// GetCoreHrbpList 获取 HRBP 列表。 +// +// doc: https://open.feishu.cn/document/uAjLw4CM/ukTMukTMukTM/corehr-v2/bp/list +func (r *CoreHRService) GetCoreHrbpList(ctx context.Context, request *GetCoreHrbpListReq, options ...MethodOptionFunc) (*GetCoreHrbpListResp, *Response, error) { + if r.cli.mock.mockCoreHRGetCoreHrbpList != nil { + r.cli.log(ctx, LogLevelDebug, "[lark] CoreHR#GetCoreHrbpList mock enable") + return r.cli.mock.mockCoreHRGetCoreHrbpList(ctx, request, options...) + } + + req := &RawRequestReq{ + Scope: "CoreHR", + API: "GetCoreHrbpList", + Method: "GET", + URL: r.cli.openBaseURL + "/open-apis/corehr/v2/bps", + Body: request, + MethodOption: newMethodOption(options), + NeedTenantAccessToken: true, + } + resp := new(getCoreHrbpListResp) + + response, err := r.cli.RawRequest(ctx, req, resp) + return resp.Data, response, err +} + +// MockCoreHRGetCoreHrbpList mock CoreHRGetCoreHrbpList method +func (r *Mock) MockCoreHRGetCoreHrbpList(f func(ctx context.Context, request *GetCoreHrbpListReq, options ...MethodOptionFunc) (*GetCoreHrbpListResp, *Response, error)) { + r.mockCoreHRGetCoreHrbpList = f +} + +// UnMockCoreHRGetCoreHrbpList un-mock CoreHRGetCoreHrbpList method +func (r *Mock) UnMockCoreHRGetCoreHrbpList() { + r.mockCoreHRGetCoreHrbpList = nil +} + +// GetCoreHrbpListReq ... +type GetCoreHrbpListReq struct { + PageSize int64 `query:"page_size" json:"-"` // 分页大小, 最大 500, 示例值: 500, 取值范围: `1` ~ `500` + PageToken *string `query:"page_token" json:"-"` // 分页标记, 第一次请求不填, 表示从头开始遍历;分页查询结果还有更多项时会同时返回新的 page_token, 下次遍历可采用该 page_token 获取查询结果, 示例值: 6891251722631890445 + 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), people_corehr_id: 以飞书人事的 ID 来识别用户, 默认值: `open_id`, 当值为 `user_id`, 字段权限要求: 获取用户 user ID + DepartmentIDType *DepartmentIDType `query:"department_id_type" json:"-"` // 此次调用中使用的部门 ID 类型, 示例值: open_department_id, 可选值有: open_department_id: 以 open_department_id 来标识部门, department_id: 以 department_id 来标识部门, people_corehr_department_id: 以 people_corehr_department_id 来标识部门, 默认值: `open_department_id` +} + +// GetCoreHrbpListResp ... +type GetCoreHrbpListResp struct { + Items []*GetCoreHrbpListRespItem `json:"items,omitempty"` // HRBP 信息 + PageToken string `json:"page_token,omitempty"` // 分页标记, 当 has_more 为 true 时, 会同时返回新的 page_token, 否则不返回 page_token + HasMore bool `json:"has_more,omitempty"` // 是否还有更多项 +} + +// GetCoreHrbpListRespItem ... +type GetCoreHrbpListRespItem struct { + DepartmentID string `json:"department_id,omitempty"` // 部门 ID + HrbpID string `json:"hrbp_id,omitempty"` // 部门 HRBP 的雇佣 ID, 不包括上级部门的 HRBP +} + +// getCoreHrbpListResp ... +type getCoreHrbpListResp struct { + Code int64 `json:"code,omitempty"` // 错误码, 非 0 表示失败 + Msg string `json:"msg,omitempty"` // 错误描述 + Data *GetCoreHrbpListResp `json:"data,omitempty"` +}