pumuki 6.3.119 → 6.3.120

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
@@ -6,6 +6,13 @@ This project follows [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
6
6
 
7
7
  ## [Unreleased]
8
8
 
9
+ ## [6.3.120] - 2026-04-28
10
+
11
+ ### Fixed
12
+
13
+ - **Watch no interactivo para auditoría machine-readable:** `pumuki watch --scope=repo --once --json` desactiva notificaciones por defecto en esa invocación de una sola pasada para terminar y emitir JSON sin depender de UI del sistema, cerrando `PUMUKI-INC-112`.
14
+ - **Bloqueos de install visibles:** cuando `pumuki install` queda bloqueado por governance, emite una notificación `gate.blocked` y añade el estado de entrega al error, cerrando la brecha de visibilidad de `PUMUKI-INC-113`.
15
+
9
16
  ## [6.3.119] - 2026-04-28
10
17
 
11
18
  ### Fixed
package/VERSION CHANGED
@@ -1 +1 @@
1
- v6.3.119
1
+ v6.3.120
@@ -721,7 +721,9 @@ export const parseLifecycleCliArgs = (argv: ReadonlyArray<string>): ParsedArgs =
721
721
  watchIntervalMs: watchIntervalMs ?? 3000,
722
722
  watchNotifyCooldownMs: watchNotifyCooldownMs ?? 30_000,
723
723
  watchSeverityThreshold: watchSeverityThreshold ?? 'high',
724
- watchNotifyEnabled: watchNotifyEnabled !== false,
724
+ watchNotifyEnabled:
725
+ watchNotifyEnabled !== false &&
726
+ !(json && watchIterations === 1),
725
727
  ...(typeof watchIterations === 'number' ? { watchIterations } : {}),
726
728
  };
727
729
  }
@@ -14,6 +14,7 @@ import { readOpenSpecManagedArtifacts, writeLifecycleState } from './state';
14
14
  import { ensureRuntimeArtifactsIgnored } from './artifacts';
15
15
  import { runLifecycleAdapterInstall } from './adapter';
16
16
  import { runPolicyReconcile } from './policyReconcile';
17
+ import { emitGateBlockedNotification } from '../notifications/emitAuditSummaryNotification';
17
18
 
18
19
  export type LifecycleInstallResult = {
19
20
  repoRoot: string;
@@ -104,6 +105,7 @@ export const runLifecycleInstall = (params?: {
104
105
  npm?: ILifecycleNpmService;
105
106
  bootstrapOpenSpec?: boolean;
106
107
  bestEffortAfterDoctorBlock?: boolean;
108
+ notifyGateBlocked?: typeof emitGateBlockedNotification;
107
109
  }): LifecycleInstallResult => {
108
110
  const git = params?.git ?? new LifecycleGitService();
109
111
  const bestEffortAfterDoctorBlock =
@@ -134,8 +136,20 @@ export const runLifecycleInstall = (params?: {
134
136
  };
135
137
  }
136
138
  const renderedIssues = report.issues.map((issue) => `- [${issue.severity}] ${issue.message}`).join('\n');
139
+ const firstIssue = report.issues[0];
140
+ const notificationResult = (params?.notifyGateBlocked ?? emitGateBlockedNotification)({
141
+ repoRoot: report.repoRoot,
142
+ stage: 'PRE_COMMIT',
143
+ totalViolations: report.issues.length,
144
+ causeCode: 'LIFECYCLE_INSTALL_SAFETY_BLOCKED',
145
+ causeMessage: firstIssue?.message ?? 'pumuki install blocked by repository safety checks.',
146
+ remediation: 'Corrige las incidencias activas del tracking externo y reintenta pumuki install.',
147
+ });
148
+ const notificationLine = notificationResult.delivered
149
+ ? '- [info] Blocking notification delivered.'
150
+ : `- [warning] Blocking notification not delivered: ${notificationResult.reason}`;
137
151
  throw new Error(
138
- `pumuki install blocked by repository safety checks.\n${renderedIssues}\n` +
152
+ `pumuki install blocked by repository safety checks.\n${renderedIssues}\n${notificationLine}\n` +
139
153
  'Fix the baseline (for example tracked node_modules) and retry.'
140
154
  );
141
155
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pumuki",
3
- "version": "6.3.119",
3
+ "version": "6.3.120",
4
4
  "description": "Enterprise-grade AST Intelligence System with multi-platform support (iOS, Android, Backend, Frontend) and Feature-First + DDD + Clean Architecture enforcement. Includes dynamic violations API for intelligent querying.",
5
5
  "main": "index.js",
6
6
  "bin": {