account.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  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. type AddContactWayOptions struct {
  140. OpenKFID string `json:"open_kfid"` // 客服帐号ID, 不多于64字节
  141. Scene string `json:"scene"` // 场景值,字符串类型,由开发者自定义, 不多于32字节, 字符串取值范围(正则表达式):[0-9a-zA-Z_-]*
  142. }
  143. // AddContactWaySchema 获取客服账号链接响应内容
  144. type AddContactWaySchema struct {
  145. util.CommonError
  146. URL string `json:"url"` // 客服链接,开发者可将该链接嵌入到H5页面中,用户点击链接即可向对应的微信客服帐号发起咨询。开发者也可根据该url自行生成需要的二维码图片
  147. }
  148. // AddContactWay 获取客服账号链接
  149. func (r *Client) AddContactWay(options AddContactWayOptions) (info AddContactWaySchema, err error) {
  150. var (
  151. accessToken string
  152. data []byte
  153. )
  154. accessToken, err = r.ctx.GetAccessToken()
  155. if err != nil {
  156. return
  157. }
  158. data, err = util.PostJSON(fmt.Sprintf(addContactWayAddr, accessToken), options)
  159. if err != nil {
  160. return
  161. }
  162. if err = json.Unmarshal(data, &info); err != nil {
  163. return
  164. }
  165. if info.ErrCode != 0 {
  166. return info, NewSDKErr(info.ErrCode, info.ErrMsg)
  167. }
  168. return info, nil
  169. }