From a5776bc9f20de7a1b99ae4e5da32f729bbe26b4e Mon Sep 17 00:00:00 2001 From: markwang Date: Wed, 9 Oct 2024 15:38:34 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E4=BC=81=E4=B8=9A=E5=BE=AE=E4=BF=A1-?= =?UTF-8?q?=E5=BE=AE=E4=BF=A1=E5=AE=A2=E6=9C=8D=EF=BC=8C=E5=AE=A2=E6=9C=8D?= =?UTF-8?q?=E8=B4=A6=E5=8F=B7=E5=88=97=E8=A1=A8=E6=8E=A5=E5=8F=A3=E6=94=AF?= =?UTF-8?q?=E6=8C=81=E5=88=86=E9=A1=B5=E6=8B=89=E5=8F=96=EF=BC=8C=E6=8E=A5?= =?UTF-8?q?=E5=BE=85=E4=BA=BA=E5=91=98=E5=A2=9E=E5=8A=A0=E9=83=A8=E9=97=A8?= =?UTF-8?q?ID?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- work/kf/account.go | 38 ++++++++++++++++++++++++++++++++++---- work/kf/servicer.go | 13 ++++++++----- 2 files changed, 42 insertions(+), 9 deletions(-) diff --git a/work/kf/account.go b/work/kf/account.go index 6153faa2e..039df83e1 100644 --- a/work/kf/account.go +++ b/work/kf/account.go @@ -33,6 +33,7 @@ type AccountAddSchema struct { } // AccountAdd 添加客服账号 +// see https://developer.work.weixin.qq.com/document/path/94662 func (r *Client) AccountAdd(options AccountAddOptions) (info AccountAddSchema, err error) { var ( accessToken string @@ -59,6 +60,7 @@ type AccountDelOptions struct { } // AccountDel 删除客服账号 +// see https://developer.work.weixin.qq.com/document/path/94663 func (r *Client) AccountDel(options AccountDelOptions) (info util.CommonError, err error) { var ( accessToken string @@ -86,7 +88,8 @@ type AccountUpdateOptions struct { MediaID string `json:"media_id"` // 客服头像临时素材。可以调用上传临时素材接口获取, 不多于128个字节 } -// AccountUpdate 修复客服账号 +// AccountUpdate 修改客服账号 +// see https://developer.work.weixin.qq.com/document/path/94664 func (r *Client) AccountUpdate(options AccountUpdateOptions) (info util.CommonError, err error) { var ( accessToken string @@ -109,9 +112,10 @@ func (r *Client) AccountUpdate(options AccountUpdateOptions) (info util.CommonEr // AccountInfoSchema 客服详情 type AccountInfoSchema struct { - OpenKFID string `json:"open_kfid"` // 客服帐号ID - Name string `json:"name"` // 客服帐号名称 - Avatar string `json:"avatar"` // 客服头像URL + OpenKFID string `json:"open_kfid"` // 客服帐号ID + Name string `json:"name"` // 客服帐号名称 + Avatar string `json:"avatar"` // 客服头像URL + ManagePrivilege bool `json:"manage_privilege"` // 当前调用接口的应用身份,是否有该客服账号的管理权限(编辑客服账号信息、分配会话和收发消息) } // AccountListSchema 获取客服账号列表响应内容 @@ -141,6 +145,31 @@ func (r *Client) AccountList() (info AccountListSchema, err error) { return info, nil } +// AccountPagingRequest 分页获取客服账号列表请求 +type AccountPagingRequest struct { + Offset int `json:"offset"` + Limit int `json:"limit"` +} + +// AccountPaging 分页获取客服账号列表 +// see https://developer.work.weixin.qq.com/document/path/94661 +func (r *Client) AccountPaging(req *AccountPagingRequest) (*AccountListSchema, error) { + var ( + accessToken string + err error + ) + if accessToken, err = r.ctx.GetAccessToken(); err != nil { + return nil, err + } + var response []byte + if response, err = util.PostJSON(fmt.Sprintf(accountListAddr, accessToken), req); err != nil { + return nil, err + } + result := &AccountListSchema{} + err = util.DecodeWithError(response, result, "AccountPaging") + return result, err +} + // AddContactWayOptions 获取客服账号链接 // 1.若scene非空,返回的客服链接开发者可拼接scene_param=SCENE_PARAM参数使用,用户进入会话事件会将SCENE_PARAM原样返回。其中SCENE_PARAM需要urlencode,且长度不能超过128字节。 // 如 https://work.weixin.qq.com/kf/kfcbf8f8d07ac7215f?enc_scene=ENCGFSDF567DF&scene_param=a%3D1%26b%3D2 @@ -158,6 +187,7 @@ type AddContactWaySchema struct { } // AddContactWay 获取客服账号链接 +// see https://developer.work.weixin.qq.com/document/path/94665 func (r *Client) AddContactWay(options AddContactWayOptions) (info AddContactWaySchema, err error) { var ( accessToken string diff --git a/work/kf/servicer.go b/work/kf/servicer.go index 5c34efc99..a620f1417 100644 --- a/work/kf/servicer.go +++ b/work/kf/servicer.go @@ -18,15 +18,17 @@ const ( // ReceptionistOptions 添加接待人员请求参数 type ReceptionistOptions struct { - OpenKFID string `json:"open_kfid"` // 客服帐号ID - UserIDList []string `json:"userid_list"` // 接待人员userid列表。第三方应用填密文userid,即open_userid 可填充个数:1 ~ 100。超过100个需分批调用。 + OpenKFID string `json:"open_kfid"` // 客服帐号ID + UserIDList []string `json:"userid_list"` // 接待人员userid列表。第三方应用填密文userid,即open_userid 可填充个数:1 ~ 100。超过100个需分批调用。 + DepartmentIDList []int `json:"department_id_list"` // 接待人员部门id列表 可填充个数:0 ~ 100。超过100个需分批调用。 } // ReceptionistSchema 添加接待人员响应内容 type ReceptionistSchema struct { util.CommonError ResultList []struct { - UserID string `json:"userid"` + UserID string `json:"userid"` + DepartmentID int `json:"department_id"` util.CommonError } `json:"result_list"` } @@ -79,8 +81,9 @@ func (r *Client) ReceptionistDel(options ReceptionistOptions) (info Receptionist type ReceptionistListSchema struct { util.CommonError ReceptionistList []struct { - UserID string `json:"userid"` // 接待人员的userid。第三方应用获取到的为密文userid,即open_userid - Status int `json:"status"` // 接待人员的接待状态。0:接待中,1:停止接待。第三方应用需具有“管理帐号、分配会话和收发消息”权限才可获取 + UserID string `json:"userid"` // 接待人员的userid。第三方应用获取到的为密文userid,即open_userid + Status int `json:"status"` // 接待人员的接待状态。0:接待中,1:停止接待。第三方应用需具有“管理帐号、分配会话和收发消息”权限才可获取 + DepartmentID int `json:"department_id"` // 接待人员部门的id } `json:"servicer_list"` }