@launchsecure/launch-kit 0.0.44 → 0.0.45
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/deck-client/assets/{_baseUniq-C6w7kg8x.js → _baseUniq-9540Lrb7.js} +1 -1
- package/dist/deck-client/assets/{arc-Cx9pT3Nn.js → arc-2FFU5_0l.js} +1 -1
- package/dist/deck-client/assets/{architectureDiagram-Q4EWVU46-BITSj3vA.js → architectureDiagram-Q4EWVU46-CV2e3n5Z.js} +1 -1
- package/dist/deck-client/assets/{blockDiagram-DXYQGD6D-BehOFuwh.js → blockDiagram-DXYQGD6D-B9JFwjAL.js} +1 -1
- package/dist/deck-client/assets/{c4Diagram-AHTNJAMY-BZTYM4na.js → c4Diagram-AHTNJAMY-C0Gwco04.js} +1 -1
- package/dist/deck-client/assets/channel-DUo1BfyB.js +1 -0
- package/dist/deck-client/assets/{chunk-4BX2VUAB-CCUx5CTd.js → chunk-4BX2VUAB-pnGex62D.js} +1 -1
- package/dist/deck-client/assets/{chunk-4TB4RGXK-UDZXXga6.js → chunk-4TB4RGXK-BRfs5enT.js} +1 -1
- package/dist/deck-client/assets/{chunk-55IACEB6-CfcU6PIW.js → chunk-55IACEB6-DV2sc7BN.js} +1 -1
- package/dist/deck-client/assets/{chunk-EDXVE4YY-BK6F5Fof.js → chunk-EDXVE4YY-BH8QD8Jn.js} +1 -1
- package/dist/deck-client/assets/{chunk-FMBD7UC4-C-2idlFB.js → chunk-FMBD7UC4-BVuRSGoP.js} +1 -1
- package/dist/deck-client/assets/{chunk-OYMX7WX6-D6hBkYLP.js → chunk-OYMX7WX6-DBBVRR48.js} +1 -1
- package/dist/deck-client/assets/{chunk-QZHKN3VN-DixNpysA.js → chunk-QZHKN3VN-DNLfqlpV.js} +1 -1
- package/dist/deck-client/assets/{chunk-YZCP3GAM-Cd3pNBtQ.js → chunk-YZCP3GAM-w7-OIPaD.js} +1 -1
- package/dist/deck-client/assets/classDiagram-6PBFFD2Q-sHUWMvyj.js +1 -0
- package/dist/deck-client/assets/classDiagram-v2-HSJHXN6E-sHUWMvyj.js +1 -0
- package/dist/deck-client/assets/clone-pfbkP49m.js +1 -0
- package/dist/deck-client/assets/{cose-bilkent-S5V4N54A-OF3JWdEt.js → cose-bilkent-S5V4N54A-D8kmXu30.js} +1 -1
- package/dist/deck-client/assets/{dagre-KV5264BT-Bqu-qcv4.js → dagre-KV5264BT--b1FD3_Y.js} +1 -1
- package/dist/deck-client/assets/{diagram-5BDNPKRD--0eHmUBS.js → diagram-5BDNPKRD-DKPVzUtl.js} +1 -1
- package/dist/deck-client/assets/{diagram-G4DWMVQ6-nss6oL20.js → diagram-G4DWMVQ6-DYSdoCus.js} +1 -1
- package/dist/deck-client/assets/{diagram-MMDJMWI5-D_gSGnLR.js → diagram-MMDJMWI5-DmqAI88z.js} +1 -1
- package/dist/deck-client/assets/{diagram-TYMM5635-BIt-P6Pk.js → diagram-TYMM5635-Dbt6BCnF.js} +1 -1
- package/dist/deck-client/assets/{erDiagram-SMLLAGMA-Bi-E4KQm.js → erDiagram-SMLLAGMA-C7Kfi12r.js} +1 -1
- package/dist/deck-client/assets/{flowDiagram-DWJPFMVM-DMJCvLMA.js → flowDiagram-DWJPFMVM-h1nKPzIv.js} +1 -1
- package/dist/deck-client/assets/{ganttDiagram-T4ZO3ILL-C3xgEoPD.js → ganttDiagram-T4ZO3ILL-40rX1Tln.js} +1 -1
- package/dist/deck-client/assets/{gitGraphDiagram-UUTBAWPF-CD0BEGAW.js → gitGraphDiagram-UUTBAWPF-CtvJWtdg.js} +1 -1
- package/dist/deck-client/assets/{graph-Dtsd9Jwe.js → graph-ByiwozwM.js} +1 -1
- package/dist/deck-client/assets/{index-TFX8vtTG.js → index-CGG2xGJc.js} +1 -1
- package/dist/deck-client/assets/{infoDiagram-42DDH7IO-7IcQYqe_.js → infoDiagram-42DDH7IO-CrGXAAvG.js} +1 -1
- package/dist/deck-client/assets/{ishikawaDiagram-UXIWVN3A-DsCEbx3u.js → ishikawaDiagram-UXIWVN3A-csBJinUG.js} +1 -1
- package/dist/deck-client/assets/{journeyDiagram-VCZTEJTY-1mP2JwCk.js → journeyDiagram-VCZTEJTY-B2dZRDOR.js} +1 -1
- package/dist/deck-client/assets/{kanban-definition-6JOO6SKY-vT0Xrqh9.js → kanban-definition-6JOO6SKY-Dyznt2QN.js} +1 -1
- package/dist/deck-client/assets/{layout-Cw4rS2pn.js → layout-tvNTD61-.js} +1 -1
- package/dist/deck-client/assets/{linear-CzOjL-Ih.js → linear-BTcLgDqZ.js} +1 -1
- package/dist/deck-client/assets/{mermaid.core-DYi3A-qK.js → mermaid.core-CZoq2C4e.js} +4 -4
- package/dist/deck-client/assets/{min-DstloRoL.js → min-J7Zsly_t.js} +1 -1
- package/dist/deck-client/assets/{mindmap-definition-QFDTVHPH-D-cCX2d2.js → mindmap-definition-QFDTVHPH-Ba-GyprJ.js} +1 -1
- package/dist/deck-client/assets/{pieDiagram-DEJITSTG-BqW2NTmy.js → pieDiagram-DEJITSTG-BMLzzK64.js} +1 -1
- package/dist/deck-client/assets/{quadrantDiagram-34T5L4WZ-DbJoWA8f.js → quadrantDiagram-34T5L4WZ-Dh_Ut0Yp.js} +1 -1
- package/dist/deck-client/assets/{requirementDiagram-MS252O5E-DQrUiz_d.js → requirementDiagram-MS252O5E-Dkva9qg0.js} +1 -1
- package/dist/deck-client/assets/{sankeyDiagram-XADWPNL6-kB7PZc3g.js → sankeyDiagram-XADWPNL6-3lcCBbua.js} +1 -1
- package/dist/deck-client/assets/{sequenceDiagram-FGHM5R23-CpyVu1TN.js → sequenceDiagram-FGHM5R23-MH0H8qIE.js} +1 -1
- package/dist/deck-client/assets/{stateDiagram-FHFEXIEX-CjqQcnty.js → stateDiagram-FHFEXIEX-ByLZbwGe.js} +1 -1
- package/dist/deck-client/assets/stateDiagram-v2-QKLJ7IA2-C87YsgaN.js +1 -0
- package/dist/deck-client/assets/{timeline-definition-GMOUNBTQ-B2PAO9bk.js → timeline-definition-GMOUNBTQ-COT8qN-f.js} +1 -1
- package/dist/deck-client/assets/{vennDiagram-DHZGUBPP-C0G3ItCr.js → vennDiagram-DHZGUBPP-YuKnKVX_.js} +1 -1
- package/dist/deck-client/assets/wardley-RL74JXVD-C4YfwXTm.js +162 -0
- package/dist/deck-client/assets/{wardleyDiagram-NUSXRM2D-B-qtbNZe.js → wardleyDiagram-NUSXRM2D-BuLtRVnC.js} +1 -1
- package/dist/deck-client/assets/{xychartDiagram-5P7HB3ND-41kcBoBE.js → xychartDiagram-5P7HB3ND-CcIc1c6H.js} +1 -1
- package/dist/deck-client/index.html +1 -1
- package/dist/server/init-entry.js +40 -11
- package/dist/server/radar-docker-init-entry.js +34 -11
- package/dist/server/rover-entry.js +515 -130
- package/package.json +1 -1
- package/scaffolds/ls-marketplace/plugins/kit/skills/ship/SKILL.md +24 -18
- package/dist/deck-client/assets/channel-Cw2WDt9a.js +0 -1
- package/dist/deck-client/assets/classDiagram-6PBFFD2Q-JLUXVCUr.js +0 -1
- package/dist/deck-client/assets/classDiagram-v2-HSJHXN6E-JLUXVCUr.js +0 -1
- package/dist/deck-client/assets/clone-H0XCnSb6.js +0 -1
- package/dist/deck-client/assets/stateDiagram-v2-QKLJ7IA2-tfMSn8xx.js +0 -1
- package/dist/deck-client/assets/wardley-RL74JXVD-B0TVaOmp.js +0 -162
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@launchsecure/launch-kit",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.45",
|
|
4
4
|
"description": "LaunchSecure toolkit — launch-sequencer (pipeline runner + terminal bridge), launch-radar (feedback webhook receiver), launch-chart (project graph MCP), launch-deck (visual playground MCP), launch-kit-beacon (feedback Web Component), launch-recall (file-watcher backup). launch-pod is the container image these run inside.",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"author": "LaunchSecure - AutomateWithUs",
|
|
@@ -12,6 +12,10 @@ The shipping log is a **Brief**: a markdown doc at `doc/shipping-logs/<date>-<ta
|
|
|
12
12
|
|
|
13
13
|
Hard rule from project memory: **never push commits the user didn't explicitly name**, and **pushing to a deploy-tracked branch may auto-deploy** — so this skill always asks per-action before pushing, even when invoked with arguments. There is no `--yes-i-mean-it` flag.
|
|
14
14
|
|
|
15
|
+
**Confirmation convention.** Every gated decision in this skill (the GO-WITH-CAVEATS gate, the migration gate, the Brief preview, the push) is presented as a **selectable option prompt via the `AskUserQuestion` tool** — not a "reply with `yes`" free-text instruction. Each gate below specifies its header + the exact options to offer. Two rules survive the switch to options:
|
|
16
|
+
- **The default/recommended option is never the destructive/irreversible one.** List the safe choice (or `cancel`) first; mark the proceed option `(Recommended)` only where proceeding is genuinely the expected path.
|
|
17
|
+
- **The escalation for a prod push is preserved by the option label itself** — the prod push option is labelled `Ship it` (not a generic `Push`), so selecting it is as deliberate as typing the word used to be. Selecting an option IS the explicit confirmation; there is no separate typed keyword.
|
|
18
|
+
|
|
15
19
|
Parse `$ARGUMENTS`:
|
|
16
20
|
|
|
17
21
|
- (empty) — full flow on the current branch → its upstream (resolved via `git rev-parse --abbrev-ref @{u}` or, missing that, `origin/<current-branch>`).
|
|
@@ -59,9 +63,10 @@ Invoke `/kit:deploy-check` against the resolved target. Forward `--quick` / `--s
|
|
|
59
63
|
Verdict handling:
|
|
60
64
|
|
|
61
65
|
- **NO-GO** → abort the ship. Print the failing checks verbatim from deploy-check. Tell the user what to fix. Do not offer to "force ship".
|
|
62
|
-
- **GO WITH CAVEATS** → surface the warnings, then ask:
|
|
63
|
-
|
|
64
|
-
-
|
|
66
|
+
- **GO WITH CAVEATS** → surface the warnings, then ask via `AskUserQuestion` (header `Ship gate`, question naming the caveat count, e.g. "deploy-check is GO WITH CAVEATS (<N> warnings above). Continue with ship?"):
|
|
67
|
+
- `Cancel ship` — abort; nothing written or pushed.
|
|
68
|
+
- `Continue (Recommended)` — proceed to step 2.
|
|
69
|
+
- **GO** → continue silently to step 2 (no prompt).
|
|
65
70
|
|
|
66
71
|
Hard rules:
|
|
67
72
|
|
|
@@ -112,11 +117,12 @@ Backup story:
|
|
|
112
117
|
or add a backup step to CI. Recovery is impossible without one.
|
|
113
118
|
```
|
|
114
119
|
|
|
115
|
-
Then ask:
|
|
120
|
+
Then ask via `AskUserQuestion` (header `Migration gate`, question "This push includes <N> migration(s). Acknowledge and continue?"):
|
|
116
121
|
|
|
117
|
-
|
|
122
|
+
- `Cancel ship` — abort; nothing written or pushed.
|
|
123
|
+
- `Understood — proceed` — acknowledge the migration push and continue.
|
|
118
124
|
|
|
119
|
-
This is a deliberate friction point —
|
|
125
|
+
This is a deliberate friction point: the acknowledgement option is labelled `Understood — proceed` (not a generic `yes`) and is **never** the auto-highlighted default — the user must actively pick it. Do not collapse this into the same prompt as another gate; the migration acknowledgement stands alone.
|
|
120
126
|
|
|
121
127
|
## Step 4 — Author the shipping-log Brief
|
|
122
128
|
|
|
@@ -190,25 +196,25 @@ Field sources:
|
|
|
190
196
|
|
|
191
197
|
### Preview + confirm
|
|
192
198
|
|
|
193
|
-
Show the full Brief in a fenced block, then ask:
|
|
194
|
-
|
|
195
|
-
> "Write this Brief to `doc/shipping-logs/<filename>` and commit it? Reply `yes` to write + commit, `edit` to tweak (summary, themes, note), `skip` to ship without a log, or `cancel` to abort the ship."
|
|
199
|
+
Show the full Brief in a fenced block, then ask via `AskUserQuestion` (header `Shipping log`, question "Write this Brief to `doc/shipping-logs/<filename>` and commit it?"):
|
|
196
200
|
|
|
197
|
-
- `
|
|
198
|
-
- `
|
|
199
|
-
- `
|
|
200
|
-
- `
|
|
201
|
+
- `Write + commit (Recommended)` → write the file, then `git add doc/shipping-logs/<filename> && git commit -m "docs(shipping-logs): ship <YYYY-MM-DD> — <target> (<one-line summary>)"`. The Brief commit is now the payload's tip.
|
|
202
|
+
- `Edit Brief` → ask what to change (summary, themes, note), redraft, re-show, re-ask.
|
|
203
|
+
- `Skip log` → no file, no commit. The ship proceeds unlogged — say so plainly: `shipping without a log entry; there will be no record of this ship.`
|
|
204
|
+
- `Cancel ship` → abort the entire ship. Nothing was written, nothing was pushed.
|
|
201
205
|
|
|
202
206
|
## Step 5 — Push confirmation
|
|
203
207
|
|
|
204
|
-
Ask
|
|
208
|
+
Ask via `AskUserQuestion` (header `Push`). The question text and the proceed-option label differ by `IS_PROD_PUSH`:
|
|
205
209
|
|
|
206
210
|
- If `IS_PROD_PUSH=false`:
|
|
207
|
-
|
|
211
|
+
- Question: "Push <N> commits to origin/<target-branch>?"
|
|
212
|
+
- Options: `Cancel` (first) · `Push` — push and continue.
|
|
208
213
|
- If `IS_PROD_PUSH=true`:
|
|
209
|
-
|
|
214
|
+
- Question: "Push <N> commits to origin/<target-branch>. This is a deploy-tracked branch — <if DEPLOY_PLATFORM≠unknown: '<platform> will deploy automatically'; else: 'whatever deploy pipeline is wired to this branch will pick it up'>. This deploys to production."
|
|
215
|
+
- Options: `Cancel` (first) · `Ship it` — push and trigger the deploy. The label is `Ship it` (not `Push`) so the prod choice is unmistakable.
|
|
210
216
|
|
|
211
|
-
`<N>` includes the Brief commit from step 4 (when not skipped).
|
|
217
|
+
`<N>` includes the Brief commit from step 4 (when not skipped). Only the explicit `Push` / `Ship it` option proceeds; selecting `Cancel`, dismissing the prompt, or any free-form answer → treat as cancel. The proceed option is **never** the auto-highlighted default for a prod push. If `--dry-run`, skip this step entirely (no prompt).
|
|
212
218
|
|
|
213
219
|
On confirm: `git push origin <current-branch>:<target-branch>`. Stream stdout. If the push fails (non-fast-forward, hook reject, auth) — surface the error verbatim, do not retry, do not `--force`.
|
|
214
220
|
|
|
@@ -283,7 +289,7 @@ Comm Hub side (when the project is LaunchSecure-wired): the "Shipping Logs" cate
|
|
|
283
289
|
|
|
284
290
|
## Notes for the assistant
|
|
285
291
|
|
|
286
|
-
- The user has explicit project-memory rules against unauthorised pushes and dumb reverts. Treat every confirmation as load-bearing —
|
|
292
|
+
- The user has explicit project-memory rules against unauthorised pushes and dumb reverts. Treat every confirmation as load-bearing — present each gate as an `AskUserQuestion` option prompt (per the Confirmation convention above), keep the destructive option off the default, and treat anything other than an explicit proceed selection as cancel.
|
|
287
293
|
- "Ship" is the user's verb for "I want this in production." If the target isn't actually deploy-tracked, the skill should still work but should say so clearly in the scope line (step 5 phrasing changes).
|
|
288
294
|
- The shipping-log Brief is the durable artifact and (when synced) the published record at once — there is no separate "publish" step and no local NDJSON file. If you find `.launchsecure/ship-log.ndjson` in a repo, it's from a pre-Brief version of this skill; leave it alone (don't migrate, don't delete) and mention it once.
|
|
289
295
|
- **Portability is the contract.** This skill is installed by `launch-kit init` into projects on stacks you can't predict. Anything you hardcode that isn't in *this* repo is a bug for the next repo. When in doubt, detect or degrade — never assume.
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{aq as o,ar as n}from"./mermaid.core-DYi3A-qK.js";const t=(r,a)=>o.lang.round(n.parse(r)[a]);export{t as c};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{s as a,c as s,a as e,C as t}from"./chunk-4TB4RGXK-UDZXXga6.js";import{_ as i}from"./mermaid.core-DYi3A-qK.js";import"./chunk-FMBD7UC4-C-2idlFB.js";import"./chunk-YZCP3GAM-Cd3pNBtQ.js";import"./chunk-55IACEB6-CfcU6PIW.js";import"./chunk-EDXVE4YY-BK6F5Fof.js";import"./index-TFX8vtTG.js";var n={parser:e,get db(){return new t},renderer:s,styles:a,init:i(r=>{r.class||(r.class={}),r.class.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{n as diagram};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{s as a,c as s,a as e,C as t}from"./chunk-4TB4RGXK-UDZXXga6.js";import{_ as i}from"./mermaid.core-DYi3A-qK.js";import"./chunk-FMBD7UC4-C-2idlFB.js";import"./chunk-YZCP3GAM-Cd3pNBtQ.js";import"./chunk-55IACEB6-CfcU6PIW.js";import"./chunk-EDXVE4YY-BK6F5Fof.js";import"./index-TFX8vtTG.js";var n={parser:e,get db(){return new t},renderer:s,styles:a,init:i(r=>{r.class||(r.class={}),r.class.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{n as diagram};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{b as r}from"./graph-Dtsd9Jwe.js";var e=4;function a(o){return r(o,e)}export{a as c};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{s as e,b as r,a,S as s}from"./chunk-OYMX7WX6-D6hBkYLP.js";import{_ as i}from"./mermaid.core-DYi3A-qK.js";import"./chunk-55IACEB6-CfcU6PIW.js";import"./chunk-EDXVE4YY-BK6F5Fof.js";import"./index-TFX8vtTG.js";var p={parser:a,get db(){return new s(2)},renderer:r,styles:e,init:i(t=>{t.state||(t.state={}),t.state.arrowMarkerAbsolute=t.arrowMarkerAbsolute},"init")};export{p as diagram};
|