project-shield 1.0.1 → 1.1.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/index.js +62 -20
- package/dist/index.js.map +1 -1
- package/dist/license/commands.d.ts +17 -0
- package/dist/license/commands.d.ts.map +1 -0
- package/dist/license/commands.js +154 -0
- package/dist/license/commands.js.map +1 -0
- package/dist/license/gate.d.ts +14 -0
- package/dist/license/gate.d.ts.map +1 -0
- package/dist/license/gate.js +35 -0
- package/dist/license/gate.js.map +1 -0
- package/dist/license/http.d.ts +7 -0
- package/dist/license/http.d.ts.map +1 -0
- package/dist/license/http.js +89 -0
- package/dist/license/http.js.map +1 -0
- package/dist/license/index.d.ts +6 -0
- package/dist/license/index.d.ts.map +1 -0
- package/dist/license/index.js +20 -0
- package/dist/license/index.js.map +1 -0
- package/dist/license/storage.d.ts +31 -0
- package/dist/license/storage.d.ts.map +1 -0
- package/dist/license/storage.js +138 -0
- package/dist/license/storage.js.map +1 -0
- package/dist/license/types.d.ts +55 -0
- package/dist/license/types.d.ts.map +1 -0
- package/dist/license/types.js +4 -0
- package/dist/license/types.js.map +1 -0
- package/dist/license/usage.d.ts +22 -0
- package/dist/license/usage.d.ts.map +1 -0
- package/dist/license/usage.js +60 -0
- package/dist/license/usage.js.map +1 -0
- package/dist/license/validator.d.ts +28 -0
- package/dist/license/validator.d.ts.map +1 -0
- package/dist/license/validator.js +108 -0
- package/dist/license/validator.js.map +1 -0
- package/dist/output/terminal.d.ts +8 -2
- package/dist/output/terminal.d.ts.map +1 -1
- package/dist/output/terminal.js +21 -2
- package/dist/output/terminal.js.map +1 -1
- package/dist/scanner/engine.d.ts.map +1 -1
- package/dist/scanner/engine.js +19 -0
- package/dist/scanner/engine.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.getConfigDir = getConfigDir;
|
|
37
|
+
exports.ensureConfigDir = ensureConfigDir;
|
|
38
|
+
exports.readLicenseFile = readLicenseFile;
|
|
39
|
+
exports.writeLicenseFile = writeLicenseFile;
|
|
40
|
+
exports.deleteLicenseFile = deleteLicenseFile;
|
|
41
|
+
exports.readUsageFile = readUsageFile;
|
|
42
|
+
exports.writeUsageFile = writeUsageFile;
|
|
43
|
+
const fs = __importStar(require("node:fs"));
|
|
44
|
+
const path = __importStar(require("node:path"));
|
|
45
|
+
const os = __importStar(require("node:os"));
|
|
46
|
+
const DIR_NAME = '.project-shield';
|
|
47
|
+
/**
|
|
48
|
+
* Get the config directory path.
|
|
49
|
+
* Uses PROJECT_SHIELD_CONFIG_DIR env var for testing, otherwise ~/.project-shield/
|
|
50
|
+
*/
|
|
51
|
+
function getConfigDir() {
|
|
52
|
+
return process.env.PROJECT_SHIELD_CONFIG_DIR ?? path.join(os.homedir(), DIR_NAME);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Ensure the config directory exists.
|
|
56
|
+
*/
|
|
57
|
+
function ensureConfigDir() {
|
|
58
|
+
const dir = getConfigDir();
|
|
59
|
+
if (!fs.existsSync(dir)) {
|
|
60
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Read the license file. Returns null if not found or corrupted.
|
|
65
|
+
*/
|
|
66
|
+
function readLicenseFile() {
|
|
67
|
+
try {
|
|
68
|
+
const filePath = path.join(getConfigDir(), 'license.json');
|
|
69
|
+
if (!fs.existsSync(filePath))
|
|
70
|
+
return null;
|
|
71
|
+
const raw = fs.readFileSync(filePath, 'utf-8');
|
|
72
|
+
const data = JSON.parse(raw);
|
|
73
|
+
// Basic shape validation
|
|
74
|
+
if (!data.cache?.license?.key || !data.cache?.validatedAt || !data.cache?.validUntil) {
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
return data;
|
|
78
|
+
}
|
|
79
|
+
catch {
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Write the license file.
|
|
85
|
+
*/
|
|
86
|
+
function writeLicenseFile(data) {
|
|
87
|
+
ensureConfigDir();
|
|
88
|
+
const filePath = path.join(getConfigDir(), 'license.json');
|
|
89
|
+
fs.writeFileSync(filePath, JSON.stringify(data, null, 2), 'utf-8');
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Delete the license file.
|
|
93
|
+
*/
|
|
94
|
+
function deleteLicenseFile() {
|
|
95
|
+
const filePath = path.join(getConfigDir(), 'license.json');
|
|
96
|
+
if (fs.existsSync(filePath)) {
|
|
97
|
+
fs.unlinkSync(filePath);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
function defaultUsage() {
|
|
101
|
+
const now = new Date();
|
|
102
|
+
const monthKey = `${now.getFullYear()}-${String(now.getMonth() + 1).padStart(2, '0')}`;
|
|
103
|
+
return {
|
|
104
|
+
usage: {
|
|
105
|
+
monthKey,
|
|
106
|
+
scanCount: 0,
|
|
107
|
+
lastScanAt: '',
|
|
108
|
+
},
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Read the usage file. Returns default if not found or corrupted.
|
|
113
|
+
*/
|
|
114
|
+
function readUsageFile() {
|
|
115
|
+
try {
|
|
116
|
+
const filePath = path.join(getConfigDir(), 'usage.json');
|
|
117
|
+
if (!fs.existsSync(filePath))
|
|
118
|
+
return defaultUsage();
|
|
119
|
+
const raw = fs.readFileSync(filePath, 'utf-8');
|
|
120
|
+
const data = JSON.parse(raw);
|
|
121
|
+
if (!data.usage?.monthKey || typeof data.usage?.scanCount !== 'number') {
|
|
122
|
+
return defaultUsage();
|
|
123
|
+
}
|
|
124
|
+
return data;
|
|
125
|
+
}
|
|
126
|
+
catch {
|
|
127
|
+
return defaultUsage();
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Write the usage file.
|
|
132
|
+
*/
|
|
133
|
+
function writeUsageFile(data) {
|
|
134
|
+
ensureConfigDir();
|
|
135
|
+
const filePath = path.join(getConfigDir(), 'usage.json');
|
|
136
|
+
fs.writeFileSync(filePath, JSON.stringify(data, null, 2), 'utf-8');
|
|
137
|
+
}
|
|
138
|
+
//# sourceMappingURL=storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage.js","sourceRoot":"","sources":["../../src/license/storage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
export interface LicenseInfo {
|
|
2
|
+
key: string;
|
|
3
|
+
tier: 'free' | 'pro';
|
|
4
|
+
email: string;
|
|
5
|
+
activatedAt: string;
|
|
6
|
+
expiresAt: string;
|
|
7
|
+
maxScansPerMonth: number;
|
|
8
|
+
}
|
|
9
|
+
export interface LicenseCache {
|
|
10
|
+
license: LicenseInfo;
|
|
11
|
+
validatedAt: string;
|
|
12
|
+
validUntil: string;
|
|
13
|
+
}
|
|
14
|
+
export interface LicenseFile {
|
|
15
|
+
cache: LicenseCache;
|
|
16
|
+
}
|
|
17
|
+
export interface UsageData {
|
|
18
|
+
monthKey: string;
|
|
19
|
+
scanCount: number;
|
|
20
|
+
lastScanAt: string;
|
|
21
|
+
}
|
|
22
|
+
export interface UsageFile {
|
|
23
|
+
usage: UsageData;
|
|
24
|
+
}
|
|
25
|
+
export type TierStatus = {
|
|
26
|
+
tier: 'free' | 'pro';
|
|
27
|
+
isPro: boolean;
|
|
28
|
+
scansRemaining: number;
|
|
29
|
+
scansUsed: number;
|
|
30
|
+
maxScans: number;
|
|
31
|
+
source: 'license' | 'default';
|
|
32
|
+
};
|
|
33
|
+
export interface FeatureGate {
|
|
34
|
+
isPro: boolean;
|
|
35
|
+
canGenerateEvidence: boolean;
|
|
36
|
+
canSeePiiDetails: boolean;
|
|
37
|
+
canSeeCleanBadge: boolean;
|
|
38
|
+
canSeeFullFixit: boolean;
|
|
39
|
+
canGenerateSealUUID: boolean;
|
|
40
|
+
}
|
|
41
|
+
export interface ValidateResponse {
|
|
42
|
+
valid: boolean;
|
|
43
|
+
license?: LicenseInfo;
|
|
44
|
+
error?: string;
|
|
45
|
+
}
|
|
46
|
+
export interface ActivateResponse {
|
|
47
|
+
success: boolean;
|
|
48
|
+
license?: LicenseInfo;
|
|
49
|
+
error?: string;
|
|
50
|
+
}
|
|
51
|
+
export interface DeactivateResponse {
|
|
52
|
+
success: boolean;
|
|
53
|
+
error?: string;
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/license/types.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,WAAW;IAC1B,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,GAAG,KAAK,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,WAAW,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,YAAY,CAAC;CACrB;AAED,MAAM,WAAW,SAAS;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,SAAS,CAAC;CAClB;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,IAAI,EAAE,MAAM,GAAG,KAAK,CAAC;IACrB,KAAK,EAAE,OAAO,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC;CAC/B,CAAC;AAEF,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,OAAO,CAAC;IACf,mBAAmB,EAAE,OAAO,CAAC;IAC7B,gBAAgB,EAAE,OAAO,CAAC;IAC1B,gBAAgB,EAAE,OAAO,CAAC;IAC1B,eAAe,EAAE,OAAO,CAAC;IACzB,mBAAmB,EAAE,OAAO,CAAC;CAC9B;AAID,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/license/types.ts"],"names":[],"mappings":";AAAA,gEAAgE"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { UsageData, TierStatus } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Get current month key in "YYYY-MM" format.
|
|
4
|
+
*/
|
|
5
|
+
export declare function getCurrentMonthKey(): string;
|
|
6
|
+
/**
|
|
7
|
+
* Get usage data for a given month. Resets if month changed.
|
|
8
|
+
*/
|
|
9
|
+
export declare function getUsageForMonth(monthKey?: string): UsageData;
|
|
10
|
+
/**
|
|
11
|
+
* Record a scan. Increments count for current month.
|
|
12
|
+
*/
|
|
13
|
+
export declare function recordScan(): void;
|
|
14
|
+
/**
|
|
15
|
+
* Check if a scan is allowed based on tier limits.
|
|
16
|
+
* free: 5/month, pro: 50/month
|
|
17
|
+
*/
|
|
18
|
+
export declare function canScan(tier: TierStatus): {
|
|
19
|
+
allowed: boolean;
|
|
20
|
+
reason?: string;
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=usage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usage.d.ts","sourceRoot":"","sources":["../../src/license/usage.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAExD;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,MAAM,CAG3C;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAc7D;AAED;;GAEG;AACH,wBAAgB,UAAU,IAAI,IAAI,CAWjC;AAED;;;GAGG;AACH,wBAAgB,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,CAY/E"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getCurrentMonthKey = getCurrentMonthKey;
|
|
4
|
+
exports.getUsageForMonth = getUsageForMonth;
|
|
5
|
+
exports.recordScan = recordScan;
|
|
6
|
+
exports.canScan = canScan;
|
|
7
|
+
const storage_js_1 = require("./storage.js");
|
|
8
|
+
/**
|
|
9
|
+
* Get current month key in "YYYY-MM" format.
|
|
10
|
+
*/
|
|
11
|
+
function getCurrentMonthKey() {
|
|
12
|
+
const now = new Date();
|
|
13
|
+
return `${now.getFullYear()}-${String(now.getMonth() + 1).padStart(2, '0')}`;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Get usage data for a given month. Resets if month changed.
|
|
17
|
+
*/
|
|
18
|
+
function getUsageForMonth(monthKey) {
|
|
19
|
+
const key = monthKey ?? getCurrentMonthKey();
|
|
20
|
+
const file = (0, storage_js_1.readUsageFile)();
|
|
21
|
+
// Month rollover → reset
|
|
22
|
+
if (file.usage.monthKey !== key) {
|
|
23
|
+
return {
|
|
24
|
+
monthKey: key,
|
|
25
|
+
scanCount: 0,
|
|
26
|
+
lastScanAt: '',
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
return file.usage;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Record a scan. Increments count for current month.
|
|
33
|
+
*/
|
|
34
|
+
function recordScan() {
|
|
35
|
+
const monthKey = getCurrentMonthKey();
|
|
36
|
+
const current = getUsageForMonth(monthKey);
|
|
37
|
+
(0, storage_js_1.writeUsageFile)({
|
|
38
|
+
usage: {
|
|
39
|
+
monthKey,
|
|
40
|
+
scanCount: current.scanCount + 1,
|
|
41
|
+
lastScanAt: new Date().toISOString(),
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Check if a scan is allowed based on tier limits.
|
|
47
|
+
* free: 5/month, pro: 50/month
|
|
48
|
+
*/
|
|
49
|
+
function canScan(tier) {
|
|
50
|
+
if (tier.scansRemaining <= 0) {
|
|
51
|
+
return {
|
|
52
|
+
allowed: false,
|
|
53
|
+
reason: `Monthly scan limit reached (${tier.maxScans}/${tier.maxScans}). ${tier.isPro
|
|
54
|
+
? 'Your Pro plan allows 50 scans/month. Resets next month.'
|
|
55
|
+
: 'Upgrade to Pro for 50 scans/month: https://project-shield.dev/pro'}`,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
return { allowed: true };
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=usage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usage.js","sourceRoot":"","sources":["../../src/license/usage.ts"],"names":[],"mappings":";;AAMA,gDAGC;AAKD,4CAcC;AAKD,gCAWC;AAMD,0BAYC;AA9DD,6CAA6D;AAG7D;;GAEG;AACH,SAAgB,kBAAkB;IAChC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,OAAO,GAAG,GAAG,CAAC,WAAW,EAAE,IAAI,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;AAC/E,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,QAAiB;IAChD,MAAM,GAAG,GAAG,QAAQ,IAAI,kBAAkB,EAAE,CAAC;IAC7C,MAAM,IAAI,GAAG,IAAA,0BAAa,GAAE,CAAC;IAE7B,yBAAyB;IACzB,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,KAAK,GAAG,EAAE,CAAC;QAChC,OAAO;YACL,QAAQ,EAAE,GAAG;YACb,SAAS,EAAE,CAAC;YACZ,UAAU,EAAE,EAAE;SACf,CAAC;IACJ,CAAC;IAED,OAAO,IAAI,CAAC,KAAK,CAAC;AACpB,CAAC;AAED;;GAEG;AACH,SAAgB,UAAU;IACxB,MAAM,QAAQ,GAAG,kBAAkB,EAAE,CAAC;IACtC,MAAM,OAAO,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IAE3C,IAAA,2BAAc,EAAC;QACb,KAAK,EAAE;YACL,QAAQ;YACR,SAAS,EAAE,OAAO,CAAC,SAAS,GAAG,CAAC;YAChC,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACrC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,IAAgB;IACtC,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,EAAE,CAAC;QAC7B,OAAO;YACL,OAAO,EAAE,KAAK;YACd,MAAM,EAAE,+BAA+B,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,MACnE,IAAI,CAAC,KAAK;gBACR,CAAC,CAAC,yDAAyD;gBAC3D,CAAC,CAAC,mEACN,EAAE;SACH,CAAC;IACJ,CAAC;IACD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAC3B,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { LicenseCache, TierStatus, ValidateResponse } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Validate key format: PSH-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}
|
|
4
|
+
*/
|
|
5
|
+
export declare function isValidKeyFormat(key: string): boolean;
|
|
6
|
+
/**
|
|
7
|
+
* Validate license with server.
|
|
8
|
+
*/
|
|
9
|
+
export declare function validateWithServer(key: string): Promise<ValidateResponse>;
|
|
10
|
+
/**
|
|
11
|
+
* Check if cache is within the 7-day validity window.
|
|
12
|
+
*/
|
|
13
|
+
export declare function isCacheValid(cache: LicenseCache): boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Check if still within the grace period (3 extra days after cache expires).
|
|
16
|
+
*/
|
|
17
|
+
export declare function isInGracePeriod(cache: LicenseCache): boolean;
|
|
18
|
+
/**
|
|
19
|
+
* Main license validation flow:
|
|
20
|
+
* 1. No license.json → free (default)
|
|
21
|
+
* 2. Cache valid (7 days) → return cached tier
|
|
22
|
+
* 3. Cache expired → try server re-validation
|
|
23
|
+
* 4. Server success → update cache, return tier
|
|
24
|
+
* 5. Server fail + grace period → cached tier + warning
|
|
25
|
+
* 6. Grace expired → downgrade to free
|
|
26
|
+
*/
|
|
27
|
+
export declare function validateLicense(): Promise<TierStatus>;
|
|
28
|
+
//# sourceMappingURL=validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator.d.ts","sourceRoot":"","sources":["../../src/license/validator.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAO7E;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAErD;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAG/E;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,YAAY,GAAG,OAAO,CAIzD;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,YAAY,GAAG,OAAO,CAK5D;AAkBD;;;;;;;;GAQG;AACH,wBAAsB,eAAe,IAAI,OAAO,CAAC,UAAU,CAAC,CA6C3D"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isValidKeyFormat = isValidKeyFormat;
|
|
4
|
+
exports.validateWithServer = validateWithServer;
|
|
5
|
+
exports.isCacheValid = isCacheValid;
|
|
6
|
+
exports.isInGracePeriod = isInGracePeriod;
|
|
7
|
+
exports.validateLicense = validateLicense;
|
|
8
|
+
const storage_js_1 = require("./storage.js");
|
|
9
|
+
const usage_js_1 = require("./usage.js");
|
|
10
|
+
const http_js_1 = require("./http.js");
|
|
11
|
+
const API_BASE = 'https://license.project-shield.dev/api/v1';
|
|
12
|
+
const KEY_PATTERN = /^PSH-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}$/;
|
|
13
|
+
const CACHE_DAYS = 7;
|
|
14
|
+
const GRACE_DAYS = 3;
|
|
15
|
+
/**
|
|
16
|
+
* Validate key format: PSH-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}
|
|
17
|
+
*/
|
|
18
|
+
function isValidKeyFormat(key) {
|
|
19
|
+
return KEY_PATTERN.test(key);
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Validate license with server.
|
|
23
|
+
*/
|
|
24
|
+
async function validateWithServer(key) {
|
|
25
|
+
const response = await (0, http_js_1.postJSON)(`${API_BASE}/validate`, { key });
|
|
26
|
+
return response;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Check if cache is within the 7-day validity window.
|
|
30
|
+
*/
|
|
31
|
+
function isCacheValid(cache) {
|
|
32
|
+
const now = Date.now();
|
|
33
|
+
const validUntil = new Date(cache.validUntil).getTime();
|
|
34
|
+
return now < validUntil;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Check if still within the grace period (3 extra days after cache expires).
|
|
38
|
+
*/
|
|
39
|
+
function isInGracePeriod(cache) {
|
|
40
|
+
const now = Date.now();
|
|
41
|
+
const validUntil = new Date(cache.validUntil).getTime();
|
|
42
|
+
const graceEnd = validUntil + GRACE_DAYS * 24 * 60 * 60 * 1000;
|
|
43
|
+
return now >= validUntil && now < graceEnd;
|
|
44
|
+
}
|
|
45
|
+
function makeTierStatus(tier, maxScans, source) {
|
|
46
|
+
const usage = (0, usage_js_1.getUsageForMonth)((0, usage_js_1.getCurrentMonthKey)());
|
|
47
|
+
return {
|
|
48
|
+
tier,
|
|
49
|
+
isPro: tier === 'pro',
|
|
50
|
+
scansRemaining: Math.max(0, maxScans - usage.scanCount),
|
|
51
|
+
scansUsed: usage.scanCount,
|
|
52
|
+
maxScans,
|
|
53
|
+
source,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Main license validation flow:
|
|
58
|
+
* 1. No license.json → free (default)
|
|
59
|
+
* 2. Cache valid (7 days) → return cached tier
|
|
60
|
+
* 3. Cache expired → try server re-validation
|
|
61
|
+
* 4. Server success → update cache, return tier
|
|
62
|
+
* 5. Server fail + grace period → cached tier + warning
|
|
63
|
+
* 6. Grace expired → downgrade to free
|
|
64
|
+
*/
|
|
65
|
+
async function validateLicense() {
|
|
66
|
+
const file = (0, storage_js_1.readLicenseFile)();
|
|
67
|
+
// 1. No license file → free
|
|
68
|
+
if (!file) {
|
|
69
|
+
return makeTierStatus('free', 5, 'default');
|
|
70
|
+
}
|
|
71
|
+
const cache = file.cache;
|
|
72
|
+
// 2. Cache valid
|
|
73
|
+
if (isCacheValid(cache)) {
|
|
74
|
+
const max = cache.license.tier === 'pro' ? 50 : 5;
|
|
75
|
+
return makeTierStatus(cache.license.tier, max, 'license');
|
|
76
|
+
}
|
|
77
|
+
// 3. Cache expired → try server
|
|
78
|
+
try {
|
|
79
|
+
const response = await validateWithServer(cache.license.key);
|
|
80
|
+
if (response.valid && response.license) {
|
|
81
|
+
// 4. Server success → update cache
|
|
82
|
+
const now = new Date();
|
|
83
|
+
const validUntil = new Date(now.getTime() + CACHE_DAYS * 24 * 60 * 60 * 1000);
|
|
84
|
+
(0, storage_js_1.writeLicenseFile)({
|
|
85
|
+
cache: {
|
|
86
|
+
license: response.license,
|
|
87
|
+
validatedAt: now.toISOString(),
|
|
88
|
+
validUntil: validUntil.toISOString(),
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
const max = response.license.tier === 'pro' ? 50 : 5;
|
|
92
|
+
return makeTierStatus(response.license.tier, max, 'license');
|
|
93
|
+
}
|
|
94
|
+
// Server says invalid → downgrade
|
|
95
|
+
return makeTierStatus('free', 5, 'default');
|
|
96
|
+
}
|
|
97
|
+
catch {
|
|
98
|
+
// 5. Server unreachable
|
|
99
|
+
if (isInGracePeriod(cache)) {
|
|
100
|
+
// Grace period → use cached tier with warning
|
|
101
|
+
const max = cache.license.tier === 'pro' ? 50 : 5;
|
|
102
|
+
return makeTierStatus(cache.license.tier, max, 'license');
|
|
103
|
+
}
|
|
104
|
+
// 6. Grace expired → downgrade
|
|
105
|
+
return makeTierStatus('free', 5, 'default');
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator.js","sourceRoot":"","sources":["../../src/license/validator.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,16 @@
|
|
|
1
1
|
import type { ScanResult, ScanScore, LockStatus, SealedResult } from '../types/index.js';
|
|
2
2
|
/**
|
|
3
3
|
* Format scan results for terminal output.
|
|
4
|
+
* @param options.isPro - If false, PII section shows summary only (no file:line details).
|
|
4
5
|
*/
|
|
5
|
-
export declare function formatTerminalOutput(result: ScanResult, rulesetVersion: string, rulesetHash: string, score?: ScanScore, lockStatus?: LockStatus
|
|
6
|
+
export declare function formatTerminalOutput(result: ScanResult, rulesetVersion: string, rulesetHash: string, score?: ScanScore, lockStatus?: LockStatus, options?: {
|
|
7
|
+
isPro?: boolean;
|
|
8
|
+
}): string;
|
|
6
9
|
/**
|
|
7
10
|
* Format scan results as JSON.
|
|
11
|
+
* @param options.isPro - If false, PII array is replaced with a summary object.
|
|
8
12
|
*/
|
|
9
|
-
export declare function formatJsonOutput(result: ScanResult, score?: ScanScore, seal?: SealedResult
|
|
13
|
+
export declare function formatJsonOutput(result: ScanResult, score?: ScanScore, seal?: SealedResult, options?: {
|
|
14
|
+
isPro?: boolean;
|
|
15
|
+
}): string;
|
|
10
16
|
//# sourceMappingURL=terminal.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"terminal.d.ts","sourceRoot":"","sources":["../../src/output/terminal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,UAAU,EAKV,SAAS,EACT,UAAU,EACV,YAAY,EACb,MAAM,mBAAmB,CAAC;AAiG3B
|
|
1
|
+
{"version":3,"file":"terminal.d.ts","sourceRoot":"","sources":["../../src/output/terminal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,UAAU,EAKV,SAAS,EACT,UAAU,EACV,YAAY,EACb,MAAM,mBAAmB,CAAC;AAiG3B;;;GAGG;AACH,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,UAAU,EAClB,cAAc,EAAE,MAAM,EACtB,WAAW,EAAE,MAAM,EACnB,KAAK,CAAC,EAAE,SAAS,EACjB,UAAU,CAAC,EAAE,UAAU,EACvB,OAAO,CAAC,EAAE;IAAE,KAAK,CAAC,EAAE,OAAO,CAAA;CAAE,GAC5B,MAAM,CAqGR;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,UAAU,EAClB,KAAK,CAAC,EAAE,SAAS,EACjB,IAAI,CAAC,EAAE,YAAY,EACnB,OAAO,CAAC,EAAE;IAAE,KAAK,CAAC,EAAE,OAAO,CAAA;CAAE,GAC5B,MAAM,CAmBR"}
|
package/dist/output/terminal.js
CHANGED
|
@@ -85,8 +85,9 @@ function formatInjectionFinding(finding) {
|
|
|
85
85
|
}
|
|
86
86
|
/**
|
|
87
87
|
* Format scan results for terminal output.
|
|
88
|
+
* @param options.isPro - If false, PII section shows summary only (no file:line details).
|
|
88
89
|
*/
|
|
89
|
-
function formatTerminalOutput(result, rulesetVersion, rulesetHash, score, lockStatus) {
|
|
90
|
+
function formatTerminalOutput(result, rulesetVersion, rulesetHash, score, lockStatus, options) {
|
|
90
91
|
const lines = [];
|
|
91
92
|
lines.push('');
|
|
92
93
|
lines.push(colors.bold('Project Shield v1.0.0'));
|
|
@@ -111,6 +112,13 @@ function formatTerminalOutput(result, rulesetVersion, rulesetHash, score, lockSt
|
|
|
111
112
|
if (result.pii.length === 0) {
|
|
112
113
|
lines.push(colors.green(' No PII detected.'));
|
|
113
114
|
}
|
|
115
|
+
else if (options?.isPro === false) {
|
|
116
|
+
// Free tier: summary only (no file:line details)
|
|
117
|
+
const confirmed = result.pii.filter(p => p.severity === 'confirmed').length;
|
|
118
|
+
const possible = result.pii.filter(p => p.severity === 'possible').length;
|
|
119
|
+
lines.push(` PII ${result.pii.length} finding(s) (Confirmed: ${confirmed}, Possible: ${possible})`);
|
|
120
|
+
lines.push(colors.dim(' Detailed PII locations available in Pro tier.'));
|
|
121
|
+
}
|
|
114
122
|
else {
|
|
115
123
|
for (const finding of result.pii) {
|
|
116
124
|
lines.push(formatPIIFinding(finding));
|
|
@@ -176,8 +184,9 @@ function formatTerminalOutput(result, rulesetVersion, rulesetHash, score, lockSt
|
|
|
176
184
|
}
|
|
177
185
|
/**
|
|
178
186
|
* Format scan results as JSON.
|
|
187
|
+
* @param options.isPro - If false, PII array is replaced with a summary object.
|
|
179
188
|
*/
|
|
180
|
-
function formatJsonOutput(result, score, seal) {
|
|
189
|
+
function formatJsonOutput(result, score, seal, options) {
|
|
181
190
|
const output = { ...result };
|
|
182
191
|
if (score) {
|
|
183
192
|
output.score = score;
|
|
@@ -185,6 +194,16 @@ function formatJsonOutput(result, score, seal) {
|
|
|
185
194
|
if (seal) {
|
|
186
195
|
output.seal = seal;
|
|
187
196
|
}
|
|
197
|
+
// Free tier: replace PII array with summary
|
|
198
|
+
if (options?.isPro === false) {
|
|
199
|
+
const confirmed = result.pii.filter(p => p.severity === 'confirmed').length;
|
|
200
|
+
const possible = result.pii.filter(p => p.severity === 'possible').length;
|
|
201
|
+
output.pii = {
|
|
202
|
+
count: result.pii.length,
|
|
203
|
+
confirmed,
|
|
204
|
+
possible,
|
|
205
|
+
};
|
|
206
|
+
}
|
|
188
207
|
return JSON.stringify(output, null, 2);
|
|
189
208
|
}
|
|
190
209
|
//# sourceMappingURL=terminal.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"terminal.js","sourceRoot":"","sources":["../../src/output/terminal.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"terminal.js","sourceRoot":"","sources":["../../src/output/terminal.ts"],"names":[],"mappings":";;AA8GA,oDA4GC;AAMD,4CAwBC;AA7OD,sFAAsF;AACtF,MAAM,MAAM,GAAG;IACb,GAAG,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,WAAW,CAAC,SAAS;IACzC,MAAM,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,WAAW,CAAC,SAAS;IAC5C,KAAK,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,WAAW,CAAC,SAAS;IAC3C,IAAI,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,WAAW,CAAC,SAAS;IAC1C,IAAI,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS;IACzC,GAAG,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS;CACzC,CAAC;AAEF,SAAS,mBAAmB,CAAC,OAAsB;IACjD,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACjG,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IAC/D,MAAM,SAAS,GAAG;QAChB,SAAS,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE;QAC3C,WAAW,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE;QACrD,WAAW,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE;KAChD,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEZ,OAAO;QACL,KAAK,IAAI,KAAK,QAAQ,EAAE;QACxB,MAAM,OAAO,CAAC,WAAW,KAAK,OAAO,CAAC,OAAO,GAAG;QAChD,cAAc,SAAS,EAAE;KAC1B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC;AAED,SAAS,gBAAgB,CAAC,OAAmB;IAC3C,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,KAAK,WAAW;QAC3C,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC;QACzB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAC9B,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IAC/D,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,KAAK,IAAI;QAClD,CAAC,CAAC,KAAK;QACP,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IACxC,MAAM,SAAS,GAAG;QAChB,SAAS,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE;QAC3C,YAAY,WAAW,EAAE;KAC1B,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEZ,OAAO;QACL,KAAK,IAAI,KAAK,QAAQ,EAAE;QACxB,MAAM,OAAO,CAAC,WAAW,KAAK,OAAO,CAAC,OAAO,GAAG;QAChD,cAAc,SAAS,EAAE;KAC1B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC;AAED,SAAS,gBAAgB,CAAC,OAAmB;IAC3C,MAAM,aAAa,GACjB,OAAO,CAAC,eAAe,KAAK,UAAU;QACpC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC;QACxB,CAAC,CAAC,OAAO,CAAC,eAAe,KAAK,SAAS;YACrC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC;YAC1B,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAE7B,MAAM,KAAK,GAAG;QACZ,KAAK,aAAa,KAAK,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,OAAO,CAAC,WAAW,YAAY;KACrF,CAAC;IAEF,MAAM,MAAM,GAAG;QACb,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE;QAC1C,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE;QAChD,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE;QACnD,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE;QACxD,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE;KACjD,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,MAAM,IAAI,GACR,KAAK,CAAC,IAAI,CAAC,MAAM,KAAK,MAAM;YAC1B,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC;YACnB,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,KAAK,UAAU;gBAChC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;gBACjB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC3B,KAAK,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,SAAS,sBAAsB,CAAC,OAAyB;IACvD,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACjG,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IAC/D,MAAM,SAAS,GAAG;QAChB,WAAW,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE;QAC/C,aAAa,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE;KACpD,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEZ,OAAO;QACL,KAAK,IAAI,KAAK,QAAQ,EAAE;QACxB,MAAM,OAAO,CAAC,WAAW,KAAK,OAAO,CAAC,IAAI,GAAG;QAC7C,eAAe,OAAO,CAAC,OAAO,gBAAgB,SAAS,EAAE;QACzD,gBAAgB,OAAO,CAAC,OAAO,GAAG;KACnC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC;AAED;;;GAGG;AACH,SAAgB,oBAAoB,CAClC,MAAkB,EAClB,cAAsB,EACtB,WAAmB,EACnB,KAAiB,EACjB,UAAuB,EACvB,OAA6B;IAE7B,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC;IACjD,KAAK,CAAC,IAAI,CAAC,aAAa,cAAc,cAAc,WAAW,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;IACvF,KAAK,CAAC,IAAI,CAAC,aAAa,MAAM,CAAC,OAAO,CAAC,YAAY,WAAW,MAAM,CAAC,OAAO,CAAC,aAAa,YAAY,CAAC,CAAC;IACxG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,kBAAkB;IAClB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC,CAAC;IACvE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,CAAC;IACrD,CAAC;SAAM,CAAC;QACN,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACrC,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;YACzC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED,cAAc;IACd,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAC,CAAC;IACtE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,MAAM,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;IACjD,CAAC;SAAM,IAAI,OAAO,EAAE,KAAK,KAAK,KAAK,EAAE,CAAC;QACpC,iDAAiD;QACjD,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,WAAW,CAAC,CAAC,MAAM,CAAC;QAC5E,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,MAAM,CAAC;QAC1E,KAAK,CAAC,IAAI,CAAC,SAAS,MAAM,CAAC,GAAG,CAAC,MAAM,2BAA2B,SAAS,eAAe,QAAQ,GAAG,CAAC,CAAC;QACrG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,iDAAiD,CAAC,CAAC,CAAC;IAC5E,CAAC;SAAM,CAAC;QACN,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,GAAG,EAAE,CAAC;YACjC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;YACtC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED,cAAc;IACd,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAC,CAAC;IACtE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,MAAM,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC,CAAC;IAClE,CAAC;SAAM,CAAC;QACN,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,GAAG,EAAE,CAAC;YACjC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;YACtC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED,oBAAoB;IACpB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC,CAAC;IACvE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,MAAM,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAC,CAAC;IAChE,CAAC;SAAM,CAAC;QACN,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;YACvC,KAAK,CAAC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC;YAC5C,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED,kBAAkB;IAClB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC,CAAC;IACvE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,eAAe,MAAM,CAAC,OAAO,CAAC,QAAQ,iBAAiB,MAAM,CAAC,OAAO,CAAC,OAAO,uBAAuB,MAAM,CAAC,OAAO,CAAC,YAAY,sBAAsB,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9L,KAAK,CAAC,IAAI,CAAC,mBAAmB,MAAM,CAAC,OAAO,CAAC,WAAW,qBAAqB,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IAC1G,KAAK,CAAC,IAAI,CAAC,yBAAyB,MAAM,CAAC,OAAO,CAAC,iBAAiB,2BAA2B,MAAM,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAClI,KAAK,CAAC,IAAI,CAAC,oBAAoB,MAAM,CAAC,OAAO,CAAC,YAAY,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IACtH,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,gBAAgB;IAChB,IAAI,KAAK,EAAE,CAAC;QACV,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC,CAAC;QACvE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACf,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,KAAK,GAAG,IAAI,KAAK,CAAC,KAAK,KAAK,GAAG;YAC3D,CAAC,CAAC,MAAM,CAAC,KAAK;YACd,CAAC,CAAC,KAAK,CAAC,KAAK,KAAK,GAAG;gBACnB,CAAC,CAAC,MAAM,CAAC,MAAM;gBACf,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;QACjB,KAAK,CAAC,IAAI,CAAC,YAAY,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,KAAK,CAAC,YAAY,WAAW,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/F,KAAK,CAAC,IAAI,CAAC,gBAAgB,KAAK,CAAC,SAAS,CAAC,aAAa,cAAc,KAAK,CAAC,SAAS,CAAC,YAAY,aAAa,KAAK,CAAC,SAAS,CAAC,aAAa,cAAc,KAAK,CAAC,SAAS,CAAC,SAAS,OAAO,CAAC,CAAC;QAC5L,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEf,cAAc;QACd,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,UAAU,CAAC,QAAQ,EAAE,CAAC;gBACxB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,8DAA8D,CAAC,CAAC,CAAC;YACzF,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,UAAU,CAAC,SAAS,mBAAmB,CAAC,CAAC,CAAC;YAChF,CAAC;YACD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED;;;GAGG;AACH,SAAgB,gBAAgB,CAC9B,MAAkB,EAClB,KAAiB,EACjB,IAAmB,EACnB,OAA6B;IAE7B,MAAM,MAAM,GAA4B,EAAE,GAAG,MAAM,EAAE,CAAC;IACtD,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IACD,IAAI,IAAI,EAAE,CAAC;QACT,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;IACrB,CAAC;IACD,4CAA4C;IAC5C,IAAI,OAAO,EAAE,KAAK,KAAK,KAAK,EAAE,CAAC;QAC7B,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,WAAW,CAAC,CAAC,MAAM,CAAC;QAC5E,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,MAAM,CAAC;QAC1E,MAAM,CAAC,GAAG,GAAG;YACX,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM;YACxB,SAAS;YACT,QAAQ;SACT,CAAC;IACJ,CAAC;IACD,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AACzC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../src/scanner/engine.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAW,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../src/scanner/engine.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAW,MAAM,mBAAmB,CAAC;AAmDzE;;GAEG;AACH,wBAAsB,IAAI,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAuGlE"}
|
package/dist/scanner/engine.js
CHANGED
|
@@ -66,7 +66,15 @@ const DEFAULT_EXCLUDE_DIRS = [
|
|
|
66
66
|
'.venv',
|
|
67
67
|
'venv',
|
|
68
68
|
'coverage',
|
|
69
|
+
'.cache',
|
|
70
|
+
'.npm',
|
|
71
|
+
'.nvm',
|
|
72
|
+
'AppData',
|
|
73
|
+
'.local',
|
|
74
|
+
'Library',
|
|
69
75
|
];
|
|
76
|
+
// Max files to scan before aborting (safety limit)
|
|
77
|
+
const MAX_FILES = 10000;
|
|
70
78
|
/**
|
|
71
79
|
* Check if a file is binary by extension.
|
|
72
80
|
*/
|
|
@@ -84,6 +92,10 @@ async function scan(config) {
|
|
|
84
92
|
const ruleset = (0, ruleset_js_1.loadRuleset)(config.rulesetPath);
|
|
85
93
|
// Load ignore patterns
|
|
86
94
|
const ignorePatterns = (0, ignore_js_1.loadIgnorePatterns)(config.targetPath, config.ignorePath);
|
|
95
|
+
// Progress: scanning started
|
|
96
|
+
if (config.format === 'terminal') {
|
|
97
|
+
process.stderr.write(`Scanning ${config.targetPath} ...\n`);
|
|
98
|
+
}
|
|
87
99
|
// Find all files
|
|
88
100
|
const allFiles = await (0, glob_1.glob)('**/*', {
|
|
89
101
|
cwd: config.targetPath,
|
|
@@ -92,6 +104,13 @@ async function scan(config) {
|
|
|
92
104
|
ignore: DEFAULT_EXCLUDE_DIRS.map(d => `${d}/**`),
|
|
93
105
|
absolute: false,
|
|
94
106
|
});
|
|
107
|
+
if (allFiles.length > MAX_FILES) {
|
|
108
|
+
if (config.format === 'terminal') {
|
|
109
|
+
process.stderr.write(`Warning: ${allFiles.length} files found (limit: ${MAX_FILES}). ` +
|
|
110
|
+
`Scanning first ${MAX_FILES} files. Use a more specific path or .shieldignore.\n`);
|
|
111
|
+
}
|
|
112
|
+
allFiles.length = MAX_FILES;
|
|
113
|
+
}
|
|
95
114
|
let filesExcluded = 0;
|
|
96
115
|
const filesToScan = [];
|
|
97
116
|
for (const file of allFiles) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/scanner/engine.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/scanner/engine.ts"],"names":[],"mappings":"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"}
|