account.go 5.8 KB

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