plugins/lisa-agy/skills/project-ideation/SKILL.md
Generate practical, verifiable product ideas for the current host project FROM EVIDENCE-DERIVED PERSONAS, then turn the selected build-ready ideas into real PRDs via lisa:research. First derives the personas the project actually serves by mining its docs, code, data model, and releases (never invented — each persona cites its evidence), then ideates per persona. Every build-ready idea must pass a practicality gate (an obtainable data/source path) and an empirical verification gate (a user-observable outcome the agent can verify). Selected ideas are handed to lisa:research, which creates each PRD in the configured source (Notion / Confluence / GitHub / Linear) — in the draft state by default, or prd-ready (auto-picked-up by lisa:intake) when prd_ready=true. Defaults to creating one PRD (the top-ranked idea); max_prds widens the batch. Invoke for 'generate feature ideas for this project', 'what should we build next for <persona>?', 'looking at <external product>, what should we add here?'. Vendor- and stack-agnostic.
npx skillsauth add codyswanngt/lisa project-ideationInstall 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.
Generate persona-grounded, verifiable ideas for the host project in $ARGUMENTS (or the current
working directory), then create PRDs for the selected build-ready ideas via lisa:research.
The value of this skill is grounding + filtering, not brainstorm volume. Ideas come from personas the project demonstrably serves, and an idea you cannot ground in obtainable data and cannot verify yourself is noise — demote it honestly.
target (first positional, optional) — a target project path, or an external product/site to
draw inspiration from. Defaults to the current working directory.prd_ready=true|false (default false) — the PRD-lifecycle state for the PRDs this run
creates. false → created in the source's draft state for human review. true → created
prd-ready so the PRD side of lisa:intake auto-claims them. Passed straight through to
lisa:research (which maps it to lisa:prd-source-write's initial_role) only after the PRD queue
pressure gate allows auto-ready writes.max_prds=<n>|all (default 1) — how many build-ready ideas become PRDs this run. Default
creates one PRD (the single top-ranked idea), because lisa:research is a heavy full flow.
max_prds=3 creates the top three; max_prds=all creates one per build-ready idea. Discovery
Spikes and Rejected ideas are never turned into PRDs regardless of max_prds.fixture=<path> (optional, verification-only) — a deterministic host-project fixture used
for idempotency verification. When present, read the fixture before ranking and honor its declared
single persona, single idea, existing-fit anchor, and expected dedupe marker. Do not use this
parameter for normal ideation runs.This skill does create PRDs (via lisa:research) for the selected ideas. It does not create
tracker tickets (that is lisa:plan) and does not change code (that is lisa:implement).
An idea may only become a Practical Idea (and thus a PRD candidate) if it passes BOTH gates. Otherwise demote it.
Failing the practicality gate → Rejected / Not Practical Yet (or Discovery Spike if a bounded probe could make it practical), naming the missing data/source/access. Failing only the verification gate → Discovery Spike (define the missing proof), never a build-ready recommendation.
Never propose ideas before you understand what exists. Inspect the host project and record:
package.json, pyproject.toml, go.mod,
Cargo.toml, Gemfile, …) and any .lisa.config.json.README, docs/, wiki/, architecture notes, ADRs, marketing/landing copy.Use Lisa's existing methodology rather than inventing a parallel flow. Route each evidence source through the matching established practice before any idea is promoted to Practical Ideas:
/lisa:codebase-research concepts: trace data flow from entry point
to output, identify modification points, map dependencies, and find reusable code or patterns./lisa:product-walkthrough methodology first: inspect the
current product surface, note existing-component reuse candidates, capture coverage smells or
behavioral surprises, and only then list a UI idea as build-ready.Ideation is persona-driven, and the personas must be gleaned from the project itself — not assumed. Mine the Step 1 evidence for who the project actually serves:
Anti-fabrication rule (mechanical): no evidence citation → no persona. Generic roles ("admin", "analyst", "end user", "power user") are banned unless the project has specific evidence for them. Each persona requires at least two grounded signals from different source classes where available; if only one strong signal exists, emit a single low-confidence "Primary documented user" persona named as such — never fabricate a full set from thin evidence.
Cap the set at 3–6 personas (merge adjacent personas by goal/workflow; more than six is taxonomy noise). Each persona records:
name — concrete and project-specific.goals — what this persona is trying to accomplish.pains — current friction for this persona, grounded in observed behavior/gaps.evidence — the specific files / doc sections / tables / releases that justify the persona.confidence — high | medium | low, with the reason.Always emit a Personas Derived From Evidence section, even when no PRDs are created. Spikes and
rejected ideas are still tagged with the persona they would serve (or cross-persona).
Only when the user references an external product, website, public dataset, or competitor:
For each derived persona, brainstorm ideas that serve that persona's goals/pains, tag each idea with the persona(s) it serves, then run every idea through BOTH gates. For each surviving idea, build a feasibility card:
Rank Practical Ideas by persona value, feasibility, verification clarity, and project fit. Then
select the creation set by max_prds (default 1 → the single top-ranked idea; <n> → top n;
all → every Practical Idea). Spikes and Rejected ideas are reported but never selected.
This step runs only when prd_ready=true. A draft run (prd_ready=false) skips this gate and
continues to Step 6, because draft PRDs do not create immediate PRD-intake pickup pressure.
Before invoking lisa:research for any selected idea, inspect the configured PRD source queue with
the same PRD reader contract used by /lisa:queue-status and evaluate it with
evaluatePrdQueuePressure from plugins/lisa/scripts/queue-status-prd-readers.mjs (source:
plugins/src/base/scripts/queue-status-prd-readers.mjs). Resolve the queue from .lisa.config.json
the same way lisa:intake resolves the PRD side, and pass the matching queue argument in the
blocked outcome (for example, github intake_mode=prd).
Queue pressure is any unresolved PRD lifecycle work that would make another auto-ready PRD compete
with existing intake work. Treat at least these roles as pressure when the helper reports them:
prd-ready, prd-in-review, prd-blocked, unresolved prd-ticketed, and source-reader failures or
misconfiguration snapshots. prd-shipped / prd-verified terminal history is not pressure unless the
reader helper explicitly reports it as unresolved.
If the helper returns allowed: false, stop before any lisa:research, lisa:prd-source-write, or
vendor PRD writer invocation. Emit PRDs Created as a blocked outcome, not as an empty success or a
silent idle run. The blocked outcome must include:
source and tracker from .lisa.config.json;role;ref and url, when the snapshot supplies them;nextStep and otherwise using
/lisa:intake <PRD queue>;Use this output shape so recurring automations can surface a useful next step without digging through debug logs:
## PRDs Created
Blocked: PRD queue pressure prevents auto-ready creation.
- source: <source>
- tracker: <tracker>
- role: <decisive role>
- item: <ref or "unavailable"> <url when available>
- next action: <helper nextStep or /lisa:intake <PRD queue>>
- write invoked: no
If the helper returns allowed: true, continue to Step 6 normally and keep the existing draft/ready
creation behavior unchanged.
For each idea in the creation set, invoke /lisa:research with:
prd_ready (this run's flag — lisa:research maps it to draft vs prd-ready),ideation_ledger_payload handoff containing the selected marker, automation id and
memory path when available, persona names, persona evidence references, rejected overlap
candidates, repo identity, prd_ready, selected idea title/key, and the expected empirical
verification artifact. This payload is the only ideation-run metadata channel between
project-ideation, research, prd-source-write, and the vendor writer; keep GitHub-specific
rendering out of this skill.lisa:research synthesizes the PRD and creates it in the configured source via
lisa:prd-source-write. project-ideation never writes to the source directly — it delegates, so
the PRD source stays switchable per project. Capture each returned PRD ref / URL / role / outcome.
When the run has a Codex automation id or memory path, maintain a concise local advisory ledger after the PRD source write returns. Resolve the memory path in this order:
memory_file=<path> or automation_memory=<path> argument, when supplied;$CODEX_AUTOMATION_MEMORY, when set;$CODEX_HOME/automations/<automation_id>/memory.md, when automation_id=<id> or
$CODEX_AUTOMATION_ID is available.Create the parent directory and memory.md if missing. Write one concise run entry keyed by the
dedupe marker and run timestamp. The entry must include the marker, PRD URL/ref, outcome
(created | reused | updated | blocked), lifecycle role (draft | ready | blocked or the returned
source role), and source_agreement (github-source-wins, memory-created, memory-updated, or
memory-missing-runtime). If memory says one thing but the PRD source search finds a matching open
PRD, GitHub/source truth wins: reuse the source PRD and update memory rather than creating a
duplicate. Keep memory advisory only; never use it to override lifecycle labels, source marker
matches, or the PRD source writer's returned role. Do not store secrets, tokens, full PRD bodies, or
private source excerpts in memory.
Each created PRD carries the marker [lisa-project-ideation] idea=<stable-key>. Compute
<stable-key> deterministically from: repo identity (configured repo or git remote + repo-root
basename) + a normalized slug of the idea name + the normalized persona key(s) + the existing-fit
anchor. Do not include rank, date, confidence, or the generated PRD title (they change across
runs). lisa:prd-source-write searches the source for an open PRD carrying this marker before
creating — matching by marker, never by title — so re-running ideation updates/references the
existing PRD rather than duplicating it.
Emit two distinct in-session sections (do not write a report file):
## Personas Derived From Evidence
- <name> — goals; pains; evidence (files/docs/tables/releases); confidence
## What Already Exists
- <current surfaces, data, commands, workflows — so duplicates aren't re-proposed>
## Practical Ideas
### 1. <Idea name> (persona: <persona(s)>)
- Persona value · Existing fit · Data/source path · Practical slice · Empirical verification ·
Evidence · Confidence
## Discovery Spikes
- <ideas needing proof of data/access/verification — name the missing proof — tagged by persona>
## Rejected / Not Practical Yet
- <attractive ideas rejected for missing data/access/legality/verification — name what's missing>
draft or ready), its dedupe marker, and created | reused. List the
Practical Ideas that were not created this run and why (e.g. "below the max_prds=1 cut").Always include the Personas, What Already Exists, Discovery Spikes, and Rejected sections (even if empty) so the user sees what was considered and filtered out.
lisa:research) is the only write this skill performs; ticket planning (lisa:plan) and
implementation (lisa:implement) are separate, user-invoked flows.lisa:research →
lisa:prd-source-write so the source stays switchable.The created PRDs flow straight into the lifecycle:
draft PRD → a human reviews it, then promotes it to ready (or re-run with prd_ready=true).prd-ready PRD → /lisa:intake (PRD side) auto-claims it → /lisa:plan decomposes it →
/lisa:implement builds each item → /lisa:codify-verification locks in the verification.Use the markdown examples in examples/ as shape references for the idea report:
host-project-only.md — ideas grounded only in the current repository.public-external-inspiration.md — public, no-login external sources as inspiration, not hidden
requirements.unavailable-data-rejection.md — naming missing private/paid/unavailable sources when demoting.evidence-card-format.md — the required evidence fields every Practical Idea card must carry.idempotency-verification-harness.md — deterministic fixture and script procedure proving that
repeated prd_ready=true ideation keeps the open GitHub marker count at one, including the
missing-memory rerun variant.documentation
Onboard a user to the project via its LLM Wiki. Interviews the user about themselves in relation to the project, captures that to project-scoped memory only, then gives a guided tour of what the project is and sample questions they can ask. Use when someone is new to the project or asks to be onboarded. Read-mostly — it does not open PRs or write PII into the wiki.
documentation
Migrate an existing, hand-rolled wiki implementation onto the lisa-wiki kernel — phased and compatibility-first, with a strict no-loss guarantee. Use when adopting lisa-wiki in a repo that already has its own wiki/, ingest skills, docs, or roles. Renaming things into the canonical shape is fine; losing functionality or data is not. Ends by running /doctor.
development
Health-check the LLM Wiki. Reports orphan pages, contradictions, stale claims, broken internal links, missing index/log coverage, structure-manifest violations, and secret/tenant leaks. Use periodically or before hardening a wiki. Read-only — it reports findings, it does not fix them.
testing
Ingest source material into the LLM Wiki. With an argument (URL, file path, or prompt) it ingests that one source; with no argument it runs a full ingest across every enabled non-external-write source. Routes to the right connector, then runs the ordered pipeline (source note → synthesis → index → log → verify → state → commit/PR). Use whenever new knowledge should enter the wiki.