钉钉企业内部应用服务端API,现在已经实现接口:
- 获取access_token
- 通讯录管理
- 部门管理
- 创建部门
- 获取子部门ID列表
- 获取部门列表
- 获取部门详情
- 删除部门
- 用户管理
- 获取用户详情
- 获取部门用户
- 部门管理
- 消息通知
- 创建会话
- 发送群消息
bindChat(钉钉文档中找不到)
- 考勤
- 获取打卡详情
- 获取打卡结果
Add this line to your application's Gemfile:
gem 'dingtalktool'
And then execute:
$ bundle
Or install it yourself as:
$ gem install dingtalktool
1.添加config/initializers/dingtalktool.rb
Dingtalktool.configure do |configuration|
configuration.corpid = "" # 必填, 企业自用账号信息中CorpId
configuration.secret = "" # 必填, 开发体验账号管理里面的CorpSecret
configuration.agentid = "" #必填,在创建微应用的时候会分配
end
2.添加配置之后就能直接使用gem提供的功能
- 获取token
token = Dingtalktool::AuthService.getAccessToken # 返回token字符串
- 获取部门列表
department_res = Dingtalktool::DepartmentService.listDept(token)
- 获取部门下所有员工
# 获取当个部门员工
department_users = Dingtalktool::UserService.list(token, department_id)
- 获取员工打卡详情
userIds = User.all.map(&:userid).uniq
user_ids = Array(userIds.each_slice(50)) # 每次最多查询50位员工,所以这里要把所有员工id分开
result = []
user_ids.each do |users|
data = {
userIds: users,
checkDateFrom: Time.now.beginning_of_day.strftime("%Y-%m-%d %H:%M:%S"),
checkDateTo: Time.now.end_of_day.strftime("%Y-%m-%d %H:%M:%S"),
isI18n: 'false'
}
listRecord = Dingtalktool::AttendanceService.listRecord(token, data)
if listRecord['errcode'] == 0 && listRecord['errmsg'] == 'ok'
result += listRecord['recordresult']
end
end
更多方法请查看下面文件结构
├── dingtalktool
│ ├── attendance_service.rb
│ ├── auth_service.rb
│ ├── cache_service.rb
│ ├── chat_service.rb
│ ├── configuration.rb
│ ├── department_service.rb
│ ├── http_service.rb
│ ├── log_service.rb
│ ├── message_service.rb
│ ├── user_service.rb
│ └── version.rb
└── dingtalktool.rb
类名 | 方法 | 备注 |
AttendanceService | listRecord | |
list | ||
AuthService | getAccessToken | |
getTicket | ||
ChatService | createChat | |
bindChat | ||
sendmsg | ||
DepartmentService | createDept | |
listDept | ||
list_ids | ||
department_info | ||
deleteDept | ||
MessageService | sendToConversation | |
send | ||
send_chat | ||
UserService | getUserInfo | |
get | ||
simplelist | ||
list |
- 添加所有服务端API
- 优化调用方式
有任何问题都联系我
- 邮箱: liu_xiaodao@163.com
- 微信/QQ: 957419420
1.1.0 缓存文件位置 1.0.2 缓存文件和日至文件位置修改
以上功能是为了满足我自己一个项目写的,所以只包含了钉钉服务端API的一小部分,后面我会持续优化,谢谢,这也是我写的第一个正式的gem
After checking out the repo, run bin/setup
to install dependencies. Then, run rake spec
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
, which will create a git tag for the version, push git commits and tags, and push the .gem
file to rubygems.org.
Bug reports and pull requests are welcome on GitHub at https://github.com/Liu-XiaoDao/dingtalktool. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
The gem is available as open source under the terms of the MIT License.
Everyone interacting in the Dingtalktool project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.