@sun-asterisk/sunlint 1.3.2 → 1.3.4
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 +73 -0
- package/README.md +5 -3
- package/config/rules/enhanced-rules-registry.json +144 -33
- package/core/analysis-orchestrator.js +173 -42
- package/core/auto-performance-manager.js +243 -0
- package/core/cli-action-handler.js +24 -2
- package/core/cli-program.js +19 -5
- package/core/constants/defaults.js +56 -0
- package/core/performance-optimizer.js +271 -0
- package/docs/FILE_LIMITS_COMPLETION_REPORT.md +151 -0
- package/docs/FILE_LIMITS_EXPLANATION.md +190 -0
- package/docs/PERFORMANCE.md +311 -0
- package/docs/PERFORMANCE_MIGRATION_GUIDE.md +368 -0
- package/docs/PERFORMANCE_OPTIMIZATION_PLAN.md +255 -0
- package/docs/QUICK_FILE_LIMITS.md +64 -0
- package/docs/SIMPLIFIED_USAGE_GUIDE.md +208 -0
- package/engines/engine-factory.js +7 -0
- package/engines/heuristic-engine.js +182 -5
- package/package.json +2 -1
- package/rules/common/C048_no_bypass_architectural_layers/analyzer.js +180 -0
- package/rules/common/C048_no_bypass_architectural_layers/config.json +50 -0
- package/rules/common/C048_no_bypass_architectural_layers/symbol-based-analyzer.js +235 -0
- package/rules/common/C052_parsing_or_data_transformation/analyzer.js +180 -0
- package/rules/common/C052_parsing_or_data_transformation/config.json +50 -0
- package/rules/common/C052_parsing_or_data_transformation/symbol-based-analyzer.js +132 -0
- package/rules/index.js +2 -0
- package/rules/security/S017_use_parameterized_queries/README.md +128 -0
- package/rules/security/S017_use_parameterized_queries/analyzer.js +286 -0
- package/rules/security/S017_use_parameterized_queries/config.json +109 -0
- package/rules/security/S017_use_parameterized_queries/regex-based-analyzer.js +541 -0
- package/rules/security/S017_use_parameterized_queries/symbol-based-analyzer.js +777 -0
- package/rules/security/S031_secure_session_cookies/README.md +127 -0
- package/rules/security/S031_secure_session_cookies/analyzer.js +245 -0
- package/rules/security/S031_secure_session_cookies/config.json +86 -0
- package/rules/security/S031_secure_session_cookies/regex-based-analyzer.js +196 -0
- package/rules/security/S031_secure_session_cookies/symbol-based-analyzer.js +1084 -0
- package/rules/security/S032_httponly_session_cookies/FRAMEWORK_SUPPORT.md +209 -0
- package/rules/security/S032_httponly_session_cookies/README.md +184 -0
- package/rules/security/S032_httponly_session_cookies/analyzer.js +282 -0
- package/rules/security/S032_httponly_session_cookies/config.json +96 -0
- package/rules/security/S032_httponly_session_cookies/regex-based-analyzer.js +715 -0
- package/rules/security/S032_httponly_session_cookies/symbol-based-analyzer.js +1348 -0
- package/rules/security/S033_samesite_session_cookies/README.md +227 -0
- package/rules/security/S033_samesite_session_cookies/analyzer.js +242 -0
- package/rules/security/S033_samesite_session_cookies/config.json +87 -0
- package/rules/security/S033_samesite_session_cookies/regex-based-analyzer.js +703 -0
- package/rules/security/S033_samesite_session_cookies/symbol-based-analyzer.js +732 -0
- package/rules/security/S034_host_prefix_session_cookies/README.md +204 -0
- package/rules/security/S034_host_prefix_session_cookies/analyzer.js +290 -0
- package/rules/security/S034_host_prefix_session_cookies/config.json +62 -0
- package/rules/security/S034_host_prefix_session_cookies/regex-based-analyzer.js +478 -0
- package/rules/security/S034_host_prefix_session_cookies/symbol-based-analyzer.js +277 -0
- package/rules/security/S035_path_session_cookies/README.md +257 -0
- package/rules/security/S035_path_session_cookies/analyzer.js +316 -0
- package/rules/security/S035_path_session_cookies/config.json +99 -0
- package/rules/security/S035_path_session_cookies/regex-based-analyzer.js +724 -0
- package/rules/security/S035_path_session_cookies/symbol-based-analyzer.js +373 -0
- package/scripts/batch-processing-demo.js +334 -0
- package/scripts/performance-test.js +541 -0
- package/scripts/quick-performance-test.js +108 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
{
|
|
2
|
+
"id": "S032",
|
|
3
|
+
"name": "Set HttpOnly attribute for Session Cookies",
|
|
4
|
+
"category": "security",
|
|
5
|
+
"description": "S032 - Set HttpOnly attribute for Session Cookies to prevent JavaScript access. This protects against XSS attacks by preventing client-side script access to sensitive cookies.",
|
|
6
|
+
"severity": "error",
|
|
7
|
+
"enabled": true,
|
|
8
|
+
"semantic": {
|
|
9
|
+
"enabled": true,
|
|
10
|
+
"priority": "high",
|
|
11
|
+
"fallback": "heuristic"
|
|
12
|
+
},
|
|
13
|
+
"patterns": {
|
|
14
|
+
"include": ["**/*.js", "**/*.ts", "**/*.jsx", "**/*.tsx"],
|
|
15
|
+
"exclude": [
|
|
16
|
+
"**/*.test.js",
|
|
17
|
+
"**/*.test.ts",
|
|
18
|
+
"**/*.spec.js",
|
|
19
|
+
"**/*.spec.ts",
|
|
20
|
+
"**/node_modules/**",
|
|
21
|
+
"**/dist/**",
|
|
22
|
+
"**/build/**"
|
|
23
|
+
]
|
|
24
|
+
},
|
|
25
|
+
"analysis": {
|
|
26
|
+
"approach": "symbol-based-primary",
|
|
27
|
+
"fallback": "regex-based",
|
|
28
|
+
"depth": 2,
|
|
29
|
+
"timeout": 5000
|
|
30
|
+
},
|
|
31
|
+
"validation": {
|
|
32
|
+
"cookieMethods": [
|
|
33
|
+
"setCookie",
|
|
34
|
+
"cookie",
|
|
35
|
+
"set",
|
|
36
|
+
"append",
|
|
37
|
+
"session",
|
|
38
|
+
"setHeader",
|
|
39
|
+
"writeHead"
|
|
40
|
+
],
|
|
41
|
+
"cookieLibraries": [
|
|
42
|
+
"express",
|
|
43
|
+
"koa",
|
|
44
|
+
"fastify",
|
|
45
|
+
"hapi",
|
|
46
|
+
"next",
|
|
47
|
+
"nuxt",
|
|
48
|
+
"nestjs",
|
|
49
|
+
"@nestjs/common",
|
|
50
|
+
"@nestjs/core",
|
|
51
|
+
"cookie",
|
|
52
|
+
"cookie-parser",
|
|
53
|
+
"express-session",
|
|
54
|
+
"connect-session",
|
|
55
|
+
"passport",
|
|
56
|
+
"next-auth",
|
|
57
|
+
"nuxt-auth",
|
|
58
|
+
"@nuxt/auth",
|
|
59
|
+
"@nuxtjs/auth"
|
|
60
|
+
],
|
|
61
|
+
"sessionIndicators": [
|
|
62
|
+
"session",
|
|
63
|
+
"sessionid",
|
|
64
|
+
"sessid",
|
|
65
|
+
"jsessionid",
|
|
66
|
+
"phpsessid",
|
|
67
|
+
"asp.net_sessionid",
|
|
68
|
+
"connect.sid",
|
|
69
|
+
"auth",
|
|
70
|
+
"token",
|
|
71
|
+
"jwt",
|
|
72
|
+
"csrf",
|
|
73
|
+
"refresh"
|
|
74
|
+
],
|
|
75
|
+
"httpOnlyPatterns": [
|
|
76
|
+
"httpOnly:\\s*true",
|
|
77
|
+
"httpOnly:true",
|
|
78
|
+
"HttpOnly",
|
|
79
|
+
"httpOnly=true"
|
|
80
|
+
],
|
|
81
|
+
"insecurePatterns": [
|
|
82
|
+
"httpOnly:\\s*false",
|
|
83
|
+
"httpOnly:false",
|
|
84
|
+
"httpOnly=false",
|
|
85
|
+
"(?<!httpOnly[\\s=:]+)(?<!HttpOnly[\\s;])Set-Cookie",
|
|
86
|
+
"res\\.cookie\\([^)]*\\)(?![^{]*httpOnly)",
|
|
87
|
+
"document\\.cookie\\s*=",
|
|
88
|
+
"@Res\\(\\).cookie\\([^)]*\\)(?![^{]*httpOnly)",
|
|
89
|
+
"response\\.cookie\\([^)]*\\)(?![^{]*httpOnly)",
|
|
90
|
+
"NextResponse\\.next\\(\\)(?![^{]*httpOnly)",
|
|
91
|
+
"setCookies?\\([^)]*\\)(?![^{]*httpOnly)",
|
|
92
|
+
"useCookie\\([^)]*\\)(?![^{]*httpOnly)",
|
|
93
|
+
"\\$cookies\\.set\\([^)]*\\)(?![^{]*httpOnly)"
|
|
94
|
+
]
|
|
95
|
+
}
|
|
96
|
+
}
|