← ClaudeAtlas

dingtalk-contactlisted

钉钉通讯录与联系人查询。当用户提到"钉钉通讯录"、"查找员工"、"搜索用户"、"查用户信息"、"获取用户详情"、"用户手机号"、"员工姓名"、"员工工号"、"查部门"、"搜索部门"、"部门成员"、"部门列表"、"部门详情"、"子部门"、"父部门"、"部门路径"、"员工总数"、"通讯录搜索"、"userId 转 unionId"、"unionId 转 userId"、"dingtalk contact"、"dingtalk directory"、"find user"、"get user info"、"department members"时使用此技能。支持:按关键词搜索用户/部门、获取用户完整信息(姓名/手机/工号/部门/职位/unionId)、获取部门成员列表、获取部门树结构、查询用户所在部门路径、员工总人数统计等全部通讯录操作。
breath57/dingtalk-skills · ★ 76 · AI & Automation · score 74
Install: claude install-skill breath57/dingtalk-skills
# 钉钉通讯录技能 负责钉钉通讯录的所有查询操作。本文件为**策略指南**,仅包含决策逻辑和工作流程。完整 API 请求格式见文末「references/api.md 查阅索引」。 > `dt_helper.sh` 位于本 `SKILL.md` 同级目录的 `scripts/dt_helper.sh`。 ## 工作流程(每次执行前) 1. **先识别本次任务类型** → 例如:搜索用户、查用户详情、搜索部门、列部门成员、查部门路径、统计员工数 2. **按本次任务校验所需配置** → 通过 `bash scripts/dt_helper.sh --get KEY` 读取;仅校验本任务必须项 3. **仅收集缺失配置** → 若缺少某项,**一次性询问用户**所有缺失值,用 `bash scripts/dt_helper.sh --set KEY=VALUE` 写入 4. **获取 Token** → 直接调用 `bash scripts/dt_helper.sh` 5. **执行操作** → 复杂的创建临时文件再执行,简单的直接执行;禁止 heredoc ### 按任务校验配置(必须先做) - **所有任务通用必需**:`DINGTALK_APP_KEY`、`DINGTALK_APP_SECRET` - **需要“以当前操作者为起点”或“直接读取本人身份信息”的任务**:必须有 `DINGTALK_MY_USER_ID` > 规则:未通过“本次任务配置校验”前,不得进入 API 调用步骤。 > 凭证禁止在输出中完整打印,确认时仅显示前 4 位 + `****` ### 所需配置 | 配置键 | 必填 | 说明 | 如何获取 | |---|---|---|---| | `DINGTALK_APP_KEY` | ✅ | 应用 AppKey | ���钉开放平台 → 应用管理 → 凭证信息 | | `DINGTALK_APP_SECRET` | ✅ | 应用 AppSecret | 同上 | | `DINGTALK_MY_USER_ID` | ❌ | **当前操作用户**的 userId(即运行此技能的人自己),仅在需要以自身为起点查询时才需要 | 管理后台 → 通讯录 → 成员管理 → 点击姓名查看 | ### 身份标识说明 | 标识 | 说明 | |---|---| | `userId`(= `staffId`) | 企业内部员工 ID,可通过通过管理后台 -> 通讯录 -> 成员管理 -> 点击姓名查看 | | `unionId` | 跨企业/跨应用唯一标识,可通过 `bash scripts/dt_helper.sh --to-unionid <userid>` 获取 | ### 执行脚本模板 ```bash #!/bin/bash set -e HELPER="./scripts/dt_helper.sh" NEW_TOKEN=$(bash "$HELPER" --token) # api.dingtalk.com 接口用 OLD_TOKEN=$(bash "$HELPER" --old-token) # oapi.dingtalk.com 接口用 # USER_ID=$(bash "$HELPER" --get DINGTALK_MY_USER_ID) # 以当前操作用户为起点时启用 # 在此追加具体 API 调用,例如按姓名搜索用户并获取详情: KEYWORD="张三" SEARCH=$(curl -s