← 返回
开发者工具 Key 中文

Ms Graph Calendar

Find available meeting times and free/busy slots for company employees using Microsoft Graph API. Use when user asks to schedule a meeting, find a free slot,...
使用 Microsoft Graph API 查找公司员工的可用会议时间和空闲/忙碌时段。当用户请求安排会议或寻找空闲时段时使用。
artisong
开发者工具 clawhub v1.0.2 1 版本 99857.1 Key: 需要
★ 0
Stars
📥 699
下载
💾 8
安装
1
版本
#latest

概述

Microsoft Graph Calendar — Find Free Slots

Use this skill when the user wants to:

  • Find a time when multiple employees are all free
  • Check if a specific person is available at a given time
  • List upcoming meetings / busy blocks for one or more people
  • Suggest meeting slots across the company

Setup (ทำครั้งแรกครั้งเดียว)

ถ้าผู้ใช้ยังไม่เคย setup หรือระบบแจ้งว่าขาด credentials ให้ทำดังนี้:

  1. ถามผู้ใช้ 3 ค่านี้ทีละค่า:
    • AZURE_TENANT_ID (Azure Portal → Azure Active Directory → Overview)
    • AZURE_CLIENT_ID (App registrations → your app → Application (client) ID)
    • AZURE_CLIENT_SECRET (App registrations → your app → Certificates & secrets)
  1. เมื่อได้ครบแล้ว รันคำสั่ง:
  2. node skills/ms-graph-calendar/scripts/setup.js \
      --tenant-id <AZURE_TENANT_ID> \
      --client-id <AZURE_CLIENT_ID> \
      --client-secret <AZURE_CLIENT_SECRET>
    

ค่าจะถูกบันทึกไว้ที่ ~/.openclaw/ms-graph-calendar.json (permission 600) และจะถูกโหลดอัตโนมัติทุกครั้งที่ใช้ skill

  1. ทดสอบด้วย:
  2. node skills/ms-graph-calendar/scripts/get-token.js
    

ถ้าได้ "✅ Token acquired" แปลว่าพร้อมใช้งานแล้ว

App Registration ต้องมี Application Permissions:

  • Calendars.Read — read all users' calendars
  • User.Read.All — list employees
  • Admin ต้อง Grant consent ก่อน

Configuration

Authentication is cached after first login. No environment variables required for device code flow.

For headless/automated operation, set these environment variables:

  • AZURE_CLIENT_ID - Azure AD app client ID
  • AZURE_CLIENT_SECRET - Azure AD app secret
  • AZURE_TENANT_ID - Tenant ID (use "consumers" for personal accounts)

Tools

This skill runs Node.js scripts via bash. Files:

  • scripts/ — Node.js scripts
  • nicknames.md — ตาราง mapping ชื่อเล่น → email (แก้ไขได้เลย)

Instructions

Step 1 — Get Access Token

Before any Graph API call, get an app-only token:

node skills/ms-graph-calendar/scripts/get-token.js

Store the token in a temp variable for subsequent calls.

Step 2 — Parse the User's Request

Extract from the user's message:

  • Who: names or emails of attendees (e.g. "Alice and Bob", "the marketing team")
  • When: date range to search (e.g. "this week", "next Monday", "March 5–7")
  • Duration: how long the meeting should be (default 60 minutes)
  • Timezone: default to Asia/Bangkok if not specified

If any info is missing, ask the user before proceeding.

Step 3 — Resolve Employee Emails

3a. ลองแปลงชื่อเล่นก่อน (เร็วกว่า ไม่ต้องเรียก API):

node skills/ms-graph-calendar/scripts/resolve-nicknames.js --names "แบงค์,มิ้ว,โบ้"

อ่านจาก nicknames.md ในโฟลเดอร์ skill — แก้ไขได้ตรงนั้นเลย

3b. ถ้าหาไม่เจอใน nicknames.md ให้ fallback ไปค้น Graph API:

node skills/ms-graph-calendar/scripts/list-users.js --search "ชื่อ"

Confirm กับ user ถ้ามีคนชื่อเดียวกันหลายคน

Step 4 — Find Free Slots (choose one method)

Method A — findMeetingTimes (best for small groups, ≤10 people):

node skills/ms-graph-calendar/scripts/find-meeting-times.js \
  --attendees "alice@company.com,bob@company.com" \
  --start "2025-03-01T08:00:00" \
  --end "2025-03-01T18:00:00" \
  --duration 60 \
  --timezone "Asia/Bangkok" \
  --max 5

Method B — getSchedule (best for large groups or viewing free/busy blocks):

node skills/ms-graph-calendar/scripts/get-schedule.js \
  --emails "alice@company.com,bob@company.com,carol@company.com" \
  --start "2025-03-01T00:00:00" \
  --end "2025-03-07T00:00:00" \
  --timezone "Asia/Bangkok" \
  --interval 30

Step 5 — Present Results

Format the available slots clearly:

📅 Available slots where everyone is free:

1. Monday 3 Mar · 10:00–11:00
2. Tuesday 4 Mar · 14:00–15:00
3. Wednesday 5 Mar · 09:00–10:00

Which slot works best?

If no slots are found, widen the search window and try again, or report that no common availability exists in that period.


Example Conversations

User: "Find a 1-hour slot this week where Alice, Bob, and Carol are all free"

Agent:

  1. Resolves emails for Alice, Bob, Carol
  2. Runs find-meeting-times.js with date range = this Mon–Fri
  3. Returns top 3 available slots

User: "Is John free tomorrow afternoon?"

Agent:

  1. Resolves John's email
  2. Runs get-schedule.js for tomorrow 12:00–18:00
  3. Reports free/busy blocks

User: "Show me everyone in the marketing team's availability next week"

Agent:

  1. Lists users in the Marketing group via list-users.js --group "Marketing"
  2. Runs get-schedule.js for all their emails
  3. Presents a visual free/busy summary

Error Handling

ErrorCauseFix
---------
401 UnauthorizedToken expired or wrong credentialsRe-run get-token.js, check env vars
403 ForbiddenMissing Admin ConsentAsk IT admin to grant consent in Azure Portal
404 Not FoundUser email doesn't existVerify email via list-users.js
No slots foundEveryone is busyWiden time range or reduce attendees

Security Notes

  • Credentials are read from env vars only — never log or echo them
  • This skill has read-only access to calendars (Calendars.Read)
  • It cannot create, edit, or delete any events
  • To restrict which mailboxes the app can read, ask your IT admin to set an App Access Policy in Exchange Online:

```powershell

New-ApplicationAccessPolicy -AppId -PolicyScopeGroupId -AccessRight RestrictAccess

```

版本历史

共 1 个版本

  • v1.0.2 当前
    2026-03-30 01:32 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

developer-tools

Agent Browser

matrixy
专为AI智能体优化的无头浏览器自动化CLI,支持无障碍树快照和基于引用的元素选择。
★ 427 📥 118,387
developer-tools

Gog

steipete
Google Workspace 命令行工具,支持 Gmail、日历、云端硬盘、通讯录、表格和文档。
★ 921 📥 185,928
developer-tools

Github

steipete
使用 `gh` CLI 与 GitHub 交互,通过 `gh issue`、`gh pr`、`gh run` 和 `gh api` 管理议题、PR、CI 运行及高级查询。
★ 672 📥 324,535