@panguard-ai/panguard-scan 1.5.6 → 1.6.0

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/cli/index.js CHANGED
@@ -30,7 +30,14 @@ const program = new Command();
30
30
  program
31
31
  .name('panguard-scan')
32
32
  .description('PanguardScan - 60-second security health check tool / 60 秒資安健檢工具')
33
- .version(PANGUARD_SCAN_VERSION);
33
+ .version(PANGUARD_SCAN_VERSION)
34
+ // Root program has --output for the default-scan command. The `code`
35
+ // subcommand also has --output. Without enablePositionalOptions(), the
36
+ // parent's flag consumes any --output after the subcommand name, so the
37
+ // subcommand's options.output was always undefined (Bug 2). With this
38
+ // call, parent options must come BEFORE the subcommand name; everything
39
+ // after the subcommand name is parsed by the subcommand.
40
+ .enablePositionalOptions();
34
41
  // ---------------------------------------------------------------------------
35
42
  // code subcommand - SAST source code scanner
36
43
  // code 子命令 - SAST 原始碼掃描器
@@ -112,6 +119,31 @@ program
112
119
  }
113
120
  console.log('');
114
121
  }
122
+ // Handle --output (PDF artifact)
123
+ // Bug 2 fix (2026-05-19): previously --output was declared but the
124
+ // action body never consumed it — clean scans printed
125
+ // "No security issues found." and exited 0 with no file written.
126
+ // Customers paying for "clean scan PDF artifact" got nothing.
127
+ // Now the artifact ships even when findings = 0 (proof-of-clean).
128
+ if (options.output) {
129
+ const { generateCodeScanPdf } = await import('../report/code-scan-pdf.js');
130
+ try {
131
+ await generateCodeScanPdf({
132
+ outputPath: options.output,
133
+ scanDir: path.resolve(options.dir),
134
+ findings: allFindings,
135
+ lang: _lang,
136
+ });
137
+ if (!options.json) {
138
+ console.error(`Report saved to: ${options.output}`);
139
+ }
140
+ }
141
+ catch (err) {
142
+ const msg = err instanceof Error ? err.message : String(err);
143
+ console.error(`Failed to generate PDF report: ${msg}`);
144
+ process.exit(2);
145
+ }
146
+ }
115
147
  // Handle --fail-on
116
148
  // 處理 --fail-on 選項
117
149
  if (options.failOn) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ /**
2
+ * Code Scan PDF Generator (slim, brand-aligned)
3
+ * 程式碼掃描 PDF 產生器(精簡、品牌一致)
4
+ *
5
+ * Targets the `panguard-scan code` subcommand. Brand-aligned (2026-05-19):
6
+ * Sage `#8B9A8E` headings, warm-near-black `#1A1614` titles, severity
7
+ * palette per panguard.ai DESIGN.md. pdfkit base-14 Helvetica fallback
8
+ * for now (custom-font embed is Phase 1B work); brand colour discipline
9
+ * carries the artifact even without Space Grotesk on PDF.
10
+ *
11
+ * Fixes Bug 2 from 2026-05-16 W1 validation + Day-5 rebrand.
12
+ *
13
+ * @module @panguard-ai/panguard-scan/report/code-scan-pdf
14
+ */
15
+ import type { Language } from '@panguard-ai/core';
16
+ import type { Finding } from '../scanners/types.js';
17
+ export interface CodeScanPdfOptions {
18
+ outputPath: string;
19
+ scanDir: string;
20
+ findings: ReadonlyArray<Finding>;
21
+ lang: Language;
22
+ scannedAt?: string;
23
+ }
24
+ /**
25
+ * Generate a brand-aligned code-scan PDF.
26
+ * Writes to outputPath; resolves on stream finish.
27
+ */
28
+ export declare function generateCodeScanPdf(opts: CodeScanPdfOptions): Promise<void>;
29
+ //# sourceMappingURL=code-scan-pdf.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-scan-pdf.d.ts","sourceRoot":"","sources":["../../src/report/code-scan-pdf.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAOH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAIpD,MAAM,WAAW,kBAAkB;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;IACjC,IAAI,EAAE,QAAQ,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAmCD;;;GAGG;AACH,wBAAsB,mBAAmB,CAAC,IAAI,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,CA6QjF"}
@@ -0,0 +1,283 @@
1
+ /**
2
+ * Code Scan PDF Generator (slim, brand-aligned)
3
+ * 程式碼掃描 PDF 產生器(精簡、品牌一致)
4
+ *
5
+ * Targets the `panguard-scan code` subcommand. Brand-aligned (2026-05-19):
6
+ * Sage `#8B9A8E` headings, warm-near-black `#1A1614` titles, severity
7
+ * palette per panguard.ai DESIGN.md. pdfkit base-14 Helvetica fallback
8
+ * for now (custom-font embed is Phase 1B work); brand colour discipline
9
+ * carries the artifact even without Space Grotesk on PDF.
10
+ *
11
+ * Fixes Bug 2 from 2026-05-16 W1 validation + Day-5 rebrand.
12
+ *
13
+ * @module @panguard-ai/panguard-scan/report/code-scan-pdf
14
+ */
15
+ import PDFDocument from 'pdfkit';
16
+ import { createWriteStream } from 'node:fs';
17
+ import { mkdir } from 'node:fs/promises';
18
+ import { dirname } from 'node:path';
19
+ import { createLogger } from '@panguard-ai/core';
20
+ const logger = createLogger('panguard-scan:code-pdf');
21
+ /** PanGuard brand tokens — sync with packages/website/DESIGN.md */
22
+ const BRAND = {
23
+ sage: '#8B9A8E',
24
+ sageDark: '#6B7A6E',
25
+ emerald: '#34D399',
26
+ emeraldDark: '#059669',
27
+ warmBlack: '#1A1614',
28
+ warmBrown: '#2E2A27',
29
+ textPrimary: '#1A1614',
30
+ textSecondary: '#4A4540',
31
+ textMuted: '#8A847A',
32
+ surfaceWarm: '#FAF8F2',
33
+ surfaceCard: '#F5F1E8',
34
+ border: '#E5DFD0',
35
+ critical: '#EF4444',
36
+ high: '#F97316',
37
+ medium: '#EAB308',
38
+ low: '#34D399',
39
+ info: '#9CA3AF',
40
+ };
41
+ const SEVERITY_COLOR = {
42
+ critical: BRAND.critical,
43
+ high: BRAND.high,
44
+ medium: BRAND.medium,
45
+ low: BRAND.low,
46
+ info: BRAND.info,
47
+ };
48
+ function t(en, zh, lang) {
49
+ return lang === 'zh-TW' ? zh : en;
50
+ }
51
+ /**
52
+ * Generate a brand-aligned code-scan PDF.
53
+ * Writes to outputPath; resolves on stream finish.
54
+ */
55
+ export async function generateCodeScanPdf(opts) {
56
+ await mkdir(dirname(opts.outputPath), { recursive: true });
57
+ const scannedAt = opts.scannedAt ?? new Date().toISOString();
58
+ const lang = opts.lang;
59
+ logger.info('Starting code-scan PDF generation', {
60
+ outputPath: opts.outputPath,
61
+ findings: opts.findings.length,
62
+ lang,
63
+ });
64
+ const doc = new PDFDocument({
65
+ size: 'A4',
66
+ margins: { top: 56, bottom: 56, left: 56, right: 56 },
67
+ info: {
68
+ Title: t('PanGuard AI - Code Security Report', 'PanGuard AI - 程式碼安全報告', lang),
69
+ Author: 'PanGuard AI',
70
+ Producer: 'pdfkit',
71
+ Creator: 'PanGuard AI',
72
+ },
73
+ });
74
+ const stream = createWriteStream(opts.outputPath);
75
+ doc.pipe(stream);
76
+ const pageWidth = doc.page.width;
77
+ const margin = 56;
78
+ const contentWidth = pageWidth - margin * 2;
79
+ // ─── Cover band ───
80
+ // Top sage band — brand presence without overwhelming
81
+ const bandHeight = 4;
82
+ doc.rect(0, 0, pageWidth, bandHeight).fill(BRAND.sage);
83
+ // Brand wordmark
84
+ doc.moveDown(2);
85
+ doc.fillColor(BRAND.sage).font('Helvetica-Bold').fontSize(11);
86
+ doc.text('PANGUARD AI', { characterSpacing: 1.5 });
87
+ doc.moveDown(0.4);
88
+ // Overline
89
+ doc
90
+ .fillColor(BRAND.sage)
91
+ .font('Helvetica-Bold')
92
+ .fontSize(9)
93
+ .text(t('CODE SECURITY REPORT', '程式碼安全報告', lang).toUpperCase(), {
94
+ characterSpacing: 1.2,
95
+ });
96
+ // Title
97
+ doc.moveDown(0.5);
98
+ doc
99
+ .fillColor(BRAND.textPrimary)
100
+ .font('Helvetica-Bold')
101
+ .fontSize(26)
102
+ .text(t('Source Code Security Scan', '原始碼安全掃描', lang));
103
+ // Subtitle
104
+ doc
105
+ .moveDown(0.3)
106
+ .fillColor(BRAND.textSecondary)
107
+ .font('Helvetica')
108
+ .fontSize(11)
109
+ .text(t('PanGuard SAST · panguard-scan code', 'PanGuard SAST · panguard-scan code', lang));
110
+ // ─── Meta block (4 rows) ───
111
+ doc.moveDown(1.5);
112
+ const metaItems = [
113
+ [t('Scanned directory', '掃描目錄', lang), opts.scanDir],
114
+ [t('Scanned at', '掃描時間', lang), scannedAt],
115
+ [t('Findings count', '發現項目', lang), String(opts.findings.length)],
116
+ [
117
+ t('Status', '狀態', lang),
118
+ opts.findings.length === 0
119
+ ? t('CLEAN — No findings', 'CLEAN — 無發現', lang)
120
+ : t(`${opts.findings.length} finding(s) require review`, `${opts.findings.length} 項待審查`, lang),
121
+ ],
122
+ ];
123
+ const metaY = doc.y;
124
+ const colWidth = contentWidth / 2;
125
+ for (let i = 0; i < metaItems.length; i++) {
126
+ const [k, v] = metaItems[i];
127
+ const col = i % 2;
128
+ const row = Math.floor(i / 2);
129
+ const x = margin + col * colWidth;
130
+ const y = metaY + row * 36;
131
+ doc
132
+ .fillColor(BRAND.textMuted)
133
+ .font('Helvetica-Bold')
134
+ .fontSize(8)
135
+ .text(k.toUpperCase(), x, y, { width: colWidth - 8, characterSpacing: 1.1 });
136
+ doc
137
+ .fillColor(BRAND.textPrimary)
138
+ .font('Helvetica')
139
+ .fontSize(11)
140
+ .text(v, x, y + 11, { width: colWidth - 8, height: 22, ellipsis: true });
141
+ }
142
+ doc.y = metaY + 36 * 2 + 8;
143
+ // ─── Severity bar (sage→emerald) ───
144
+ doc.moveDown(1);
145
+ const counts = opts.findings.reduce((acc, f) => {
146
+ acc[f.severity] = (acc[f.severity] ?? 0) + 1;
147
+ return acc;
148
+ }, {});
149
+ const tags = [
150
+ [t('Critical', '嚴重', lang), String(counts['critical'] ?? 0), BRAND.critical],
151
+ [t('High', '高', lang), String(counts['high'] ?? 0), BRAND.high],
152
+ [t('Medium', '中', lang), String(counts['medium'] ?? 0), BRAND.medium],
153
+ [t('Low', '低', lang), String(counts['low'] ?? 0), BRAND.low],
154
+ ];
155
+ const tagY = doc.y;
156
+ const tagWidth = (contentWidth - 24) / 4;
157
+ for (let i = 0; i < tags.length; i++) {
158
+ const [label, count, color] = tags[i];
159
+ const x = margin + i * (tagWidth + 8);
160
+ doc.roundedRect(x, tagY, tagWidth, 56, 8).fillAndStroke(BRAND.surfaceCard, BRAND.border);
161
+ doc
162
+ .fillColor(color)
163
+ .font('Helvetica-Bold')
164
+ .fontSize(22)
165
+ .text(count, x, tagY + 8, { width: tagWidth, align: 'center' });
166
+ doc
167
+ .fillColor(BRAND.textMuted)
168
+ .font('Helvetica-Bold')
169
+ .fontSize(8)
170
+ .text(label.toUpperCase(), x, tagY + 36, {
171
+ width: tagWidth,
172
+ align: 'center',
173
+ characterSpacing: 1.1,
174
+ });
175
+ }
176
+ doc.y = tagY + 56 + 24;
177
+ // ─── Body ───
178
+ if (opts.findings.length === 0) {
179
+ // Clean scan emphasis
180
+ doc
181
+ .fillColor(BRAND.emerald)
182
+ .font('Helvetica-Bold')
183
+ .fontSize(16)
184
+ .text(t('Clean Scan — No Findings', '掃描完成 — 無發現', lang));
185
+ doc.moveDown(0.4);
186
+ doc
187
+ .fillColor(BRAND.textSecondary)
188
+ .font('Helvetica')
189
+ .fontSize(11)
190
+ .text(t('The static analyzer found no security vulnerabilities in the scanned source tree. This artifact serves as evidence of a clean scan as of the timestamp above.', '靜態分析器在掃描的原始碼樹中未發現安全漏洞。本文件作為上述時間戳的乾淨掃描證據。', lang), { width: contentWidth });
191
+ }
192
+ else {
193
+ // Findings section header
194
+ doc
195
+ .fillColor(BRAND.textPrimary)
196
+ .font('Helvetica-Bold')
197
+ .fontSize(15)
198
+ .text(t('Findings', '發現項目', lang));
199
+ doc
200
+ .moveTo(margin, doc.y + 4)
201
+ .lineTo(margin + contentWidth, doc.y + 4)
202
+ .strokeColor(BRAND.border)
203
+ .lineWidth(1)
204
+ .stroke();
205
+ doc.moveDown(0.8);
206
+ for (let i = 0; i < opts.findings.length; i++) {
207
+ const f = opts.findings[i];
208
+ const sevColor = SEVERITY_COLOR[f.severity] ?? BRAND.textPrimary;
209
+ if (doc.y > doc.page.height - 200)
210
+ doc.addPage();
211
+ // Severity tag + ID inline
212
+ doc
213
+ .fillColor(sevColor)
214
+ .font('Helvetica-Bold')
215
+ .fontSize(8)
216
+ .text(`[${f.severity.toUpperCase()}]`, { continued: true, characterSpacing: 0.8 });
217
+ doc.fillColor(BRAND.textMuted).font('Courier').fontSize(9).text(` ${f.id}`);
218
+ // Title
219
+ doc
220
+ .fillColor(BRAND.textPrimary)
221
+ .font('Helvetica-Bold')
222
+ .fontSize(12)
223
+ .text(f.title, { width: contentWidth });
224
+ doc
225
+ .fillColor(BRAND.textMuted)
226
+ .font('Helvetica')
227
+ .fontSize(9)
228
+ .text(`${t('Category', '分類', lang)}: ${f.category}`);
229
+ if (f.description) {
230
+ doc.moveDown(0.2);
231
+ doc
232
+ .fillColor(BRAND.textSecondary)
233
+ .font('Helvetica')
234
+ .fontSize(10)
235
+ .text(f.description, { width: contentWidth });
236
+ }
237
+ if (f.details) {
238
+ doc.moveDown(0.2);
239
+ doc
240
+ .fillColor(BRAND.textMuted)
241
+ .font('Courier')
242
+ .fontSize(8)
243
+ .text(f.details, { width: contentWidth });
244
+ }
245
+ if (f.remediation) {
246
+ doc.moveDown(0.2);
247
+ doc
248
+ .fillColor(BRAND.sage)
249
+ .font('Helvetica-Bold')
250
+ .fontSize(9)
251
+ .text(`▸ ${t('Remediation', '修復', lang)}: `, { continued: true });
252
+ doc
253
+ .fillColor(BRAND.textPrimary)
254
+ .font('Helvetica')
255
+ .fontSize(10)
256
+ .text(f.remediation, { width: contentWidth });
257
+ }
258
+ doc.moveDown(1.2);
259
+ }
260
+ }
261
+ // ─── Footer ───
262
+ doc.moveDown(3);
263
+ const footerY = doc.y;
264
+ doc
265
+ .moveTo(margin, footerY)
266
+ .lineTo(margin + contentWidth, footerY)
267
+ .strokeColor(BRAND.border)
268
+ .lineWidth(1)
269
+ .stroke();
270
+ doc.moveDown(0.5);
271
+ doc
272
+ .fillColor(BRAND.textMuted)
273
+ .font('Helvetica')
274
+ .fontSize(8)
275
+ .text(t('Confidential — PanGuard AI Code Security Report. Generated automatically by panguard-scan.', '機密 — PanGuard AI 程式碼安全報告。由 panguard-scan 自動產生。', lang), { align: 'center', width: contentWidth, characterSpacing: 0.3 });
276
+ doc.end();
277
+ await new Promise((resolve, reject) => {
278
+ stream.on('finish', () => resolve());
279
+ stream.on('error', reject);
280
+ });
281
+ logger.info('Code-scan PDF written', { outputPath: opts.outputPath });
282
+ }
283
+ //# sourceMappingURL=code-scan-pdf.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"code-scan-pdf.js","sourceRoot":"","sources":["../../src/report/code-scan-pdf.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@panguard-ai/panguard-scan",
3
- "version": "1.5.6",
3
+ "version": "1.6.0",
4
4
  "license": "MIT",
5
5
  "repository": {
6
6
  "type": "git",
@@ -34,7 +34,7 @@
34
34
  "dependencies": {
35
35
  "commander": "^12.0.0",
36
36
  "pdfkit": "^0.15.0",
37
- "@panguard-ai/core": "1.5.6",
37
+ "@panguard-ai/core": "1.6.0",
38
38
  "@panguard-ai/security-hardening": "1.5.6"
39
39
  },
40
40
  "devDependencies": {