@j3r3my/scan-orchestrator 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/LICENSE +21 -0
- package/README.md +230 -0
- package/dist/src/adapters/queue/QueueAdapter.d.ts +1 -0
- package/dist/src/adapters/queue/QueueAdapter.d.ts.map +1 -0
- package/dist/src/adapters/queue/QueueAdapter.js +2 -0
- package/dist/src/adapters/queue/QueueAdapter.js.map +1 -0
- package/dist/src/adapters/storage/StorageAdapter.d.ts +1 -0
- package/dist/src/adapters/storage/StorageAdapter.d.ts.map +1 -0
- package/dist/src/adapters/storage/StorageAdapter.js +2 -0
- package/dist/src/adapters/storage/StorageAdapter.js.map +1 -0
- package/dist/src/core/Orchestrator.d.ts +1 -0
- package/dist/src/core/Orchestrator.d.ts.map +1 -0
- package/dist/src/core/Orchestrator.js +2 -0
- package/dist/src/core/Orchestrator.js.map +1 -0
- package/dist/src/core/ScanStateManager.d.ts +1 -0
- package/dist/src/core/ScanStateManager.d.ts.map +1 -0
- package/dist/src/core/ScanStateManager.js +2 -0
- package/dist/src/core/ScanStateManager.js.map +1 -0
- package/dist/src/core/TaskDispatcher.d.ts +1 -0
- package/dist/src/core/TaskDispatcher.d.ts.map +1 -0
- package/dist/src/core/TaskDispatcher.js +2 -0
- package/dist/src/core/TaskDispatcher.js.map +1 -0
- package/dist/src/core/TaskScheduler.d.ts +1 -0
- package/dist/src/core/TaskScheduler.d.ts.map +1 -0
- package/dist/src/core/TaskScheduler.js +2 -0
- package/dist/src/core/TaskScheduler.js.map +1 -0
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +18 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/types/__tests__/attack-payloads.test.d.ts +2 -0
- package/dist/src/types/__tests__/attack-payloads.test.d.ts.map +1 -0
- package/dist/src/types/__tests__/attack-payloads.test.js +116 -0
- package/dist/src/types/__tests__/attack-payloads.test.js.map +1 -0
- package/dist/src/types/__tests__/task-payload.test.d.ts +2 -0
- package/dist/src/types/__tests__/task-payload.test.d.ts.map +1 -0
- package/dist/src/types/__tests__/task-payload.test.js +125 -0
- package/dist/src/types/__tests__/task-payload.test.js.map +1 -0
- package/dist/src/types/__tests__/task-type.failure.d.ts +1 -0
- package/dist/src/types/__tests__/task-type.failure.d.ts.map +1 -0
- package/dist/src/types/__tests__/task-type.failure.js +11 -0
- package/dist/src/types/__tests__/task-type.failure.js.map +1 -0
- package/dist/src/types/__tests__/task-type.test.d.ts +2 -0
- package/dist/src/types/__tests__/task-type.test.d.ts.map +1 -0
- package/dist/src/types/__tests__/task-type.test.js +35 -0
- package/dist/src/types/__tests__/task-type.test.js.map +1 -0
- package/dist/src/types/__tests__/task.failure.d.ts +1 -0
- package/dist/src/types/__tests__/task.failure.d.ts.map +1 -0
- package/dist/src/types/__tests__/task.failure.js +21 -0
- package/dist/src/types/__tests__/task.failure.js.map +1 -0
- package/dist/src/types/__tests__/task.test.d.ts +2 -0
- package/dist/src/types/__tests__/task.test.d.ts.map +1 -0
- package/dist/src/types/__tests__/task.test.js +15 -0
- package/dist/src/types/__tests__/task.test.js.map +1 -0
- package/dist/src/types/analyze/AnalyzeJsPayload.d.ts +8 -0
- package/dist/src/types/analyze/AnalyzeJsPayload.d.ts.map +1 -0
- package/dist/src/types/analyze/AnalyzeJsPayload.js +3 -0
- package/dist/src/types/analyze/AnalyzeJsPayload.js.map +1 -0
- package/dist/src/types/analyze/AnalyzePayload.d.ts +10 -0
- package/dist/src/types/analyze/AnalyzePayload.d.ts.map +1 -0
- package/dist/src/types/analyze/AnalyzePayload.js +3 -0
- package/dist/src/types/analyze/AnalyzePayload.js.map +1 -0
- package/dist/src/types/analyze/index.d.ts +3 -0
- package/dist/src/types/analyze/index.d.ts.map +1 -0
- package/dist/src/types/analyze/index.js +19 -0
- package/dist/src/types/analyze/index.js.map +1 -0
- package/dist/src/types/attack/client/OpenRedirectPayload.d.ts +5 -0
- package/dist/src/types/attack/client/OpenRedirectPayload.d.ts.map +1 -0
- package/dist/src/types/attack/client/OpenRedirectPayload.js +3 -0
- package/dist/src/types/attack/client/OpenRedirectPayload.js.map +1 -0
- package/dist/src/types/attack/client/XssReflectedPayload.d.ts +5 -0
- package/dist/src/types/attack/client/XssReflectedPayload.d.ts.map +1 -0
- package/dist/src/types/attack/client/XssReflectedPayload.js +3 -0
- package/dist/src/types/attack/client/XssReflectedPayload.js.map +1 -0
- package/dist/src/types/attack/client/XssStoredPayload.d.ts +5 -0
- package/dist/src/types/attack/client/XssStoredPayload.d.ts.map +1 -0
- package/dist/src/types/attack/client/XssStoredPayload.js +3 -0
- package/dist/src/types/attack/client/XssStoredPayload.js.map +1 -0
- package/dist/src/types/attack/client/index.d.ts +4 -0
- package/dist/src/types/attack/client/index.d.ts.map +1 -0
- package/dist/src/types/attack/client/index.js +20 -0
- package/dist/src/types/attack/client/index.js.map +1 -0
- package/dist/src/types/attack/common/AttackBasePayload.d.ts +7 -0
- package/dist/src/types/attack/common/AttackBasePayload.d.ts.map +1 -0
- package/dist/src/types/attack/common/AttackBasePayload.js +3 -0
- package/dist/src/types/attack/common/AttackBasePayload.js.map +1 -0
- package/dist/src/types/attack/common/GenericAttackPayload.d.ts +10 -0
- package/dist/src/types/attack/common/GenericAttackPayload.d.ts.map +1 -0
- package/dist/src/types/attack/common/GenericAttackPayload.js +3 -0
- package/dist/src/types/attack/common/GenericAttackPayload.js.map +1 -0
- package/dist/src/types/attack/common/index.d.ts +3 -0
- package/dist/src/types/attack/common/index.d.ts.map +1 -0
- package/dist/src/types/attack/common/index.js +19 -0
- package/dist/src/types/attack/common/index.js.map +1 -0
- package/dist/src/types/attack/index.d.ts +4 -0
- package/dist/src/types/attack/index.d.ts.map +1 -0
- package/dist/src/types/attack/index.js +20 -0
- package/dist/src/types/attack/index.js.map +1 -0
- package/dist/src/types/attack/server/HeadersPayload.d.ts +6 -0
- package/dist/src/types/attack/server/HeadersPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/HeadersPayload.js +3 -0
- package/dist/src/types/attack/server/HeadersPayload.js.map +1 -0
- package/dist/src/types/attack/server/LfiPayload.d.ts +5 -0
- package/dist/src/types/attack/server/LfiPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/LfiPayload.js +3 -0
- package/dist/src/types/attack/server/LfiPayload.js.map +1 -0
- package/dist/src/types/attack/server/OpenRedirectPayload.d.ts +4 -0
- package/dist/src/types/attack/server/OpenRedirectPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/OpenRedirectPayload.js +3 -0
- package/dist/src/types/attack/server/OpenRedirectPayload.js.map +1 -0
- package/dist/src/types/attack/server/PathTraversalPayload.d.ts +6 -0
- package/dist/src/types/attack/server/PathTraversalPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/PathTraversalPayload.js +3 -0
- package/dist/src/types/attack/server/PathTraversalPayload.js.map +1 -0
- package/dist/src/types/attack/server/RcePayload.d.ts +6 -0
- package/dist/src/types/attack/server/RcePayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/RcePayload.js +3 -0
- package/dist/src/types/attack/server/RcePayload.js.map +1 -0
- package/dist/src/types/attack/server/RfiPayload.d.ts +5 -0
- package/dist/src/types/attack/server/RfiPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/RfiPayload.js +3 -0
- package/dist/src/types/attack/server/RfiPayload.js.map +1 -0
- package/dist/src/types/attack/server/SqliBooleanPayload.d.ts +5 -0
- package/dist/src/types/attack/server/SqliBooleanPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/SqliBooleanPayload.js +3 -0
- package/dist/src/types/attack/server/SqliBooleanPayload.js.map +1 -0
- package/dist/src/types/attack/server/SqliErrorPayload.d.ts +5 -0
- package/dist/src/types/attack/server/SqliErrorPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/SqliErrorPayload.js +3 -0
- package/dist/src/types/attack/server/SqliErrorPayload.js.map +1 -0
- package/dist/src/types/attack/server/SqliStackedPayload.d.ts +5 -0
- package/dist/src/types/attack/server/SqliStackedPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/SqliStackedPayload.js +3 -0
- package/dist/src/types/attack/server/SqliStackedPayload.js.map +1 -0
- package/dist/src/types/attack/server/SqliTimePayload.d.ts +5 -0
- package/dist/src/types/attack/server/SqliTimePayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/SqliTimePayload.js +3 -0
- package/dist/src/types/attack/server/SqliTimePayload.js.map +1 -0
- package/dist/src/types/attack/server/SqliUnionPayload.d.ts +5 -0
- package/dist/src/types/attack/server/SqliUnionPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/SqliUnionPayload.js +3 -0
- package/dist/src/types/attack/server/SqliUnionPayload.js.map +1 -0
- package/dist/src/types/attack/server/SsrfPayload.d.ts +9 -0
- package/dist/src/types/attack/server/SsrfPayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/SsrfPayload.js +3 -0
- package/dist/src/types/attack/server/SsrfPayload.js.map +1 -0
- package/dist/src/types/attack/server/XxePayload.d.ts +6 -0
- package/dist/src/types/attack/server/XxePayload.d.ts.map +1 -0
- package/dist/src/types/attack/server/XxePayload.js +3 -0
- package/dist/src/types/attack/server/XxePayload.js.map +1 -0
- package/dist/src/types/attack/server/index.d.ts +10 -0
- package/dist/src/types/attack/server/index.d.ts.map +1 -0
- package/dist/src/types/attack/server/index.js +26 -0
- package/dist/src/types/attack/server/index.js.map +1 -0
- package/dist/src/types/core/Scan.d.ts +26 -0
- package/dist/src/types/core/Scan.d.ts.map +1 -0
- package/dist/src/types/core/Scan.js +3 -0
- package/dist/src/types/core/Scan.js.map +1 -0
- package/dist/src/types/core/SecurityContextPayload.d.ts +10 -0
- package/dist/src/types/core/SecurityContextPayload.d.ts.map +1 -0
- package/dist/src/types/core/SecurityContextPayload.js +3 -0
- package/dist/src/types/core/SecurityContextPayload.js.map +1 -0
- package/dist/src/types/core/Task.d.ts +10 -0
- package/dist/src/types/core/Task.d.ts.map +1 -0
- package/dist/src/types/core/Task.js +3 -0
- package/dist/src/types/core/Task.js.map +1 -0
- package/dist/src/types/core/TaskPayload.d.ts +3 -0
- package/dist/src/types/core/TaskPayload.d.ts.map +1 -0
- package/dist/src/types/core/TaskPayload.js +3 -0
- package/dist/src/types/core/TaskPayload.js.map +1 -0
- package/dist/src/types/core/TaskPayloadMap.d.ts +52 -0
- package/dist/src/types/core/TaskPayloadMap.d.ts.map +1 -0
- package/dist/src/types/core/TaskPayloadMap.js +4 -0
- package/dist/src/types/core/TaskPayloadMap.js.map +1 -0
- package/dist/src/types/core/TaskType.d.ts +27 -0
- package/dist/src/types/core/TaskType.d.ts.map +1 -0
- package/dist/src/types/core/TaskType.js +36 -0
- package/dist/src/types/core/TaskType.js.map +1 -0
- package/dist/src/types/core/WorkerResult.d.ts +18 -0
- package/dist/src/types/core/WorkerResult.d.ts.map +1 -0
- package/dist/src/types/core/WorkerResult.js +3 -0
- package/dist/src/types/core/WorkerResult.js.map +1 -0
- package/dist/src/types/core/index.d.ts +6 -0
- package/dist/src/types/core/index.d.ts.map +1 -0
- package/dist/src/types/core/index.js +22 -0
- package/dist/src/types/core/index.js.map +1 -0
- package/dist/src/types/crawls/CrawlApiPayload.d.ts +6 -0
- package/dist/src/types/crawls/CrawlApiPayload.d.ts.map +1 -0
- package/dist/src/types/crawls/CrawlApiPayload.js +3 -0
- package/dist/src/types/crawls/CrawlApiPayload.js.map +1 -0
- package/dist/src/types/crawls/CrawlAssetsPayload.d.ts +10 -0
- package/dist/src/types/crawls/CrawlAssetsPayload.d.ts.map +1 -0
- package/dist/src/types/crawls/CrawlAssetsPayload.js +3 -0
- package/dist/src/types/crawls/CrawlAssetsPayload.js.map +1 -0
- package/dist/src/types/crawls/CrawlFormPayload.d.ts +9 -0
- package/dist/src/types/crawls/CrawlFormPayload.d.ts.map +1 -0
- package/dist/src/types/crawls/CrawlFormPayload.js +3 -0
- package/dist/src/types/crawls/CrawlFormPayload.js.map +1 -0
- package/dist/src/types/crawls/CrawlPagePayload.d.ts +6 -0
- package/dist/src/types/crawls/CrawlPagePayload.d.ts.map +1 -0
- package/dist/src/types/crawls/CrawlPagePayload.js +3 -0
- package/dist/src/types/crawls/CrawlPagePayload.js.map +1 -0
- package/dist/src/types/crawls/index.d.ts +5 -0
- package/dist/src/types/crawls/index.d.ts.map +1 -0
- package/dist/src/types/crawls/index.js +21 -0
- package/dist/src/types/crawls/index.js.map +1 -0
- package/dist/src/types/index.d.ts +6 -0
- package/dist/src/types/index.d.ts.map +1 -0
- package/dist/src/types/index.js +22 -0
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/types/normalize/NormalizeAssetsPayload.d.ts +5 -0
- package/dist/src/types/normalize/NormalizeAssetsPayload.d.ts.map +1 -0
- package/dist/src/types/normalize/NormalizeAssetsPayload.js +3 -0
- package/dist/src/types/normalize/NormalizeAssetsPayload.js.map +1 -0
- package/dist/src/types/normalize/NormalizeAttackPayload.d.ts +5 -0
- package/dist/src/types/normalize/NormalizeAttackPayload.d.ts.map +1 -0
- package/dist/src/types/normalize/NormalizeAttackPayload.js +3 -0
- package/dist/src/types/normalize/NormalizeAttackPayload.js.map +1 -0
- package/dist/src/types/normalize/NormalizeContextPayload.d.ts +4 -0
- package/dist/src/types/normalize/NormalizeContextPayload.d.ts.map +1 -0
- package/dist/src/types/normalize/NormalizeContextPayload.js +3 -0
- package/dist/src/types/normalize/NormalizeContextPayload.js.map +1 -0
- package/dist/src/types/normalize/index.d.ts +4 -0
- package/dist/src/types/normalize/index.d.ts.map +1 -0
- package/dist/src/types/normalize/index.js +20 -0
- package/dist/src/types/normalize/index.js.map +1 -0
- package/dist/src/workers/analyze/domAnalyze.worker.d.ts +1 -0
- package/dist/src/workers/analyze/domAnalyze.worker.d.ts.map +1 -0
- package/dist/src/workers/analyze/domAnalyze.worker.js +2 -0
- package/dist/src/workers/analyze/domAnalyze.worker.js.map +1 -0
- package/dist/src/workers/analyze/httpAnalyze.worker.d.ts +1 -0
- package/dist/src/workers/analyze/httpAnalyze.worker.d.ts.map +1 -0
- package/dist/src/workers/analyze/httpAnalyze.worker.js +2 -0
- package/dist/src/workers/analyze/httpAnalyze.worker.js.map +1 -0
- package/dist/src/workers/attack/__tests__/headers.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/headers.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/headers.worker.test.js +68 -0
- package/dist/src/workers/attack/__tests__/headers.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/lfi.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/lfi.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/lfi.worker.test.js +65 -0
- package/dist/src/workers/attack/__tests__/lfi.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/openRedirect.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/openRedirect.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/openRedirect.worker.test.js +42 -0
- package/dist/src/workers/attack/__tests__/openRedirect.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/rfi.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/rfi.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/rfi.worker.test.js +75 -0
- package/dist/src/workers/attack/__tests__/rfi.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliBoolean.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/sqliBoolean.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliBoolean.worker.test.js +51 -0
- package/dist/src/workers/attack/__tests__/sqliBoolean.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliError.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/sqliError.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliError.worker.test.js +60 -0
- package/dist/src/workers/attack/__tests__/sqliError.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliStacked.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/sqliStacked.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliStacked.worker.test.js +42 -0
- package/dist/src/workers/attack/__tests__/sqliStacked.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliTime.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/sqliTime.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliTime.worker.test.js +43 -0
- package/dist/src/workers/attack/__tests__/sqliTime.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliUnion.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/sqliUnion.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/sqliUnion.worker.test.js +51 -0
- package/dist/src/workers/attack/__tests__/sqliUnion.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/xssReflected.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/xssReflected.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/xssReflected.worker.test.js +42 -0
- package/dist/src/workers/attack/__tests__/xssReflected.worker.test.js.map +1 -0
- package/dist/src/workers/attack/__tests__/xssStored.worker.test.d.ts +2 -0
- package/dist/src/workers/attack/__tests__/xssStored.worker.test.d.ts.map +1 -0
- package/dist/src/workers/attack/__tests__/xssStored.worker.test.js +33 -0
- package/dist/src/workers/attack/__tests__/xssStored.worker.test.js.map +1 -0
- package/dist/src/workers/attack/headers.worker.d.ts +5 -0
- package/dist/src/workers/attack/headers.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/headers.worker.js +38 -0
- package/dist/src/workers/attack/headers.worker.js.map +1 -0
- package/dist/src/workers/attack/lfi.worker.d.ts +4 -0
- package/dist/src/workers/attack/lfi.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/lfi.worker.js +68 -0
- package/dist/src/workers/attack/lfi.worker.js.map +1 -0
- package/dist/src/workers/attack/openRedirect.worker.d.ts +4 -0
- package/dist/src/workers/attack/openRedirect.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/openRedirect.worker.js +50 -0
- package/dist/src/workers/attack/openRedirect.worker.js.map +1 -0
- package/dist/src/workers/attack/rfi.worker.d.ts +4 -0
- package/dist/src/workers/attack/rfi.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/rfi.worker.js +66 -0
- package/dist/src/workers/attack/rfi.worker.js.map +1 -0
- package/dist/src/workers/attack/sqliBoolean.worker.d.ts +4 -0
- package/dist/src/workers/attack/sqliBoolean.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/sqliBoolean.worker.js +54 -0
- package/dist/src/workers/attack/sqliBoolean.worker.js.map +1 -0
- package/dist/src/workers/attack/sqliError.worker.d.ts +4 -0
- package/dist/src/workers/attack/sqliError.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/sqliError.worker.js +44 -0
- package/dist/src/workers/attack/sqliError.worker.js.map +1 -0
- package/dist/src/workers/attack/sqliStacked.worker.d.ts +4 -0
- package/dist/src/workers/attack/sqliStacked.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/sqliStacked.worker.js +57 -0
- package/dist/src/workers/attack/sqliStacked.worker.js.map +1 -0
- package/dist/src/workers/attack/sqliTime.worker.d.ts +4 -0
- package/dist/src/workers/attack/sqliTime.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/sqliTime.worker.js +31 -0
- package/dist/src/workers/attack/sqliTime.worker.js.map +1 -0
- package/dist/src/workers/attack/sqliUnion.worker.d.ts +4 -0
- package/dist/src/workers/attack/sqliUnion.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/sqliUnion.worker.js +48 -0
- package/dist/src/workers/attack/sqliUnion.worker.js.map +1 -0
- package/dist/src/workers/attack/xssReflected.worker.d.ts +4 -0
- package/dist/src/workers/attack/xssReflected.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/xssReflected.worker.js +52 -0
- package/dist/src/workers/attack/xssReflected.worker.js.map +1 -0
- package/dist/src/workers/attack/xssStored.worker.d.ts +4 -0
- package/dist/src/workers/attack/xssStored.worker.d.ts.map +1 -0
- package/dist/src/workers/attack/xssStored.worker.js +49 -0
- package/dist/src/workers/attack/xssStored.worker.js.map +1 -0
- package/dist/src/workers/crawl/crawlApi.worker.d.ts +1 -0
- package/dist/src/workers/crawl/crawlApi.worker.d.ts.map +1 -0
- package/dist/src/workers/crawl/crawlApi.worker.js +2 -0
- package/dist/src/workers/crawl/crawlApi.worker.js.map +1 -0
- package/dist/src/workers/crawl/crawlAssets.worker.d.ts +1 -0
- package/dist/src/workers/crawl/crawlAssets.worker.d.ts.map +1 -0
- package/dist/src/workers/crawl/crawlAssets.worker.js +2 -0
- package/dist/src/workers/crawl/crawlAssets.worker.js.map +1 -0
- package/dist/src/workers/crawl/crawlForm.worker.d.ts +1 -0
- package/dist/src/workers/crawl/crawlForm.worker.d.ts.map +1 -0
- package/dist/src/workers/crawl/crawlForm.worker.js +2 -0
- package/dist/src/workers/crawl/crawlForm.worker.js.map +1 -0
- package/dist/src/workers/crawl/crawlPage.worker.d.ts +1 -0
- package/dist/src/workers/crawl/crawlPage.worker.d.ts.map +1 -0
- package/dist/src/workers/crawl/crawlPage.worker.js +2 -0
- package/dist/src/workers/crawl/crawlPage.worker.js.map +1 -0
- package/dist/src/workers/normalize/normalizeAttack.worker.d.ts +1 -0
- package/dist/src/workers/normalize/normalizeAttack.worker.d.ts.map +1 -0
- package/dist/src/workers/normalize/normalizeAttack.worker.js +2 -0
- package/dist/src/workers/normalize/normalizeAttack.worker.js.map +1 -0
- package/dist/src/workers/normalize/normalizeContext.worker.d.ts +1 -0
- package/dist/src/workers/normalize/normalizeContext.worker.d.ts.map +1 -0
- package/dist/src/workers/normalize/normalizeContext.worker.js +2 -0
- package/dist/src/workers/normalize/normalizeContext.worker.js.map +1 -0
- package/package.json +33 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const sqliStacked_worker_1 = require("../sqliStacked.worker");
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
describe("sqliStacked.worker", () => {
|
|
6
|
+
const base = {
|
|
7
|
+
url: "https://example.com",
|
|
8
|
+
method: "GET",
|
|
9
|
+
headers: {},
|
|
10
|
+
body: {},
|
|
11
|
+
query: {},
|
|
12
|
+
};
|
|
13
|
+
it("détecte un ; DROP TABLE", async () => {
|
|
14
|
+
const payload = {
|
|
15
|
+
...base,
|
|
16
|
+
query: { q: "1; DROP TABLE users;" },
|
|
17
|
+
response: null,
|
|
18
|
+
};
|
|
19
|
+
const result = await (0, sqliStacked_worker_1.worker)(payload);
|
|
20
|
+
expect(result.findings.length).toBe(1);
|
|
21
|
+
expect(result.findings[0].taskType).toBe(core_1.TaskType.ATTACK_SQLI_STACKED);
|
|
22
|
+
});
|
|
23
|
+
it("détecte un ; SELECT obfusqué", async () => {
|
|
24
|
+
const payload = {
|
|
25
|
+
...base,
|
|
26
|
+
query: { q: "1;%20SELECT%201" },
|
|
27
|
+
response: null,
|
|
28
|
+
};
|
|
29
|
+
const result = await (0, sqliStacked_worker_1.worker)(payload);
|
|
30
|
+
expect(result.findings.length).toBe(1);
|
|
31
|
+
});
|
|
32
|
+
it("ne détecte rien sur une requête normale", async () => {
|
|
33
|
+
const payload = {
|
|
34
|
+
...base,
|
|
35
|
+
query: { q: "hello world" },
|
|
36
|
+
response: null,
|
|
37
|
+
};
|
|
38
|
+
const result = await (0, sqliStacked_worker_1.worker)(payload);
|
|
39
|
+
expect(result.findings.length).toBe(0);
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=sqliStacked.worker.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliStacked.worker.test.js","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/sqliStacked.worker.test.ts"],"names":[],"mappings":";;AAAA,8DAA+C;AAE/C,uCAAwC;AAExC,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,MAAM,IAAI,GAAqC;QAC7C,GAAG,EAAE,qBAAqB;QAC1B,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACvC,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,sBAAsB,EAAE;YACpC,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,2BAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,eAAQ,CAAC,mBAAmB,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,iBAAiB,EAAE;YAC/B,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,2BAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,aAAa,EAAE;YAC3B,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,2BAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliTime.worker.test.d.ts","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/sqliTime.worker.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const sqliTime_worker_1 = require("../sqliTime.worker");
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
describe("sqliTime.worker", () => {
|
|
6
|
+
const base = {
|
|
7
|
+
url: "https://example.com",
|
|
8
|
+
method: "GET",
|
|
9
|
+
headers: {},
|
|
10
|
+
body: {},
|
|
11
|
+
query: {},
|
|
12
|
+
};
|
|
13
|
+
it("détecte un délai anormal (SQLi Time-Based)", async () => {
|
|
14
|
+
const payload = {
|
|
15
|
+
...base,
|
|
16
|
+
response: null,
|
|
17
|
+
responseTime: 3500,
|
|
18
|
+
baselineTime: 200,
|
|
19
|
+
};
|
|
20
|
+
const result = await (0, sqliTime_worker_1.worker)(payload);
|
|
21
|
+
expect(result.findings.length).toBe(1);
|
|
22
|
+
expect(result.findings[0].taskType).toBe(core_1.TaskType.ATTACK_SQLI_TIME);
|
|
23
|
+
});
|
|
24
|
+
it("ne détecte rien si le délai est normal", async () => {
|
|
25
|
+
const payload = {
|
|
26
|
+
...base,
|
|
27
|
+
response: null,
|
|
28
|
+
responseTime: 150,
|
|
29
|
+
baselineTime: 100,
|
|
30
|
+
};
|
|
31
|
+
const result = await (0, sqliTime_worker_1.worker)(payload);
|
|
32
|
+
expect(result.findings.length).toBe(0);
|
|
33
|
+
});
|
|
34
|
+
it("ne détecte rien si responseTime est absent", async () => {
|
|
35
|
+
const payload = {
|
|
36
|
+
...base,
|
|
37
|
+
response: null,
|
|
38
|
+
};
|
|
39
|
+
const result = await (0, sqliTime_worker_1.worker)(payload);
|
|
40
|
+
expect(result.findings.length).toBe(0);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=sqliTime.worker.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliTime.worker.test.js","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/sqliTime.worker.test.ts"],"names":[],"mappings":";;AAAA,wDAA4C;AAE5C,uCAAwC;AAExC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,MAAM,IAAI,GAAqC;QAC7C,GAAG,EAAE,qBAAqB;QAC1B,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,QAAQ,EAAE,IAAI;YACd,YAAY,EAAE,IAAI;YAClB,YAAY,EAAE,GAAG;SACX,CAAC;QAET,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,eAAQ,CAAC,gBAAgB,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,QAAQ,EAAE,IAAI;YACd,YAAY,EAAE,GAAG;YACjB,YAAY,EAAE,GAAG;SACX,CAAC;QAET,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,QAAQ,EAAE,IAAI;SACR,CAAC;QAET,MAAM,MAAM,GAAG,MAAM,IAAA,wBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliUnion.worker.test.d.ts","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/sqliUnion.worker.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const sqliUnion_worker_1 = require("../sqliUnion.worker");
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
describe("sqliUnion.worker", () => {
|
|
6
|
+
const base = {
|
|
7
|
+
url: "https://example.com",
|
|
8
|
+
method: "GET",
|
|
9
|
+
headers: {},
|
|
10
|
+
body: {},
|
|
11
|
+
query: {},
|
|
12
|
+
};
|
|
13
|
+
it("détecte un UNION SELECT classique", async () => {
|
|
14
|
+
const payload = {
|
|
15
|
+
...base,
|
|
16
|
+
query: { q: "UNION SELECT username, password FROM users" },
|
|
17
|
+
response: null,
|
|
18
|
+
};
|
|
19
|
+
const result = await (0, sqliUnion_worker_1.worker)(payload);
|
|
20
|
+
expect(result.findings.length).toBe(1);
|
|
21
|
+
expect(result.findings[0].taskType).toBe(core_1.TaskType.ATTACK_SQLI_UNION);
|
|
22
|
+
});
|
|
23
|
+
it("détecte un UNION SELECT obfusqué", async () => {
|
|
24
|
+
const payload = {
|
|
25
|
+
...base,
|
|
26
|
+
query: { q: "UNION/**/SELECT 1,2" },
|
|
27
|
+
response: null,
|
|
28
|
+
};
|
|
29
|
+
const result = await (0, sqliUnion_worker_1.worker)(payload);
|
|
30
|
+
expect(result.findings.length).toBe(1);
|
|
31
|
+
});
|
|
32
|
+
it("détecte un UNION SELECT encodé", async () => {
|
|
33
|
+
const payload = {
|
|
34
|
+
...base,
|
|
35
|
+
query: { q: "UNION%20SELECT%201,2" },
|
|
36
|
+
response: null,
|
|
37
|
+
};
|
|
38
|
+
const result = await (0, sqliUnion_worker_1.worker)(payload);
|
|
39
|
+
expect(result.findings.length).toBe(1);
|
|
40
|
+
});
|
|
41
|
+
it("ne détecte rien si aucun pattern n'est présent", async () => {
|
|
42
|
+
const payload = {
|
|
43
|
+
...base,
|
|
44
|
+
query: { q: "hello world" },
|
|
45
|
+
response: null,
|
|
46
|
+
};
|
|
47
|
+
const result = await (0, sqliUnion_worker_1.worker)(payload);
|
|
48
|
+
expect(result.findings.length).toBe(0);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
//# sourceMappingURL=sqliUnion.worker.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliUnion.worker.test.js","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/sqliUnion.worker.test.ts"],"names":[],"mappings":";;AAAA,0DAA6C;AAE7C,uCAAwC;AAExC,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,MAAM,IAAI,GAAqC;QAC7C,GAAG,EAAE,qBAAqB;QAC1B,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,EAAE,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,4CAA4C,EAAE;YAC1D,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,yBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,eAAQ,CAAC,iBAAiB,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,qBAAqB,EAAE;YACnC,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,yBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,sBAAsB,EAAE;YACpC,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,yBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC9D,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,aAAa,EAAE;YAC3B,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,yBAAM,EAAC,OAAO,CAAC,CAAC;QAErC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xssReflected.worker.test.d.ts","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/xssReflected.worker.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const xssReflected_worker_1 = require("../xssReflected.worker");
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
describe("xssReflected.worker", () => {
|
|
6
|
+
const base = {
|
|
7
|
+
url: "https://example.com",
|
|
8
|
+
method: "GET",
|
|
9
|
+
headers: {},
|
|
10
|
+
body: {},
|
|
11
|
+
query: {},
|
|
12
|
+
};
|
|
13
|
+
it("détecte un <script>alert(1)</script>", async () => {
|
|
14
|
+
const payload = {
|
|
15
|
+
...base,
|
|
16
|
+
query: { q: "<script>alert(1)</script>" },
|
|
17
|
+
response: null,
|
|
18
|
+
};
|
|
19
|
+
const result = await (0, xssReflected_worker_1.worker)(payload);
|
|
20
|
+
expect(result.findings.length).toBe(1);
|
|
21
|
+
expect(result.findings[0].taskType).toBe(core_1.TaskType.ATTACK_XSS_REFLECTED);
|
|
22
|
+
});
|
|
23
|
+
it("détecte un XSS via onerror", async () => {
|
|
24
|
+
const payload = {
|
|
25
|
+
...base,
|
|
26
|
+
query: { q: "<img src=x onerror=alert(1)>" },
|
|
27
|
+
response: null,
|
|
28
|
+
};
|
|
29
|
+
const result = await (0, xssReflected_worker_1.worker)(payload);
|
|
30
|
+
expect(result.findings.length).toBe(1);
|
|
31
|
+
});
|
|
32
|
+
it("ne détecte rien sur une valeur safe", async () => {
|
|
33
|
+
const payload = {
|
|
34
|
+
...base,
|
|
35
|
+
query: { q: "hello world" },
|
|
36
|
+
response: null,
|
|
37
|
+
};
|
|
38
|
+
const result = await (0, xssReflected_worker_1.worker)(payload);
|
|
39
|
+
expect(result.findings.length).toBe(0);
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=xssReflected.worker.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xssReflected.worker.test.js","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/xssReflected.worker.test.ts"],"names":[],"mappings":";;AAAA,gEAAgD;AAEhD,uCAAwC;AAExC,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,MAAM,IAAI,GAAqC;QAC7C,GAAG,EAAE,qBAAqB;QAC1B,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,2BAA2B,EAAE;YACzC,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,eAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAC1C,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,8BAA8B,EAAE;YAC5C,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;QACnD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,EAAE,CAAC,EAAE,aAAa,EAAE;YAC3B,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xssStored.worker.test.d.ts","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/xssStored.worker.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const xssStored_worker_1 = require("../xssStored.worker");
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
describe("xssStored.worker", () => {
|
|
6
|
+
const base = {
|
|
7
|
+
url: "https://example.com",
|
|
8
|
+
method: "POST",
|
|
9
|
+
headers: {},
|
|
10
|
+
body: {},
|
|
11
|
+
query: {},
|
|
12
|
+
};
|
|
13
|
+
it("détecte un XSS stocké", async () => {
|
|
14
|
+
const payload = {
|
|
15
|
+
...base,
|
|
16
|
+
body: { comment: "<script>alert(1)</script>" },
|
|
17
|
+
response: null,
|
|
18
|
+
};
|
|
19
|
+
const result = await (0, xssStored_worker_1.worker)(payload);
|
|
20
|
+
expect(result.findings.length).toBe(1);
|
|
21
|
+
expect(result.findings[0].taskType).toBe(core_1.TaskType.ATTACK_XSS_STORED);
|
|
22
|
+
});
|
|
23
|
+
it("ne détecte rien sur un contenu safe", async () => {
|
|
24
|
+
const payload = {
|
|
25
|
+
...base,
|
|
26
|
+
body: { comment: "Nice article!" },
|
|
27
|
+
response: null,
|
|
28
|
+
};
|
|
29
|
+
const result = await (0, xssStored_worker_1.worker)(payload);
|
|
30
|
+
expect(result.findings.length).toBe(0);
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=xssStored.worker.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"xssStored.worker.test.js","sourceRoot":"","sources":["../../../../../src/workers/attack/__tests__/xssStored.worker.test.ts"],"names":[],"mappings":";;AAAA,0DAA6C;AAE7C,uCAAwC;AAExC,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,MAAM,IAAI,GAAqC;QAC7C,GAAG,EAAE,qBAAqB;QAC1B,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,EAAE,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;QACrC,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,IAAI,EAAE,EAAE,OAAO,EAAE,2BAA2B,EAAE;YAC9C,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,yBAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,eAAQ,CAAC,iBAAiB,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;QACnD,MAAM,OAAO,GAAmB;YAC9B,GAAG,IAAI;YACP,IAAI,EAAE,EAAE,OAAO,EAAE,eAAe,EAAE;YAClC,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,yBAAM,EAAC,OAAO,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,QAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { TaskPayloadMap } from "@/types/core";
|
|
2
|
+
import { WorkerResult } from "@/types/core";
|
|
3
|
+
import { TaskType } from "@/types/core";
|
|
4
|
+
export declare function worker(payload: TaskPayloadMap[TaskType.ATTACK_HEADERS]): Promise<WorkerResult>;
|
|
5
|
+
//# sourceMappingURL=headers.worker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"headers.worker.d.ts","sourceRoot":"","sources":["../../../../src/workers/attack/headers.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAiB,YAAY,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC,wBAAsB,MAAM,CAC1B,OAAO,EAAE,cAAc,CAAC,QAAQ,CAAC,cAAc,CAAC,GAC/C,OAAO,CAAC,YAAY,CAAC,CAuCvB"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.worker = worker;
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
async function worker(payload) {
|
|
6
|
+
const { url, method, headers } = payload;
|
|
7
|
+
const findings = [];
|
|
8
|
+
if (!headers["content-security-policy"]) {
|
|
9
|
+
findings.push({
|
|
10
|
+
message: "Missing Content-Security-Policy header",
|
|
11
|
+
severity: "medium",
|
|
12
|
+
taskType: core_1.TaskType.ATTACK_HEADERS,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
if (headers["x-powered-by"]) {
|
|
16
|
+
findings.push({
|
|
17
|
+
message: `Leaking technology via X-Powered-By: ${headers["x-powered-by"]}`,
|
|
18
|
+
severity: "low",
|
|
19
|
+
taskType: core_1.TaskType.ATTACK_HEADERS,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
if (headers["server"]) {
|
|
23
|
+
findings.push({
|
|
24
|
+
message: `Server header exposed: ${headers["server"]}`,
|
|
25
|
+
severity: "low",
|
|
26
|
+
taskType: core_1.TaskType.ATTACK_HEADERS,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
taskType: core_1.TaskType.ATTACK_HEADERS,
|
|
31
|
+
status: "success",
|
|
32
|
+
output: {
|
|
33
|
+
analyzedHeaders: Object.keys(headers),
|
|
34
|
+
},
|
|
35
|
+
findings,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=headers.worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"headers.worker.js","sourceRoot":"","sources":["../../../../src/workers/attack/headers.worker.ts"],"names":[],"mappings":";;AAIA,wBAyCC;AA3CD,uCAAwC;AAEjC,KAAK,UAAU,MAAM,CAC1B,OAAgD;IAEhD,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAEzC,MAAM,QAAQ,GAAoB,EAAE,CAAC;IAErC,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAC,EAAE,CAAC;QACxC,QAAQ,CAAC,IAAI,CAAC;YACZ,OAAO,EAAE,wCAAwC;YACjD,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,eAAQ,CAAC,cAAc;SAClC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC;QAC5B,QAAQ,CAAC,IAAI,CAAC;YACZ,OAAO,EAAE,wCAAwC,OAAO,CAAC,cAAc,CAAC,EAAE;YAC1E,QAAQ,EAAE,KAAK;YACf,QAAQ,EAAE,eAAQ,CAAC,cAAc;SAClC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QACtB,QAAQ,CAAC,IAAI,CAAC;YACZ,OAAO,EAAE,0BAA0B,OAAO,CAAC,QAAQ,CAAC,EAAE;YACtD,QAAQ,EAAE,KAAK;YACf,QAAQ,EAAE,eAAQ,CAAC,cAAc;SAClC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,eAAQ,CAAC,cAAc;QACjC,MAAM,EAAE,SAAS;QAEjB,MAAM,EAAE;YACN,eAAe,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;SACtC;QAED,QAAQ;KACT,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lfi.worker.d.ts","sourceRoot":"","sources":["../../../../src/workers/attack/lfi.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,YAAY,EAAY,MAAM,cAAc,CAAC;AAErE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAoBjD,wBAAsB,MAAM,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,CAAC,CAoD3E"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.worker = worker;
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
const LFI_PATTERNS = [
|
|
6
|
+
/\.\.\/\.\.\//i, // ../../
|
|
7
|
+
/\.\.\//i, // ../
|
|
8
|
+
/\/etc\/passwd/i,
|
|
9
|
+
/\/etc\/shadow/i,
|
|
10
|
+
/windows\/win\.ini/i,
|
|
11
|
+
/php:\/\/filter/i,
|
|
12
|
+
/file:\/\//i,
|
|
13
|
+
];
|
|
14
|
+
function detectLfi(value) {
|
|
15
|
+
if (!value)
|
|
16
|
+
return false;
|
|
17
|
+
const str = String(value);
|
|
18
|
+
return LFI_PATTERNS.some((regex) => regex.test(str));
|
|
19
|
+
}
|
|
20
|
+
async function worker(payload) {
|
|
21
|
+
const findings = [];
|
|
22
|
+
const { url, method, headers, body, query } = payload;
|
|
23
|
+
// 1. Scan query parameters
|
|
24
|
+
for (const [key, val] of Object.entries(query ?? {})) {
|
|
25
|
+
if (detectLfi(val)) {
|
|
26
|
+
findings.push({
|
|
27
|
+
message: `Possible LFI detected in query parameter "${key}"`,
|
|
28
|
+
severity: "high",
|
|
29
|
+
taskType: core_1.TaskType.ATTACK_LFI,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// 2. Scan body
|
|
34
|
+
for (const [key, val] of Object.entries(body ?? {})) {
|
|
35
|
+
if (detectLfi(val)) {
|
|
36
|
+
findings.push({
|
|
37
|
+
message: `Possible LFI detected in body field "${key}"`,
|
|
38
|
+
severity: "high",
|
|
39
|
+
taskType: core_1.TaskType.ATTACK_LFI,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
// 3. Scan headers
|
|
44
|
+
for (const [key, val] of Object.entries(headers ?? {})) {
|
|
45
|
+
if (detectLfi(val)) {
|
|
46
|
+
findings.push({
|
|
47
|
+
message: `Possible LFI detected in header "${key}"`,
|
|
48
|
+
severity: "medium",
|
|
49
|
+
taskType: core_1.TaskType.ATTACK_LFI,
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return {
|
|
54
|
+
taskType: core_1.TaskType.ATTACK_LFI,
|
|
55
|
+
status: "success",
|
|
56
|
+
findings,
|
|
57
|
+
output: {
|
|
58
|
+
url,
|
|
59
|
+
method,
|
|
60
|
+
scannedFields: {
|
|
61
|
+
query: Object.keys(query ?? {}),
|
|
62
|
+
body: Object.keys(body ?? {}),
|
|
63
|
+
headers: Object.keys(headers ?? {}),
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=lfi.worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lfi.worker.js","sourceRoot":"","sources":["../../../../src/workers/attack/lfi.worker.ts"],"names":[],"mappings":";;AAsBA,wBAoDC;AA1ED,uCAAqE;AAIrE,MAAM,YAAY,GAAG;IACnB,eAAe,EAAE,SAAS;IAC1B,SAAS,EAAE,MAAM;IACjB,gBAAgB;IAChB,gBAAgB;IAChB,oBAAoB;IACpB,iBAAiB;IACjB,YAAY;CACb,CAAC;AAEF,SAAS,SAAS,CAAC,KAAc;IAC/B,IAAI,CAAC,KAAK;QAAE,OAAO,KAAK,CAAC;IAEzB,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAE1B,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AACvD,CAAC;AAEM,KAAK,UAAU,MAAM,CAAC,OAAuB;IAClD,MAAM,QAAQ,GAAoB,EAAE,CAAC;IAErC,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAEtD,2BAA2B;IAC3B,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,CAAC;QACrD,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,6CAA6C,GAAG,GAAG;gBAC5D,QAAQ,EAAE,MAAM;gBAChB,QAAQ,EAAE,eAAQ,CAAC,UAAU;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,eAAe;IACf,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE,CAAC;QACpD,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,wCAAwC,GAAG,GAAG;gBACvD,QAAQ,EAAE,MAAM;gBAChB,QAAQ,EAAE,eAAQ,CAAC,UAAU;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,kBAAkB;IAClB,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC;QACvD,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,oCAAoC,GAAG,GAAG;gBACnD,QAAQ,EAAE,QAAQ;gBAClB,QAAQ,EAAE,eAAQ,CAAC,UAAU;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,eAAQ,CAAC,UAAU;QAC7B,MAAM,EAAE,SAAS;QACjB,QAAQ;QACR,MAAM,EAAE;YACN,GAAG;YACH,MAAM;YACN,aAAa,EAAE;gBACb,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC;gBAC/B,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;gBAC7B,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;aACpC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openRedirect.worker.d.ts","sourceRoot":"","sources":["../../../../src/workers/attack/openRedirect.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAA2B,YAAY,EAAE,MAAM,cAAc,CAAC;AA0BrE,wBAAsB,MAAM,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,CAAC,CA4B3E"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.worker = worker;
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
const REDIRECT_KEYS = ["redirect", "next", "url", "continue", "return", "goto"];
|
|
6
|
+
const EVIL_PATTERNS = [
|
|
7
|
+
/^https?:\/\//i,
|
|
8
|
+
/^\/\//i,
|
|
9
|
+
/%2f%2f/i,
|
|
10
|
+
/%68%74%74%70%3a%2f%2f/i, // http:// encodé
|
|
11
|
+
];
|
|
12
|
+
function normalize(value) {
|
|
13
|
+
if (!value)
|
|
14
|
+
return "";
|
|
15
|
+
try {
|
|
16
|
+
return decodeURIComponent(String(value)).toLowerCase();
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
return String(value).toLowerCase();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
function detectOpenRedirect(key, value) {
|
|
23
|
+
const val = normalize(value);
|
|
24
|
+
if (!REDIRECT_KEYS.includes(key.toLowerCase()))
|
|
25
|
+
return false;
|
|
26
|
+
return EVIL_PATTERNS.some((regex) => regex.test(val));
|
|
27
|
+
}
|
|
28
|
+
async function worker(payload) {
|
|
29
|
+
const findings = [];
|
|
30
|
+
const { query } = payload;
|
|
31
|
+
const entries = Object.entries(query ?? {});
|
|
32
|
+
const hasRedirect = entries.some(([key, value]) => detectOpenRedirect(key, value));
|
|
33
|
+
if (hasRedirect) {
|
|
34
|
+
findings.push({
|
|
35
|
+
message: "Possible Open Redirect detected in request parameters",
|
|
36
|
+
severity: "high",
|
|
37
|
+
taskType: core_1.TaskType.ATTACK_OPEN_REDIRECT,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return {
|
|
41
|
+
taskType: core_1.TaskType.ATTACK_OPEN_REDIRECT,
|
|
42
|
+
status: "success",
|
|
43
|
+
findings,
|
|
44
|
+
output: {
|
|
45
|
+
scannedParams: entries.length,
|
|
46
|
+
detected: hasRedirect,
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=openRedirect.worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openRedirect.worker.js","sourceRoot":"","sources":["../../../../src/workers/attack/openRedirect.worker.ts"],"names":[],"mappings":";;AA2BA,wBA4BC;AAtDD,uCAAqE;AAErE,MAAM,aAAa,GAAG,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;AAEhF,MAAM,aAAa,GAAG;IACpB,eAAe;IACf,QAAQ;IACR,SAAS;IACT,wBAAwB,EAAE,iBAAiB;CAC5C,CAAC;AAEF,SAAS,SAAS,CAAC,KAAc;IAC/B,IAAI,CAAC,KAAK;QAAE,OAAO,EAAE,CAAC;IACtB,IAAI,CAAC;QACH,OAAO,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;IACzD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IACrC,CAAC;AACH,CAAC;AAED,SAAS,kBAAkB,CAAC,GAAW,EAAE,KAAc;IACrD,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QAAE,OAAO,KAAK,CAAC;IAC7D,OAAO,aAAa,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AACxD,CAAC;AAEM,KAAK,UAAU,MAAM,CAAC,OAAuB;IAClD,MAAM,QAAQ,GAAoB,EAAE,CAAC;IAErC,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAE1B,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;IAE5C,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAChD,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAC/B,CAAC;IAEF,IAAI,WAAW,EAAE,CAAC;QAChB,QAAQ,CAAC,IAAI,CAAC;YACZ,OAAO,EAAE,uDAAuD;YAChE,QAAQ,EAAE,MAAM;YAChB,QAAQ,EAAE,eAAQ,CAAC,oBAAoB;SACxC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,eAAQ,CAAC,oBAAoB;QACvC,MAAM,EAAE,SAAS;QACjB,QAAQ;QACR,MAAM,EAAE;YACN,aAAa,EAAE,OAAO,CAAC,MAAM;YAC7B,QAAQ,EAAE,WAAW;SACtB;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rfi.worker.d.ts","sourceRoot":"","sources":["../../../../src/workers/attack/rfi.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAA2B,YAAY,EAAE,MAAM,cAAc,CAAC;AAgBrE,wBAAsB,MAAM,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,CAAC,CAoD3E"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.worker = worker;
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
const RFI_PATTERNS = [
|
|
6
|
+
/^https?:\/\//i,
|
|
7
|
+
/^ftp:\/\//i,
|
|
8
|
+
/^smb:\/\//i,
|
|
9
|
+
/^php:\/\/input/i,
|
|
10
|
+
/^data:\/\//i,
|
|
11
|
+
];
|
|
12
|
+
function detectRfi(value) {
|
|
13
|
+
if (!value)
|
|
14
|
+
return false;
|
|
15
|
+
const str = String(value);
|
|
16
|
+
return RFI_PATTERNS.some((regex) => regex.test(str));
|
|
17
|
+
}
|
|
18
|
+
async function worker(payload) {
|
|
19
|
+
const findings = [];
|
|
20
|
+
const { url, method, headers, body, query } = payload;
|
|
21
|
+
// 1. Query parameters
|
|
22
|
+
for (const [key, val] of Object.entries(query ?? {})) {
|
|
23
|
+
if (detectRfi(val)) {
|
|
24
|
+
findings.push({
|
|
25
|
+
message: `Possible RFI detected in query parameter "${key}"`,
|
|
26
|
+
severity: "critical",
|
|
27
|
+
taskType: core_1.TaskType.ATTACK_RFI,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
// 2. Body fields
|
|
32
|
+
for (const [key, val] of Object.entries(body ?? {})) {
|
|
33
|
+
if (detectRfi(val)) {
|
|
34
|
+
findings.push({
|
|
35
|
+
message: `Possible RFI detected in body field "${key}"`,
|
|
36
|
+
severity: "critical",
|
|
37
|
+
taskType: core_1.TaskType.ATTACK_RFI,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
// 3. Headers
|
|
42
|
+
for (const [key, val] of Object.entries(headers ?? {})) {
|
|
43
|
+
if (detectRfi(val)) {
|
|
44
|
+
findings.push({
|
|
45
|
+
message: `Possible RFI detected in header "${key}"`,
|
|
46
|
+
severity: "high",
|
|
47
|
+
taskType: core_1.TaskType.ATTACK_RFI,
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
taskType: core_1.TaskType.ATTACK_RFI,
|
|
53
|
+
status: "success",
|
|
54
|
+
findings,
|
|
55
|
+
output: {
|
|
56
|
+
url,
|
|
57
|
+
method,
|
|
58
|
+
scannedFields: {
|
|
59
|
+
query: Object.keys(query ?? {}),
|
|
60
|
+
body: Object.keys(body ?? {}),
|
|
61
|
+
headers: Object.keys(headers ?? {}),
|
|
62
|
+
},
|
|
63
|
+
},
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=rfi.worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rfi.worker.js","sourceRoot":"","sources":["../../../../src/workers/attack/rfi.worker.ts"],"names":[],"mappings":";;AAiBA,wBAoDC;AApED,uCAAqE;AAErE,MAAM,YAAY,GAAG;IACnB,eAAe;IACf,YAAY;IACZ,YAAY;IACZ,iBAAiB;IACjB,aAAa;CACd,CAAC;AAEF,SAAS,SAAS,CAAC,KAAc;IAC/B,IAAI,CAAC,KAAK;QAAE,OAAO,KAAK,CAAC;IACzB,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAC1B,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AACvD,CAAC;AAEM,KAAK,UAAU,MAAM,CAAC,OAAuB;IAClD,MAAM,QAAQ,GAAoB,EAAE,CAAC;IAErC,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAEtD,sBAAsB;IACtB,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,CAAC;QACrD,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,6CAA6C,GAAG,GAAG;gBAC5D,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE,eAAQ,CAAC,UAAU;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,iBAAiB;IACjB,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE,CAAC;QACpD,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,wCAAwC,GAAG,GAAG;gBACvD,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE,eAAQ,CAAC,UAAU;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,aAAa;IACb,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC;QACvD,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,OAAO,EAAE,oCAAoC,GAAG,GAAG;gBACnD,QAAQ,EAAE,MAAM;gBAChB,QAAQ,EAAE,eAAQ,CAAC,UAAU;aAC9B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,eAAQ,CAAC,UAAU;QAC7B,MAAM,EAAE,SAAS;QACjB,QAAQ;QACR,MAAM,EAAE;YACN,GAAG;YACH,MAAM;YACN,aAAa,EAAE;gBACb,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC;gBAC/B,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;gBAC7B,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;aACpC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliBoolean.worker.d.ts","sourceRoot":"","sources":["../../../../src/workers/attack/sqliBoolean.worker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAA2B,YAAY,EAAE,MAAM,cAAc,CAAC;AA0BrE,wBAAsB,MAAM,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,CAAC,CA+B3E"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.worker = worker;
|
|
4
|
+
const core_1 = require("@/types/core");
|
|
5
|
+
const BOOLEAN_PATTERNS = [
|
|
6
|
+
/'\s*or\s*'1'\s*=\s*'1/i,
|
|
7
|
+
/"\s*or\s*"1"\s*=\s*"1/i,
|
|
8
|
+
/\sor\s1=1/i,
|
|
9
|
+
/\sand\s1=1/i,
|
|
10
|
+
/\sand\s1=2/i,
|
|
11
|
+
/\sor\s'[^']*'\s*=\s*'[^']*'/i,
|
|
12
|
+
/\sor\strue--/i,
|
|
13
|
+
];
|
|
14
|
+
function normalize(value) {
|
|
15
|
+
if (!value)
|
|
16
|
+
return "";
|
|
17
|
+
try {
|
|
18
|
+
return decodeURIComponent(String(value)).toLowerCase();
|
|
19
|
+
}
|
|
20
|
+
catch {
|
|
21
|
+
return String(value).toLowerCase();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
function detectBooleanSqli(value) {
|
|
25
|
+
const str = normalize(value);
|
|
26
|
+
return BOOLEAN_PATTERNS.some((regex) => regex.test(str));
|
|
27
|
+
}
|
|
28
|
+
async function worker(payload) {
|
|
29
|
+
const findings = [];
|
|
30
|
+
const { query, body, headers } = payload;
|
|
31
|
+
const allValues = [
|
|
32
|
+
...Object.values(query ?? {}),
|
|
33
|
+
...Object.values(body ?? {}),
|
|
34
|
+
...Object.values(headers ?? {}),
|
|
35
|
+
];
|
|
36
|
+
const hasBoolean = allValues.some((v) => detectBooleanSqli(v));
|
|
37
|
+
if (hasBoolean) {
|
|
38
|
+
findings.push({
|
|
39
|
+
message: "Possible SQL Injection (Boolean-Based) detected in request parameters",
|
|
40
|
+
severity: "critical",
|
|
41
|
+
taskType: core_1.TaskType.ATTACK_SQLI_BOOLEAN,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
return {
|
|
45
|
+
taskType: core_1.TaskType.ATTACK_SQLI_BOOLEAN,
|
|
46
|
+
status: "success",
|
|
47
|
+
findings,
|
|
48
|
+
output: {
|
|
49
|
+
scannedValues: allValues.length,
|
|
50
|
+
detected: hasBoolean,
|
|
51
|
+
},
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=sqliBoolean.worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqliBoolean.worker.js","sourceRoot":"","sources":["../../../../src/workers/attack/sqliBoolean.worker.ts"],"names":[],"mappings":";;AA2BA,wBA+BC;AAzDD,uCAAqE;AAErE,MAAM,gBAAgB,GAAG;IACvB,wBAAwB;IACxB,wBAAwB;IACxB,YAAY;IACZ,aAAa;IACb,aAAa;IACb,8BAA8B;IAC9B,eAAe;CAChB,CAAC;AAEF,SAAS,SAAS,CAAC,KAAc;IAC/B,IAAI,CAAC,KAAK;QAAE,OAAO,EAAE,CAAC;IACtB,IAAI,CAAC;QACH,OAAO,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;IACzD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IACrC,CAAC;AACH,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAc;IACvC,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IAC7B,OAAO,gBAAgB,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC3D,CAAC;AAEM,KAAK,UAAU,MAAM,CAAC,OAAuB;IAClD,MAAM,QAAQ,GAAoB,EAAE,CAAC;IAErC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAEzC,MAAM,SAAS,GAAG;QAChB,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC;QAC7B,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QAC5B,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC;KAChC,CAAC;IAEF,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;IAE/D,IAAI,UAAU,EAAE,CAAC;QACf,QAAQ,CAAC,IAAI,CAAC;YACZ,OAAO,EACL,uEAAuE;YACzE,QAAQ,EAAE,UAAU;YACpB,QAAQ,EAAE,eAAQ,CAAC,mBAAmB;SACvC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,eAAQ,CAAC,mBAAmB;QACtC,MAAM,EAAE,SAAS;QACjB,QAAQ;QACR,MAAM,EAAE;YACN,aAAa,EAAE,SAAS,CAAC,MAAM;YAC/B,QAAQ,EAAE,UAAU;SACrB;KACF,CAAC;AACJ,CAAC"}
|