project-shield 1.0.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/README.md +440 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +151 -0
- package/dist/index.js.map +1 -0
- package/dist/integrity/failsafe.d.ts +17 -0
- package/dist/integrity/failsafe.d.ts.map +1 -0
- package/dist/integrity/failsafe.js +45 -0
- package/dist/integrity/failsafe.js.map +1 -0
- package/dist/integrity/ruleset.d.ts +12 -0
- package/dist/integrity/ruleset.d.ts.map +1 -0
- package/dist/integrity/ruleset.js +77 -0
- package/dist/integrity/ruleset.js.map +1 -0
- package/dist/integrity/seal.d.ts +12 -0
- package/dist/integrity/seal.d.ts.map +1 -0
- package/dist/integrity/seal.js +77 -0
- package/dist/integrity/seal.js.map +1 -0
- package/dist/output/badge.d.ts +16 -0
- package/dist/output/badge.d.ts.map +1 -0
- package/dist/output/badge.js +112 -0
- package/dist/output/badge.js.map +1 -0
- package/dist/output/evidence.d.ts +18 -0
- package/dist/output/evidence.d.ts.map +1 -0
- package/dist/output/evidence.js +205 -0
- package/dist/output/evidence.js.map +1 -0
- package/dist/output/fixit.d.ts +32 -0
- package/dist/output/fixit.d.ts.map +1 -0
- package/dist/output/fixit.js +387 -0
- package/dist/output/fixit.js.map +1 -0
- package/dist/output/terminal.d.ts +10 -0
- package/dist/output/terminal.d.ts.map +1 -0
- package/dist/output/terminal.js +190 -0
- package/dist/output/terminal.js.map +1 -0
- package/dist/scanner/engine.d.ts +6 -0
- package/dist/scanner/engine.d.ts.map +1 -0
- package/dist/scanner/engine.js +155 -0
- package/dist/scanner/engine.js.map +1 -0
- package/dist/scanner/ignore.d.ts +20 -0
- package/dist/scanner/ignore.d.ts.map +1 -0
- package/dist/scanner/ignore.js +125 -0
- package/dist/scanner/ignore.js.map +1 -0
- package/dist/scanner/injection.d.ts +15 -0
- package/dist/scanner/injection.d.ts.map +1 -0
- package/dist/scanner/injection.js +234 -0
- package/dist/scanner/injection.js.map +1 -0
- package/dist/scanner/mcp.d.ts +6 -0
- package/dist/scanner/mcp.d.ts.map +1 -0
- package/dist/scanner/mcp.js +322 -0
- package/dist/scanner/mcp.js.map +1 -0
- package/dist/scanner/pii.d.ts +21 -0
- package/dist/scanner/pii.d.ts.map +1 -0
- package/dist/scanner/pii.js +161 -0
- package/dist/scanner/pii.js.map +1 -0
- package/dist/scanner/secrets.d.ts +10 -0
- package/dist/scanner/secrets.d.ts.map +1 -0
- package/dist/scanner/secrets.js +224 -0
- package/dist/scanner/secrets.js.map +1 -0
- package/dist/scoring/lock.d.ts +12 -0
- package/dist/scoring/lock.d.ts.map +1 -0
- package/dist/scoring/lock.js +58 -0
- package/dist/scoring/lock.js.map +1 -0
- package/dist/scoring/score.d.ts +14 -0
- package/dist/scoring/score.d.ts.map +1 -0
- package/dist/scoring/score.js +74 -0
- package/dist/scoring/score.js.map +1 -0
- package/dist/types/index.d.ts +205 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/package.json +52 -0
- package/rules/v1.0.0.json +248 -0
package/package.json
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "project-shield",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Security scanner for AI coders and MCP users — detects API keys, secrets, and PII",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"bin": {
|
|
7
|
+
"project-shield": "dist/index.js"
|
|
8
|
+
},
|
|
9
|
+
"scripts": {
|
|
10
|
+
"build": "tsc",
|
|
11
|
+
"typecheck": "tsc --noEmit",
|
|
12
|
+
"lint": "eslint src/",
|
|
13
|
+
"test": "vitest run",
|
|
14
|
+
"test:watch": "vitest",
|
|
15
|
+
"gate": "npm run typecheck && npm run lint && npm run test && npm run build",
|
|
16
|
+
"prepublishOnly": "npm run gate"
|
|
17
|
+
},
|
|
18
|
+
"files": [
|
|
19
|
+
"dist/",
|
|
20
|
+
"rules/"
|
|
21
|
+
],
|
|
22
|
+
"keywords": [
|
|
23
|
+
"security",
|
|
24
|
+
"scanner",
|
|
25
|
+
"secrets",
|
|
26
|
+
"pii",
|
|
27
|
+
"mcp",
|
|
28
|
+
"injection",
|
|
29
|
+
"prompt-injection",
|
|
30
|
+
"ai-security",
|
|
31
|
+
"claude",
|
|
32
|
+
"llm"
|
|
33
|
+
],
|
|
34
|
+
"author": "",
|
|
35
|
+
"license": "MIT",
|
|
36
|
+
"type": "commonjs",
|
|
37
|
+
"dependencies": {
|
|
38
|
+
"chalk": "^5.6.2",
|
|
39
|
+
"commander": "^14.0.3",
|
|
40
|
+
"glob": "^13.0.3",
|
|
41
|
+
"pdfkit": "^0.17.2"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"@types/node": "^25.2.3",
|
|
45
|
+
"@types/pdfkit": "^0.17.5",
|
|
46
|
+
"@typescript-eslint/eslint-plugin": "^8.55.0",
|
|
47
|
+
"@typescript-eslint/parser": "^8.55.0",
|
|
48
|
+
"eslint": "^9.39.2",
|
|
49
|
+
"typescript": "^5.9.3",
|
|
50
|
+
"vitest": "^4.0.18"
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": "1.0.0",
|
|
3
|
+
"sha256": "f408a4fd6101780424087ef8e3de8f4759fc857144e1d88bd273ab6305cfb8bd",
|
|
4
|
+
"secrets": {
|
|
5
|
+
"patterns": [
|
|
6
|
+
{
|
|
7
|
+
"id": "aws_access_key",
|
|
8
|
+
"name": "AWS Access Key",
|
|
9
|
+
"regex": "AKIA[0-9A-Z]{16}",
|
|
10
|
+
"description": "AWS Access Key detected"
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
"id": "aws_secret_key",
|
|
14
|
+
"name": "AWS Secret Key",
|
|
15
|
+
"regex": "[A-Za-z0-9/+=]{40}",
|
|
16
|
+
"description": "AWS Secret Key detected"
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
"id": "stripe_live",
|
|
20
|
+
"name": "Stripe Live Key",
|
|
21
|
+
"regex": "sk_live_[0-9a-zA-Z]{24,}",
|
|
22
|
+
"description": "Stripe Live Key detected",
|
|
23
|
+
"severity_override": "critical"
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"id": "stripe_test",
|
|
27
|
+
"name": "Stripe Test Key",
|
|
28
|
+
"regex": "sk_test_[0-9a-zA-Z]{24,}",
|
|
29
|
+
"description": "Stripe Test Key detected",
|
|
30
|
+
"severity_override": "warning"
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
"id": "openai_key",
|
|
34
|
+
"name": "OpenAI API Key",
|
|
35
|
+
"regex": "sk-[a-zA-Z0-9]{20,}",
|
|
36
|
+
"description": "OpenAI API Key detected"
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
"id": "github_pat",
|
|
40
|
+
"name": "GitHub Personal Access Token",
|
|
41
|
+
"regex": "ghp_[0-9a-zA-Z]{36}",
|
|
42
|
+
"description": "GitHub PAT detected"
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
"id": "github_oauth",
|
|
46
|
+
"name": "GitHub OAuth Token",
|
|
47
|
+
"regex": "gho_[0-9a-zA-Z]{36}",
|
|
48
|
+
"description": "GitHub OAuth Token detected"
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
"id": "slack_token",
|
|
52
|
+
"name": "Slack Token",
|
|
53
|
+
"regex": "xoxb-[0-9]{10,13}-[0-9]{10,13}-[a-zA-Z0-9]{24}",
|
|
54
|
+
"description": "Slack Bot Token detected"
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
"id": "google_api_key",
|
|
58
|
+
"name": "Google API Key",
|
|
59
|
+
"regex": "AIza[0-9A-Za-z_-]{35}",
|
|
60
|
+
"description": "Google API Key detected"
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
"id": "private_key",
|
|
64
|
+
"name": "Private Key",
|
|
65
|
+
"regex": "-----BEGIN (RSA |EC |OPENSSH )?PRIVATE KEY-----",
|
|
66
|
+
"description": "Private Key detected",
|
|
67
|
+
"severity_override": "critical"
|
|
68
|
+
}
|
|
69
|
+
],
|
|
70
|
+
"entropy_threshold": 4.5,
|
|
71
|
+
"context_keywords": [
|
|
72
|
+
"key",
|
|
73
|
+
"secret",
|
|
74
|
+
"token",
|
|
75
|
+
"password",
|
|
76
|
+
"passwd",
|
|
77
|
+
"credential",
|
|
78
|
+
"api_key",
|
|
79
|
+
"apikey",
|
|
80
|
+
"access_token",
|
|
81
|
+
"auth_token",
|
|
82
|
+
"private_key",
|
|
83
|
+
"client_secret"
|
|
84
|
+
]
|
|
85
|
+
},
|
|
86
|
+
"pii": {
|
|
87
|
+
"patterns": [
|
|
88
|
+
{
|
|
89
|
+
"id": "korean_rrn_hyphen",
|
|
90
|
+
"name": "Korean RRN (with hyphen)",
|
|
91
|
+
"regex": "\\d{6}-[1-4]\\d{6}",
|
|
92
|
+
"description": "Korean Resident Registration Number detected",
|
|
93
|
+
"locale": "kr",
|
|
94
|
+
"has_checksum": true
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
"id": "korean_rrn_no_hyphen",
|
|
98
|
+
"name": "Korean RRN (no hyphen)",
|
|
99
|
+
"regex": "\\d{6}[1-4]\\d{6}",
|
|
100
|
+
"description": "Korean Resident Registration Number detected (no hyphen)",
|
|
101
|
+
"locale": "kr",
|
|
102
|
+
"has_checksum": true
|
|
103
|
+
},
|
|
104
|
+
{
|
|
105
|
+
"id": "korean_phone",
|
|
106
|
+
"name": "Korean Phone Number",
|
|
107
|
+
"regex": "01[016789]-\\d{3,4}-\\d{4}",
|
|
108
|
+
"description": "Korean phone number detected",
|
|
109
|
+
"locale": "kr",
|
|
110
|
+
"has_checksum": false
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
"id": "korean_business_number",
|
|
114
|
+
"name": "Korean Business Registration Number",
|
|
115
|
+
"regex": "\\d{3}-\\d{2}-\\d{5}",
|
|
116
|
+
"description": "Korean Business Registration Number detected",
|
|
117
|
+
"locale": "kr",
|
|
118
|
+
"has_checksum": true
|
|
119
|
+
},
|
|
120
|
+
{
|
|
121
|
+
"id": "korean_passport",
|
|
122
|
+
"name": "Korean Passport Number",
|
|
123
|
+
"regex": "[A-Z]{1,2}\\d{7}",
|
|
124
|
+
"description": "Korean Passport Number detected",
|
|
125
|
+
"locale": "kr",
|
|
126
|
+
"has_checksum": false
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
"id": "email",
|
|
130
|
+
"name": "Email Address",
|
|
131
|
+
"regex": "[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}",
|
|
132
|
+
"description": "Email address detected",
|
|
133
|
+
"locale": "kr",
|
|
134
|
+
"has_checksum": false
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
"id": "us_ssn",
|
|
138
|
+
"name": "US Social Security Number",
|
|
139
|
+
"regex": "\\d{3}-\\d{2}-\\d{4}",
|
|
140
|
+
"description": "US SSN detected",
|
|
141
|
+
"locale": "global",
|
|
142
|
+
"has_checksum": false
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
"id": "credit_card",
|
|
146
|
+
"name": "Credit Card Number",
|
|
147
|
+
"regex": "\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}",
|
|
148
|
+
"description": "Credit card number detected",
|
|
149
|
+
"locale": "global",
|
|
150
|
+
"has_checksum": true
|
|
151
|
+
}
|
|
152
|
+
]
|
|
153
|
+
},
|
|
154
|
+
"mcp": {
|
|
155
|
+
"config_files": [
|
|
156
|
+
"mcp.json",
|
|
157
|
+
"mcp-config.json",
|
|
158
|
+
"claude_desktop_config.json",
|
|
159
|
+
".mcp.yaml",
|
|
160
|
+
".mcp.yml"
|
|
161
|
+
],
|
|
162
|
+
"auth_fields": [
|
|
163
|
+
"auth",
|
|
164
|
+
"authentication",
|
|
165
|
+
"oauth",
|
|
166
|
+
"apiKey",
|
|
167
|
+
"api_key",
|
|
168
|
+
"bearer",
|
|
169
|
+
"token",
|
|
170
|
+
"credentials"
|
|
171
|
+
],
|
|
172
|
+
"dangerous_tool_keywords": [
|
|
173
|
+
"exec",
|
|
174
|
+
"eval",
|
|
175
|
+
"system",
|
|
176
|
+
"shell",
|
|
177
|
+
"spawn",
|
|
178
|
+
"child_process",
|
|
179
|
+
"rm",
|
|
180
|
+
"delete",
|
|
181
|
+
"drop"
|
|
182
|
+
],
|
|
183
|
+
"permission_patterns": [
|
|
184
|
+
{
|
|
185
|
+
"id": "root_fs",
|
|
186
|
+
"name": "Root filesystem",
|
|
187
|
+
"type": "permission_pattern",
|
|
188
|
+
"values": [
|
|
189
|
+
"/",
|
|
190
|
+
"C:\\"
|
|
191
|
+
],
|
|
192
|
+
"description": "Root filesystem access"
|
|
193
|
+
},
|
|
194
|
+
{
|
|
195
|
+
"id": "wildcard_network",
|
|
196
|
+
"name": "Wildcard network",
|
|
197
|
+
"type": "permission_pattern",
|
|
198
|
+
"values": [
|
|
199
|
+
"*",
|
|
200
|
+
"0.0.0.0"
|
|
201
|
+
],
|
|
202
|
+
"description": "Wildcard network access"
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
"id": "privileged_mode",
|
|
206
|
+
"name": "Privileged mode",
|
|
207
|
+
"type": "permission_pattern",
|
|
208
|
+
"values": [
|
|
209
|
+
"privileged",
|
|
210
|
+
"--privileged"
|
|
211
|
+
],
|
|
212
|
+
"description": "Docker privileged mode"
|
|
213
|
+
}
|
|
214
|
+
],
|
|
215
|
+
"logging_fields": [
|
|
216
|
+
"logging",
|
|
217
|
+
"audit",
|
|
218
|
+
"log_level",
|
|
219
|
+
"logLevel",
|
|
220
|
+
"stderr",
|
|
221
|
+
"stdout",
|
|
222
|
+
"log"
|
|
223
|
+
]
|
|
224
|
+
},
|
|
225
|
+
"injection": {
|
|
226
|
+
"direct_patterns": [
|
|
227
|
+
{ "id": "inj_ignore_prev", "name": "Ignore Previous Instructions", "regex": "(?:ignore|disregard)\\s+(?:all\\s+)?(?:previous|prior|above)\\s+(?:instructions|prompts|context)", "type": "direct", "description": "Direct instruction override attempt" },
|
|
228
|
+
{ "id": "inj_forget_all", "name": "Forget Everything", "regex": "forget\\s+(?:everything|all|previous)", "type": "direct", "description": "Memory wipe attempt" },
|
|
229
|
+
{ "id": "inj_you_are_now", "name": "Identity Override", "regex": "you\\s+are\\s+now\\s+", "type": "direct", "description": "Identity override attempt" },
|
|
230
|
+
{ "id": "inj_new_instructions", "name": "New Instructions", "regex": "new\\s+instructions\\s*:", "type": "direct", "description": "New instruction injection" },
|
|
231
|
+
{ "id": "inj_system_prompt", "name": "System Prompt Override", "regex": "system\\s+prompt\\s*:", "type": "direct", "description": "System prompt override attempt" },
|
|
232
|
+
{ "id": "inj_important_override", "name": "Important Override", "regex": "IMPORTANT\\s*:\\s*override", "type": "direct", "description": "Priority override attempt" }
|
|
233
|
+
],
|
|
234
|
+
"indirect_patterns": [
|
|
235
|
+
{ "id": "inj_when_user", "name": "Conditional Redirect", "regex": "when\\s+(?:the\\s+)?user\\s+asks?.*(?:instead|do|say)", "type": "indirect", "description": "Conditional behavior redirect" },
|
|
236
|
+
{ "id": "inj_always_include", "name": "Always Include", "regex": "always\\s+include\\s+the\\s+following", "type": "indirect", "description": "Forced inclusion directive" },
|
|
237
|
+
{ "id": "inj_before_responding", "name": "Pre-response Hook", "regex": "before\\s+responding\\s*,?\\s*first", "type": "indirect", "description": "Pre-response injection" },
|
|
238
|
+
{ "id": "inj_do_not_tell", "name": "Secrecy Directive", "regex": "do\\s+not\\s+tell\\s+the\\s+user", "type": "indirect", "description": "Information suppression" },
|
|
239
|
+
{ "id": "inj_secretly", "name": "Covert Action", "regex": "\\bsecretly\\b", "type": "indirect", "description": "Covert action directive" }
|
|
240
|
+
],
|
|
241
|
+
"structural": {
|
|
242
|
+
"html_comment_regex": "<!--[\\s\\S]*?-->",
|
|
243
|
+
"markdown_comment_regex": "\\[//\\]:\\s*#\\s*\\(.*?\\)",
|
|
244
|
+
"zero_width_chars": ["\\u200B", "\\u200C", "\\u200D", "\\uFEFF", "\\u2060"],
|
|
245
|
+
"tool_length_multiplier": 5
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
}
|