Package Exports
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@harness-lab/cli) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Harness CLI
Small Harness Lab CLI for facilitator auth, workshop operations, and portable workshop skill installation.
Current shipped scope:
harness versionharness skill installharness auth loginharness auth logoutharness auth statusharness instance currentharness instance selectharness workshop statusharness instance listharness instance showharness workshop participant-accessharness instance createharness instance updateharness instance resetharness instance sync-localharness workshop prepareharness instance removeharness workshop archiveharness workshop phase set <phase-id>
Current implementation posture:
- targets the existing shared dashboard facilitator APIs
- defaults to a browser/device approval flow backed by dashboard-side facilitator broker sessions
- keeps
--auth basicand--auth neonas explicit local-dev/bootstrap fallback modes - stores session material in a local file under
HARNESS_CLI_HOMEor~/.harnessby default - supports macOS Keychain, Windows Credential Manager, and Linux Secret Service as explicit
HARNESS_SESSION_STORAGEoverrides - supports brokered facilitator commands over the same workshop APIs used by the dashboard
Usage
Install
Participant-facing default install:
npm install -g @harness-lab/cliSupported runtime:
- Node
22or newer - npm
10or newer recommended
Verify the binary:
harness --version
harness --helpDevelopment or fallback install from this repository:
npm install -g ./harness-clior:
cd harness-cli
npm linkVerify the local install:
harness version
harness --helpParticipant Quick Start
If you are a workshop participant, this is the only command you need:
harness skill installThis installs the workshop skill into your current repo. After install, open Codex or Claude Code in the same repo and run $workshop commands to get started. You do not need any of the facilitator commands below.
Optional explicit target:
harness skill install --target /path/to/team-repoThis creates .agents/skills/workshop in the target repo. The install does not require a local clone of the Harness Lab source repo.
Rerunning harness skill install refreshes the installed bundle when the packaged workshop content changed and reports clearly when the target is already current. Use --force only when you want a full reinstall.
After install, the CLI prints the first recommended agent commands, starting with Codex: $workshop commands and Claude Code: /skill:workshop.
Treat the installed workshop skill as the first participant entrypoint. It should route setup, reference, and workshop guidance through live contentLang when available or the best reviewed bundled locale otherwise, instead of assuming the base authored Czech docs are always the right first stop.
Treat .agents/skills/workshop as generated workshop bundle content. The canonical authored source remains in this repository under workshop-skill/, workshop-blueprint/, selected docs/, and selected materials/.
After install — what a participant sees
Installing the skill does not log anyone in. When the facilitator starts the room, a participant opens the dashboard at /participant and walks through three steps:
- Event code — the facilitator reads the shared code aloud; the participant redeems it to enter the room.
- Name pick — the participant sees a picker scoped to the roster the facilitator pre-pasted (or a walk-in path when
allow_walk_insis on). Prefix-matching; no free-text guessing. - Password — first time through, the participant sets a password. On return, they enter the same password. Identity persists across browser close because each participant has a real Neon Auth account.
The CLI is not in this flow — the identify surface is the dashboard. Reference: docs/adr/2026-04-19-name-first-identify-with-neon-auth.md.
Facilitator Commands
Everything below this line is for facilitators managing workshop instances.
Default device/browser login:
harness auth login \
--dashboard-url https://harness-lab-dashboard.vercel.appThe CLI prints a verification URL plus user code, optionally opens the browser when supported, then polls until the facilitator approves the request on /admin/device.
Explicit local file-mode / Basic Auth fallback:
harness auth login \
--auth basic \
--dashboard-url http://localhost:3000 \
--username facilitator \
--password secretExplicit Neon email/password bootstrap fallback:
harness auth login \
--auth neon \
--dashboard-url https://harness-lab-dashboard.vercel.app \
--email facilitator@example.comWorkshop commands:
harness auth status
harness skill install
harness instance list
harness instance select sample-workshop-demo-orbit
harness instance current
harness workshop status
harness instance show sample-workshop-demo-orbit
harness workshop participant-access
harness workshop participant-access --rotate
harness workshop participant-access --rotate --code orbit7-bridge4-shift2
harness instance create sample-workshop-demo-orbit --event-title "Sample Workshop Demo"
harness instance update --room-name Orbit
harness instance reset --template-id blueprint-default
harness instance reset --blueprint-file .local/workshop-packs/no-repo-switching-cs.json
harness instance sync-local --blueprint-file .local/workshop-packs/no-repo-switching-cs.json --phase-ids opening,intermezzo-1,intermezzo-2
harness workshop prepare
harness instance remove
harness workshop phase set rotation
harness workshop archive --notes "Manual archive"
harness instance select --clear
harness auth logoutTargeting model:
harness instance listis the discovery entrypoint for facilitator-visible workshopsharness instance select <instance-id>stores a local current target for later workshop commandsharness instance currentreports the stored target and resolves its current server stateharness workshop status,harness workshop phase set <phase-id>, andharness workshop archiverequire a selected instance and hard-error with "No instance selected" when none is pinnedharness instance show,update,reset,prepare, andremoveaccept an explicit<instance-id>but may also use the stored selection as a fallbackharness workshop participant-accessaccepts an explicit<instance-id>but may also use the stored selection as a fallbackharness instance select --clearremoves the stored selection- No environment-variable fallback. Pin an instance explicitly with
instance select.
Machine-readable output:
harness --json ...prints strict JSON output without headings- prefer this for agent or script consumption instead of parsing human-oriented terminal copy
Facilitator lifecycle commands are intentionally CLI-first:
- skill invokes
harness harnessinvokes the protected dashboard APIs- the dashboard APIs remain the source of truth for authorization, validation, idempotency, and audit logging
Local blueprint override:
harness instance reset --from-localreads the generated local blueprint fromdashboard/lib/generated/agenda-{lang}.jsonharness instance reset --blueprint-file <path>reads an explicit local agenda pack JSON file and sends it to the reset API directly- use
--blueprint-filefor one-off workshop variants that should stay local and git-ignored rather than mutating the tracked blueprint harness instance sync-local --blueprint-file <path>patches matching agenda items and presenter scenes through the protectedagenda/scenesAPIs instead of relying on reset semantics- use
sync-localwhen you want an existing instance to pick up local-only content edits without resetting the whole instance
Environment variables:
HARNESS_DASHBOARD_URLHARNESS_AUTH_MODEHARNESS_ADMIN_USERNAMEHARNESS_ADMIN_PASSWORDHARNESS_FACILITATOR_EMAILHARNESS_FACILITATOR_PASSWORDHARNESS_CLI_HOMEHARNESS_SESSION_STORAGE(file,keychain,credential-manager, orsecret-service)
Not a CLI input: NEON_API_KEY. It is a dashboard-side control-plane credential used server-side by dashboard/lib/auth/admin-create-user.ts to provision participant accounts during identify. Do not set it for the CLI — it belongs in the dashboard deployment environment only.
Release Gate
Public npm publication is controlled by the release gate in docs/harness-cli-publication-gate.md. Normal development should still happen from this repository; npm is the participant-facing distribution path, not a substitute for repo-local development.