@warnyin/agents 0.18.0 → 0.18.1

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/CHANGELOG.md CHANGED
@@ -23,6 +23,12 @@
23
23
 
24
24
  ## [Unreleased]
25
25
 
26
+ ## [0.18.1] - 2026-06-13
27
+
28
+ ### Fixed
29
+ - **installer เงียบ exit 0 ไม่ติดตั้งเมื่อรันผ่าน symlink** (critical — กระทบ `npx @warnyin/agents` ของผู้ใช้ปลายทาง + `setup:dogfood`) — main-guard ของ `cli.mjs` เทียบ `path.resolve(process.argv[1])` กับ `fileURLToPath(import.meta.url)` แต่ ESM `import.meta.url` เป็น realpath เสมอ ส่วน `argv[1]` เป็น symlink path (npx รัน bin ผ่าน `node_modules/.bin/` symlink; `setup:dogfood` extract tarball ลง `os.tmpdir()` ที่เป็น symlink บน macOS) → เทียบไม่ตรง → `main()` ไม่ถูกเรียก → ไม่ติดตั้งอะไร. แก้ด้วย `isEntrypoint()` ที่ realpath ทั้งสองฝั่ง (+ fallback `path.resolve`)
30
+ - **setup:dogfood ดึง payload เก่า + รายงานสำเร็จลวง (false-success)** — fix 3 ชั้น: `verifyInstalled` active เมื่อ stamp ขาด + version ≥ 0.17.0 (LR2), `installViaPack` เพิ่ม `prefer-online` สมมาตรกับ npx + `checkTarballVersion` เทียบ version ที่ source, `installViaNpx` ระบุ explicit bin `warnyin-agents`
31
+
26
32
  ## [0.18.0] - 2026-06-13
27
33
 
28
34
  ### Added
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@warnyin/agents",
3
- "version": "0.18.0",
3
+ "version": "0.18.1",
4
4
  "description": "Warnyin Standard Workflow installer — 5-stage ways of work (Discovery/DESIGN/BUILD/VERIFY/SHIP) สำหรับทุกโปรเจกต์",
5
5
  "type": "module",
6
6
  "license": "MIT",
package/src/bin/cli.mjs CHANGED
@@ -327,7 +327,31 @@ async function main() {
327
327
  }
328
328
  }
329
329
 
330
- // main-guard: รันเฉพาะตอน execute ตรง ๆ (ไม่ trigger ตอน import เพื่อ unit-test resolveMode)
331
- if (process.argv[1] && path.resolve(process.argv[1]) === fileURLToPath(import.meta.url)) {
330
+ /**
331
+ * ตรวจว่า module ถูก execute ตรง ๆ (entrypoint) ไม่ใช่ถูก import — เทียบ argv[1] กับ path ของ module เอง
332
+ * ★ ต้อง realpath argv[1] ด้วย: ESM `import.meta.url` เป็น realpath (resolve symlink) เสมอ แต่ argv[1]
333
+ * เป็น path ตามที่ผู้เรียกระบุ (ไม่ resolve symlink). เมื่อรันผ่าน symlink — npx รัน bin ผ่าน
334
+ * `.bin/<name>` symlink, setup:dogfood extract tarball ลง `os.tmpdir()` ที่เป็น symlink บน macOS
335
+ * (`/var/folders/.../T` → `/private/var/...`) — `path.resolve(argv[1])` จะคืน symlink path ≠ realpath
336
+ * ของ module → mismatch → main() ไม่ถูกเรียก → installer เงียบ exit 0 ไม่ทำอะไร (bug critical:
337
+ * กระทบทั้ง npx ของผู้ใช้ปลายทาง + setup:dogfood). realpath ทั้งสองฝั่งจึง match ถูกต้อง.
338
+ * @param {string|undefined} argv1 — process.argv[1] (path ของ script ที่ node รัน)
339
+ * @param {string} metaUrl — import.meta.url ของ module (เป็น realpath เสมอใน ESM)
340
+ * @param {(p: string) => string} [realpath] — injectable เพื่อ unit-test (default fs.realpathSync)
341
+ * @returns {boolean}
342
+ */
343
+ export function isEntrypoint(argv1, metaUrl, realpath = fs.realpathSync) {
344
+ if (!argv1) return false
345
+ const self = fileURLToPath(metaUrl)
346
+ try {
347
+ return realpath(argv1) === self
348
+ } catch {
349
+ // argv1 resolve เป็น realpath ไม่ได้ (ไฟล์ไม่อยู่จริง ฯลฯ) → fallback เทียบ path ปกติ
350
+ return path.resolve(argv1) === self
351
+ }
352
+ }
353
+
354
+ // main-guard: รันเฉพาะตอน execute ตรง ๆ (ไม่ trigger ตอน import เพื่อ unit-test resolveMode/isEntrypoint)
355
+ if (isEntrypoint(process.argv[1], import.meta.url)) {
332
356
  await main()
333
357
  }