contact_way.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. package externalcontact
  2. import (
  3. "fmt"
  4. "github.com/silenceper/wechat/v2/util"
  5. )
  6. const (
  7. // addContactWayURL 配置客户联系「联系我」方式
  8. addContactWayURL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/add_contact_way?access_token=%s"
  9. // getContactWayURL 获取企业已配置的「联系我」方式
  10. getContactWayURL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/get_contact_way?access_token=%s"
  11. // updateContactWayURL 更新企业已配置的「联系我」方式
  12. updateContactWayURL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/update_contact_way?access_token=%s"
  13. // listContactWayURL 获取企业已配置的「联系我」列表
  14. listContactWayURL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/list_contact_way?access_token=%s"
  15. // delContactWayURL 删除企业已配置的「联系我」方式
  16. delContactWayURL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/del_contact_way?access_token=%s"
  17. // closeTempChatURL 结束临时会话
  18. closeTempChatURL = "https://qyapi.weixin.qq.com/cgi-bin/externalcontact/close_temp_chat?access_token=%s"
  19. )
  20. type (
  21. // ConclusionsRequest 结束语请求
  22. ConclusionsRequest struct {
  23. Text ConclusionsText `json:"text"`
  24. Image ConclusionsImageRequest `json:"image"`
  25. Link ConclusionsLink `json:"link"`
  26. MiniProgram ConclusionsMiniProgram `json:"miniprogram"`
  27. }
  28. // ConclusionsText 文本格式结束语
  29. ConclusionsText struct {
  30. Content string `json:"content"`
  31. }
  32. // ConclusionsImageRequest 图片格式结束语请求
  33. ConclusionsImageRequest struct {
  34. MediaID string `json:"media_id"`
  35. }
  36. // ConclusionsLink 链接格式结束语
  37. ConclusionsLink struct {
  38. Title string `json:"title"`
  39. PicURL string `json:"picurl"`
  40. Desc string `json:"desc"`
  41. URL string `json:"url"`
  42. }
  43. // ConclusionsMiniProgram 小程序格式结束语
  44. ConclusionsMiniProgram struct {
  45. Title string `json:"title"`
  46. PicMediaID string `json:"pic_media_id"`
  47. AppID string `json:"appid"`
  48. Page string `json:"page"`
  49. }
  50. // ConclusionsResponse 结束语响应
  51. ConclusionsResponse struct {
  52. Text ConclusionsText `json:"text"`
  53. Image ConclusionsImageResponse `json:"image"`
  54. Link ConclusionsLink `json:"link"`
  55. MiniProgram ConclusionsMiniProgram `json:"miniprogram"`
  56. }
  57. // ConclusionsImageResponse 图片格式结束语响应
  58. ConclusionsImageResponse struct {
  59. PicURL string `json:"pic_url"`
  60. }
  61. )
  62. type (
  63. // AddContactWayRequest 配置客户联系「联系我」方式请求
  64. AddContactWayRequest struct {
  65. Type int `json:"type"`
  66. Scene int `json:"scene"`
  67. Style int `json:"style"`
  68. Remark string `json:"remark"`
  69. SkipVerify bool `json:"skip_verify"`
  70. State string `json:"state"`
  71. User []string `json:"user"`
  72. Party []int `json:"party"`
  73. IsTemp bool `json:"is_temp"`
  74. ExpiresIn int `json:"expires_in"`
  75. ChatExpiresIn int `json:"chat_expires_in"`
  76. UnionID string `json:"unionid"`
  77. IsExclusive bool `json:"is_exclusive"`
  78. MarkSource bool `json:"mark_source"`
  79. Conclusions ConclusionsRequest `json:"conclusions"`
  80. }
  81. // AddContactWayResponse 配置客户联系「联系我」方式响应
  82. AddContactWayResponse struct {
  83. util.CommonError
  84. ConfigID string `json:"config_id"`
  85. QrCode string `json:"qr_code"`
  86. }
  87. )
  88. // AddContactWay 配置客户联系「联系我」方式
  89. // see https://developer.work.weixin.qq.com/document/path/92228
  90. func (r *Client) AddContactWay(req *AddContactWayRequest) (*AddContactWayResponse, error) {
  91. var (
  92. accessToken string
  93. err error
  94. )
  95. if accessToken, err = r.GetAccessToken(); err != nil {
  96. return nil, err
  97. }
  98. var response []byte
  99. if response, err = util.PostJSON(fmt.Sprintf(addContactWayURL, accessToken), req); err != nil {
  100. return nil, err
  101. }
  102. result := &AddContactWayResponse{}
  103. err = util.DecodeWithError(response, result, "AddContactWay")
  104. return result, err
  105. }
  106. type (
  107. // GetContactWayRequest 获取企业已配置的「联系我」方式请求
  108. GetContactWayRequest struct {
  109. ConfigID string `json:"config_id"`
  110. }
  111. // GetContactWayResponse 获取企业已配置的「联系我」方式响应
  112. GetContactWayResponse struct {
  113. util.CommonError
  114. ContactWay ContactWay `json:"contact_way"`
  115. }
  116. // ContactWay 「联系我」配置
  117. ContactWay struct {
  118. ConfigID string `json:"config_id"`
  119. Type int `json:"type"`
  120. Scene int `json:"scene"`
  121. Style int `json:"style"`
  122. Remark string `json:"remark"`
  123. SkipVerify bool `json:"skip_verify"`
  124. State string `json:"state"`
  125. QrCode string `json:"qr_code"`
  126. User []string `json:"user"`
  127. Party []int `json:"party"`
  128. IsTemp bool `json:"is_temp"`
  129. ExpiresIn int `json:"expires_in"`
  130. ChatExpiresIn int `json:"chat_expires_in"`
  131. UnionID string `json:"unionid"`
  132. MarkSource bool `json:"mark_source"`
  133. Conclusions ConclusionsResponse `json:"conclusions"`
  134. }
  135. )
  136. // GetContactWay 获取企业已配置的「联系我」方式
  137. // see https://developer.work.weixin.qq.com/document/path/92228
  138. func (r *Client) GetContactWay(req *GetContactWayRequest) (*GetContactWayResponse, error) {
  139. var (
  140. accessToken string
  141. err error
  142. )
  143. if accessToken, err = r.GetAccessToken(); err != nil {
  144. return nil, err
  145. }
  146. var response []byte
  147. if response, err = util.PostJSON(fmt.Sprintf(getContactWayURL, accessToken), req); err != nil {
  148. return nil, err
  149. }
  150. result := &GetContactWayResponse{}
  151. err = util.DecodeWithError(response, result, "GetContactWay")
  152. return result, err
  153. }
  154. type (
  155. // UpdateContactWayRequest 更新企业已配置的「联系我」方式请求
  156. UpdateContactWayRequest struct {
  157. ConfigID string `json:"config_id"`
  158. Remark string `json:"remark"`
  159. SkipVerify bool `json:"skip_verify"`
  160. Style int `json:"style"`
  161. State string `json:"state"`
  162. User []string `json:"user"`
  163. Party []int `json:"party"`
  164. ExpiresIn int `json:"expires_in"`
  165. ChatExpiresIn int `json:"chat_expires_in"`
  166. UnionID string `json:"unionid"`
  167. MarkSource bool `json:"mark_source"`
  168. Conclusions ConclusionsRequest `json:"conclusions"`
  169. }
  170. // UpdateContactWayResponse 更新企业已配置的「联系我」方式响应
  171. UpdateContactWayResponse struct {
  172. util.CommonError
  173. }
  174. )
  175. // UpdateContactWay 更新企业已配置的「联系我」方式
  176. // see https://developer.work.weixin.qq.com/document/path/92228
  177. func (r *Client) UpdateContactWay(req *UpdateContactWayRequest) (*UpdateContactWayResponse, error) {
  178. var (
  179. accessToken string
  180. err error
  181. )
  182. if accessToken, err = r.GetAccessToken(); err != nil {
  183. return nil, err
  184. }
  185. var response []byte
  186. if response, err = util.PostJSON(fmt.Sprintf(updateContactWayURL, accessToken), req); err != nil {
  187. return nil, err
  188. }
  189. result := &UpdateContactWayResponse{}
  190. err = util.DecodeWithError(response, result, "UpdateContactWay")
  191. return result, err
  192. }
  193. type (
  194. //ListContactWayRequest 获取企业已配置的「联系我」列表请求
  195. ListContactWayRequest struct {
  196. StartTime int `json:"start_time"`
  197. EndTime int `json:"end_time"`
  198. Cursor string `json:"cursor"`
  199. Limit int `json:"limit"`
  200. }
  201. //ListContactWayResponse 获取企业已配置的「联系我」列表响应
  202. ListContactWayResponse struct {
  203. util.CommonError
  204. ContactWay []*ContactWayForList `json:"contact_way"`
  205. NextCursor string `json:"next_cursor"`
  206. }
  207. // ContactWayForList 「联系我」配置
  208. ContactWayForList struct {
  209. ConfigID string `json:"config_id"`
  210. }
  211. )
  212. // ListContactWay 获取企业已配置的「联系我」列表
  213. // see https://developer.work.weixin.qq.com/document/path/92228
  214. func (r *Client) ListContactWay(req *ListContactWayRequest) (*ListContactWayResponse, error) {
  215. var (
  216. accessToken string
  217. err error
  218. )
  219. if accessToken, err = r.GetAccessToken(); err != nil {
  220. return nil, err
  221. }
  222. var response []byte
  223. if response, err = util.PostJSON(fmt.Sprintf(listContactWayURL, accessToken), req); err != nil {
  224. return nil, err
  225. }
  226. result := &ListContactWayResponse{}
  227. err = util.DecodeWithError(response, result, "ListContactWay")
  228. return result, err
  229. }
  230. type (
  231. // DelContactWayRequest 删除企业已配置的「联系我」方式请求
  232. DelContactWayRequest struct {
  233. ConfigID string `json:"config_id"`
  234. }
  235. // DelContactWayResponse 删除企业已配置的「联系我」方式响应
  236. DelContactWayResponse struct {
  237. util.CommonError
  238. }
  239. )
  240. // DelContactWay 删除企业已配置的「联系我」方式
  241. // see https://developer.work.weixin.qq.com/document/path/92228
  242. func (r *Client) DelContactWay(req *DelContactWayRequest) (*DelContactWayResponse, error) {
  243. var (
  244. accessToken string
  245. err error
  246. )
  247. if accessToken, err = r.GetAccessToken(); err != nil {
  248. return nil, err
  249. }
  250. var response []byte
  251. if response, err = util.PostJSON(fmt.Sprintf(delContactWayURL, accessToken), req); err != nil {
  252. return nil, err
  253. }
  254. result := &DelContactWayResponse{}
  255. err = util.DecodeWithError(response, result, "DelContactWay")
  256. return result, err
  257. }
  258. // CloseTempChatRequest 结束临时会话请求
  259. type CloseTempChatRequest struct {
  260. UserID string `json:"userid"`
  261. ExternalUserID string `json:"external_userid"`
  262. }
  263. // CloseTempChat 结束临时会话
  264. // @see https://developer.work.weixin.qq.com/document/path/92228
  265. func (r *Client) CloseTempChat(req *CloseTempChatRequest) error {
  266. var (
  267. accessToken string
  268. err error
  269. )
  270. if accessToken, err = r.GetAccessToken(); err != nil {
  271. return err
  272. }
  273. var response []byte
  274. if response, err = util.PostJSON(fmt.Sprintf(closeTempChatURL, accessToken), req); err != nil {
  275. return err
  276. }
  277. return util.DecodeWithCommonError(response, "CloseTempChat")
  278. }