@dxworks/insider 2.9.1

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 (385) hide show
  1. package/.github/workflows/build.yml +19 -0
  2. package/.github/workflows/release-docs.yml +15 -0
  3. package/.github/workflows/release-voyager.yml +57 -0
  4. package/.github/workflows/release.yml +102 -0
  5. package/Dockerfile +8 -0
  6. package/README.md +89 -0
  7. package/TODO.txt +7 -0
  8. package/bin/insider.bat +1 -0
  9. package/bin/insider.sh +1 -0
  10. package/build.gradle +55 -0
  11. package/config/.ignore +4 -0
  12. package/config/comments.json +71 -0
  13. package/config/fingerprints/_anomalies-full.json +116 -0
  14. package/config/fingerprints/_extLibs.json +2555 -0
  15. package/config/fingerprints/code_smells.json +94 -0
  16. package/config/fingerprints/generated_code.json +17 -0
  17. package/config/fingerprints/libraries.json +4667 -0
  18. package/config/ignoredImports.txt +0 -0
  19. package/config/insider-conf.properties +3 -0
  20. package/config/rules/cloud_services/ad_networks.json +50 -0
  21. package/config/rules/cloud_services/bigdata.json +21 -0
  22. package/config/rules/cloud_services/cloud_hosting.json +398 -0
  23. package/config/rules/cloud_services/data_storage.json +291 -0
  24. package/config/rules/cloud_services/ecommerce.json +45 -0
  25. package/config/rules/cloud_services/socialmedia.json +82 -0
  26. package/config/rules/cloud_services/web_analytics.json +108 -0
  27. package/config/rules/components/active_content.json +157 -0
  28. package/config/rules/components/load_dll.json +66 -0
  29. package/config/rules/cryptography/algorithm_implementation.json +62 -0
  30. package/config/rules/cryptography/certificate.json +199 -0
  31. package/config/rules/cryptography/ciphers.json +174 -0
  32. package/config/rules/cryptography/crypto_currency.json +32 -0
  33. package/config/rules/cryptography/encoding.json +20 -0
  34. package/config/rules/cryptography/extended.json +220 -0
  35. package/config/rules/cryptography/external_libraries.json +141 -0
  36. package/config/rules/cryptography/hash_algorithm.json +98 -0
  37. package/config/rules/cryptography/key_derivation.json +65 -0
  38. package/config/rules/cryptography/protocol.json +156 -0
  39. package/config/rules/cryptography/random.json +97 -0
  40. package/config/rules/cryptography/weakssl.json +206 -0
  41. package/config/rules/data_handling/compressed_files.json +18 -0
  42. package/config/rules/data_handling/database.json +361 -0
  43. package/config/rules/data_handling/deserialization.json +296 -0
  44. package/config/rules/data_handling/json_parsing.json +49 -0
  45. package/config/rules/data_handling/media_parsing.json +33 -0
  46. package/config/rules/data_handling/pastebin.json +18 -0
  47. package/config/rules/data_handling/xml_parsing.json +168 -0
  48. package/config/rules/data_types/financial.json +106 -0
  49. package/config/rules/data_types/media.json +48 -0
  50. package/config/rules/data_types/secrets.json +91 -0
  51. package/config/rules/data_types/sensitive.json +176 -0
  52. package/config/rules/device_permissions/IOSPermissions.json +240 -0
  53. package/config/rules/device_permissions/UWP.json +221 -0
  54. package/config/rules/device_permissions/android_intents.json +599 -0
  55. package/config/rules/frameworks/PHP.json +172 -0
  56. package/config/rules/frameworks/build.json +189 -0
  57. package/config/rules/frameworks/c.json +45 -0
  58. package/config/rules/frameworks/csharp-nonMS.json +19 -0
  59. package/config/rules/frameworks/java.json +291 -0
  60. package/config/rules/frameworks/javascript.json +318 -0
  61. package/config/rules/frameworks/logging.json +103 -0
  62. package/config/rules/frameworks/microsoft.json +257 -0
  63. package/config/rules/frameworks/python.json +274 -0
  64. package/config/rules/frameworks/ruby.json +53 -0
  65. package/config/rules/frameworks/rust.json +77 -0
  66. package/config/rules/general/OSS_license.json +146 -0
  67. package/config/rules/general/code_metrics.json +132 -0
  68. package/config/rules/general/dependencies.json +199 -0
  69. package/config/rules/general/hygiene.json +47 -0
  70. package/config/rules/general/platforms.json +283 -0
  71. package/config/rules/general/solutioninfo.json +378 -0
  72. package/config/rules/infrastructure/hashicorp_packers_tmpl.json +18 -0
  73. package/config/rules/infrastructure/hashicorp_terraform_tmpl.json +19 -0
  74. package/config/rules/infrastructure/microsoft_arm_tmpl.json +198 -0
  75. package/config/rules/networkcomms/outbound_network.json +429 -0
  76. package/config/rules/os/acl.json +250 -0
  77. package/config/rules/os/dynamic_execution.json +359 -0
  78. package/config/rules/os/file_io.json +468 -0
  79. package/config/rules/os/process.json +179 -0
  80. package/config/rules/os/setenv.json +270 -0
  81. package/config/rules/os/system_registry.json +237 -0
  82. package/config/rules/os/user_accts.json +34 -0
  83. package/config/rules/security_feature/authentication.json +387 -0
  84. package/config/rules/security_feature/authorization.json +148 -0
  85. package/config/rules/test_frameworks/cpp_testing.json +194 -0
  86. package/config/rules/test_frameworks/go_testing.json +18 -0
  87. package/config/rules/test_frameworks/java_testing.json +720 -0
  88. package/config/rules/test_frameworks/javascript_testing.json +724 -0
  89. package/config/rules/test_frameworks/objectiveC_testing.json +146 -0
  90. package/config/rules/test_frameworks/php_testing.json +156 -0
  91. package/config/rules/test_frameworks/powershell_testing.json +17 -0
  92. package/config/rules/test_frameworks/python_testing.json +108 -0
  93. package/config/rules/test_frameworks/ruby_testing.json +114 -0
  94. package/config/rules/tools/pipeline.json +195 -0
  95. package/config/rules/webapp/comms.json +89 -0
  96. package/config/rules/webapp/headers.json +178 -0
  97. package/config/rules/webapp/media.json +56 -0
  98. package/config/rules/webapp/sessions.json +228 -0
  99. package/config/rules/webapp/storage.json +215 -0
  100. package/dist/config/.ignore +4 -0
  101. package/dist/config/comments.json +71 -0
  102. package/dist/config/fingerprints/_anomalies-full.json +116 -0
  103. package/dist/config/fingerprints/_extLibs.json +2555 -0
  104. package/dist/config/fingerprints/code_smells.json +94 -0
  105. package/dist/config/fingerprints/generated_code.json +17 -0
  106. package/dist/config/fingerprints/libraries.json +4667 -0
  107. package/dist/config/ignoredImports.txt +0 -0
  108. package/dist/config/insider-conf.properties +3 -0
  109. package/dist/config/rules/cloud_services/ad_networks.json +50 -0
  110. package/dist/config/rules/cloud_services/bigdata.json +21 -0
  111. package/dist/config/rules/cloud_services/cloud_hosting.json +398 -0
  112. package/dist/config/rules/cloud_services/data_storage.json +291 -0
  113. package/dist/config/rules/cloud_services/ecommerce.json +45 -0
  114. package/dist/config/rules/cloud_services/socialmedia.json +82 -0
  115. package/dist/config/rules/cloud_services/web_analytics.json +108 -0
  116. package/dist/config/rules/components/active_content.json +157 -0
  117. package/dist/config/rules/components/load_dll.json +66 -0
  118. package/dist/config/rules/cryptography/algorithm_implementation.json +62 -0
  119. package/dist/config/rules/cryptography/certificate.json +199 -0
  120. package/dist/config/rules/cryptography/ciphers.json +174 -0
  121. package/dist/config/rules/cryptography/crypto_currency.json +32 -0
  122. package/dist/config/rules/cryptography/encoding.json +20 -0
  123. package/dist/config/rules/cryptography/extended.json +220 -0
  124. package/dist/config/rules/cryptography/external_libraries.json +141 -0
  125. package/dist/config/rules/cryptography/hash_algorithm.json +98 -0
  126. package/dist/config/rules/cryptography/key_derivation.json +65 -0
  127. package/dist/config/rules/cryptography/protocol.json +156 -0
  128. package/dist/config/rules/cryptography/random.json +97 -0
  129. package/dist/config/rules/cryptography/weakssl.json +206 -0
  130. package/dist/config/rules/data_handling/compressed_files.json +18 -0
  131. package/dist/config/rules/data_handling/database.json +361 -0
  132. package/dist/config/rules/data_handling/deserialization.json +296 -0
  133. package/dist/config/rules/data_handling/json_parsing.json +49 -0
  134. package/dist/config/rules/data_handling/media_parsing.json +33 -0
  135. package/dist/config/rules/data_handling/pastebin.json +18 -0
  136. package/dist/config/rules/data_handling/xml_parsing.json +168 -0
  137. package/dist/config/rules/data_types/financial.json +106 -0
  138. package/dist/config/rules/data_types/media.json +48 -0
  139. package/dist/config/rules/data_types/secrets.json +91 -0
  140. package/dist/config/rules/data_types/sensitive.json +176 -0
  141. package/dist/config/rules/device_permissions/IOSPermissions.json +240 -0
  142. package/dist/config/rules/device_permissions/UWP.json +221 -0
  143. package/dist/config/rules/device_permissions/android_intents.json +599 -0
  144. package/dist/config/rules/frameworks/PHP.json +172 -0
  145. package/dist/config/rules/frameworks/build.json +189 -0
  146. package/dist/config/rules/frameworks/c.json +45 -0
  147. package/dist/config/rules/frameworks/csharp-nonMS.json +19 -0
  148. package/dist/config/rules/frameworks/java.json +291 -0
  149. package/dist/config/rules/frameworks/javascript.json +318 -0
  150. package/dist/config/rules/frameworks/logging.json +103 -0
  151. package/dist/config/rules/frameworks/microsoft.json +257 -0
  152. package/dist/config/rules/frameworks/python.json +274 -0
  153. package/dist/config/rules/frameworks/ruby.json +53 -0
  154. package/dist/config/rules/frameworks/rust.json +77 -0
  155. package/dist/config/rules/general/OSS_license.json +146 -0
  156. package/dist/config/rules/general/code_metrics.json +132 -0
  157. package/dist/config/rules/general/dependencies.json +199 -0
  158. package/dist/config/rules/general/hygiene.json +47 -0
  159. package/dist/config/rules/general/platforms.json +283 -0
  160. package/dist/config/rules/general/solutioninfo.json +378 -0
  161. package/dist/config/rules/infrastructure/hashicorp_packers_tmpl.json +18 -0
  162. package/dist/config/rules/infrastructure/hashicorp_terraform_tmpl.json +19 -0
  163. package/dist/config/rules/infrastructure/microsoft_arm_tmpl.json +198 -0
  164. package/dist/config/rules/networkcomms/outbound_network.json +429 -0
  165. package/dist/config/rules/os/acl.json +250 -0
  166. package/dist/config/rules/os/dynamic_execution.json +359 -0
  167. package/dist/config/rules/os/file_io.json +468 -0
  168. package/dist/config/rules/os/process.json +179 -0
  169. package/dist/config/rules/os/setenv.json +270 -0
  170. package/dist/config/rules/os/system_registry.json +237 -0
  171. package/dist/config/rules/os/user_accts.json +34 -0
  172. package/dist/config/rules/security_feature/authentication.json +387 -0
  173. package/dist/config/rules/security_feature/authorization.json +148 -0
  174. package/dist/config/rules/test_frameworks/cpp_testing.json +194 -0
  175. package/dist/config/rules/test_frameworks/go_testing.json +18 -0
  176. package/dist/config/rules/test_frameworks/java_testing.json +720 -0
  177. package/dist/config/rules/test_frameworks/javascript_testing.json +724 -0
  178. package/dist/config/rules/test_frameworks/objectiveC_testing.json +146 -0
  179. package/dist/config/rules/test_frameworks/php_testing.json +156 -0
  180. package/dist/config/rules/test_frameworks/powershell_testing.json +17 -0
  181. package/dist/config/rules/test_frameworks/python_testing.json +108 -0
  182. package/dist/config/rules/test_frameworks/ruby_testing.json +114 -0
  183. package/dist/config/rules/tools/pipeline.json +195 -0
  184. package/dist/config/rules/webapp/comms.json +89 -0
  185. package/dist/config/rules/webapp/headers.json +178 -0
  186. package/dist/config/rules/webapp/media.json +56 -0
  187. package/dist/config/rules/webapp/sessions.json +228 -0
  188. package/dist/config/rules/webapp/storage.json +215 -0
  189. package/dist/index.js +13 -0
  190. package/dist/insider.jar +0 -0
  191. package/dist/insider.js +7 -0
  192. package/dist/lib.js +21 -0
  193. package/docs/config/config.md +3 -0
  194. package/docs/config/ignore.md +3 -0
  195. package/docs/config/languages.md +3 -0
  196. package/docs/index.md +58 -0
  197. package/dxworks-site.json +13 -0
  198. package/gradle.properties +0 -0
  199. package/gradlew +240 -0
  200. package/gradlew.bat +91 -0
  201. package/insider/README.md +89 -0
  202. package/insider/config/.ignore +4 -0
  203. package/insider/config/comments.json +71 -0
  204. package/insider/config/fingerprints/_anomalies-full.json +116 -0
  205. package/insider/config/fingerprints/_extLibs.json +2555 -0
  206. package/insider/config/fingerprints/code_smells.json +94 -0
  207. package/insider/config/fingerprints/generated_code.json +17 -0
  208. package/insider/config/fingerprints/libraries.json +4667 -0
  209. package/insider/config/ignoredImports.txt +0 -0
  210. package/insider/config/insider-conf.properties +3 -0
  211. package/insider/config/rules/cloud_services/ad_networks.json +50 -0
  212. package/insider/config/rules/cloud_services/bigdata.json +21 -0
  213. package/insider/config/rules/cloud_services/cloud_hosting.json +398 -0
  214. package/insider/config/rules/cloud_services/data_storage.json +291 -0
  215. package/insider/config/rules/cloud_services/ecommerce.json +45 -0
  216. package/insider/config/rules/cloud_services/socialmedia.json +82 -0
  217. package/insider/config/rules/cloud_services/web_analytics.json +108 -0
  218. package/insider/config/rules/components/active_content.json +157 -0
  219. package/insider/config/rules/components/load_dll.json +66 -0
  220. package/insider/config/rules/cryptography/algorithm_implementation.json +62 -0
  221. package/insider/config/rules/cryptography/certificate.json +199 -0
  222. package/insider/config/rules/cryptography/ciphers.json +174 -0
  223. package/insider/config/rules/cryptography/crypto_currency.json +32 -0
  224. package/insider/config/rules/cryptography/encoding.json +20 -0
  225. package/insider/config/rules/cryptography/extended.json +220 -0
  226. package/insider/config/rules/cryptography/external_libraries.json +141 -0
  227. package/insider/config/rules/cryptography/hash_algorithm.json +98 -0
  228. package/insider/config/rules/cryptography/key_derivation.json +65 -0
  229. package/insider/config/rules/cryptography/protocol.json +156 -0
  230. package/insider/config/rules/cryptography/random.json +97 -0
  231. package/insider/config/rules/cryptography/weakssl.json +206 -0
  232. package/insider/config/rules/data_handling/compressed_files.json +18 -0
  233. package/insider/config/rules/data_handling/database.json +361 -0
  234. package/insider/config/rules/data_handling/deserialization.json +296 -0
  235. package/insider/config/rules/data_handling/json_parsing.json +49 -0
  236. package/insider/config/rules/data_handling/media_parsing.json +33 -0
  237. package/insider/config/rules/data_handling/pastebin.json +18 -0
  238. package/insider/config/rules/data_handling/xml_parsing.json +168 -0
  239. package/insider/config/rules/data_types/financial.json +106 -0
  240. package/insider/config/rules/data_types/media.json +48 -0
  241. package/insider/config/rules/data_types/secrets.json +91 -0
  242. package/insider/config/rules/data_types/sensitive.json +176 -0
  243. package/insider/config/rules/device_permissions/IOSPermissions.json +240 -0
  244. package/insider/config/rules/device_permissions/UWP.json +221 -0
  245. package/insider/config/rules/device_permissions/android_intents.json +599 -0
  246. package/insider/config/rules/frameworks/PHP.json +172 -0
  247. package/insider/config/rules/frameworks/build.json +189 -0
  248. package/insider/config/rules/frameworks/c.json +45 -0
  249. package/insider/config/rules/frameworks/csharp-nonMS.json +19 -0
  250. package/insider/config/rules/frameworks/java.json +291 -0
  251. package/insider/config/rules/frameworks/javascript.json +318 -0
  252. package/insider/config/rules/frameworks/logging.json +103 -0
  253. package/insider/config/rules/frameworks/microsoft.json +257 -0
  254. package/insider/config/rules/frameworks/python.json +274 -0
  255. package/insider/config/rules/frameworks/ruby.json +53 -0
  256. package/insider/config/rules/frameworks/rust.json +77 -0
  257. package/insider/config/rules/general/OSS_license.json +146 -0
  258. package/insider/config/rules/general/code_metrics.json +132 -0
  259. package/insider/config/rules/general/dependencies.json +199 -0
  260. package/insider/config/rules/general/hygiene.json +47 -0
  261. package/insider/config/rules/general/platforms.json +283 -0
  262. package/insider/config/rules/general/solutioninfo.json +378 -0
  263. package/insider/config/rules/infrastructure/hashicorp_packers_tmpl.json +18 -0
  264. package/insider/config/rules/infrastructure/hashicorp_terraform_tmpl.json +19 -0
  265. package/insider/config/rules/infrastructure/microsoft_arm_tmpl.json +198 -0
  266. package/insider/config/rules/networkcomms/outbound_network.json +429 -0
  267. package/insider/config/rules/os/acl.json +250 -0
  268. package/insider/config/rules/os/dynamic_execution.json +359 -0
  269. package/insider/config/rules/os/file_io.json +468 -0
  270. package/insider/config/rules/os/process.json +179 -0
  271. package/insider/config/rules/os/setenv.json +270 -0
  272. package/insider/config/rules/os/system_registry.json +237 -0
  273. package/insider/config/rules/os/user_accts.json +34 -0
  274. package/insider/config/rules/security_feature/authentication.json +387 -0
  275. package/insider/config/rules/security_feature/authorization.json +148 -0
  276. package/insider/config/rules/test_frameworks/cpp_testing.json +194 -0
  277. package/insider/config/rules/test_frameworks/go_testing.json +18 -0
  278. package/insider/config/rules/test_frameworks/java_testing.json +720 -0
  279. package/insider/config/rules/test_frameworks/javascript_testing.json +724 -0
  280. package/insider/config/rules/test_frameworks/objectiveC_testing.json +146 -0
  281. package/insider/config/rules/test_frameworks/php_testing.json +156 -0
  282. package/insider/config/rules/test_frameworks/powershell_testing.json +17 -0
  283. package/insider/config/rules/test_frameworks/python_testing.json +108 -0
  284. package/insider/config/rules/test_frameworks/ruby_testing.json +114 -0
  285. package/insider/config/rules/tools/pipeline.json +195 -0
  286. package/insider/config/rules/webapp/comms.json +89 -0
  287. package/insider/config/rules/webapp/headers.json +178 -0
  288. package/insider/config/rules/webapp/media.json +56 -0
  289. package/insider/config/rules/webapp/sessions.json +228 -0
  290. package/insider/config/rules/webapp/storage.json +215 -0
  291. package/insider/insider.bat +1 -0
  292. package/insider/insider.jar +0 -0
  293. package/insider/insider.sh +1 -0
  294. package/insider/languages.yml +3988 -0
  295. package/instrument.yml +37 -0
  296. package/languages.yml +3988 -0
  297. package/lib/index.js +13 -0
  298. package/lib/insider.js +7 -0
  299. package/lib/lib.js +21 -0
  300. package/lombok.config +2 -0
  301. package/mkdocs.yml +18 -0
  302. package/package.json +51 -0
  303. package/releaseNotes/v2.6.0.md +1 -0
  304. package/releaseNotes/v2.7.1.md +1 -0
  305. package/settings.gradle +2 -0
  306. package/src/main/java/org/dxworks/insider/ChronosTag.java +14 -0
  307. package/src/main/java/org/dxworks/insider/Insider.java +214 -0
  308. package/src/main/java/org/dxworks/insider/InsiderAnalysis.java +7 -0
  309. package/src/main/java/org/dxworks/insider/InsiderFile.java +125 -0
  310. package/src/main/java/org/dxworks/insider/InsiderOptions.java +78 -0
  311. package/src/main/java/org/dxworks/insider/InsiderResult.java +15 -0
  312. package/src/main/java/org/dxworks/insider/application/inspector/CodeRuleExtractor.java +14 -0
  313. package/src/main/java/org/dxworks/insider/application/inspector/CommentRuleExtractor.java +14 -0
  314. package/src/main/java/org/dxworks/insider/application/inspector/FileRuleExtractor.java +14 -0
  315. package/src/main/java/org/dxworks/insider/application/inspector/RuleExtractor.java +11 -0
  316. package/src/main/java/org/dxworks/insider/application/inspector/dtos/Comment.java +18 -0
  317. package/src/main/java/org/dxworks/insider/application/inspector/dtos/CommentPattern.java +44 -0
  318. package/src/main/java/org/dxworks/insider/application/inspector/dtos/Condition.java +15 -0
  319. package/src/main/java/org/dxworks/insider/application/inspector/dtos/InsiderPattern.java +149 -0
  320. package/src/main/java/org/dxworks/insider/application/inspector/dtos/PatternMatch.java +23 -0
  321. package/src/main/java/org/dxworks/insider/application/inspector/dtos/Rule.java +61 -0
  322. package/src/main/java/org/dxworks/insider/application/inspector/services/CommentService.java +165 -0
  323. package/src/main/java/org/dxworks/insider/application/inspector/services/RuleService.java +54 -0
  324. package/src/main/java/org/dxworks/insider/commands/AddCommand.java +125 -0
  325. package/src/main/java/org/dxworks/insider/commands/AllFilesCommand.java +4 -0
  326. package/src/main/java/org/dxworks/insider/commands/ConvertCommand.java +55 -0
  327. package/src/main/java/org/dxworks/insider/commands/DetectCommand.java +42 -0
  328. package/src/main/java/org/dxworks/insider/commands/DiagnoseCommand.java +74 -0
  329. package/src/main/java/org/dxworks/insider/commands/ExtractCommand.java +35 -0
  330. package/src/main/java/org/dxworks/insider/commands/FindCommand.java +102 -0
  331. package/src/main/java/org/dxworks/insider/commands/HelpCommand.java +56 -0
  332. package/src/main/java/org/dxworks/insider/commands/IndentationCount.java +69 -0
  333. package/src/main/java/org/dxworks/insider/commands/InsiderCommand.java +71 -0
  334. package/src/main/java/org/dxworks/insider/commands/InspectCommand.java +98 -0
  335. package/src/main/java/org/dxworks/insider/commands/MeasureCommand.java +47 -0
  336. package/src/main/java/org/dxworks/insider/commands/NoFilesCommand.java +4 -0
  337. package/src/main/java/org/dxworks/insider/commands/VersionCommand.java +34 -0
  338. package/src/main/java/org/dxworks/insider/configuration/InsiderConfiguration.java +123 -0
  339. package/src/main/java/org/dxworks/insider/constants/InsiderConstants.java +19 -0
  340. package/src/main/java/org/dxworks/insider/depext/AbstractImportsProcessor.java +57 -0
  341. package/src/main/java/org/dxworks/insider/depext/CPPImportsProcessor.java +55 -0
  342. package/src/main/java/org/dxworks/insider/depext/CSharpImportsProcessor.java +53 -0
  343. package/src/main/java/org/dxworks/insider/depext/DependencyExtractor.java +105 -0
  344. package/src/main/java/org/dxworks/insider/depext/ImportItem.java +19 -0
  345. package/src/main/java/org/dxworks/insider/depext/ImportResult.java +32 -0
  346. package/src/main/java/org/dxworks/insider/depext/JavastackImportsProcessor.java +88 -0
  347. package/src/main/java/org/dxworks/insider/depext/VBImportsProcessor.java +41 -0
  348. package/src/main/java/org/dxworks/insider/exceptions/InsiderException.java +7 -0
  349. package/src/main/java/org/dxworks/insider/library/detector/C_ImportsContainer.java +73 -0
  350. package/src/main/java/org/dxworks/insider/library/detector/ImportsContainer.java +122 -0
  351. package/src/main/java/org/dxworks/insider/library/detector/JavaImportsContainer.java +63 -0
  352. package/src/main/java/org/dxworks/insider/library/detector/LibraryDetector.java +150 -0
  353. package/src/main/java/org/dxworks/insider/library/detector/LibraryDetectorLanguage.java +6 -0
  354. package/src/main/java/org/dxworks/insider/library/detector/model/PackagingUnit.java +26 -0
  355. package/src/main/java/org/dxworks/insider/technology/finder/LinguistService.java +79 -0
  356. package/src/main/java/org/dxworks/insider/technology/finder/converters/XmlToJsonConverter.java +41 -0
  357. package/src/main/java/org/dxworks/insider/technology/finder/exceptions/FingerprintParseException.java +7 -0
  358. package/src/main/java/org/dxworks/insider/technology/finder/model/Technology.java +73 -0
  359. package/src/main/java/org/dxworks/insider/technology/finder/model/json/JsonConfigurationDTO.java +14 -0
  360. package/src/main/java/org/dxworks/insider/technology/finder/model/json/TechnologyJsonDTO.java +66 -0
  361. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/CategoryXmlDTO.java +21 -0
  362. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/ConfigurationDataXmlDTO.java +17 -0
  363. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/FingerprintXmlDTO.java +17 -0
  364. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/LanguageXmlDTO.java +20 -0
  365. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/LanguagesXmlDTO.java +18 -0
  366. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/TechnologyXmlDTO.java +19 -0
  367. package/src/main/java/org/dxworks/insider/technology/finder/model/xml/old/XmlConfigurationDTO.java +17 -0
  368. package/src/main/java/org/dxworks/insider/technology/finder/parsers/FingerprintsParser.java +14 -0
  369. package/src/main/java/org/dxworks/insider/technology/finder/parsers/FingerprintsXmlParser.java +57 -0
  370. package/src/main/java/org/dxworks/insider/technology/finder/parsers/JavaLibrariesCsvParser.java +71 -0
  371. package/src/main/java/org/dxworks/insider/technology/finder/parsers/JsonFingerprintParser.java +58 -0
  372. package/src/main/java/org/dxworks/insider/utils/FileUtils.java +45 -0
  373. package/src/main/java/org/dxworks/insider/utils/ImportUtils.java +21 -0
  374. package/src/main/java/org/dxworks/insider/utils/LibraryImport.java +17 -0
  375. package/src/main/java/org/dxworks/insider/utils/LibraryImportInOtherTechnology.java +30 -0
  376. package/src/main/java/org/dxworks/insider/utils/MapUtils.java +19 -0
  377. package/src/main/resources/insider-version +1 -0
  378. package/src/test/java/org/dxworks/insider/application/inspector/services/CommentServiceTest.java +40 -0
  379. package/src/test/java/org/dxworks/insider/technology/finder/parsers/FingerprintsXmlParserTest.java +15 -0
  380. package/src/test/java/org/dxworks/insider/utils/FileUtilsTest.java +31 -0
  381. package/src/test/java/org/dxworks/insider/utils/ImportUtilsTest.java +24 -0
  382. package/src/test/java/org/dxworks/insider/utils/transformers/JsonToCsvTransformerTest.java +18 -0
  383. package/src/test/resources/Test1.java +21 -0
  384. package/src/test/resources/Test2.java +21 -0
  385. package/src/test/resources/cobol/CM201M.CBL +88 -0
@@ -0,0 +1,97 @@
1
+ [
2
+ {
3
+ "name": "Cryptography: PRNG",
4
+ "id": "AI010000",
5
+ "description": "Cryptography: PRNG",
6
+ "tags":[ "Cryptography.Randomness.PRNG" ],
7
+ "applies_to": [
8
+ "c",
9
+ "cpp"
10
+ ],
11
+ "severity": "critical",
12
+ "patterns": [
13
+ {
14
+ "pattern": "DUAL_EC_DRBG",
15
+ "type": "string",
16
+ "scopes": [ "code" ],
17
+ "confidence": "high"
18
+ },
19
+ {
20
+ "pattern": "pseudoRandomBytes",
21
+ "type": "string",
22
+ "scopes": [ "code" ],
23
+ "confidence": "high"
24
+ },
25
+ {
26
+ "pattern": "rand|srand",
27
+ "type": "regexword",
28
+ "scopes": [ "code" ],
29
+ "confidence": "low"
30
+ }
31
+ ]
32
+ },
33
+ {
34
+ "name": "Cryptography: PRNG",
35
+ "id": "AI010100",
36
+ "description": "Cryptography: PRNG",
37
+ "tags":[ "Cryptography.Randomness.PRNG" ],
38
+ "applies_to":[ "javascript","typescript" ],
39
+ "severity": "critical",
40
+ "patterns": [
41
+ {
42
+ "pattern": "(pseudo)?randombytes",
43
+ "type": "string",
44
+ "scopes": [ "code" ],
45
+ "modifiers": [ "i" ],
46
+ "confidence": "high"
47
+ }
48
+ ]
49
+ },
50
+ {
51
+ "name": "Cryptography: PRNG",
52
+ "id": "AI010200",
53
+ "description": "Cryptography: PRNG",
54
+ "tags":[ "Cryptography.Randomness.PRNG" ],
55
+ "applies_to":[ "java" ],
56
+ "severity": "critical",
57
+ "patterns": [
58
+ {
59
+ "pattern": "SecureRandom",
60
+ "type": "string",
61
+ "scopes": [ "code" ],
62
+ "confidence": "high"
63
+ }
64
+ ]
65
+ },
66
+ {
67
+ "name": "Cryptography: PRNG",
68
+ "id": "AI010300",
69
+ "description": "Cryptography: PRNG",
70
+ "tags":[ "Cryptography.Randomness.PRNG" ],
71
+ "applies_to":[ "csharp" ],
72
+ "severity": "critical",
73
+ "patterns": [
74
+ {
75
+ "pattern": "RandomNumberGenerator",
76
+ "type": "string",
77
+ "scopes": [ "code" ],
78
+ "confidence": "high"
79
+ }
80
+ ]
81
+ },
82
+ {
83
+ "name": "Cryptography: PRNG",
84
+ "id": "AI010400",
85
+ "description": "Cryptography: PRNG",
86
+ "tags":[ "Cryptography.Randomness.PRNG" ],
87
+ "severity": "critical",
88
+ "patterns": [
89
+ {
90
+ "pattern": "random",
91
+ "type": "string",
92
+ "scopes": [ "code" ],
93
+ "confidence": "low"
94
+ }
95
+ ]
96
+ }
97
+ ]
@@ -0,0 +1,206 @@
1
+ [
2
+ {
3
+ "name": "Detect Weak Cryptography",
4
+ "id": "AI010500",
5
+ "description": "Detect use of cryptography",
6
+ "recommendation": "",
7
+ "applies_to": [
8
+ "c",
9
+ "cpp",
10
+ "csharp"
11
+ ],
12
+ "tags":[ "Cryptography.Protocol.TLS.WeakSSL" ],
13
+ "severity": "critical",
14
+ "rule_info": "",
15
+ "patterns": [
16
+ {
17
+ "pattern": "^iv.*=| +iv.*=",
18
+ "type": "regex",
19
+ "scopes": [ "code" ],
20
+ "confidence": "high"
21
+ },
22
+ {
23
+ "pattern": "SECURITY_FLAG_IGNORE_",
24
+ "type": "regex",
25
+ "scopes": [ "code" ],
26
+ "confidence": "high",
27
+ "_comment": "handles multiple ignore flag options for WinHttp"
28
+ },
29
+ {
30
+ "pattern": "SP_PROT_PCT1_",
31
+ "type": "regex",
32
+ "scopes": [ "code" ],
33
+ "confidence": "high"
34
+ },
35
+ {
36
+ "pattern": "kSSLProtocol",
37
+ "type": "regex",
38
+ "scopes": [ "code" ],
39
+ "confidence": "high"
40
+ },
41
+ {
42
+ "pattern": "CryptUnprotectData",
43
+ "type": "regex",
44
+ "scopes": [ "code" ],
45
+ "confidence": "high"
46
+ },
47
+ {
48
+ "pattern": "mwc1616",
49
+ "type": "regex",
50
+ "scopes": [ "code" ],
51
+ "confidence": "high"
52
+ },
53
+ {
54
+ "pattern": "32969|18273",
55
+ "type": "regex",
56
+ "scopes": [ "code" ],
57
+ "confidence": "high"
58
+ },
59
+ {
60
+ "pattern": "StoreName.Root",
61
+ "type": "substring",
62
+ "scopes": [ "code" ],
63
+ "confidence": "high"
64
+ },
65
+ {
66
+ "pattern": "OAUTHLIB_INSECURE_TRANSPORT",
67
+ "type": "regex",
68
+ "scopes": [ "code" ],
69
+ "confidence": "high"
70
+ },
71
+ {
72
+ "pattern": ".trustAllCerts()",
73
+ "type": "substring",
74
+ "scopes": [ "code" ],
75
+ "confidence": "high"
76
+ },
77
+ {
78
+ "pattern": ".trustAllHosts()",
79
+ "type": "substring",
80
+ "scopes": [ "code" ],
81
+ "confidence": "high"
82
+ },
83
+ {
84
+ "pattern": "NXOAuth2TrustModeAnyCertificate",
85
+ "type": "regex",
86
+ "scopes": [ "code" ],
87
+ "confidence": "high"
88
+ },
89
+ {
90
+ "pattern": "--no-check-certificate",
91
+ "type": "substring",
92
+ "scopes": [ "code" ],
93
+ "confidence": "high"
94
+ },
95
+ {
96
+ "pattern": "--insecure",
97
+ "type": "substring",
98
+ "scopes": [ "code" ],
99
+ "confidence": "high"
100
+ },
101
+ {
102
+ "pattern": "encrypt=false",
103
+ "type": "regex",
104
+ "scopes": [ "code" ],
105
+ "confidence": "high"
106
+ },
107
+ {
108
+ "pattern": "encryption=false",
109
+ "type": "regex",
110
+ "scopes": [ "code" ],
111
+ "confidence": "high"
112
+ },
113
+ {
114
+ "pattern": "OpenSSL::SSL::VERIFY_NONE",
115
+ "type": "regex",
116
+ "scopes": [ "code" ],
117
+ "confidence": "high"
118
+ },
119
+ {
120
+ "pattern": "RelaxSSLCertificateValidation",
121
+ "type": "regex",
122
+ "scopes": [ "code" ],
123
+ "confidence": "high"
124
+ },
125
+ {
126
+ "pattern": "setAllowsAnyHTTPSCertificate",
127
+ "type": "regex",
128
+ "scopes": [ "code" ],
129
+ "confidence": "high"
130
+ },
131
+ {
132
+ "pattern": "continueWithoutCredentialForAuthenticationChallenge",
133
+ "type": "regex",
134
+ "scopes": [ "code" ],
135
+ "confidence": "high"
136
+ },
137
+ {
138
+ "pattern": "disable_ssl_certificate_validation",
139
+ "type": "regex",
140
+ "scopes": [ "code" ],
141
+ "confidence": "high"
142
+ },
143
+ {
144
+ "pattern": "CERT_NONE",
145
+ "type": "regex",
146
+ "scopes": [ "code" ],
147
+ "confidence": "high"
148
+ },
149
+ {
150
+ "pattern": ".ServerCertificateValidationCallback",
151
+ "type": "substring",
152
+ "scopes": [ "code" ],
153
+ "confidence": "high"
154
+ },
155
+ {
156
+ "pattern": "IgnorableServerCertificateErrors",
157
+ "type": "regex",
158
+ "scopes": [ "code" ],
159
+ "confidence": "high"
160
+ },
161
+ {
162
+ "pattern": "certificateValidationMode",
163
+ "type": "regex",
164
+ "scopes": [ "code" ],
165
+ "confidence": "high"
166
+ },
167
+ {
168
+ "pattern": "CERT_CHAIN_POLICY_IGNORE_",
169
+ "type": "regex",
170
+ "scopes": [ "code" ],
171
+ "confidence": "high"
172
+ },
173
+ {
174
+ "pattern": "WINHTTP_ENABLE_SSL_REVOCATION",
175
+ "type": "regex",
176
+ "scopes": [ "code" ],
177
+ "confidence": "high"
178
+ },
179
+ {
180
+ "pattern": "CERT_CHAIN_REVOCATION_ACCUMULATIVE_TIMEOUT",
181
+ "type": "regex",
182
+ "scopes": [ "code" ],
183
+ "confidence": "high"
184
+ },
185
+ {
186
+ "pattern": "ISC_REQ_MANUAL_CRED_VALIDATION",
187
+ "type": "regex",
188
+ "scopes": [ "code" ],
189
+ "confidence": "high"
190
+ },
191
+ {
192
+ "pattern": "SECPKG_ATTR_REMOTE_CERT_CONTEXT",
193
+ "type": "regex",
194
+ "scopes": [ "code" ],
195
+ "confidence": "high"
196
+ },
197
+ {
198
+ "pattern": "disable_ssl_certificate_validation",
199
+ "type": "regex",
200
+ "scopes": [ "code" ],
201
+ "confidence": "high",
202
+ "modifiers": [ "i" ]
203
+ }
204
+ ]
205
+ }
206
+ ]
@@ -0,0 +1,18 @@
1
+ [
2
+ {
3
+ "name": "Data: Compressed File (Zip,Tgz)",
4
+ "id": "AI010600",
5
+ "description": "Data: Compressed File Handling",
6
+ "tags":[ "Data.Zipfile" ],
7
+ "severity": "moderate",
8
+ "patterns": [
9
+ {
10
+ "pattern": "\\.(zip|gz|gzip|gem|tar|tgz|tar\\.gz|xz|7z)",
11
+ "type": "regexword",
12
+ "scopes": [ "code" ],
13
+ "modifiers": [ "i" ],
14
+ "confidence": "high"
15
+ }
16
+ ]
17
+ }
18
+ ]
@@ -0,0 +1,361 @@
1
+ [
2
+ {
3
+ "name": "Data: ORM (SQL Alchemy)",
4
+ "id": "AI010700",
5
+ "description": "Data: ORM (SQL Alchemy)",
6
+ "applies_to": [ "python" ],
7
+ "tags":[ "Data.DBMS.ORM.SQLAlchemy" ],
8
+ "severity": "moderate",
9
+ "patterns": [
10
+ {
11
+ "pattern": "sqlalchemy",
12
+ "type": "string",
13
+ "scopes": [ "code", "comment" ],
14
+ "modifiers": [ "i" ],
15
+ "confidence": "high"
16
+ }
17
+ ]
18
+ },
19
+ {
20
+ "name": "Data: ORM (Django)",
21
+ "id": "AI010800",
22
+ "description": "Data: ORM (Django)",
23
+ "applies_to": [ "python" ],
24
+ "tags":[ "Data.DBMS.ORM.Django" ],
25
+ "severity": "moderate",
26
+ "patterns": [
27
+ {
28
+ "pattern": "django",
29
+ "type": "string",
30
+ "scopes": [ "code", "comment" ],
31
+ "modifiers": [ "i" ]
32
+ }
33
+ ]
34
+ },
35
+ {
36
+ "name": "Data: DBMS (SQLite)",
37
+ "id": "AI010900",
38
+ "description": "Data: DBMS (SQLite)",
39
+ "applies_to": [ "python" ],
40
+ "tags":[ "Data.DBMS.SQLite" ],
41
+ "severity": "moderate",
42
+ "patterns": [
43
+ {
44
+ "pattern": "sqlite|python3-apsw",
45
+ "type": "regex",
46
+ "scopes": [ "code" ],
47
+ "confidence": "high",
48
+ "modifiers": [ "i" ]
49
+ },
50
+ {
51
+ "pattern": "apsw",
52
+ "type": "string",
53
+ "scopes": [ "code" ],
54
+ "confidence": "medium",
55
+ "modifiers": [ "i" ]
56
+ }
57
+ ]
58
+ },
59
+ {
60
+ "name": "Data: DBMS (SQLite)",
61
+ "id": "AI010910",
62
+ "description": "Data: DBMS (SQLite)",
63
+ "applies_to": [ "csharp" ],
64
+ "tags":[ "Data.DBMS.SQLite" ],
65
+ "severity": "moderate",
66
+ "patterns": [
67
+ {
68
+ "pattern": "SqliteCommand|SqliteConnection|System\\.Data\\.SQLite|Microsoft\\.Data\\.SQLite",
69
+ "type": "regex",
70
+ "scopes": [ "code" ],
71
+ "confidence": "high"
72
+ }
73
+ ]
74
+ },
75
+ {
76
+ "name": "Data: DBMS (SQLite)",
77
+ "id": "AI010920",
78
+ "description": "Data: DBMS (SQLite)",
79
+ "applies_to": [
80
+ "java",
81
+ "objective-c",
82
+ "php",
83
+ "c",
84
+ "cpp"
85
+ ],
86
+ "tags":[ "Data.DBMS.SQLite" ],
87
+ "severity": "moderate",
88
+ "patterns": [
89
+ {
90
+ "pattern": "sqlite",
91
+ "type": "regex",
92
+ "scopes": [ "code" ],
93
+ "confidence": "high",
94
+ "modifiers": [ "i" ]
95
+ }
96
+ ]
97
+ },
98
+ {
99
+ "name": "Data: DBMS (PostgreSQL)",
100
+ "id": "AI011000",
101
+ "description": "Data: DBMS (PostgreSQL)",
102
+ "applies_to": [ "javascript", "typescript" ],
103
+ "tags":[ "Data.DBMS.PostgreSQL" ],
104
+ "severity": "moderate",
105
+ "patterns": [
106
+ {
107
+ "pattern": "(pgsql|PG)\\.connect|PG::Connection",
108
+ "type": "regex",
109
+ "scopes": [ "code" ],
110
+ "modifiers": [ "i" ],
111
+ "confidence": "high"
112
+ },
113
+ {
114
+ "pattern": "require(['\"]pg['\"]);",
115
+ "type": "regexword",
116
+ "scopes": [ "code" ],
117
+ "confidence": "high"
118
+ }
119
+ ]
120
+ },
121
+ {
122
+ "name": "Data: DBMS (PostgreSQL)",
123
+ "id": "AI011010",
124
+ "description": "Data: DBMS (PostgreSQL)",
125
+ "applies_to": [ "ruby" ],
126
+ "tags":[ "Data.DBMS.PostgreSQL" ],
127
+ "severity": "moderate",
128
+ "patterns": [
129
+ {
130
+ "pattern": "require 'pg'|(pgsql|PG)\\.connect|PG::Connection",
131
+ "type": "regex",
132
+ "scopes": [ "code" ],
133
+ "modifiers": [ "i" ],
134
+ "confidence": "high"
135
+ }
136
+ ]
137
+ },
138
+ {
139
+ "name": "Data: DBMS (PostgreSQL)",
140
+ "id": "AI011100",
141
+ "description": "Data: DBMS (PostgreSQL)",
142
+ "applies_to": [ "python" ],
143
+ "tags":[ "Data.DBMS.PostgreSQL" ],
144
+ "severity": "moderate",
145
+ "patterns": [
146
+ {
147
+ "pattern": "psycopg2",
148
+ "type": "string",
149
+ "scopes": [ "code" ],
150
+ "modifiers": [ "i" ],
151
+ "confidence": "high"
152
+ }
153
+ ]
154
+ },
155
+ {
156
+ "name": "Data: DBMS (PostgreSQL)",
157
+ "id": "AI011200",
158
+ "description": "Data: DBMS (PostgreSQL)",
159
+ "applies_to": [ "csharp" ],
160
+ "tags":[ "Data.DBMS.PostgreSQL" ],
161
+ "severity": "moderate",
162
+ "patterns": [
163
+ {
164
+ "pattern": "npgsql",
165
+ "type": "string",
166
+ "scopes": [ "code" ],
167
+ "modifiers": [ "i" ],
168
+ "confidence": "high"
169
+ }
170
+ ]
171
+ },
172
+ {
173
+ "name": "Data: DBMS (NoSQL)",
174
+ "id": "AI011300",
175
+ "description": "Data: DBMS (NoSQL)",
176
+ "tags":[ "Data.DBMS.NoSQL" ],
177
+ "severity": "moderate",
178
+ "patterns": [
179
+ {
180
+ "pattern": "mongodb|mongoose|mongoclient|pymongo|redis|hbase|neo4j|cassandra|couchbase|memcached|couchdb|litedb|LiteDatabase|tinydb",
181
+ "type": "regexword",
182
+ "scopes": [ "code" ],
183
+ "modifiers": [ "i" ],
184
+ "confidence": "high"
185
+ }
186
+ ]
187
+ },
188
+ {
189
+ "name": "Data: DBMS (SQL)",
190
+ "id": "AI011400",
191
+ "description": "Data: DBMS SQL",
192
+ "applies_to": [ "java" ],
193
+ "tags":[ "Data.DBMS.SQL" ],
194
+ "severity": "moderate",
195
+ "patterns": [
196
+ {
197
+ "pattern": "import java.sql",
198
+ "type": "string",
199
+ "scopes": [ "code" ],
200
+ "confidence": "high"
201
+ }
202
+ ]
203
+ },
204
+ {
205
+ "name": "Data: DBMS (SQL)",
206
+ "id": "AI011500",
207
+ "description": "Data: DBMS (SQL)",
208
+ "applies_to": [ "csharp" ],
209
+ "tags":[ "Data.DBMS.SQL" ],
210
+ "severity": "moderate",
211
+ "patterns": [
212
+ {
213
+ "pattern": "using system.data.sqlclient",
214
+ "type": "string",
215
+ "scopes": [ "code" ],
216
+ "confidence": "high"
217
+ }
218
+ ]
219
+ },
220
+ {
221
+ "name": "Data: DBMS (SQL)",
222
+ "id": "AI011600",
223
+ "description": "Data: DBMS (SQL)",
224
+ "applies_to": [],
225
+ "tags":[ "Data.DBMS.SQL" ],
226
+ "severity": "moderate",
227
+ "patterns": [
228
+ {
229
+ "pattern": "['\\\"](select|insert|delete|update)\\s.*",
230
+ "type": "regex",
231
+ "scopes": [ "code" ],
232
+ "modifiers": [ "i" ],
233
+ "confidence": "high"
234
+ }
235
+ ],
236
+ "conditions": [
237
+ {
238
+ "pattern": {
239
+ "pattern": "from|where",
240
+ "type": "regexword",
241
+ "scopes": [ "code" ],
242
+ "modifiers": [ "i" ]
243
+ },
244
+ "search_in": "finding-region(-5,5)",
245
+ "negate_finding": false
246
+ }
247
+ ]
248
+ },
249
+ {
250
+ "name": "Data: DBMS (SQL)",
251
+ "id": "AI011610",
252
+ "description": "Data: DBMS (SQL)",
253
+ "applies_to": [],
254
+ "tags":[ "Data.DBMS.SQL" ],
255
+ "severity": "moderate",
256
+ "patterns": [
257
+ {
258
+ "pattern": "mysql",
259
+ "type": "string",
260
+ "scopes": [ "code" ],
261
+ "modifiers": [ "i" ],
262
+ "confidence": "high"
263
+ }
264
+ ]
265
+ },
266
+ {
267
+ "name": "Data: DBMS (Oracle)",
268
+ "id": "AI011700",
269
+ "description": "Data: DBMS (Oracle)",
270
+ "applies_to": [ "java", "pom.xml" ],
271
+ "tags":[ "Data.DBMS.SQL.Oracle" ],
272
+ "severity": "moderate",
273
+ "patterns": [
274
+ {
275
+ "pattern": "oracle\\.jdbc|oracledriver|com.oracle",
276
+ "type": "regex",
277
+ "scopes": [ "code" ],
278
+ "confidence": "high"
279
+ },
280
+ {
281
+ "pattern": "oracle",
282
+ "type": "string",
283
+ "scopes": [ "code" ],
284
+ "modifiers": [ "i" ],
285
+ "confidence": "medium"
286
+ }
287
+ ]
288
+ },
289
+ {
290
+ "name": "Data: DBMS (Oracle)",
291
+ "id": "AI011800",
292
+ "description": "Data: DBMS (Oracle)",
293
+ "applies_to": [ "python" ],
294
+ "tags":[ "Data.DBMS.SQL.Oracle" ],
295
+ "severity": "moderate",
296
+ "patterns": [
297
+ {
298
+ "pattern": "import cx_Oracle",
299
+ "type": "regex",
300
+ "scopes": [ "code" ],
301
+ "modifiers": [ "i" ],
302
+ "confidence": "high"
303
+ },
304
+ {
305
+ "pattern": "oracle",
306
+ "type": "string",
307
+ "scopes": [ "code" ],
308
+ "modifiers": [ "i" ],
309
+ "confidence": "low"
310
+ }
311
+ ]
312
+ },
313
+ {
314
+ "name": "Data: DBMS (General)",
315
+ "id": "AI011900",
316
+ "description": "Data: DBMS (General)",
317
+ "applies_to": [ "csharp", "cpp", "java", "python", "objective-c", "go" ],
318
+ "tags":[ "Data.DBMS.General" ],
319
+ "severity": "moderate",
320
+ "patterns": [
321
+ {
322
+ "pattern": "database",
323
+ "type": "string",
324
+ "scopes": [ "code", "comment" ],
325
+ "confidence": "high"
326
+ }
327
+ ]
328
+ },
329
+ {
330
+ "name": "Data: ODBC",
331
+ "id": "AI012000",
332
+ "description": "Data: ODBC",
333
+ "applies_to": [ "csharp" ],
334
+ "tags":[ "Data.DBMS.Connection.ODBC" ],
335
+ "severity": "moderate",
336
+ "patterns": [
337
+ {
338
+ "pattern": "OdbcConnection|OdbcCommand|OdbcDataReader",
339
+ "type": "regexword",
340
+ "scopes": [ "code" ],
341
+ "confidence": "high"
342
+ }
343
+ ]
344
+ },
345
+ {
346
+ "name": "Data: ODBC",
347
+ "id": "AI012010",
348
+ "description": "Data: ODBC",
349
+ "applies_to": [ "csharp", "cpp", "java", "python", "objective-c", "go" ],
350
+ "tags":[ "Data.DBMS.Connection.ODBC" ],
351
+ "severity": "moderate",
352
+ "patterns": [
353
+ {
354
+ "pattern": "Odbc",
355
+ "type": "string",
356
+ "scopes": [ "code" ],
357
+ "confidence": "high"
358
+ }
359
+ ]
360
+ }
361
+ ]