skills/cyrus-setup/SKILL.md
Set up Cyrus end-to-end — install prerequisites, configure authentication, create integrations (Linear, GitHub, Slack), add repositories, and launch. Run this once to get Cyrus running as a background agent.
npx skillsauth add ceedaragents/cyrus cyrus-setupInstall 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.
One-command setup for self-hosted Cyrus. This orchestrator walks you through everything needed to run Claude Code as a background agent from Linear, Slack, and GitHub.
FORBIDDEN: Do NOT use Read, Edit, or Write tools on ~/.cyrus/.env or any file inside ~/.cyrus/. This file contains secrets (API keys, tokens, signing secrets). All interaction with this file MUST go through Bash commands (grep, printf >> ..., etc.) which the user can see and approve. Never read its contents into the conversation context.
The goal of browser automation in this skill is to reduce sign-in and setup fatigue — the agent navigates web UIs, fills forms, and scrapes credentials so the user doesn't have to do it all manually.
Three modes, in order of preference:
claude-in-chrome (preferred when available) — if the user is running Claude Code and has the claude-in-chrome MCP extension connected, use it. This has the huge advantage of using the user's existing Chrome with all their signed-in sessions (Linear, Slack, GitHub). Check availability by seeing if mcp__claude-in-chrome__* tools exist.agent-browser CLI — a standalone Playwright-based binary invoked via Bash. Requires launching a fresh Chrome profile with remote debugging enabled (the user will need to sign in to services in that profile). Check with which agent-browser.Determining which mode to use:
claude-in-chrome MCP tools are available in the current session. If yes, use those — no setup needed.which agent-browser. If installed, launch a fresh Chrome profile (see below).agent-browser, or follow manual instructions?agent-browser setup — fresh Chrome profile:
agent-browser needs a Chrome instance with remote debugging enabled. Launch one with an isolated profile:
# Find an open port
for port in $(seq 9222 9322); do
if ! lsof -i :"$port" > /dev/null 2>&1; then
echo "Open port found: $port"
break
fi
done
# Create a fresh profile directory
mkdir -p ~/.cyrus/chrome-profile
# Launch Chrome with remote debugging (runs in background)
# macOS:
"/Applications/Google Chrome.app/Contents/MacOS/Google Chrome" \
--remote-debugging-port=<port> \
--user-data-dir="$HOME/.cyrus/chrome-profile" &
# Linux:
google-chrome --remote-debugging-port=<port> \
--user-data-dir="$HOME/.cyrus/chrome-profile" &
# Connect agent-browser to it
agent-browser connect <port>
After connecting, commands work normally:
agent-browser navigate "https://example.com"
agent-browser click "button:text('Submit')"
agent-browser fill "#input-id" "value"
agent-browser screenshot
agent-browser eval "document.title"
Important: The user will need to sign in to Linear, Slack, and GitHub in this fresh Chrome profile before the agent can automate app creation. The agent should navigate to each service and pause for the user to sign in before proceeding with automation.
Cleanup: After setup is complete, close the Chrome instance:
lsof -ti :<port> | xargs kill 2>/dev/null
This skill runs sub-skills in order, skipping any that are already complete. You can re-run /cyrus-setup at any time to add integrations or fix configuration.
Each step references a sub-skill file. To execute a sub-skill, read the SKILL.md file using the Read tool and follow its instructions. The sub-skill files are sibling directories to this skill:
| Step | Sub-skill | File to read |
|------|-----------|-------------|
| 1 | setup-prerequisites | cyrus-setup-prerequisites/SKILL.md (relative to skills directory) |
| 2 | setup-claude-auth | cyrus-setup-claude-auth/SKILL.md |
| 3 | setup-endpoint | cyrus-setup-endpoint/SKILL.md |
| 4 | setup-linear | cyrus-setup-linear/SKILL.md |
| 5 | setup-github | cyrus-setup-github/SKILL.md |
| 5b | setup-gitlab | cyrus-setup-gitlab/SKILL.md |
| 6 | setup-slack | cyrus-setup-slack/SKILL.md |
| 7 | setup-repository | cyrus-setup-repository/SKILL.md |
| 8 | setup-launch | cyrus-setup-launch/SKILL.md |
To find the files, look for them relative to this file's directory (go up one level, then into the sub-skill directory). For example, if this file is at ~/.claude/skills/cyrus-setup/SKILL.md, the sub-skills are at ~/.claude/skills/cyrus-setup-prerequisites/SKILL.md, etc.
If a sub-skill file is not found, use Glob to search for it: **/cyrus-setup-prerequisites/SKILL.md
Before anything else, collect preferences from the user. Use the AskUserQuestion tool if available — ask questions interactively rather than printing them as a text block. You may bundle related questions into a single ask, or ask them one at a time.
Ask the user (defaults in parentheses):
Cyrus)AI coding agent for automated development)Store as AGENT_NAME and AGENT_DESCRIPTION — used when creating Linear, Slack, and GitHub apps.
Ask the user to select one or more:
At least one is required. Store the selection — it determines which integration sub-skills run (Steps 4-6).
Ask: npm, pnpm, bun, or yarn?
Store the answer — used by the prerequisites skill.
Read the cyrus-setup-prerequisites/SKILL.md sub-skill and follow its instructions.
Pass the user's package manager preference from Step 0.
Read the cyrus-setup-claude-auth/SKILL.md sub-skill and follow its instructions.
Read the cyrus-setup-endpoint/SKILL.md sub-skill and follow its instructions.
Only if the user selected Linear in Step 0.
Read the cyrus-setup-linear/SKILL.md sub-skill and follow its instructions.
Only if the user selected GitHub in Step 0.
Read the cyrus-setup-github/SKILL.md sub-skill and follow its instructions.
Only if the user selected GitLab in Step 0.
Read the cyrus-setup-gitlab/SKILL.md sub-skill and follow its instructions.
Only if the user selected Slack in Step 0.
Read the cyrus-setup-slack/SKILL.md sub-skill and follow its instructions. All paths (A-1, A-2, and B) must use the manifest-based creation flow — never create the Slack app "from scratch" with manual scope/event configuration.
Read the cyrus-setup-repository/SKILL.md sub-skill and follow its instructions.
Read the cyrus-setup-launch/SKILL.md sub-skill and follow its instructions.
/setup is safe.CYRUS_SERVER_PORT and LINEAR_DIRECT_WEBHOOKS are written directly by the agent.agent-browser for Linear/Slack app creation; falls back to guided manual steps if not installed.documentation
Configure Slack integration for Cyrus — create a Slack app from manifest, then guide the user to save credentials.
tools
Configure GitHub for Cyrus — gh CLI login and git config for PRs, with optional webhook setup to enable @mention responses in PR comments, automated rebases and merges, and auto-fixing based on CI failures (coming soon).
testing
Orchestrate F1 test drives to validate the Cyrus agent system end-to-end across issue-tracker, EdgeWorker, and activity rendering.
tools
Create a Linear OAuth application and configure Cyrus to use it — supports agent-browser automation or guided manual setup.