department.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package addresslist
  2. import (
  3. "fmt"
  4. "github.com/silenceper/wechat/v2/util"
  5. )
  6. const (
  7. // departmentCreateURL 创建部门
  8. departmentCreateURL = "https://qyapi.weixin.qq.com/cgi-bin/department/create?access_token=%s"
  9. // departmentSimpleListURL 获取子部门ID列表
  10. departmentSimpleListURL = "https://qyapi.weixin.qq.com/cgi-bin/department/simplelist?access_token=%s&id=%d"
  11. // departmentListURL 获取部门列表
  12. departmentListURL = "https://qyapi.weixin.qq.com/cgi-bin/department/list?access_token=%s"
  13. // departmentGetURL 获取单个部门详情 https://qyapi.weixin.qq.com/cgi-bin/department/get?access_token=ACCESS_TOKEN&id=ID
  14. departmentGetURL = "https://qyapi.weixin.qq.com/cgi-bin/department/get?access_token=%s&id=%d"
  15. )
  16. type (
  17. // DepartmentCreateRequest 创建部门数据请求
  18. DepartmentCreateRequest struct {
  19. Name string `json:"name"`
  20. NameEn string `json:"name_en,omitempty"`
  21. ParentID int `json:"parentid"`
  22. Order int `json:"order,omitempty"`
  23. ID int `json:"id,omitempty"`
  24. }
  25. // DepartmentCreateResponse 创建部门数据响应
  26. DepartmentCreateResponse struct {
  27. util.CommonError
  28. ID int `json:"id"`
  29. }
  30. // DepartmentSimpleListResponse 获取子部门ID列表响应
  31. DepartmentSimpleListResponse struct {
  32. util.CommonError
  33. DepartmentID []*DepartmentID `json:"department_id"`
  34. }
  35. // DepartmentID 子部门ID
  36. DepartmentID struct {
  37. ID int `json:"id"`
  38. ParentID int `json:"parentid"`
  39. Order int `json:"order"`
  40. }
  41. // DepartmentListResponse 获取部门列表响应
  42. DepartmentListResponse struct {
  43. util.CommonError
  44. Department []*Department `json:"department"`
  45. }
  46. // Department 部门列表数据
  47. Department struct {
  48. ID int `json:"id"` // 创建的部门id
  49. Name string `json:"name"` // 部门名称
  50. NameEn string `json:"name_en"` // 英文名称
  51. DepartmentLeader []string `json:"department_leader"` // 部门负责人的UserID
  52. ParentID int `json:"parentid"` // 父部门id。根部门为1
  53. Order int `json:"order"` // 在父部门中的次序值。order值大的排序靠前
  54. }
  55. // DepartmentGetResponse 获取单个部门详情
  56. DepartmentGetResponse struct {
  57. util.CommonError
  58. Department Department `json:"department"`
  59. }
  60. )
  61. // DepartmentCreate 创建部门
  62. // see https://developer.work.weixin.qq.com/document/path/90205
  63. func (r *Client) DepartmentCreate(req *DepartmentCreateRequest) (*DepartmentCreateResponse, error) {
  64. var (
  65. accessToken string
  66. err error
  67. )
  68. if accessToken, err = r.GetAccessToken(); err != nil {
  69. return nil, err
  70. }
  71. var response []byte
  72. if response, err = util.PostJSON(fmt.Sprintf(departmentCreateURL, accessToken), req); err != nil {
  73. return nil, err
  74. }
  75. result := &DepartmentCreateResponse{}
  76. err = util.DecodeWithError(response, result, "DepartmentCreate")
  77. return result, err
  78. }
  79. // DepartmentSimpleList 获取子部门ID列表
  80. // see https://developer.work.weixin.qq.com/document/path/95350
  81. func (r *Client) DepartmentSimpleList(departmentID int) ([]*DepartmentID, error) {
  82. var (
  83. accessToken string
  84. err error
  85. )
  86. if accessToken, err = r.GetAccessToken(); err != nil {
  87. return nil, err
  88. }
  89. var response []byte
  90. if response, err = util.HTTPGet(fmt.Sprintf(departmentSimpleListURL, accessToken, departmentID)); err != nil {
  91. return nil, err
  92. }
  93. result := &DepartmentSimpleListResponse{}
  94. err = util.DecodeWithError(response, result, "DepartmentSimpleList")
  95. return result.DepartmentID, err
  96. }
  97. // DepartmentList 获取部门列表
  98. // @desc https://developer.work.weixin.qq.com/document/path/90208
  99. func (r *Client) DepartmentList() ([]*Department, error) {
  100. // 获取accessToken
  101. accessToken, err := r.GetAccessToken()
  102. if err != nil {
  103. return nil, err
  104. }
  105. // 发起http请求
  106. response, err := util.HTTPGet(fmt.Sprintf(departmentListURL, accessToken))
  107. if err != nil {
  108. return nil, err
  109. }
  110. // 按照结构体解析返回值
  111. result := &DepartmentListResponse{}
  112. err = util.DecodeWithError(response, result, "DepartmentList")
  113. // 返回数据
  114. return result.Department, err
  115. }
  116. // DepartmentGet 获取单个部门详情
  117. // see https://developer.work.weixin.qq.com/document/path/95351
  118. func (r *Client) DepartmentGet(departmentID int) (*Department, error) {
  119. var (
  120. accessToken string
  121. err error
  122. )
  123. if accessToken, err = r.GetAccessToken(); err != nil {
  124. return nil, err
  125. }
  126. var response []byte
  127. if response, err = util.HTTPGet(fmt.Sprintf(departmentGetURL, accessToken, departmentID)); err != nil {
  128. return nil, err
  129. }
  130. result := &DepartmentGetResponse{}
  131. err = util.DecodeWithError(response, result, "DepartmentGet")
  132. return &result.Department, err
  133. }