account.go 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. package kf
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/silenceper/wechat/v2/util"
  6. )
  7. const (
  8. // 添加客服账号
  9. accountAddAddr = "https://qyapi.weixin.qq.com/cgi-bin/kf/account/add?access_token=%s"
  10. // 删除客服账号
  11. accountDelAddr = "https://qyapi.weixin.qq.com/cgi-bin/kf/account/del?access_token=%s"
  12. // 修改客服账号
  13. accountUpdateAddr = "https://qyapi.weixin.qq.com/cgi-bin/kf/account/update?access_token=%s"
  14. // 获取客服账号列表
  15. accountListAddr = "https://qyapi.weixin.qq.com/cgi-bin/kf/account/list?access_token=%s"
  16. // 获取客服账号链接
  17. addContactWayAddr = "https://qyapi.weixin.qq.com/cgi-bin/kf/add_contact_way?access_token=%s"
  18. )
  19. // AccountAddOptions 添加客服账号请求参数
  20. type AccountAddOptions struct {
  21. Name string `json:"name"` // 客服帐号名称, 不多于16个字符
  22. MediaID string `json:"media_id"` // 客服头像临时素材。可以调用上传临时素材接口获取, 不多于128个字节
  23. }
  24. // AccountAddSchema 添加客服账号响应内容
  25. type AccountAddSchema struct {
  26. util.CommonError
  27. OpenKFID string `json:"open_kfid"` // 新创建的客服张号ID
  28. }
  29. // AccountAdd 添加客服账号
  30. func (r *Client) AccountAdd(options AccountAddOptions) (info AccountAddSchema, err error) {
  31. var (
  32. accessToken string
  33. data []byte
  34. )
  35. if accessToken, err = r.ctx.GetAccessToken(); err != nil {
  36. return
  37. }
  38. if data, err = util.PostJSON(fmt.Sprintf(accountAddAddr, accessToken), options); err != nil {
  39. return
  40. }
  41. if err = json.Unmarshal(data, &info); err != nil {
  42. return
  43. }
  44. if info.ErrCode != 0 {
  45. return info, NewSDKErr(info.ErrCode, info.ErrMsg)
  46. }
  47. return info, nil
  48. }
  49. // AccountDelOptions 删除客服账号请求参数
  50. type AccountDelOptions struct {
  51. OpenKFID string `json:"open_kfid"` // 客服帐号ID, 不多于64字节
  52. }
  53. // AccountDel 删除客服账号
  54. func (r *Client) AccountDel(options AccountDelOptions) (info util.CommonError, err error) {
  55. var (
  56. accessToken string
  57. data []byte
  58. )
  59. if accessToken, err = r.ctx.GetAccessToken(); err != nil {
  60. return
  61. }
  62. if data, err = util.PostJSON(fmt.Sprintf(accountDelAddr, accessToken), options); err != nil {
  63. return
  64. }
  65. if err = json.Unmarshal(data, &info); err != nil {
  66. return
  67. }
  68. if info.ErrCode != 0 {
  69. return info, NewSDKErr(info.ErrCode, info.ErrMsg)
  70. }
  71. return info, nil
  72. }
  73. // AccountUpdateOptions 修改客服账号请求参数
  74. type AccountUpdateOptions struct {
  75. OpenKFID string `json:"open_kfid"` // 客服帐号ID, 不多于64字节
  76. Name string `json:"name"` // 客服帐号名称, 不多于16个字符
  77. MediaID string `json:"media_id"` // 客服头像临时素材。可以调用上传临时素材接口获取, 不多于128个字节
  78. }
  79. // AccountUpdate 修复客服账号
  80. func (r *Client) AccountUpdate(options AccountUpdateOptions) (info util.CommonError, err error) {
  81. var (
  82. accessToken string
  83. data []byte
  84. )
  85. if accessToken, err = r.ctx.GetAccessToken(); err != nil {
  86. return
  87. }
  88. if data, err = util.PostJSON(fmt.Sprintf(accountUpdateAddr, accessToken), options); err != nil {
  89. return
  90. }
  91. if err = json.Unmarshal(data, &info); err != nil {
  92. return
  93. }
  94. if info.ErrCode != 0 {
  95. return info, NewSDKErr(info.ErrCode, info.ErrMsg)
  96. }
  97. return info, nil
  98. }
  99. // AccountInfoSchema 客服详情
  100. type AccountInfoSchema struct {
  101. OpenKFID string `json:"open_kfid"` // 客服帐号ID
  102. Name string `json:"name"` // 客服帐号名称
  103. Avatar string `json:"avatar"` // 客服头像URL
  104. }
  105. // AccountListSchema 获取客服账号列表响应内容
  106. type AccountListSchema struct {
  107. util.CommonError
  108. AccountList []AccountInfoSchema `json:"account_list"` // 客服账号列表
  109. }
  110. // AccountList 获取客服账号列表
  111. func (r *Client) AccountList() (info AccountListSchema, err error) {
  112. var (
  113. accessToken string
  114. data []byte
  115. )
  116. if accessToken, err = r.ctx.GetAccessToken(); err != nil {
  117. return
  118. }
  119. if data, err = util.HTTPGet(fmt.Sprintf(accountListAddr, accessToken)); err != nil {
  120. return
  121. }
  122. if err = json.Unmarshal(data, &info); err != nil {
  123. return
  124. }
  125. if info.ErrCode != 0 {
  126. return info, NewSDKErr(info.ErrCode, info.ErrMsg)
  127. }
  128. return info, nil
  129. }
  130. // AddContactWayOptions 获取客服账号链接
  131. // 1.若scene非空,返回的客服链接开发者可拼接scene_param=SCENE_PARAM参数使用,用户进入会话事件会将SCENE_PARAM原样返回。其中SCENE_PARAM需要urlencode,且长度不能超过128字节。
  132. // 如 https://work.weixin.qq.com/kf/kfcbf8f8d07ac7215f?enc_scene=ENCGFSDF567DF&scene_param=a%3D1%26b%3D2
  133. // 2.历史调用接口返回的客服链接(包含encScene=XXX参数),不支持scene_param参数。
  134. // 3.返回的客服链接,不能修改或复制参数到其他链接使用。否则进入会话事件参数校验不通过,导致无法回调。
  135. type AddContactWayOptions struct {
  136. OpenKFID string `json:"open_kfid"` // 客服帐号ID, 不多于64字节
  137. Scene string `json:"scene"` // 场景值,字符串类型,由开发者自定义, 不多于32字节, 字符串取值范围(正则表达式):[0-9a-zA-Z_-]*
  138. }
  139. // AddContactWaySchema 获取客服账号链接响应内容
  140. type AddContactWaySchema struct {
  141. util.CommonError
  142. URL string `json:"url"` // 客服链接,开发者可将该链接嵌入到H5页面中,用户点击链接即可向对应的微信客服帐号发起咨询。开发者也可根据该url自行生成需要的二维码图片
  143. }
  144. // AddContactWay 获取客服账号链接
  145. func (r *Client) AddContactWay(options AddContactWayOptions) (info AddContactWaySchema, err error) {
  146. var (
  147. accessToken string
  148. data []byte
  149. )
  150. if accessToken, err = r.ctx.GetAccessToken(); err != nil {
  151. return
  152. }
  153. if data, err = util.PostJSON(fmt.Sprintf(addContactWayAddr, accessToken), options); err != nil {
  154. return
  155. }
  156. if err = json.Unmarshal(data, &info); err != nil {
  157. return
  158. }
  159. if info.ErrCode != 0 {
  160. return info, NewSDKErr(info.ErrCode, info.ErrMsg)
  161. }
  162. return info, nil
  163. }