Lisa Update Projects
Updates local Lisa projects in batches by running the package manager update command for @codyswann/lisa in each configured project, which triggers Lisa's postinstall script to apply template changes automatically.
Instructions
- Read @.lisa.config.local.json to get the list of projects and their target branches.
- For each project directory, checkout the target branch and pull the latest from the remote.
- If you can't because of existing changes or a dirty worktree, don't do anything. Ask the human what should be done about it before moving on.
- Once you have resolution, within each clean project, check out a new branch (e.g.
chore/lisa-update-YYYY-MM-DD). - Check if
@codyswann/lisais in the project'strustedDependenciesarray inpackage.json. If missing, add it usingjq. Bun only runs postinstall scripts for trusted packages, so without this entry Lisa's postinstall (template application and file deletions) is silently skipped. - Run the project's package manager update command for
@codyswann/lisa(e.g.bun update @codyswann/lisaornpm update @codyswann/lisa). This triggers Lisa's postinstall script which applies templates automatically. - After updating, check if
@codyswann/lisaappears in the project'sdependencies(notdevDependencies). If so, move it: remove fromdependenciesand ensure it's indevDependencies. Usejqto check and the package manager to reinstall correctly. - Check for legacy inline Claude workflows that need migration. For each file in
.github/workflows/matchingclaude*.yml,claude*.yaml,auto-update-pr-branches.yml,auto-update-pr-branches.yaml,ci.yml,ci.yaml,deploy.yml, anddeploy.yaml:- If the workflow has inline
steps:blocks instead of callinguses: CodySwannGT/lisa/.github/workflows/reusable-*.yml@main, it is legacy. - Detect project capabilities independently (Rails: has
bin/railsorconfig/application.rb; TypeScript: hastsconfig.jsonorpackage.jsonwith TypeScript signals). A repo may be both. - Apply per-file mapping rules — not a single repo-wide template selection — so dual-stack repos get the correct template for each workflow file:
ci.yml/ci.yamlin a Rails project →rails/create-only/.github/workflows/ci.yml(callsquality-rails.yml@main)deploy.yml/deploy.yamlin a Rails project →rails/create-only/.github/workflows/deploy.yml(callsrelease-rails.yml@main)ci.yml/ci.yamlin a TypeScript-only project →typescript/create-only/.github/workflows/ci.yml(callsquality.yml@main)claude*.yml/claude*.yaml→typescript/create-only/.github/workflows/(e.g.,claude.yml→reusable-claude.yml@main,claude-ci-auto-fix.yml→reusable-claude-ci-auto-fix.yml@main)auto-update-pr-branches.yml/auto-update-pr-branches.yaml→typescript/create-only/.github/workflows/(callsreusable-auto-update-pr-branches.yml@main)
- The create-only templates are the source of truth for the correct caller format.
- If the workflow has inline
- Remove stale
file:references to bundled ESLint plugins from the project'spackage.json. Previous Lisa versions copied plugin directories and addedfile:./dependencies; current Lisa deletes the directories but thepackage.jsonreferences remain. Usejqto remove these keys from bothdependenciesanddevDependenciesif they exist:eslint-plugin-code-organizationeslint-plugin-component-structureeslint-plugin-ui-standards
- Remove stale
$CLAUDE_PROJECT_DIR/.claude/hooks/references from the project's.claude/settings.json. Previous Lisa versions installed hook scripts into the project's.claude/hooks/directory and registered them in.claude/settings.json. Current Lisa deletes these scripts viaall/deletions.jsonand provides them through the plugin system (${CLAUDE_PLUGIN_ROOT}/hooks/inplugin.json) instead. The settings.json references to the deleted scripts cause "No such file or directory" errors. Usejqto:
- Remove any hook entry objects where the
commandcontains$CLAUDE_PROJECT_DIR/.claude/hooks/ - Remove entire hook matcher blocks that become empty after removing those entries
- Remove entire hook category arrays that have no remaining matcher blocks
- Preserve all non-file-path hook entries (inline commands like
echo ...,command -v entire ..., etc.)
- Update create-only workflow schedules that have drifted from the current templates. For each create-only workflow in
.github/workflows/(e.g.,claude-nightly-jira-triage.yml), compare thecronschedule against the corresponding template intypescript/create-only/.github/workflows/(orrails/create-only/for Rails projects) in the Lisa repo. If the project's schedule differs from the template, update it to match. For example, if the template uses0 */2 * * *but the project still has0 6 * * 1-5, update the project file. - Check
git diffto see if the project changed any Lisa-managed files. If so, examine them to see if any changes need to be upstreamed back to Lisa and do so if necessary. - Commit, push, and PR the branch to the project's target branch specified in @.lisa.config.local.json.
- If you hit any pre-push blockers, fix them and upstream anything that needs to. Do not lower any thresholds to get around a pre-push block. Instead, fix the code.
For steps 4-13, use up to 4 parallel subagents to accomplish those steps.
Fixing Upstream Bugs
If the Lisa postinstall crashes, rolls back changes, or applies incorrect templates during a project update, do not just work around it in the downstream project. Instead:
- Diagnose the root cause in the Lisa source code at the current working directory.
- Fix the bug in Lisa (create a branch, commit, push, and open a PR).
- Wait for the fix to merge and release before continuing project updates, OR apply the workaround in downstream projects only as a temporary measure while the upstream fix is in flight.
Common symptoms that indicate an upstream Lisa bug:
- Postinstall crashes with errors (e.g., missing function, module resolution failures)
- Templates from a parent stack (typescript) overwriting child stack templates (expo, nestjs, cdk) — this means the postinstall crashed after applying parent templates but before child templates could override them, triggering a rollback
- Rollback messages in the postinstall output (
[WARN] Rolling back changes...) followed by an error - Files that should be stack-specific (eslint.config.ts, tsconfig.json, knip.json) containing generic TypeScript config instead of the expected child stack config
The goal is to fix bugs at the source so they don't recur on every future update across all projects.