Pp Slack — Workflow
Overview
How the pp-slack skill works, step by step.
Source Workflow
Codex skill workflow.
Step-by-step Workflow
Slack - Printing Press CLI
Prerequisites: Install the CLI
This skill drives the slack-pp-cli binary. You must verify the CLI is installed before invoking any command from this skill. If it is missing, install it first:
- Install via the Printing Press installer:
npx -y @mvanhorn/printing-press install slack --cli-only - Verify:
slack-pp-cli --version - Ensure
$GOPATH/bin(or$HOME/go/bin) is on$PATH.
If the npx install fails (no Node, offline, etc.), fall back to a direct Go install (requires Go 1.26.3 or newer):
go install github.com/mvanhorn/printing-press-library/library/productivity/slack/cmd/slack-pp-cli@latest
If --version reports "command not found" after install, the install step did not put the binary on $PATH. Do not proceed with skill commands until verification succeeds.
When to Use This CLI
Reach for this when the user wants:
- send a Slack message to a channel or DM
- search Slack across channels, DMs, and threads (live or synced)
- list users, channels, usergroups, custom emoji, pinned items, or reminders
- understand channel health (quiet channels, activity trends, response times, digest)
- find stale or unanswered threads across the workspace
- pull an activity summary for a user or channel
- export channel history to JSONL for archival or migration
- discover the funniest messages in public channels (local-sync-powered novelty query)
Skip it when the user wants to create Slack apps, workflows, or manage admin-only team settings beyond team access logs. Those surfaces are better served by the Slack web admin.
Two Auth Surfaces
Slack has two parallel token types and this CLI supports both:
| Token | Scopes | When to use |
|---|---|---|
SLACK_BOT_TOKEN (xoxb-) | workspace-scoped bot permissions | Default for post-message, read-channel, list-users, etc. |
SLACK_USER_TOKEN (xoxp-) | user-scoped | DM history, search on behalf of a user, stars, reminders |
Set whichever the workspace permits. If both are set, user-token wins for user-scoped endpoints and bot-token otherwise. Get a token at https://api.slack.com/apps -> your app -> OAuth & Permissions.
Argument Parsing
Parse $ARGUMENTS:
- Empty,
help, or--help-> showslack-pp-cli --help - Starts with
install-> ends withmcp-> MCP installation; otherwise -> CLI installation - Anything else -> Direct Use (map to the best command and run it)
MCP Server Installation
The CLI also ships an MCP server at slack-pp-mcp. Install and register:
go install github.com/mvanhorn/printing-press-library/library/productivity/slack/cmd/slack-pp-mcp@latest
claude mcp add -e SLACK_BOT_TOKEN=xoxb-... slack-pp-mcp -- slack-pp-mcp
Ask the user for the actual token value before running.
Direct Use
- Check installed:
which slack-pp-cli. If missing, offer CLI installation. - Discover commands:
slack-pp-cli --help; drill intoslack-pp-cli <cmd> --help. - Match the user query to the best command (see Notable Commands below).
- Execute with
--agentfor structured output:slack-pp-cli <command> [args] --agent - The
--agentflag sets--json --compact --no-input --no-color --yes.
Source routing (local vs live) is controlled by --data-source: auto (default) prefers local-synced data with live fallback; live always hits the API; local runs fully offline against the SQLite snapshot. Run slack-pp-cli sync first to populate the local store for analytics queries.
Notable Commands
| Command | What it does |
|---|---|
conversations | List channels and DMs in the workspace |
users | List all users in the workspace |
search <query> | Full-text search across synced messages (or live API with --data-source live) |
digest | Daily/weekly activity digest from locally synced data |
health | Channel health report (activity, engagement, stagnation) |
quiet | Find dead or low-activity channels |
response-times | Average first-response time in threads |
threads-stale | Unanswered or stale threads |
activity <user-or-channel> | Activity summary across channels from local sync |
trends | Week-over-week channel activity trends |
sync | Populate the local SQLite store for offline analytics |
emoji / reminders / pins / stars | Workspace directory queries |
team | Access logs (requires admin token) |
Run any command with --help for full flag documentation.
Agent Mode
Add --agent to any command. Expands to: --json --compact --no-input --no-color --yes.
- Pipeable — JSON on stdout, errors on stderr
- Filterable —
--selectkeeps a subset of fields, with dotted-path support (see below) - Previewable —
--dry-runshows the request without sending - Cacheable — GET responses cached for 5 minutes, bypass with
--no-cache - Non-interactive — never prompts, every input is a flag
Filtering output
--select accepts dotted paths to descend into nested responses; arrays traverse element-wise:
slack-pp-cli <command> --agent --select id,name
slack-pp-cli <command> --agent --select items.id,items.owner.name
Use this to narrow huge payloads to the fields you actually need — critical for deeply nested API responses.
Response envelope
Data-layer commands wrap output in {"meta": {...}, "results": <data>}. Parse .results for data and .meta.source to know whether it's live or local. The N results (live) summary is printed to stderr only when stdout is a TTY; piped/agent consumers see pure JSON on stdout.
Exit Codes
| Code | Meaning |
|---|---|
| 0 | Success |
| 2 | Usage error (wrong arguments) |
| 3 | Resource not found (channel, user, message) |
| 4 | Authentication required (token missing or invalid) |
| 5 | API error (Slack upstream, including not_in_channel, channel_not_found) |
| 7 | Rate limited (Slack 429; CLI honors Retry-After) |
Execution Logic
The skill executes when its trigger fires (slash command, natural-language match, or direct invocation). It reads its references, applies its rules, and produces the documented outputs.
Edge Cases
See the source skill's references/ and scripts/ folders for edge-case handling.
Failure Handling
A skill failure surfaces as a tool error or a partial output; never a silent skip. Re-run with --verbose (where applicable) for diagnostics.
Integration Notes
- Claude — invoked via the
Skilltool withskill: "pp-slack". - Codex — referenced from
AGENTS.mdif mirrored. - Antigravity — referenced from the workspace agent rules if mirrored.
- HQ Project — listed on the landing page Skills section + post-login sidebar.
- MD Project (md.sgnk.ai) — file rendered from
Skills/Pp Slack/workflow.md. - Obsidian — file rendered with frontmatter + tags.
Usage Examples
Invoke via slash command or natural language matching the skill description.
Source: (none)