driftdetect-detectors 0.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.
Files changed (509) hide show
  1. package/dist/accessibility/alt-text.d.ts +63 -0
  2. package/dist/accessibility/alt-text.d.ts.map +1 -0
  3. package/dist/accessibility/alt-text.js +100 -0
  4. package/dist/accessibility/alt-text.js.map +1 -0
  5. package/dist/accessibility/aria-roles.d.ts +65 -0
  6. package/dist/accessibility/aria-roles.d.ts.map +1 -0
  7. package/dist/accessibility/aria-roles.js +87 -0
  8. package/dist/accessibility/aria-roles.js.map +1 -0
  9. package/dist/accessibility/focus-management.d.ts +62 -0
  10. package/dist/accessibility/focus-management.d.ts.map +1 -0
  11. package/dist/accessibility/focus-management.js +88 -0
  12. package/dist/accessibility/focus-management.js.map +1 -0
  13. package/dist/accessibility/heading-hierarchy.d.ts +66 -0
  14. package/dist/accessibility/heading-hierarchy.d.ts.map +1 -0
  15. package/dist/accessibility/heading-hierarchy.js +94 -0
  16. package/dist/accessibility/heading-hierarchy.js.map +1 -0
  17. package/dist/accessibility/index.d.ts +25 -0
  18. package/dist/accessibility/index.d.ts.map +1 -0
  19. package/dist/accessibility/index.js +21 -0
  20. package/dist/accessibility/index.js.map +1 -0
  21. package/dist/accessibility/keyboard-nav.d.ts +63 -0
  22. package/dist/accessibility/keyboard-nav.d.ts.map +1 -0
  23. package/dist/accessibility/keyboard-nav.js +86 -0
  24. package/dist/accessibility/keyboard-nav.js.map +1 -0
  25. package/dist/accessibility/semantic-html.d.ts +76 -0
  26. package/dist/accessibility/semantic-html.d.ts.map +1 -0
  27. package/dist/accessibility/semantic-html.js +204 -0
  28. package/dist/accessibility/semantic-html.js.map +1 -0
  29. package/dist/api/client-patterns.d.ts +121 -0
  30. package/dist/api/client-patterns.d.ts.map +1 -0
  31. package/dist/api/client-patterns.js +478 -0
  32. package/dist/api/client-patterns.js.map +1 -0
  33. package/dist/api/error-format.d.ts +140 -0
  34. package/dist/api/error-format.d.ts.map +1 -0
  35. package/dist/api/error-format.js +614 -0
  36. package/dist/api/error-format.js.map +1 -0
  37. package/dist/api/http-methods.d.ts +255 -0
  38. package/dist/api/http-methods.d.ts.map +1 -0
  39. package/dist/api/http-methods.js +890 -0
  40. package/dist/api/http-methods.js.map +1 -0
  41. package/dist/api/index.d.ts +16 -0
  42. package/dist/api/index.d.ts.map +1 -0
  43. package/dist/api/index.js +37 -0
  44. package/dist/api/index.js.map +1 -0
  45. package/dist/api/pagination.d.ts +133 -0
  46. package/dist/api/pagination.d.ts.map +1 -0
  47. package/dist/api/pagination.js +521 -0
  48. package/dist/api/pagination.js.map +1 -0
  49. package/dist/api/response-envelope.d.ts +261 -0
  50. package/dist/api/response-envelope.d.ts.map +1 -0
  51. package/dist/api/response-envelope.js +1050 -0
  52. package/dist/api/response-envelope.js.map +1 -0
  53. package/dist/api/retry-patterns.d.ts +117 -0
  54. package/dist/api/retry-patterns.d.ts.map +1 -0
  55. package/dist/api/retry-patterns.js +480 -0
  56. package/dist/api/retry-patterns.js.map +1 -0
  57. package/dist/api/route-structure.d.ts +128 -0
  58. package/dist/api/route-structure.d.ts.map +1 -0
  59. package/dist/api/route-structure.js +738 -0
  60. package/dist/api/route-structure.js.map +1 -0
  61. package/dist/auth/audit-logging.d.ts +80 -0
  62. package/dist/auth/audit-logging.d.ts.map +1 -0
  63. package/dist/auth/audit-logging.js +370 -0
  64. package/dist/auth/audit-logging.js.map +1 -0
  65. package/dist/auth/index.d.ts +33 -0
  66. package/dist/auth/index.d.ts.map +1 -0
  67. package/dist/auth/index.js +49 -0
  68. package/dist/auth/index.js.map +1 -0
  69. package/dist/auth/middleware-usage.d.ts +65 -0
  70. package/dist/auth/middleware-usage.d.ts.map +1 -0
  71. package/dist/auth/middleware-usage.js +192 -0
  72. package/dist/auth/middleware-usage.js.map +1 -0
  73. package/dist/auth/permission-checks.d.ts +60 -0
  74. package/dist/auth/permission-checks.d.ts.map +1 -0
  75. package/dist/auth/permission-checks.js +159 -0
  76. package/dist/auth/permission-checks.js.map +1 -0
  77. package/dist/auth/rbac-patterns.d.ts +68 -0
  78. package/dist/auth/rbac-patterns.d.ts.map +1 -0
  79. package/dist/auth/rbac-patterns.js +143 -0
  80. package/dist/auth/rbac-patterns.js.map +1 -0
  81. package/dist/auth/resource-ownership.d.ts +77 -0
  82. package/dist/auth/resource-ownership.d.ts.map +1 -0
  83. package/dist/auth/resource-ownership.js +324 -0
  84. package/dist/auth/resource-ownership.js.map +1 -0
  85. package/dist/auth/token-handling.d.ts +64 -0
  86. package/dist/auth/token-handling.d.ts.map +1 -0
  87. package/dist/auth/token-handling.js +151 -0
  88. package/dist/auth/token-handling.js.map +1 -0
  89. package/dist/base/ast-detector.d.ts +421 -0
  90. package/dist/base/ast-detector.d.ts.map +1 -0
  91. package/dist/base/ast-detector.js +699 -0
  92. package/dist/base/ast-detector.js.map +1 -0
  93. package/dist/base/base-detector.d.ts +366 -0
  94. package/dist/base/base-detector.d.ts.map +1 -0
  95. package/dist/base/base-detector.js +170 -0
  96. package/dist/base/base-detector.js.map +1 -0
  97. package/dist/base/index.d.ts +12 -0
  98. package/dist/base/index.d.ts.map +1 -0
  99. package/dist/base/index.js +17 -0
  100. package/dist/base/index.js.map +1 -0
  101. package/dist/base/regex-detector.d.ts +421 -0
  102. package/dist/base/regex-detector.d.ts.map +1 -0
  103. package/dist/base/regex-detector.js +537 -0
  104. package/dist/base/regex-detector.js.map +1 -0
  105. package/dist/base/structural-detector.d.ts +424 -0
  106. package/dist/base/structural-detector.d.ts.map +1 -0
  107. package/dist/base/structural-detector.js +731 -0
  108. package/dist/base/structural-detector.js.map +1 -0
  109. package/dist/base/types.d.ts +53 -0
  110. package/dist/base/types.d.ts.map +1 -0
  111. package/dist/base/types.js +5 -0
  112. package/dist/base/types.js.map +1 -0
  113. package/dist/components/component-structure.d.ts +163 -0
  114. package/dist/components/component-structure.d.ts.map +1 -0
  115. package/dist/components/component-structure.js +500 -0
  116. package/dist/components/component-structure.js.map +1 -0
  117. package/dist/components/composition.d.ts +287 -0
  118. package/dist/components/composition.d.ts.map +1 -0
  119. package/dist/components/composition.js +1123 -0
  120. package/dist/components/composition.js.map +1 -0
  121. package/dist/components/duplicate-detection.d.ts +251 -0
  122. package/dist/components/duplicate-detection.d.ts.map +1 -0
  123. package/dist/components/duplicate-detection.js +804 -0
  124. package/dist/components/duplicate-detection.js.map +1 -0
  125. package/dist/components/index.d.ts +16 -0
  126. package/dist/components/index.d.ts.map +1 -0
  127. package/dist/components/index.js +51 -0
  128. package/dist/components/index.js.map +1 -0
  129. package/dist/components/near-duplicate.d.ts +402 -0
  130. package/dist/components/near-duplicate.d.ts.map +1 -0
  131. package/dist/components/near-duplicate.js +1090 -0
  132. package/dist/components/near-duplicate.js.map +1 -0
  133. package/dist/components/props-patterns.d.ts +194 -0
  134. package/dist/components/props-patterns.d.ts.map +1 -0
  135. package/dist/components/props-patterns.js +795 -0
  136. package/dist/components/props-patterns.js.map +1 -0
  137. package/dist/components/ref-forwarding.d.ts +250 -0
  138. package/dist/components/ref-forwarding.d.ts.map +1 -0
  139. package/dist/components/ref-forwarding.js +832 -0
  140. package/dist/components/ref-forwarding.js.map +1 -0
  141. package/dist/components/state-patterns.d.ts +291 -0
  142. package/dist/components/state-patterns.d.ts.map +1 -0
  143. package/dist/components/state-patterns.js +970 -0
  144. package/dist/components/state-patterns.js.map +1 -0
  145. package/dist/config/config-validation.d.ts +74 -0
  146. package/dist/config/config-validation.d.ts.map +1 -0
  147. package/dist/config/config-validation.js +446 -0
  148. package/dist/config/config-validation.js.map +1 -0
  149. package/dist/config/default-values.d.ts +72 -0
  150. package/dist/config/default-values.d.ts.map +1 -0
  151. package/dist/config/default-values.js +386 -0
  152. package/dist/config/default-values.js.map +1 -0
  153. package/dist/config/env-naming.d.ts +73 -0
  154. package/dist/config/env-naming.d.ts.map +1 -0
  155. package/dist/config/env-naming.js +429 -0
  156. package/dist/config/env-naming.js.map +1 -0
  157. package/dist/config/environment-detection.d.ts +72 -0
  158. package/dist/config/environment-detection.d.ts.map +1 -0
  159. package/dist/config/environment-detection.js +400 -0
  160. package/dist/config/environment-detection.js.map +1 -0
  161. package/dist/config/feature-flags.d.ts +72 -0
  162. package/dist/config/feature-flags.d.ts.map +1 -0
  163. package/dist/config/feature-flags.js +384 -0
  164. package/dist/config/feature-flags.js.map +1 -0
  165. package/dist/config/index.d.ts +27 -0
  166. package/dist/config/index.d.ts.map +1 -0
  167. package/dist/config/index.js +43 -0
  168. package/dist/config/index.js.map +1 -0
  169. package/dist/config/required-optional.d.ts +71 -0
  170. package/dist/config/required-optional.d.ts.map +1 -0
  171. package/dist/config/required-optional.js +344 -0
  172. package/dist/config/required-optional.js.map +1 -0
  173. package/dist/data-access/connection-pooling.d.ts +63 -0
  174. package/dist/data-access/connection-pooling.d.ts.map +1 -0
  175. package/dist/data-access/connection-pooling.js +297 -0
  176. package/dist/data-access/connection-pooling.js.map +1 -0
  177. package/dist/data-access/dto-patterns.d.ts +64 -0
  178. package/dist/data-access/dto-patterns.d.ts.map +1 -0
  179. package/dist/data-access/dto-patterns.js +291 -0
  180. package/dist/data-access/dto-patterns.js.map +1 -0
  181. package/dist/data-access/index.d.ts +31 -0
  182. package/dist/data-access/index.d.ts.map +1 -0
  183. package/dist/data-access/index.js +49 -0
  184. package/dist/data-access/index.js.map +1 -0
  185. package/dist/data-access/n-plus-one.d.ts +60 -0
  186. package/dist/data-access/n-plus-one.d.ts.map +1 -0
  187. package/dist/data-access/n-plus-one.js +264 -0
  188. package/dist/data-access/n-plus-one.js.map +1 -0
  189. package/dist/data-access/query-patterns.d.ts +64 -0
  190. package/dist/data-access/query-patterns.d.ts.map +1 -0
  191. package/dist/data-access/query-patterns.js +314 -0
  192. package/dist/data-access/query-patterns.js.map +1 -0
  193. package/dist/data-access/repository-pattern.d.ts +62 -0
  194. package/dist/data-access/repository-pattern.d.ts.map +1 -0
  195. package/dist/data-access/repository-pattern.js +257 -0
  196. package/dist/data-access/repository-pattern.js.map +1 -0
  197. package/dist/data-access/transaction-patterns.d.ts +61 -0
  198. package/dist/data-access/transaction-patterns.d.ts.map +1 -0
  199. package/dist/data-access/transaction-patterns.js +277 -0
  200. package/dist/data-access/transaction-patterns.js.map +1 -0
  201. package/dist/data-access/validation-patterns.d.ts +62 -0
  202. package/dist/data-access/validation-patterns.d.ts.map +1 -0
  203. package/dist/data-access/validation-patterns.js +301 -0
  204. package/dist/data-access/validation-patterns.js.map +1 -0
  205. package/dist/documentation/deprecation.d.ts +62 -0
  206. package/dist/documentation/deprecation.d.ts.map +1 -0
  207. package/dist/documentation/deprecation.js +83 -0
  208. package/dist/documentation/deprecation.js.map +1 -0
  209. package/dist/documentation/example-code.d.ts +64 -0
  210. package/dist/documentation/example-code.d.ts.map +1 -0
  211. package/dist/documentation/example-code.js +79 -0
  212. package/dist/documentation/example-code.js.map +1 -0
  213. package/dist/documentation/index.d.ts +22 -0
  214. package/dist/documentation/index.d.ts.map +1 -0
  215. package/dist/documentation/index.js +19 -0
  216. package/dist/documentation/index.js.map +1 -0
  217. package/dist/documentation/jsdoc-patterns.d.ts +72 -0
  218. package/dist/documentation/jsdoc-patterns.d.ts.map +1 -0
  219. package/dist/documentation/jsdoc-patterns.js +92 -0
  220. package/dist/documentation/jsdoc-patterns.js.map +1 -0
  221. package/dist/documentation/readme-structure.d.ts +67 -0
  222. package/dist/documentation/readme-structure.d.ts.map +1 -0
  223. package/dist/documentation/readme-structure.js +76 -0
  224. package/dist/documentation/readme-structure.js.map +1 -0
  225. package/dist/documentation/todo-patterns.d.ts +67 -0
  226. package/dist/documentation/todo-patterns.d.ts.map +1 -0
  227. package/dist/documentation/todo-patterns.js +73 -0
  228. package/dist/documentation/todo-patterns.js.map +1 -0
  229. package/dist/errors/async-errors.d.ts +72 -0
  230. package/dist/errors/async-errors.d.ts.map +1 -0
  231. package/dist/errors/async-errors.js +214 -0
  232. package/dist/errors/async-errors.js.map +1 -0
  233. package/dist/errors/circuit-breaker.d.ts +53 -0
  234. package/dist/errors/circuit-breaker.d.ts.map +1 -0
  235. package/dist/errors/circuit-breaker.js +241 -0
  236. package/dist/errors/circuit-breaker.js.map +1 -0
  237. package/dist/errors/error-codes.d.ts +73 -0
  238. package/dist/errors/error-codes.d.ts.map +1 -0
  239. package/dist/errors/error-codes.js +211 -0
  240. package/dist/errors/error-codes.js.map +1 -0
  241. package/dist/errors/error-logging.d.ts +73 -0
  242. package/dist/errors/error-logging.d.ts.map +1 -0
  243. package/dist/errors/error-logging.js +256 -0
  244. package/dist/errors/error-logging.js.map +1 -0
  245. package/dist/errors/error-propagation.d.ts +73 -0
  246. package/dist/errors/error-propagation.d.ts.map +1 -0
  247. package/dist/errors/error-propagation.js +244 -0
  248. package/dist/errors/error-propagation.js.map +1 -0
  249. package/dist/errors/exception-hierarchy.d.ts +75 -0
  250. package/dist/errors/exception-hierarchy.d.ts.map +1 -0
  251. package/dist/errors/exception-hierarchy.js +259 -0
  252. package/dist/errors/exception-hierarchy.js.map +1 -0
  253. package/dist/errors/index.d.ts +31 -0
  254. package/dist/errors/index.d.ts.map +1 -0
  255. package/dist/errors/index.js +49 -0
  256. package/dist/errors/index.js.map +1 -0
  257. package/dist/errors/try-catch-placement.d.ts +73 -0
  258. package/dist/errors/try-catch-placement.d.ts.map +1 -0
  259. package/dist/errors/try-catch-placement.js +214 -0
  260. package/dist/errors/try-catch-placement.js.map +1 -0
  261. package/dist/index.d.ts +221 -0
  262. package/dist/index.d.ts.map +1 -0
  263. package/dist/index.js +245 -0
  264. package/dist/index.js.map +1 -0
  265. package/dist/logging/context-fields.d.ts +48 -0
  266. package/dist/logging/context-fields.d.ts.map +1 -0
  267. package/dist/logging/context-fields.js +160 -0
  268. package/dist/logging/context-fields.js.map +1 -0
  269. package/dist/logging/correlation-ids.d.ts +44 -0
  270. package/dist/logging/correlation-ids.d.ts.map +1 -0
  271. package/dist/logging/correlation-ids.js +144 -0
  272. package/dist/logging/correlation-ids.js.map +1 -0
  273. package/dist/logging/health-checks.d.ts +45 -0
  274. package/dist/logging/health-checks.d.ts.map +1 -0
  275. package/dist/logging/health-checks.js +165 -0
  276. package/dist/logging/health-checks.js.map +1 -0
  277. package/dist/logging/index.d.ts +31 -0
  278. package/dist/logging/index.d.ts.map +1 -0
  279. package/dist/logging/index.js +49 -0
  280. package/dist/logging/index.js.map +1 -0
  281. package/dist/logging/log-levels.d.ts +46 -0
  282. package/dist/logging/log-levels.d.ts.map +1 -0
  283. package/dist/logging/log-levels.js +178 -0
  284. package/dist/logging/log-levels.js.map +1 -0
  285. package/dist/logging/metric-naming.d.ts +46 -0
  286. package/dist/logging/metric-naming.d.ts.map +1 -0
  287. package/dist/logging/metric-naming.js +157 -0
  288. package/dist/logging/metric-naming.js.map +1 -0
  289. package/dist/logging/pii-redaction.d.ts +44 -0
  290. package/dist/logging/pii-redaction.d.ts.map +1 -0
  291. package/dist/logging/pii-redaction.js +166 -0
  292. package/dist/logging/pii-redaction.js.map +1 -0
  293. package/dist/logging/structured-format.d.ts +53 -0
  294. package/dist/logging/structured-format.d.ts.map +1 -0
  295. package/dist/logging/structured-format.js +235 -0
  296. package/dist/logging/structured-format.js.map +1 -0
  297. package/dist/performance/bundle-size.d.ts +79 -0
  298. package/dist/performance/bundle-size.d.ts.map +1 -0
  299. package/dist/performance/bundle-size.js +276 -0
  300. package/dist/performance/bundle-size.js.map +1 -0
  301. package/dist/performance/caching-patterns.d.ts +78 -0
  302. package/dist/performance/caching-patterns.d.ts.map +1 -0
  303. package/dist/performance/caching-patterns.js +257 -0
  304. package/dist/performance/caching-patterns.js.map +1 -0
  305. package/dist/performance/code-splitting.d.ts +86 -0
  306. package/dist/performance/code-splitting.d.ts.map +1 -0
  307. package/dist/performance/code-splitting.js +447 -0
  308. package/dist/performance/code-splitting.js.map +1 -0
  309. package/dist/performance/debounce-throttle.d.ts +75 -0
  310. package/dist/performance/debounce-throttle.d.ts.map +1 -0
  311. package/dist/performance/debounce-throttle.js +232 -0
  312. package/dist/performance/debounce-throttle.js.map +1 -0
  313. package/dist/performance/index.d.ts +28 -0
  314. package/dist/performance/index.d.ts.map +1 -0
  315. package/dist/performance/index.js +39 -0
  316. package/dist/performance/index.js.map +1 -0
  317. package/dist/performance/lazy-loading.d.ts +75 -0
  318. package/dist/performance/lazy-loading.d.ts.map +1 -0
  319. package/dist/performance/lazy-loading.js +233 -0
  320. package/dist/performance/lazy-loading.js.map +1 -0
  321. package/dist/performance/memoization.d.ts +75 -0
  322. package/dist/performance/memoization.d.ts.map +1 -0
  323. package/dist/performance/memoization.js +251 -0
  324. package/dist/performance/memoization.js.map +1 -0
  325. package/dist/registry/detector-registry.d.ts +266 -0
  326. package/dist/registry/detector-registry.d.ts.map +1 -0
  327. package/dist/registry/detector-registry.js +526 -0
  328. package/dist/registry/detector-registry.js.map +1 -0
  329. package/dist/registry/index.d.ts +10 -0
  330. package/dist/registry/index.d.ts.map +1 -0
  331. package/dist/registry/index.js +10 -0
  332. package/dist/registry/index.js.map +1 -0
  333. package/dist/registry/loader.d.ts +232 -0
  334. package/dist/registry/loader.d.ts.map +1 -0
  335. package/dist/registry/loader.js +419 -0
  336. package/dist/registry/loader.js.map +1 -0
  337. package/dist/registry/types.d.ts +111 -0
  338. package/dist/registry/types.d.ts.map +1 -0
  339. package/dist/registry/types.js +19 -0
  340. package/dist/registry/types.js.map +1 -0
  341. package/dist/security/csp-headers.d.ts +78 -0
  342. package/dist/security/csp-headers.d.ts.map +1 -0
  343. package/dist/security/csp-headers.js +401 -0
  344. package/dist/security/csp-headers.js.map +1 -0
  345. package/dist/security/csrf-protection.d.ts +72 -0
  346. package/dist/security/csrf-protection.d.ts.map +1 -0
  347. package/dist/security/csrf-protection.js +344 -0
  348. package/dist/security/csrf-protection.js.map +1 -0
  349. package/dist/security/index.d.ts +30 -0
  350. package/dist/security/index.d.ts.map +1 -0
  351. package/dist/security/index.js +48 -0
  352. package/dist/security/index.js.map +1 -0
  353. package/dist/security/input-sanitization.d.ts +74 -0
  354. package/dist/security/input-sanitization.d.ts.map +1 -0
  355. package/dist/security/input-sanitization.js +373 -0
  356. package/dist/security/input-sanitization.js.map +1 -0
  357. package/dist/security/rate-limiting.d.ts +81 -0
  358. package/dist/security/rate-limiting.d.ts.map +1 -0
  359. package/dist/security/rate-limiting.js +535 -0
  360. package/dist/security/rate-limiting.js.map +1 -0
  361. package/dist/security/secret-management.d.ts +83 -0
  362. package/dist/security/secret-management.d.ts.map +1 -0
  363. package/dist/security/secret-management.js +547 -0
  364. package/dist/security/secret-management.js.map +1 -0
  365. package/dist/security/sql-injection.d.ts +76 -0
  366. package/dist/security/sql-injection.d.ts.map +1 -0
  367. package/dist/security/sql-injection.js +383 -0
  368. package/dist/security/sql-injection.js.map +1 -0
  369. package/dist/security/xss-prevention.d.ts +80 -0
  370. package/dist/security/xss-prevention.d.ts.map +1 -0
  371. package/dist/security/xss-prevention.js +416 -0
  372. package/dist/security/xss-prevention.js.map +1 -0
  373. package/dist/structural/barrel-exports.d.ts +178 -0
  374. package/dist/structural/barrel-exports.d.ts.map +1 -0
  375. package/dist/structural/barrel-exports.js +553 -0
  376. package/dist/structural/barrel-exports.js.map +1 -0
  377. package/dist/structural/circular-deps.d.ts +140 -0
  378. package/dist/structural/circular-deps.d.ts.map +1 -0
  379. package/dist/structural/circular-deps.js +422 -0
  380. package/dist/structural/circular-deps.js.map +1 -0
  381. package/dist/structural/co-location.d.ts +202 -0
  382. package/dist/structural/co-location.d.ts.map +1 -0
  383. package/dist/structural/co-location.js +640 -0
  384. package/dist/structural/co-location.js.map +1 -0
  385. package/dist/structural/directory-structure.d.ts +151 -0
  386. package/dist/structural/directory-structure.d.ts.map +1 -0
  387. package/dist/structural/directory-structure.js +457 -0
  388. package/dist/structural/directory-structure.js.map +1 -0
  389. package/dist/structural/file-naming.d.ts +61 -0
  390. package/dist/structural/file-naming.d.ts.map +1 -0
  391. package/dist/structural/file-naming.js +231 -0
  392. package/dist/structural/file-naming.js.map +1 -0
  393. package/dist/structural/import-ordering.d.ts +212 -0
  394. package/dist/structural/import-ordering.d.ts.map +1 -0
  395. package/dist/structural/import-ordering.js +821 -0
  396. package/dist/structural/import-ordering.js.map +1 -0
  397. package/dist/structural/index.d.ts +23 -0
  398. package/dist/structural/index.d.ts.map +1 -0
  399. package/dist/structural/index.js +26 -0
  400. package/dist/structural/index.js.map +1 -0
  401. package/dist/structural/module-boundaries.d.ts +164 -0
  402. package/dist/structural/module-boundaries.d.ts.map +1 -0
  403. package/dist/structural/module-boundaries.js +616 -0
  404. package/dist/structural/module-boundaries.js.map +1 -0
  405. package/dist/structural/package-boundaries.d.ts +182 -0
  406. package/dist/structural/package-boundaries.d.ts.map +1 -0
  407. package/dist/structural/package-boundaries.js +602 -0
  408. package/dist/structural/package-boundaries.js.map +1 -0
  409. package/dist/styling/class-naming.d.ts +263 -0
  410. package/dist/styling/class-naming.d.ts.map +1 -0
  411. package/dist/styling/class-naming.js +892 -0
  412. package/dist/styling/class-naming.js.map +1 -0
  413. package/dist/styling/color-usage.d.ts +213 -0
  414. package/dist/styling/color-usage.d.ts.map +1 -0
  415. package/dist/styling/color-usage.js +732 -0
  416. package/dist/styling/color-usage.js.map +1 -0
  417. package/dist/styling/design-tokens.d.ts +212 -0
  418. package/dist/styling/design-tokens.d.ts.map +1 -0
  419. package/dist/styling/design-tokens.js +748 -0
  420. package/dist/styling/design-tokens.js.map +1 -0
  421. package/dist/styling/index.d.ts +16 -0
  422. package/dist/styling/index.d.ts.map +1 -0
  423. package/dist/styling/index.js +56 -0
  424. package/dist/styling/index.js.map +1 -0
  425. package/dist/styling/responsive.d.ts +304 -0
  426. package/dist/styling/responsive.d.ts.map +1 -0
  427. package/dist/styling/responsive.js +888 -0
  428. package/dist/styling/responsive.js.map +1 -0
  429. package/dist/styling/spacing-scale.d.ts +248 -0
  430. package/dist/styling/spacing-scale.d.ts.map +1 -0
  431. package/dist/styling/spacing-scale.js +865 -0
  432. package/dist/styling/spacing-scale.js.map +1 -0
  433. package/dist/styling/tailwind-patterns.d.ts +305 -0
  434. package/dist/styling/tailwind-patterns.d.ts.map +1 -0
  435. package/dist/styling/tailwind-patterns.js +1181 -0
  436. package/dist/styling/tailwind-patterns.js.map +1 -0
  437. package/dist/styling/typography.d.ts +281 -0
  438. package/dist/styling/typography.d.ts.map +1 -0
  439. package/dist/styling/typography.js +1004 -0
  440. package/dist/styling/typography.js.map +1 -0
  441. package/dist/styling/z-index-scale.d.ts +270 -0
  442. package/dist/styling/z-index-scale.d.ts.map +1 -0
  443. package/dist/styling/z-index-scale.js +714 -0
  444. package/dist/styling/z-index-scale.js.map +1 -0
  445. package/dist/testing/co-location.d.ts +42 -0
  446. package/dist/testing/co-location.d.ts.map +1 -0
  447. package/dist/testing/co-location.js +134 -0
  448. package/dist/testing/co-location.js.map +1 -0
  449. package/dist/testing/describe-naming.d.ts +47 -0
  450. package/dist/testing/describe-naming.d.ts.map +1 -0
  451. package/dist/testing/describe-naming.js +150 -0
  452. package/dist/testing/describe-naming.js.map +1 -0
  453. package/dist/testing/file-naming.d.ts +44 -0
  454. package/dist/testing/file-naming.d.ts.map +1 -0
  455. package/dist/testing/file-naming.js +131 -0
  456. package/dist/testing/file-naming.js.map +1 -0
  457. package/dist/testing/fixture-patterns.d.ts +52 -0
  458. package/dist/testing/fixture-patterns.d.ts.map +1 -0
  459. package/dist/testing/fixture-patterns.js +228 -0
  460. package/dist/testing/fixture-patterns.js.map +1 -0
  461. package/dist/testing/index.d.ts +31 -0
  462. package/dist/testing/index.d.ts.map +1 -0
  463. package/dist/testing/index.js +49 -0
  464. package/dist/testing/index.js.map +1 -0
  465. package/dist/testing/mock-patterns.d.ts +53 -0
  466. package/dist/testing/mock-patterns.d.ts.map +1 -0
  467. package/dist/testing/mock-patterns.js +264 -0
  468. package/dist/testing/mock-patterns.js.map +1 -0
  469. package/dist/testing/setup-teardown.d.ts +55 -0
  470. package/dist/testing/setup-teardown.d.ts.map +1 -0
  471. package/dist/testing/setup-teardown.js +262 -0
  472. package/dist/testing/setup-teardown.js.map +1 -0
  473. package/dist/testing/test-structure.d.ts +51 -0
  474. package/dist/testing/test-structure.d.ts.map +1 -0
  475. package/dist/testing/test-structure.js +225 -0
  476. package/dist/testing/test-structure.js.map +1 -0
  477. package/dist/types/any-usage.d.ts +99 -0
  478. package/dist/types/any-usage.d.ts.map +1 -0
  479. package/dist/types/any-usage.js +641 -0
  480. package/dist/types/any-usage.js.map +1 -0
  481. package/dist/types/file-location.d.ts +76 -0
  482. package/dist/types/file-location.d.ts.map +1 -0
  483. package/dist/types/file-location.js +395 -0
  484. package/dist/types/file-location.js.map +1 -0
  485. package/dist/types/generic-patterns.d.ts +97 -0
  486. package/dist/types/generic-patterns.d.ts.map +1 -0
  487. package/dist/types/generic-patterns.js +615 -0
  488. package/dist/types/generic-patterns.js.map +1 -0
  489. package/dist/types/index.d.ts +31 -0
  490. package/dist/types/index.d.ts.map +1 -0
  491. package/dist/types/index.js +43 -0
  492. package/dist/types/index.js.map +1 -0
  493. package/dist/types/interface-vs-type.d.ts +81 -0
  494. package/dist/types/interface-vs-type.d.ts.map +1 -0
  495. package/dist/types/interface-vs-type.js +440 -0
  496. package/dist/types/interface-vs-type.js.map +1 -0
  497. package/dist/types/naming-conventions.d.ts +84 -0
  498. package/dist/types/naming-conventions.d.ts.map +1 -0
  499. package/dist/types/naming-conventions.js +455 -0
  500. package/dist/types/naming-conventions.js.map +1 -0
  501. package/dist/types/type-assertions.d.ts +98 -0
  502. package/dist/types/type-assertions.d.ts.map +1 -0
  503. package/dist/types/type-assertions.js +639 -0
  504. package/dist/types/type-assertions.js.map +1 -0
  505. package/dist/types/utility-types.d.ts +110 -0
  506. package/dist/types/utility-types.d.ts.map +1 -0
  507. package/dist/types/utility-types.js +547 -0
  508. package/dist/types/utility-types.js.map +1 -0
  509. package/package.json +44 -0
@@ -0,0 +1,547 @@
1
+ /**
2
+ * Secret Management Detector - Secret and credential handling pattern detection
3
+ *
4
+ * Detects secret management patterns including:
5
+ * - Hardcoded secrets and credentials
6
+ * - Environment variable usage
7
+ * - Secret manager integrations
8
+ * - API key patterns
9
+ * - Credential rotation patterns
10
+ *
11
+ * @requirements 16.6 - Secret management patterns
12
+ */
13
+ import { RegexDetector } from '../base/regex-detector.js';
14
+ // ============================================================================
15
+ // Constants
16
+ // ============================================================================
17
+ export const ENV_VARIABLE_PATTERNS = [
18
+ /process\.env\.[A-Z_][A-Z0-9_]*/gi,
19
+ /process\.env\[['"`][A-Z_][A-Z0-9_]*['"`]\]/gi,
20
+ /import\.meta\.env\.[A-Z_][A-Z0-9_]*/gi,
21
+ /Deno\.env\.get\s*\(\s*['"`][A-Z_][A-Z0-9_]*['"`]\s*\)/gi,
22
+ /os\.environ\[['"`][A-Z_][A-Z0-9_]*['"`]\]/gi,
23
+ /os\.getenv\s*\(\s*['"`][A-Z_][A-Z0-9_]*['"`]\s*\)/gi,
24
+ /ENV\[['"`][A-Z_][A-Z0-9_]*['"`]\]/gi,
25
+ /\$\{[A-Z_][A-Z0-9_]*\}/gi,
26
+ ];
27
+ export const SECRET_MANAGER_PATTERNS = [
28
+ /SecretsManager/gi,
29
+ /SecretManagerServiceClient/gi,
30
+ /getSecretValue/gi,
31
+ /secretsmanager/gi,
32
+ /aws-sdk.*secrets/gi,
33
+ /@aws-sdk\/client-secrets-manager/gi,
34
+ /google-cloud.*secret/gi,
35
+ /azure.*keyvault/gi,
36
+ /KeyVaultClient/gi,
37
+ /SecretClient/gi,
38
+ ];
39
+ export const VAULT_PATTERNS = [
40
+ /hashicorp.*vault/gi,
41
+ /vault\.read/gi,
42
+ /vault\.write/gi,
43
+ /VaultClient/gi,
44
+ /hvac\./gi,
45
+ /vault-client/gi,
46
+ /node-vault/gi,
47
+ /VAULT_ADDR/gi,
48
+ /VAULT_TOKEN/gi,
49
+ ];
50
+ export const KEY_ROTATION_PATTERNS = [
51
+ /rotateSecret/gi,
52
+ /keyRotation/gi,
53
+ /rotate.*key/gi,
54
+ /key.*rotation/gi,
55
+ /credential.*rotation/gi,
56
+ /rotate.*credential/gi,
57
+ /refreshToken/gi,
58
+ /renewToken/gi,
59
+ ];
60
+ export const CREDENTIAL_STORE_PATTERNS = [
61
+ /CredentialStore/gi,
62
+ /KeychainAccess/gi,
63
+ /SecureStorage/gi,
64
+ /EncryptedSharedPreferences/gi,
65
+ /keytar/gi,
66
+ /node-keytar/gi,
67
+ /credential-manager/gi,
68
+ /windows-credential/gi,
69
+ ];
70
+ export const CONFIG_ENCRYPTION_PATTERNS = [
71
+ /encryptConfig/gi,
72
+ /decryptConfig/gi,
73
+ /sealed.*secret/gi,
74
+ /SealedSecret/gi,
75
+ /sops/gi,
76
+ /age.*encrypt/gi,
77
+ /gpg.*encrypt/gi,
78
+ /kms.*encrypt/gi,
79
+ ];
80
+ // Hardcoded secret patterns - these are violations
81
+ export const HARDCODED_SECRET_PATTERNS = [
82
+ /['"`](?:sk|pk|api|secret|key)[-_]?[a-zA-Z0-9]{20,}['"`]/gi,
83
+ /['"`][a-zA-Z0-9+/]{40,}={0,2}['"`]/gi, // Base64 encoded secrets
84
+ /password\s*[=:]\s*['"`][^'"`]{8,}['"`]/gi,
85
+ /secret\s*[=:]\s*['"`][^'"`]{8,}['"`]/gi,
86
+ /apiKey\s*[=:]\s*['"`][^'"`]{16,}['"`]/gi,
87
+ /api_key\s*[=:]\s*['"`][^'"`]{16,}['"`]/gi,
88
+ /privateKey\s*[=:]\s*['"`][^'"`]{20,}['"`]/gi,
89
+ /private_key\s*[=:]\s*['"`][^'"`]{20,}['"`]/gi,
90
+ ];
91
+ export const HARDCODED_API_KEY_PATTERNS = [
92
+ /['"`]AIza[0-9A-Za-z-_]{35}['"`]/gi, // Google API key
93
+ /['"`]AKIA[0-9A-Z]{16}['"`]/gi, // AWS Access Key
94
+ /['"`]sk-[a-zA-Z0-9]{48}['"`]/gi, // OpenAI API key
95
+ /['"`]ghp_[a-zA-Z0-9]{36}['"`]/gi, // GitHub Personal Access Token
96
+ /['"`]gho_[a-zA-Z0-9]{36}['"`]/gi, // GitHub OAuth Token
97
+ /['"`]xox[baprs]-[0-9]{10,13}-[0-9]{10,13}-[a-zA-Z0-9]{24}['"`]/gi, // Slack token
98
+ /['"`]sk_live_[a-zA-Z0-9]{24,}['"`]/gi, // Stripe live key
99
+ /['"`]sk_test_[a-zA-Z0-9]{24,}['"`]/gi, // Stripe test key
100
+ /['"`]SG\.[a-zA-Z0-9_-]{22}\.[a-zA-Z0-9_-]{43}['"`]/gi, // SendGrid API key
101
+ ];
102
+ export const HARDCODED_PASSWORD_PATTERNS = [
103
+ /password\s*[=:]\s*['"`](?!process\.env|import\.meta\.env|\$\{)[^'"`]{4,}['"`]/gi,
104
+ /passwd\s*[=:]\s*['"`](?!process\.env|import\.meta\.env|\$\{)[^'"`]{4,}['"`]/gi,
105
+ /pwd\s*[=:]\s*['"`](?!process\.env|import\.meta\.env|\$\{)[^'"`]{4,}['"`]/gi,
106
+ /DB_PASSWORD\s*[=:]\s*['"`](?!process\.env|import\.meta\.env|\$\{)[^'"`]{4,}['"`]/gi,
107
+ /DATABASE_PASSWORD\s*[=:]\s*['"`](?!process\.env|import\.meta\.env|\$\{)[^'"`]{4,}['"`]/gi,
108
+ ];
109
+ export const HARDCODED_TOKEN_PATTERNS = [
110
+ /token\s*[=:]\s*['"`](?!process\.env|import\.meta\.env|\$\{)[a-zA-Z0-9_-]{20,}['"`]/gi,
111
+ /bearer\s+[a-zA-Z0-9_-]{20,}/gi,
112
+ /authorization\s*[=:]\s*['"`]Bearer\s+[a-zA-Z0-9_-]{20,}['"`]/gi,
113
+ /jwt\s*[=:]\s*['"`]eyJ[a-zA-Z0-9_-]+\.[a-zA-Z0-9_-]+\.[a-zA-Z0-9_-]+['"`]/gi,
114
+ ];
115
+ export const EXPOSED_CREDENTIAL_PATTERNS = [
116
+ /console\.log\s*\([^)]*(?:password|secret|token|apiKey|api_key|credential)/gi,
117
+ /console\.debug\s*\([^)]*(?:password|secret|token|apiKey|api_key|credential)/gi,
118
+ /logger\.[a-z]+\s*\([^)]*(?:password|secret|token|apiKey|api_key|credential)/gi,
119
+ /print\s*\([^)]*(?:password|secret|token|apiKey|api_key|credential)/gi,
120
+ ];
121
+ export const INSECURE_STORAGE_PATTERNS = [
122
+ /localStorage\.setItem\s*\([^)]*(?:token|secret|password|apiKey|api_key)/gi,
123
+ /sessionStorage\.setItem\s*\([^)]*(?:token|secret|password|apiKey|api_key)/gi,
124
+ /document\.cookie\s*=.*(?:token|secret|password|apiKey|api_key)/gi,
125
+ /window\.__[A-Z_]*(?:TOKEN|SECRET|KEY)/gi,
126
+ ];
127
+ // ============================================================================
128
+ // Analysis Functions
129
+ // ============================================================================
130
+ export function shouldExcludeFile(filePath) {
131
+ const excludePatterns = [
132
+ /\.test\.[jt]sx?$/,
133
+ /\.spec\.[jt]sx?$/,
134
+ /__tests__\//,
135
+ /\.d\.ts$/,
136
+ /node_modules\//,
137
+ /\.min\.[jt]s$/,
138
+ /\.example$/,
139
+ /\.sample$/,
140
+ /\.template$/,
141
+ ];
142
+ return excludePatterns.some((p) => p.test(filePath));
143
+ }
144
+ export function detectEnvVariables(content, filePath) {
145
+ const results = [];
146
+ const lines = content.split('\n');
147
+ for (let i = 0; i < lines.length; i++) {
148
+ const line = lines[i];
149
+ for (const pattern of ENV_VARIABLE_PATTERNS) {
150
+ const regex = new RegExp(pattern.source, pattern.flags);
151
+ let match;
152
+ while ((match = regex.exec(line)) !== null) {
153
+ results.push({
154
+ type: 'env-variable',
155
+ file: filePath,
156
+ line: i + 1,
157
+ column: match.index + 1,
158
+ matchedText: match[0],
159
+ context: line.trim(),
160
+ });
161
+ }
162
+ }
163
+ }
164
+ return results;
165
+ }
166
+ export function detectSecretManager(content, filePath) {
167
+ const results = [];
168
+ const lines = content.split('\n');
169
+ for (let i = 0; i < lines.length; i++) {
170
+ const line = lines[i];
171
+ for (const pattern of SECRET_MANAGER_PATTERNS) {
172
+ const regex = new RegExp(pattern.source, pattern.flags);
173
+ let match;
174
+ while ((match = regex.exec(line)) !== null) {
175
+ let provider = 'unknown';
176
+ if (/aws|secretsmanager/i.test(match[0]))
177
+ provider = 'aws';
178
+ else if (/google|gcp/i.test(match[0]))
179
+ provider = 'gcp';
180
+ else if (/azure|keyvault/i.test(match[0]))
181
+ provider = 'azure';
182
+ results.push({
183
+ type: 'secret-manager',
184
+ file: filePath,
185
+ line: i + 1,
186
+ column: match.index + 1,
187
+ matchedText: match[0],
188
+ provider,
189
+ context: line.trim(),
190
+ });
191
+ }
192
+ }
193
+ }
194
+ return results;
195
+ }
196
+ export function detectVaultIntegration(content, filePath) {
197
+ const results = [];
198
+ const lines = content.split('\n');
199
+ for (let i = 0; i < lines.length; i++) {
200
+ const line = lines[i];
201
+ for (const pattern of VAULT_PATTERNS) {
202
+ const regex = new RegExp(pattern.source, pattern.flags);
203
+ let match;
204
+ while ((match = regex.exec(line)) !== null) {
205
+ results.push({
206
+ type: 'vault-integration',
207
+ file: filePath,
208
+ line: i + 1,
209
+ column: match.index + 1,
210
+ matchedText: match[0],
211
+ provider: 'hashicorp',
212
+ context: line.trim(),
213
+ });
214
+ }
215
+ }
216
+ }
217
+ return results;
218
+ }
219
+ export function detectKeyRotation(content, filePath) {
220
+ const results = [];
221
+ const lines = content.split('\n');
222
+ for (let i = 0; i < lines.length; i++) {
223
+ const line = lines[i];
224
+ for (const pattern of KEY_ROTATION_PATTERNS) {
225
+ const regex = new RegExp(pattern.source, pattern.flags);
226
+ let match;
227
+ while ((match = regex.exec(line)) !== null) {
228
+ results.push({
229
+ type: 'key-rotation',
230
+ file: filePath,
231
+ line: i + 1,
232
+ column: match.index + 1,
233
+ matchedText: match[0],
234
+ context: line.trim(),
235
+ });
236
+ }
237
+ }
238
+ }
239
+ return results;
240
+ }
241
+ export function detectCredentialStore(content, filePath) {
242
+ const results = [];
243
+ const lines = content.split('\n');
244
+ for (let i = 0; i < lines.length; i++) {
245
+ const line = lines[i];
246
+ for (const pattern of CREDENTIAL_STORE_PATTERNS) {
247
+ const regex = new RegExp(pattern.source, pattern.flags);
248
+ let match;
249
+ while ((match = regex.exec(line)) !== null) {
250
+ results.push({
251
+ type: 'credential-store',
252
+ file: filePath,
253
+ line: i + 1,
254
+ column: match.index + 1,
255
+ matchedText: match[0],
256
+ context: line.trim(),
257
+ });
258
+ }
259
+ }
260
+ }
261
+ return results;
262
+ }
263
+ export function detectConfigEncryption(content, filePath) {
264
+ const results = [];
265
+ const lines = content.split('\n');
266
+ for (let i = 0; i < lines.length; i++) {
267
+ const line = lines[i];
268
+ for (const pattern of CONFIG_ENCRYPTION_PATTERNS) {
269
+ const regex = new RegExp(pattern.source, pattern.flags);
270
+ let match;
271
+ while ((match = regex.exec(line)) !== null) {
272
+ results.push({
273
+ type: 'config-encryption',
274
+ file: filePath,
275
+ line: i + 1,
276
+ column: match.index + 1,
277
+ matchedText: match[0],
278
+ context: line.trim(),
279
+ });
280
+ }
281
+ }
282
+ }
283
+ return results;
284
+ }
285
+ export function detectHardcodedSecrets(content, filePath) {
286
+ const results = [];
287
+ const lines = content.split('\n');
288
+ for (let i = 0; i < lines.length; i++) {
289
+ const line = lines[i];
290
+ // Skip comments
291
+ if (/^\s*\/\/|^\s*\/\*|^\s*\*|^\s*#/.test(line))
292
+ continue;
293
+ for (const pattern of HARDCODED_SECRET_PATTERNS) {
294
+ const regex = new RegExp(pattern.source, pattern.flags);
295
+ let match;
296
+ while ((match = regex.exec(line)) !== null) {
297
+ results.push({
298
+ type: 'hardcoded-secret',
299
+ file: filePath,
300
+ line: i + 1,
301
+ column: match.index + 1,
302
+ matchedText: match[0].substring(0, 20) + '...',
303
+ issue: 'Potential hardcoded secret detected',
304
+ suggestedFix: 'Use environment variables or a secret manager',
305
+ severity: 'critical',
306
+ secretType: 'generic',
307
+ });
308
+ }
309
+ }
310
+ }
311
+ return results;
312
+ }
313
+ export function detectHardcodedApiKeys(content, filePath) {
314
+ const results = [];
315
+ const lines = content.split('\n');
316
+ for (let i = 0; i < lines.length; i++) {
317
+ const line = lines[i];
318
+ if (/^\s*\/\/|^\s*\/\*|^\s*\*|^\s*#/.test(line))
319
+ continue;
320
+ for (const pattern of HARDCODED_API_KEY_PATTERNS) {
321
+ const regex = new RegExp(pattern.source, pattern.flags);
322
+ let match;
323
+ while ((match = regex.exec(line)) !== null) {
324
+ let secretType = 'api-key';
325
+ if (/AIza/.test(match[0]))
326
+ secretType = 'google-api-key';
327
+ else if (/AKIA/.test(match[0]))
328
+ secretType = 'aws-access-key';
329
+ else if (/sk-/.test(match[0]))
330
+ secretType = 'openai-api-key';
331
+ else if (/ghp_|gho_/.test(match[0]))
332
+ secretType = 'github-token';
333
+ else if (/xox/.test(match[0]))
334
+ secretType = 'slack-token';
335
+ else if (/sk_live|sk_test/.test(match[0]))
336
+ secretType = 'stripe-key';
337
+ else if (/SG\./.test(match[0]))
338
+ secretType = 'sendgrid-key';
339
+ results.push({
340
+ type: 'hardcoded-api-key',
341
+ file: filePath,
342
+ line: i + 1,
343
+ column: match.index + 1,
344
+ matchedText: match[0].substring(0, 15) + '...',
345
+ issue: `Hardcoded ${secretType} detected`,
346
+ suggestedFix: 'Store API keys in environment variables or secret manager',
347
+ severity: 'critical',
348
+ secretType,
349
+ });
350
+ }
351
+ }
352
+ }
353
+ return results;
354
+ }
355
+ export function detectHardcodedPasswords(content, filePath) {
356
+ const results = [];
357
+ const lines = content.split('\n');
358
+ for (let i = 0; i < lines.length; i++) {
359
+ const line = lines[i];
360
+ if (/^\s*\/\/|^\s*\/\*|^\s*\*|^\s*#/.test(line))
361
+ continue;
362
+ // Skip type definitions and interfaces
363
+ if (/:\s*string|interface\s+|type\s+/.test(line))
364
+ continue;
365
+ for (const pattern of HARDCODED_PASSWORD_PATTERNS) {
366
+ const regex = new RegExp(pattern.source, pattern.flags);
367
+ let match;
368
+ while ((match = regex.exec(line)) !== null) {
369
+ results.push({
370
+ type: 'hardcoded-password',
371
+ file: filePath,
372
+ line: i + 1,
373
+ column: match.index + 1,
374
+ matchedText: '[REDACTED]',
375
+ issue: 'Hardcoded password detected',
376
+ suggestedFix: 'Use environment variables for passwords',
377
+ severity: 'critical',
378
+ secretType: 'password',
379
+ });
380
+ }
381
+ }
382
+ }
383
+ return results;
384
+ }
385
+ export function detectHardcodedTokens(content, filePath) {
386
+ const results = [];
387
+ const lines = content.split('\n');
388
+ for (let i = 0; i < lines.length; i++) {
389
+ const line = lines[i];
390
+ if (/^\s*\/\/|^\s*\/\*|^\s*\*|^\s*#/.test(line))
391
+ continue;
392
+ for (const pattern of HARDCODED_TOKEN_PATTERNS) {
393
+ const regex = new RegExp(pattern.source, pattern.flags);
394
+ let match;
395
+ while ((match = regex.exec(line)) !== null) {
396
+ let secretType = 'token';
397
+ if (/jwt|eyJ/.test(match[0]))
398
+ secretType = 'jwt';
399
+ else if (/bearer/i.test(match[0]))
400
+ secretType = 'bearer-token';
401
+ results.push({
402
+ type: 'hardcoded-token',
403
+ file: filePath,
404
+ line: i + 1,
405
+ column: match.index + 1,
406
+ matchedText: match[0].substring(0, 15) + '...',
407
+ issue: `Hardcoded ${secretType} detected`,
408
+ suggestedFix: 'Tokens should be retrieved dynamically, not hardcoded',
409
+ severity: 'high',
410
+ secretType,
411
+ });
412
+ }
413
+ }
414
+ }
415
+ return results;
416
+ }
417
+ export function detectExposedCredentials(content, filePath) {
418
+ const results = [];
419
+ const lines = content.split('\n');
420
+ for (let i = 0; i < lines.length; i++) {
421
+ const line = lines[i];
422
+ for (const pattern of EXPOSED_CREDENTIAL_PATTERNS) {
423
+ const regex = new RegExp(pattern.source, pattern.flags);
424
+ let match;
425
+ while ((match = regex.exec(line)) !== null) {
426
+ results.push({
427
+ type: 'exposed-credential',
428
+ file: filePath,
429
+ line: i + 1,
430
+ column: match.index + 1,
431
+ matchedText: match[0],
432
+ issue: 'Credential may be exposed in logs',
433
+ suggestedFix: 'Remove sensitive data from log statements',
434
+ severity: 'high',
435
+ });
436
+ }
437
+ }
438
+ }
439
+ return results;
440
+ }
441
+ export function detectInsecureStorage(content, filePath) {
442
+ const results = [];
443
+ const lines = content.split('\n');
444
+ for (let i = 0; i < lines.length; i++) {
445
+ const line = lines[i];
446
+ for (const pattern of INSECURE_STORAGE_PATTERNS) {
447
+ const regex = new RegExp(pattern.source, pattern.flags);
448
+ let match;
449
+ while ((match = regex.exec(line)) !== null) {
450
+ results.push({
451
+ type: 'insecure-storage',
452
+ file: filePath,
453
+ line: i + 1,
454
+ column: match.index + 1,
455
+ matchedText: match[0],
456
+ issue: 'Sensitive data stored in insecure browser storage',
457
+ suggestedFix: 'Use httpOnly cookies or secure storage mechanisms',
458
+ severity: 'high',
459
+ });
460
+ }
461
+ }
462
+ }
463
+ return results;
464
+ }
465
+ export function analyzeSecretManagement(content, filePath) {
466
+ if (shouldExcludeFile(filePath)) {
467
+ return {
468
+ patterns: [],
469
+ violations: [],
470
+ usesEnvVariables: false,
471
+ usesSecretManager: false,
472
+ usesVault: false,
473
+ confidence: 1.0,
474
+ };
475
+ }
476
+ const patterns = [
477
+ ...detectEnvVariables(content, filePath),
478
+ ...detectSecretManager(content, filePath),
479
+ ...detectVaultIntegration(content, filePath),
480
+ ...detectKeyRotation(content, filePath),
481
+ ...detectCredentialStore(content, filePath),
482
+ ...detectConfigEncryption(content, filePath),
483
+ ];
484
+ const violations = [
485
+ ...detectHardcodedSecrets(content, filePath),
486
+ ...detectHardcodedApiKeys(content, filePath),
487
+ ...detectHardcodedPasswords(content, filePath),
488
+ ...detectHardcodedTokens(content, filePath),
489
+ ...detectExposedCredentials(content, filePath),
490
+ ...detectInsecureStorage(content, filePath),
491
+ ];
492
+ const usesEnvVariables = patterns.some((p) => p.type === 'env-variable');
493
+ const usesSecretManager = patterns.some((p) => p.type === 'secret-manager');
494
+ const usesVault = patterns.some((p) => p.type === 'vault-integration');
495
+ let confidence = 0.7;
496
+ if (usesEnvVariables)
497
+ confidence += 0.1;
498
+ if (usesSecretManager || usesVault)
499
+ confidence += 0.15;
500
+ if (violations.length === 0)
501
+ confidence += 0.05;
502
+ confidence = Math.min(confidence, 0.95);
503
+ return {
504
+ patterns,
505
+ violations,
506
+ usesEnvVariables,
507
+ usesSecretManager,
508
+ usesVault,
509
+ confidence,
510
+ };
511
+ }
512
+ // ============================================================================
513
+ // Detector Class
514
+ // ============================================================================
515
+ export class SecretManagementDetector extends RegexDetector {
516
+ id = 'security/secret-management';
517
+ name = 'Secret Management Detector';
518
+ description = 'Detects secret management patterns and identifies hardcoded credentials';
519
+ category = 'security';
520
+ subcategory = 'secret-management';
521
+ supportedLanguages = ['typescript', 'javascript', 'python'];
522
+ async detect(context) {
523
+ if (!this.supportsLanguage(context.language)) {
524
+ return this.createEmptyResult();
525
+ }
526
+ const analysis = analyzeSecretManagement(context.content, context.file);
527
+ if (analysis.patterns.length === 0 && analysis.violations.length === 0) {
528
+ return this.createEmptyResult();
529
+ }
530
+ return this.createResult([], [], analysis.confidence, {
531
+ custom: {
532
+ patterns: analysis.patterns,
533
+ violations: analysis.violations,
534
+ usesEnvVariables: analysis.usesEnvVariables,
535
+ usesSecretManager: analysis.usesSecretManager,
536
+ usesVault: analysis.usesVault,
537
+ },
538
+ });
539
+ }
540
+ generateQuickFix(_violation) {
541
+ return null;
542
+ }
543
+ }
544
+ export function createSecretManagementDetector() {
545
+ return new SecretManagementDetector();
546
+ }
547
+ //# sourceMappingURL=secret-management.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"secret-management.js","sourceRoot":"","sources":["../../src/security/secret-management.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,76 @@
1
+ /**
2
+ * SQL Injection Detector - SQL injection vulnerability detection
3
+ *
4
+ * Detects SQL injection prevention patterns including:
5
+ * - Parameterized queries (prepared statements)
6
+ * - ORM usage (Prisma, TypeORM, Sequelize)
7
+ * - Query builder patterns
8
+ * - String concatenation violations
9
+ * - Template literal SQL violations
10
+ *
11
+ * @requirements 16.2 - SQL injection prevention patterns
12
+ */
13
+ import type { Violation, QuickFix, PatternCategory, Language } from 'driftdetect-core';
14
+ import { RegexDetector } from '../base/regex-detector.js';
15
+ import type { DetectionContext, DetectionResult } from '../base/base-detector.js';
16
+ export type SQLInjectionPatternType = 'parameterized-query' | 'prepared-statement' | 'orm-query' | 'query-builder' | 'escape-function' | 'tagged-template';
17
+ export type SQLInjectionViolationType = 'string-concatenation' | 'template-literal-injection' | 'dynamic-query' | 'raw-sql-with-input';
18
+ export interface SQLInjectionPatternInfo {
19
+ type: SQLInjectionPatternType;
20
+ file: string;
21
+ line: number;
22
+ column: number;
23
+ matchedText: string;
24
+ queryType?: string | undefined;
25
+ context?: string | undefined;
26
+ }
27
+ export interface SQLInjectionViolationInfo {
28
+ type: SQLInjectionViolationType;
29
+ file: string;
30
+ line: number;
31
+ column: number;
32
+ matchedText: string;
33
+ issue: string;
34
+ suggestedFix?: string | undefined;
35
+ severity: 'high' | 'medium' | 'low';
36
+ }
37
+ export interface SQLInjectionAnalysis {
38
+ patterns: SQLInjectionPatternInfo[];
39
+ violations: SQLInjectionViolationInfo[];
40
+ hasParameterizedQueries: boolean;
41
+ usesORM: boolean;
42
+ hasViolations: boolean;
43
+ confidence: number;
44
+ }
45
+ export declare const PARAMETERIZED_QUERY_PATTERNS: readonly [RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp];
46
+ export declare const PREPARED_STATEMENT_PATTERNS: readonly [RegExp, RegExp, RegExp, RegExp, RegExp, RegExp];
47
+ export declare const ORM_QUERY_PATTERNS: readonly [RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp, RegExp];
48
+ export declare const QUERY_BUILDER_PATTERNS: readonly [RegExp, RegExp, RegExp, RegExp, RegExp];
49
+ export declare const ESCAPE_FUNCTION_PATTERNS: readonly [RegExp, RegExp, RegExp];
50
+ export declare const TAGGED_TEMPLATE_PATTERNS: readonly [RegExp, RegExp, RegExp];
51
+ export declare const STRING_CONCAT_VIOLATION_PATTERNS: readonly [RegExp, RegExp, RegExp, RegExp, RegExp];
52
+ export declare const TEMPLATE_LITERAL_VIOLATION_PATTERNS: readonly [RegExp];
53
+ export declare const RAW_SQL_WITH_INPUT_PATTERNS: readonly [RegExp, RegExp];
54
+ export declare function shouldExcludeFile(filePath: string): boolean;
55
+ export declare function detectParameterizedQueries(content: string, filePath: string): SQLInjectionPatternInfo[];
56
+ export declare function detectPreparedStatements(content: string, filePath: string): SQLInjectionPatternInfo[];
57
+ export declare function detectORMQueries(content: string, filePath: string): SQLInjectionPatternInfo[];
58
+ export declare function detectQueryBuilders(content: string, filePath: string): SQLInjectionPatternInfo[];
59
+ export declare function detectEscapeFunctions(content: string, filePath: string): SQLInjectionPatternInfo[];
60
+ export declare function detectTaggedTemplates(content: string, filePath: string): SQLInjectionPatternInfo[];
61
+ export declare function detectStringConcatViolations(content: string, filePath: string): SQLInjectionViolationInfo[];
62
+ export declare function detectTemplateLiteralViolations(content: string, filePath: string): SQLInjectionViolationInfo[];
63
+ export declare function detectRawSQLViolations(content: string, filePath: string): SQLInjectionViolationInfo[];
64
+ export declare function analyzeSQLInjection(content: string, filePath: string): SQLInjectionAnalysis;
65
+ export declare class SQLInjectionDetector extends RegexDetector {
66
+ readonly id = "security/sql-injection";
67
+ readonly name = "SQL Injection Detector";
68
+ readonly description = "Detects SQL injection prevention patterns and identifies potential vulnerabilities";
69
+ readonly category: PatternCategory;
70
+ readonly subcategory = "sql-injection";
71
+ readonly supportedLanguages: Language[];
72
+ detect(context: DetectionContext): Promise<DetectionResult>;
73
+ generateQuickFix(_violation: Violation): QuickFix | null;
74
+ }
75
+ export declare function createSQLInjectionDetector(): SQLInjectionDetector;
76
+ //# sourceMappingURL=sql-injection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql-injection.d.ts","sourceRoot":"","sources":["../../src/security/sql-injection.ts"],"names":[],"mappings":"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"}