workspace/skills/slack-user-context/SKILL.md
Leverage Slack user profiles, presence, DND status, and workspace context to personalize responses, route escalations, and coordinate team operations. Use when checking who is on-call, routing an escalation, personalizing responses based on user role, or respecting Do Not Disturb before paging someone.
npx skillsauth add automateyournetwork/netclaw slack-user-contextInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
| Scope | Purpose |
|-------|---------|
| users:read | View workspace members and their basic info |
| users.profile:read | View detailed profiles (title, department, timezone) |
| users:write | Set NetClaw's own presence status |
| dnd:read | Check Do Not Disturb before escalating |
| im:read | View DM channel info |
| im:history | Read DM context for personalized responses |
| channels:read | Know which channels exist and their purposes |
| search:read.public | Search public channels for relevant discussions |
Before escalating an alert to a specific person:
Escalation Decision Matrix:
| DND | Presence | Severity | Action | |-----|----------|----------|--------| | Off | Active | Any | Mention directly | | Off | Away | P1/P2 | Mention (they'll see notification) | | Off | Away | P3/P4 | Post to channel, don't mention | | On | Any | P1 | Mention anyway (override DND for P1) | | On | Any | P2 | Try next person in rotation | | On | Any | P3/P4 | Post to channel only |
Adjust response complexity based on who's asking:
From user profile title/department:
| Title Contains | Response Style | |----------------|---------------| | "Network Engineer", "CCIE" | Full technical detail, CLI output, protocol specifics | | "NOC", "Operations" | Actionable steps, severity, impact summary | | "Manager", "Director" | Executive summary, business impact, timeline | | "Security", "InfoSec" | Focus on security implications, CVEs, compliance | | "Developer", "DevOps" | API perspectives, connectivity impact, service mapping | | "Help Desk", "Support" | Simple status, ETA, who to contact |
When scheduling reports or maintenance windows:
When a user asks a follow-up question:
When NetClaw needs to escalate:
:telephone_receiver: *Escalation Attempt*
Checking team availability...
• @engineer1 — :green_circle: Active (Network Engineer) — *SELECTED*
• @engineer2 — :red_circle: DND until 08:00 EST (Senior NetEng)
• @engineer3 — :yellow_circle: Away (NOC Analyst) — last active 2h ago
• @manager1 — :green_circle: Active (Net Ops Manager) — CC'd on P1
Escalating to @engineer1...
If NetClaw sees a user is already active in multiple incident threads:
:information_source: Note: @engineer1 is currently active in 2 other incident threads.
Consider routing to @engineer3 if this is non-urgent.
When a shift change is approaching:
:arrows_counterclockwise: *Shift Handoff Summary for @nightshift_engineer*
*Active Items:*
1. :warning: R2 memory trending high (78% → 82% over 8h) — monitoring
2. :wrench: SW1 firmware upgrade scheduled for 02:00 UTC — prep done
3. :white_check_mark: R1 Loopback99 change completed and verified
*Pending:*
4. :hourglass: Waiting on ISP ticket #45678 for R3 circuit
5. :clipboard: Security audit scheduled for SW2 tomorrow
_Full context in #netclaw-reports thread →_
Set NetClaw's own presence to reflect its status:
| NetClaw Status | Slack Presence | Meaning | |----------------|---------------|---------| | Idle | :green_circle: Active | Ready for requests | | Running health check | :green_circle: Active | Processing (responsive) | | Running fleet-wide ops | :yellow_circle: Away | Batch processing (may be slow) | | Error / unreachable MCP | :red_circle: DND | Degraded — some skills unavailable |
Before answering questions about the network, search public channels for recent discussions:
| Skill | User Context Enhancement | |-------|-------------------------| | slack-network-alerts | Route to active, available engineers | | slack-incident-workflow | IC assignment based on availability | | slack-report-delivery | Adjust detail level per audience | | All pyATS skills | Include requestor context in GAIT trail |
testing
Human-in-the-loop escalation via HumanRail — route low-confidence agent decisions, pre-destructive operation approvals, and ambiguous incident tickets to real human engineers. Human answers are verified and returned as structured output. Workers are paid via Lightning Network. Use when the agent is uncertain, when a destructive change needs explicit human sign-off beyond a ServiceNow CR, or when an ambiguous ticket requires human triage before automated handling.
testing
Manage EVE-NG node lifecycle. Use when listing nodes, checking runtime state, creating or deleting nodes, starting or stopping nodes or whole labs, verifying node details, or wiping node NVRAM back to factory defaults.
development
Manage EVE-NG labs and platform inventory. Use when listing labs, checking lab metadata, creating or deleting labs, importing or exporting lab archives, checking EVE-NG health or auth, or verifying available node images before build work.
tools
Execute live CLI commands on running EVE-NG nodes over telnet console. Use when running show commands, making live config changes, verifying protocol state, testing connectivity, checking console readiness, or interacting with IOS, Junos, VPCS, EOS, or NX-OS nodes.