@mitre/hdf-converters 2.12.6 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (828) hide show
  1. package/README.md +139 -56
  2. package/dist/converters/aws-config-to-hdf/typescript/converter.d.ts +9 -0
  3. package/dist/converters/aws-config-to-hdf/typescript/converter.d.ts.map +1 -0
  4. package/dist/converters/aws-config-to-hdf/typescript/converter.js +132 -0
  5. package/dist/converters/aws-config-to-hdf/typescript/converter.js.map +1 -0
  6. package/dist/converters/aws-config-to-hdf/typescript/fingerprint.d.ts +10 -0
  7. package/dist/converters/aws-config-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  8. package/dist/converters/aws-config-to-hdf/typescript/fingerprint.js +32 -0
  9. package/dist/converters/aws-config-to-hdf/typescript/fingerprint.js.map +1 -0
  10. package/dist/converters/aws-config-to-hdf/typescript/index.d.ts +2 -0
  11. package/dist/converters/aws-config-to-hdf/typescript/index.d.ts.map +1 -0
  12. package/dist/converters/aws-config-to-hdf/typescript/index.js +2 -0
  13. package/dist/converters/aws-config-to-hdf/typescript/index.js.map +1 -0
  14. package/dist/converters/burpsuite-to-hdf/typescript/converter.d.ts +11 -0
  15. package/dist/converters/burpsuite-to-hdf/typescript/converter.d.ts.map +1 -0
  16. package/dist/converters/burpsuite-to-hdf/typescript/converter.js +169 -0
  17. package/dist/converters/burpsuite-to-hdf/typescript/converter.js.map +1 -0
  18. package/dist/converters/burpsuite-to-hdf/typescript/fingerprint.d.ts +9 -0
  19. package/dist/converters/burpsuite-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  20. package/dist/converters/burpsuite-to-hdf/typescript/fingerprint.js +33 -0
  21. package/dist/converters/burpsuite-to-hdf/typescript/fingerprint.js.map +1 -0
  22. package/dist/converters/burpsuite-to-hdf/typescript/index.d.ts +2 -0
  23. package/dist/converters/burpsuite-to-hdf/typescript/index.d.ts.map +1 -0
  24. package/dist/converters/burpsuite-to-hdf/typescript/index.js +2 -0
  25. package/dist/converters/burpsuite-to-hdf/typescript/index.js.map +1 -0
  26. package/dist/converters/conveyor-to-hdf/typescript/converter.d.ts +9 -0
  27. package/dist/converters/conveyor-to-hdf/typescript/converter.d.ts.map +1 -0
  28. package/dist/converters/conveyor-to-hdf/typescript/converter.js +206 -0
  29. package/dist/converters/conveyor-to-hdf/typescript/converter.js.map +1 -0
  30. package/dist/converters/conveyor-to-hdf/typescript/fingerprint.d.ts +10 -0
  31. package/dist/converters/conveyor-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  32. package/dist/converters/conveyor-to-hdf/typescript/fingerprint.js +37 -0
  33. package/dist/converters/conveyor-to-hdf/typescript/fingerprint.js.map +1 -0
  34. package/dist/converters/conveyor-to-hdf/typescript/index.d.ts +2 -0
  35. package/dist/converters/conveyor-to-hdf/typescript/index.d.ts.map +1 -0
  36. package/dist/converters/conveyor-to-hdf/typescript/index.js +2 -0
  37. package/dist/converters/conveyor-to-hdf/typescript/index.js.map +1 -0
  38. package/dist/converters/cyclonedx-to-hdf/typescript/converter.d.ts +8 -0
  39. package/dist/converters/cyclonedx-to-hdf/typescript/converter.d.ts.map +1 -0
  40. package/dist/converters/cyclonedx-to-hdf/typescript/converter.js +199 -0
  41. package/dist/converters/cyclonedx-to-hdf/typescript/converter.js.map +1 -0
  42. package/dist/converters/cyclonedx-to-hdf/typescript/fingerprint.d.ts +10 -0
  43. package/dist/converters/cyclonedx-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  44. package/dist/converters/cyclonedx-to-hdf/typescript/fingerprint.js +34 -0
  45. package/dist/converters/cyclonedx-to-hdf/typescript/fingerprint.js.map +1 -0
  46. package/dist/converters/cyclonedx-to-hdf/typescript/index.d.ts +2 -0
  47. package/dist/converters/cyclonedx-to-hdf/typescript/index.d.ts.map +1 -0
  48. package/dist/converters/cyclonedx-to-hdf/typescript/index.js +2 -0
  49. package/dist/converters/cyclonedx-to-hdf/typescript/index.js.map +1 -0
  50. package/dist/converters/dbprotect-to-hdf/typescript/converter.d.ts +10 -0
  51. package/dist/converters/dbprotect-to-hdf/typescript/converter.d.ts.map +1 -0
  52. package/dist/converters/dbprotect-to-hdf/typescript/converter.js +171 -0
  53. package/dist/converters/dbprotect-to-hdf/typescript/converter.js.map +1 -0
  54. package/dist/converters/dbprotect-to-hdf/typescript/fingerprint.d.ts +10 -0
  55. package/dist/converters/dbprotect-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  56. package/dist/converters/dbprotect-to-hdf/typescript/fingerprint.js +35 -0
  57. package/dist/converters/dbprotect-to-hdf/typescript/fingerprint.js.map +1 -0
  58. package/dist/converters/dbprotect-to-hdf/typescript/index.d.ts +2 -0
  59. package/dist/converters/dbprotect-to-hdf/typescript/index.d.ts.map +1 -0
  60. package/dist/converters/dbprotect-to-hdf/typescript/index.js +2 -0
  61. package/dist/converters/dbprotect-to-hdf/typescript/index.js.map +1 -0
  62. package/dist/converters/deptrack-to-hdf/typescript/converter.d.ts +8 -0
  63. package/dist/converters/deptrack-to-hdf/typescript/converter.d.ts.map +1 -0
  64. package/dist/converters/deptrack-to-hdf/typescript/converter.js +120 -0
  65. package/dist/converters/deptrack-to-hdf/typescript/converter.js.map +1 -0
  66. package/dist/converters/deptrack-to-hdf/typescript/fingerprint.d.ts +10 -0
  67. package/dist/converters/deptrack-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  68. package/dist/converters/deptrack-to-hdf/typescript/fingerprint.js +46 -0
  69. package/dist/converters/deptrack-to-hdf/typescript/fingerprint.js.map +1 -0
  70. package/dist/converters/deptrack-to-hdf/typescript/index.d.ts +2 -0
  71. package/dist/converters/deptrack-to-hdf/typescript/index.d.ts.map +1 -0
  72. package/dist/converters/deptrack-to-hdf/typescript/index.js +2 -0
  73. package/dist/converters/deptrack-to-hdf/typescript/index.js.map +1 -0
  74. package/dist/converters/fortify-to-hdf/typescript/converter.d.ts +12 -0
  75. package/dist/converters/fortify-to-hdf/typescript/converter.d.ts.map +1 -0
  76. package/dist/converters/fortify-to-hdf/typescript/converter.js +211 -0
  77. package/dist/converters/fortify-to-hdf/typescript/converter.js.map +1 -0
  78. package/dist/converters/fortify-to-hdf/typescript/fingerprint.d.ts +11 -0
  79. package/dist/converters/fortify-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  80. package/dist/converters/fortify-to-hdf/typescript/fingerprint.js +42 -0
  81. package/dist/converters/fortify-to-hdf/typescript/fingerprint.js.map +1 -0
  82. package/dist/converters/fortify-to-hdf/typescript/index.d.ts +2 -0
  83. package/dist/converters/fortify-to-hdf/typescript/index.d.ts.map +1 -0
  84. package/dist/converters/fortify-to-hdf/typescript/index.js +2 -0
  85. package/dist/converters/fortify-to-hdf/typescript/index.js.map +1 -0
  86. package/dist/converters/gitlab-to-hdf/typescript/converter.d.ts +2 -0
  87. package/dist/converters/gitlab-to-hdf/typescript/converter.d.ts.map +1 -0
  88. package/dist/converters/gitlab-to-hdf/typescript/converter.js +222 -0
  89. package/dist/converters/gitlab-to-hdf/typescript/converter.js.map +1 -0
  90. package/dist/converters/gitlab-to-hdf/typescript/fingerprint.d.ts +10 -0
  91. package/dist/converters/gitlab-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  92. package/dist/converters/gitlab-to-hdf/typescript/fingerprint.js +37 -0
  93. package/dist/converters/gitlab-to-hdf/typescript/fingerprint.js.map +1 -0
  94. package/dist/converters/gitlab-to-hdf/typescript/index.d.ts +2 -0
  95. package/dist/converters/gitlab-to-hdf/typescript/index.d.ts.map +1 -0
  96. package/dist/converters/gitlab-to-hdf/typescript/index.js +2 -0
  97. package/dist/converters/gitlab-to-hdf/typescript/index.js.map +1 -0
  98. package/dist/converters/gosec-to-hdf/typescript/converter.d.ts +10 -0
  99. package/dist/converters/gosec-to-hdf/typescript/converter.d.ts.map +1 -0
  100. package/dist/converters/gosec-to-hdf/typescript/converter.js +126 -0
  101. package/dist/converters/gosec-to-hdf/typescript/converter.js.map +1 -0
  102. package/dist/converters/gosec-to-hdf/typescript/fingerprint.d.ts +10 -0
  103. package/dist/converters/gosec-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  104. package/dist/converters/gosec-to-hdf/typescript/fingerprint.js +32 -0
  105. package/dist/converters/gosec-to-hdf/typescript/fingerprint.js.map +1 -0
  106. package/dist/converters/gosec-to-hdf/typescript/index.d.ts +2 -0
  107. package/dist/converters/gosec-to-hdf/typescript/index.d.ts.map +1 -0
  108. package/dist/converters/gosec-to-hdf/typescript/index.js +2 -0
  109. package/dist/converters/gosec-to-hdf/typescript/index.js.map +1 -0
  110. package/dist/converters/grype-to-hdf/typescript/converter.d.ts +2 -0
  111. package/dist/converters/grype-to-hdf/typescript/converter.d.ts.map +1 -0
  112. package/dist/converters/grype-to-hdf/typescript/converter.js +222 -0
  113. package/dist/converters/grype-to-hdf/typescript/converter.js.map +1 -0
  114. package/dist/converters/grype-to-hdf/typescript/fingerprint.d.ts +10 -0
  115. package/dist/converters/grype-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  116. package/dist/converters/grype-to-hdf/typescript/fingerprint.js +38 -0
  117. package/dist/converters/grype-to-hdf/typescript/fingerprint.js.map +1 -0
  118. package/dist/converters/grype-to-hdf/typescript/index.d.ts +2 -0
  119. package/dist/converters/grype-to-hdf/typescript/index.d.ts.map +1 -0
  120. package/dist/converters/grype-to-hdf/typescript/index.js +2 -0
  121. package/dist/converters/grype-to-hdf/typescript/index.js.map +1 -0
  122. package/dist/converters/hdf-to-csv/typescript/converter.d.ts +7 -0
  123. package/dist/converters/hdf-to-csv/typescript/converter.d.ts.map +1 -0
  124. package/dist/converters/hdf-to-csv/typescript/converter.js +108 -0
  125. package/dist/converters/hdf-to-csv/typescript/converter.js.map +1 -0
  126. package/dist/converters/hdf-to-csv/typescript/fingerprint.d.ts +10 -0
  127. package/dist/converters/hdf-to-csv/typescript/fingerprint.d.ts.map +1 -0
  128. package/dist/converters/hdf-to-csv/typescript/fingerprint.js +28 -0
  129. package/dist/converters/hdf-to-csv/typescript/fingerprint.js.map +1 -0
  130. package/dist/converters/hdf-to-csv/typescript/index.d.ts +2 -0
  131. package/dist/converters/hdf-to-csv/typescript/index.d.ts.map +1 -0
  132. package/dist/converters/hdf-to-csv/typescript/index.js +2 -0
  133. package/dist/converters/hdf-to-csv/typescript/index.js.map +1 -0
  134. package/dist/converters/hdf-to-oscal-poam/typescript/converter.d.ts +13 -0
  135. package/dist/converters/hdf-to-oscal-poam/typescript/converter.d.ts.map +1 -0
  136. package/dist/converters/hdf-to-oscal-poam/typescript/converter.js +156 -0
  137. package/dist/converters/hdf-to-oscal-poam/typescript/converter.js.map +1 -0
  138. package/dist/converters/hdf-to-oscal-poam/typescript/fingerprint.d.ts +10 -0
  139. package/dist/converters/hdf-to-oscal-poam/typescript/fingerprint.d.ts.map +1 -0
  140. package/dist/converters/hdf-to-oscal-poam/typescript/fingerprint.js +28 -0
  141. package/dist/converters/hdf-to-oscal-poam/typescript/fingerprint.js.map +1 -0
  142. package/dist/converters/hdf-to-oscal-poam/typescript/index.d.ts +2 -0
  143. package/dist/converters/hdf-to-oscal-poam/typescript/index.d.ts.map +1 -0
  144. package/dist/converters/hdf-to-oscal-poam/typescript/index.js +2 -0
  145. package/dist/converters/hdf-to-oscal-poam/typescript/index.js.map +1 -0
  146. package/dist/converters/hdf-to-oscal-sar/typescript/converter.d.ts +22 -0
  147. package/dist/converters/hdf-to-oscal-sar/typescript/converter.d.ts.map +1 -0
  148. package/dist/converters/hdf-to-oscal-sar/typescript/converter.js +276 -0
  149. package/dist/converters/hdf-to-oscal-sar/typescript/converter.js.map +1 -0
  150. package/dist/converters/hdf-to-oscal-sar/typescript/fingerprint.d.ts +10 -0
  151. package/dist/converters/hdf-to-oscal-sar/typescript/fingerprint.d.ts.map +1 -0
  152. package/dist/converters/hdf-to-oscal-sar/typescript/fingerprint.js +28 -0
  153. package/dist/converters/hdf-to-oscal-sar/typescript/fingerprint.js.map +1 -0
  154. package/dist/converters/hdf-to-oscal-sar/typescript/index.d.ts +2 -0
  155. package/dist/converters/hdf-to-oscal-sar/typescript/index.d.ts.map +1 -0
  156. package/dist/converters/hdf-to-oscal-sar/typescript/index.js +2 -0
  157. package/dist/converters/hdf-to-oscal-sar/typescript/index.js.map +1 -0
  158. package/dist/converters/hdf-to-xccdf/typescript/converter.d.ts +8 -0
  159. package/dist/converters/hdf-to-xccdf/typescript/converter.d.ts.map +1 -0
  160. package/dist/converters/hdf-to-xccdf/typescript/converter.js +186 -0
  161. package/dist/converters/hdf-to-xccdf/typescript/converter.js.map +1 -0
  162. package/dist/converters/hdf-to-xccdf/typescript/index.d.ts +2 -0
  163. package/dist/converters/hdf-to-xccdf/typescript/index.d.ts.map +1 -0
  164. package/dist/converters/hdf-to-xccdf/typescript/index.js +2 -0
  165. package/dist/converters/hdf-to-xccdf/typescript/index.js.map +1 -0
  166. package/dist/converters/hdf-to-xml/typescript/converter.d.ts +7 -0
  167. package/dist/converters/hdf-to-xml/typescript/converter.d.ts.map +1 -0
  168. package/dist/converters/hdf-to-xml/typescript/converter.js +140 -0
  169. package/dist/converters/hdf-to-xml/typescript/converter.js.map +1 -0
  170. package/dist/converters/hdf-to-xml/typescript/fingerprint.d.ts +10 -0
  171. package/dist/converters/hdf-to-xml/typescript/fingerprint.d.ts.map +1 -0
  172. package/dist/converters/hdf-to-xml/typescript/fingerprint.js +28 -0
  173. package/dist/converters/hdf-to-xml/typescript/fingerprint.js.map +1 -0
  174. package/dist/converters/hdf-to-xml/typescript/index.d.ts +2 -0
  175. package/dist/converters/hdf-to-xml/typescript/index.d.ts.map +1 -0
  176. package/dist/converters/hdf-to-xml/typescript/index.js +2 -0
  177. package/dist/converters/hdf-to-xml/typescript/index.js.map +1 -0
  178. package/dist/converters/hdf-v2-passthrough/typescript/fingerprint.d.ts +15 -0
  179. package/dist/converters/hdf-v2-passthrough/typescript/fingerprint.d.ts.map +1 -0
  180. package/dist/converters/hdf-v2-passthrough/typescript/fingerprint.js +33 -0
  181. package/dist/converters/hdf-v2-passthrough/typescript/fingerprint.js.map +1 -0
  182. package/dist/converters/ionchannel-to-hdf/typescript/converter.d.ts +2 -0
  183. package/dist/converters/ionchannel-to-hdf/typescript/converter.d.ts.map +1 -0
  184. package/dist/converters/ionchannel-to-hdf/typescript/converter.js +150 -0
  185. package/dist/converters/ionchannel-to-hdf/typescript/converter.js.map +1 -0
  186. package/dist/converters/ionchannel-to-hdf/typescript/fingerprint.d.ts +11 -0
  187. package/dist/converters/ionchannel-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  188. package/dist/converters/ionchannel-to-hdf/typescript/fingerprint.js +41 -0
  189. package/dist/converters/ionchannel-to-hdf/typescript/fingerprint.js.map +1 -0
  190. package/dist/converters/ionchannel-to-hdf/typescript/index.d.ts +2 -0
  191. package/dist/converters/ionchannel-to-hdf/typescript/index.d.ts.map +1 -0
  192. package/dist/converters/ionchannel-to-hdf/typescript/index.js +2 -0
  193. package/dist/converters/ionchannel-to-hdf/typescript/index.js.map +1 -0
  194. package/dist/converters/jfrog-xray-to-hdf/typescript/converter.d.ts +8 -0
  195. package/dist/converters/jfrog-xray-to-hdf/typescript/converter.d.ts.map +1 -0
  196. package/dist/converters/jfrog-xray-to-hdf/typescript/converter.js +149 -0
  197. package/dist/converters/jfrog-xray-to-hdf/typescript/converter.js.map +1 -0
  198. package/dist/converters/jfrog-xray-to-hdf/typescript/fingerprint.d.ts +10 -0
  199. package/dist/converters/jfrog-xray-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  200. package/dist/converters/jfrog-xray-to-hdf/typescript/fingerprint.js +28 -0
  201. package/dist/converters/jfrog-xray-to-hdf/typescript/fingerprint.js.map +1 -0
  202. package/dist/converters/jfrog-xray-to-hdf/typescript/index.d.ts +2 -0
  203. package/dist/converters/jfrog-xray-to-hdf/typescript/index.d.ts.map +1 -0
  204. package/dist/converters/jfrog-xray-to-hdf/typescript/index.js +2 -0
  205. package/dist/converters/jfrog-xray-to-hdf/typescript/index.js.map +1 -0
  206. package/dist/converters/junit-to-hdf/typescript/converter.d.ts +5 -0
  207. package/dist/converters/junit-to-hdf/typescript/converter.d.ts.map +1 -0
  208. package/dist/converters/junit-to-hdf/typescript/converter.js +142 -0
  209. package/dist/converters/junit-to-hdf/typescript/converter.js.map +1 -0
  210. package/dist/converters/junit-to-hdf/typescript/fingerprint.d.ts +9 -0
  211. package/dist/converters/junit-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  212. package/dist/converters/junit-to-hdf/typescript/fingerprint.js +28 -0
  213. package/dist/converters/junit-to-hdf/typescript/fingerprint.js.map +1 -0
  214. package/dist/converters/junit-to-hdf/typescript/index.d.ts +2 -0
  215. package/dist/converters/junit-to-hdf/typescript/index.d.ts.map +1 -0
  216. package/dist/converters/junit-to-hdf/typescript/index.js +2 -0
  217. package/dist/converters/junit-to-hdf/typescript/index.js.map +1 -0
  218. package/dist/converters/legacyhdf-to-hdf/typescript/converter.d.ts +232 -0
  219. package/dist/converters/legacyhdf-to-hdf/typescript/converter.d.ts.map +1 -0
  220. package/dist/converters/legacyhdf-to-hdf/typescript/converter.js +418 -0
  221. package/dist/converters/legacyhdf-to-hdf/typescript/converter.js.map +1 -0
  222. package/dist/converters/legacyhdf-to-hdf/typescript/fingerprint.d.ts +17 -0
  223. package/dist/converters/legacyhdf-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  224. package/dist/converters/legacyhdf-to-hdf/typescript/fingerprint.js +49 -0
  225. package/dist/converters/legacyhdf-to-hdf/typescript/fingerprint.js.map +1 -0
  226. package/dist/converters/legacyhdf-to-hdf/typescript/index.d.ts +8 -0
  227. package/dist/converters/legacyhdf-to-hdf/typescript/index.d.ts.map +1 -0
  228. package/dist/converters/legacyhdf-to-hdf/typescript/index.js +8 -0
  229. package/dist/converters/legacyhdf-to-hdf/typescript/index.js.map +1 -0
  230. package/dist/converters/msft-defender-cloud-to-hdf/typescript/converter.d.ts +8 -0
  231. package/dist/converters/msft-defender-cloud-to-hdf/typescript/converter.d.ts.map +1 -0
  232. package/dist/converters/msft-defender-cloud-to-hdf/typescript/converter.js +153 -0
  233. package/dist/converters/msft-defender-cloud-to-hdf/typescript/converter.js.map +1 -0
  234. package/dist/converters/msft-defender-cloud-to-hdf/typescript/fingerprint.d.ts +11 -0
  235. package/dist/converters/msft-defender-cloud-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  236. package/dist/converters/msft-defender-cloud-to-hdf/typescript/fingerprint.js +37 -0
  237. package/dist/converters/msft-defender-cloud-to-hdf/typescript/fingerprint.js.map +1 -0
  238. package/dist/converters/msft-defender-cloud-to-hdf/typescript/index.d.ts +2 -0
  239. package/dist/converters/msft-defender-cloud-to-hdf/typescript/index.d.ts.map +1 -0
  240. package/dist/converters/msft-defender-cloud-to-hdf/typescript/index.js +2 -0
  241. package/dist/converters/msft-defender-cloud-to-hdf/typescript/index.js.map +1 -0
  242. package/dist/converters/msft-defender-devops-to-hdf/typescript/converter.d.ts +7 -0
  243. package/dist/converters/msft-defender-devops-to-hdf/typescript/converter.d.ts.map +1 -0
  244. package/dist/converters/msft-defender-devops-to-hdf/typescript/converter.js +126 -0
  245. package/dist/converters/msft-defender-devops-to-hdf/typescript/converter.js.map +1 -0
  246. package/dist/converters/msft-defender-devops-to-hdf/typescript/fingerprint.d.ts +13 -0
  247. package/dist/converters/msft-defender-devops-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  248. package/dist/converters/msft-defender-devops-to-hdf/typescript/fingerprint.js +62 -0
  249. package/dist/converters/msft-defender-devops-to-hdf/typescript/fingerprint.js.map +1 -0
  250. package/dist/converters/msft-defender-devops-to-hdf/typescript/index.d.ts +2 -0
  251. package/dist/converters/msft-defender-devops-to-hdf/typescript/index.d.ts.map +1 -0
  252. package/dist/converters/msft-defender-devops-to-hdf/typescript/index.js +2 -0
  253. package/dist/converters/msft-defender-devops-to-hdf/typescript/index.js.map +1 -0
  254. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/converter.d.ts +9 -0
  255. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/converter.d.ts.map +1 -0
  256. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/converter.js +194 -0
  257. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/converter.js.map +1 -0
  258. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/fingerprint.d.ts +11 -0
  259. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  260. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/fingerprint.js +39 -0
  261. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/fingerprint.js.map +1 -0
  262. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/index.d.ts +2 -0
  263. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/index.d.ts.map +1 -0
  264. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/index.js +2 -0
  265. package/dist/converters/msft-defender-endpoint-to-hdf/typescript/index.js.map +1 -0
  266. package/dist/converters/msft-secure-score-to-hdf/typescript/converter.d.ts +11 -0
  267. package/dist/converters/msft-secure-score-to-hdf/typescript/converter.d.ts.map +1 -0
  268. package/dist/converters/msft-secure-score-to-hdf/typescript/converter.js +160 -0
  269. package/dist/converters/msft-secure-score-to-hdf/typescript/converter.js.map +1 -0
  270. package/dist/converters/msft-secure-score-to-hdf/typescript/fingerprint.d.ts +11 -0
  271. package/dist/converters/msft-secure-score-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  272. package/dist/converters/msft-secure-score-to-hdf/typescript/fingerprint.js +41 -0
  273. package/dist/converters/msft-secure-score-to-hdf/typescript/fingerprint.js.map +1 -0
  274. package/dist/converters/msft-secure-score-to-hdf/typescript/index.d.ts +2 -0
  275. package/dist/converters/msft-secure-score-to-hdf/typescript/index.d.ts.map +1 -0
  276. package/dist/converters/msft-secure-score-to-hdf/typescript/index.js +2 -0
  277. package/dist/converters/msft-secure-score-to-hdf/typescript/index.js.map +1 -0
  278. package/dist/converters/nessus-to-hdf/typescript/converter.d.ts +6 -0
  279. package/dist/converters/nessus-to-hdf/typescript/converter.d.ts.map +1 -0
  280. package/dist/converters/nessus-to-hdf/typescript/converter.js +329 -0
  281. package/dist/converters/nessus-to-hdf/typescript/converter.js.map +1 -0
  282. package/dist/converters/nessus-to-hdf/typescript/fingerprint.d.ts +9 -0
  283. package/dist/converters/nessus-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  284. package/dist/converters/nessus-to-hdf/typescript/fingerprint.js +34 -0
  285. package/dist/converters/nessus-to-hdf/typescript/fingerprint.js.map +1 -0
  286. package/dist/converters/nessus-to-hdf/typescript/index.d.ts +2 -0
  287. package/dist/converters/nessus-to-hdf/typescript/index.d.ts.map +1 -0
  288. package/dist/converters/nessus-to-hdf/typescript/index.js +2 -0
  289. package/dist/converters/nessus-to-hdf/typescript/index.js.map +1 -0
  290. package/dist/converters/netsparker-to-hdf/typescript/converter.d.ts +9 -0
  291. package/dist/converters/netsparker-to-hdf/typescript/converter.d.ts.map +1 -0
  292. package/dist/converters/netsparker-to-hdf/typescript/converter.js +211 -0
  293. package/dist/converters/netsparker-to-hdf/typescript/converter.js.map +1 -0
  294. package/dist/converters/netsparker-to-hdf/typescript/fingerprint.d.ts +10 -0
  295. package/dist/converters/netsparker-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  296. package/dist/converters/netsparker-to-hdf/typescript/fingerprint.js +29 -0
  297. package/dist/converters/netsparker-to-hdf/typescript/fingerprint.js.map +1 -0
  298. package/dist/converters/netsparker-to-hdf/typescript/index.d.ts +2 -0
  299. package/dist/converters/netsparker-to-hdf/typescript/index.d.ts.map +1 -0
  300. package/dist/converters/netsparker-to-hdf/typescript/index.js +2 -0
  301. package/dist/converters/netsparker-to-hdf/typescript/index.js.map +1 -0
  302. package/dist/converters/neuvector-to-hdf/typescript/converter.d.ts +16 -0
  303. package/dist/converters/neuvector-to-hdf/typescript/converter.d.ts.map +1 -0
  304. package/dist/converters/neuvector-to-hdf/typescript/converter.js +148 -0
  305. package/dist/converters/neuvector-to-hdf/typescript/converter.js.map +1 -0
  306. package/dist/converters/neuvector-to-hdf/typescript/fingerprint.d.ts +11 -0
  307. package/dist/converters/neuvector-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  308. package/dist/converters/neuvector-to-hdf/typescript/fingerprint.js +37 -0
  309. package/dist/converters/neuvector-to-hdf/typescript/fingerprint.js.map +1 -0
  310. package/dist/converters/neuvector-to-hdf/typescript/index.d.ts +2 -0
  311. package/dist/converters/neuvector-to-hdf/typescript/index.d.ts.map +1 -0
  312. package/dist/converters/neuvector-to-hdf/typescript/index.js +2 -0
  313. package/dist/converters/neuvector-to-hdf/typescript/index.js.map +1 -0
  314. package/dist/converters/nikto-to-hdf/typescript/converter.d.ts +2 -0
  315. package/dist/converters/nikto-to-hdf/typescript/converter.d.ts.map +1 -0
  316. package/dist/converters/nikto-to-hdf/typescript/converter.js +111 -0
  317. package/dist/converters/nikto-to-hdf/typescript/converter.js.map +1 -0
  318. package/dist/converters/nikto-to-hdf/typescript/fingerprint.d.ts +10 -0
  319. package/dist/converters/nikto-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  320. package/dist/converters/nikto-to-hdf/typescript/fingerprint.js +33 -0
  321. package/dist/converters/nikto-to-hdf/typescript/fingerprint.js.map +1 -0
  322. package/dist/converters/nikto-to-hdf/typescript/index.d.ts +2 -0
  323. package/dist/converters/nikto-to-hdf/typescript/index.d.ts.map +1 -0
  324. package/dist/converters/nikto-to-hdf/typescript/index.js +2 -0
  325. package/dist/converters/nikto-to-hdf/typescript/index.js.map +1 -0
  326. package/dist/converters/oscal-to-hdf/typescript/converter-catalog.d.ts +20 -0
  327. package/dist/converters/oscal-to-hdf/typescript/converter-catalog.d.ts.map +1 -0
  328. package/dist/converters/oscal-to-hdf/typescript/converter-catalog.js +134 -0
  329. package/dist/converters/oscal-to-hdf/typescript/converter-catalog.js.map +1 -0
  330. package/dist/converters/oscal-to-hdf/typescript/converter-component.d.ts +13 -0
  331. package/dist/converters/oscal-to-hdf/typescript/converter-component.d.ts.map +1 -0
  332. package/dist/converters/oscal-to-hdf/typescript/converter-component.js +92 -0
  333. package/dist/converters/oscal-to-hdf/typescript/converter-component.js.map +1 -0
  334. package/dist/converters/oscal-to-hdf/typescript/converter-poam.d.ts +13 -0
  335. package/dist/converters/oscal-to-hdf/typescript/converter-poam.d.ts.map +1 -0
  336. package/dist/converters/oscal-to-hdf/typescript/converter-poam.js +196 -0
  337. package/dist/converters/oscal-to-hdf/typescript/converter-poam.js.map +1 -0
  338. package/dist/converters/oscal-to-hdf/typescript/converter-profile.d.ts +26 -0
  339. package/dist/converters/oscal-to-hdf/typescript/converter-profile.d.ts.map +1 -0
  340. package/dist/converters/oscal-to-hdf/typescript/converter-profile.js +239 -0
  341. package/dist/converters/oscal-to-hdf/typescript/converter-profile.js.map +1 -0
  342. package/dist/converters/oscal-to-hdf/typescript/converter-sap.d.ts +13 -0
  343. package/dist/converters/oscal-to-hdf/typescript/converter-sap.d.ts.map +1 -0
  344. package/dist/converters/oscal-to-hdf/typescript/converter-sap.js +196 -0
  345. package/dist/converters/oscal-to-hdf/typescript/converter-sap.js.map +1 -0
  346. package/dist/converters/oscal-to-hdf/typescript/converter-sar.d.ts +13 -0
  347. package/dist/converters/oscal-to-hdf/typescript/converter-sar.d.ts.map +1 -0
  348. package/dist/converters/oscal-to-hdf/typescript/converter-sar.js +270 -0
  349. package/dist/converters/oscal-to-hdf/typescript/converter-sar.js.map +1 -0
  350. package/dist/converters/oscal-to-hdf/typescript/converter-ssp.d.ts +13 -0
  351. package/dist/converters/oscal-to-hdf/typescript/converter-ssp.d.ts.map +1 -0
  352. package/dist/converters/oscal-to-hdf/typescript/converter-ssp.js +246 -0
  353. package/dist/converters/oscal-to-hdf/typescript/converter-ssp.js.map +1 -0
  354. package/dist/converters/oscal-to-hdf/typescript/detect.d.ts +15 -0
  355. package/dist/converters/oscal-to-hdf/typescript/detect.d.ts.map +1 -0
  356. package/dist/converters/oscal-to-hdf/typescript/detect.js +33 -0
  357. package/dist/converters/oscal-to-hdf/typescript/detect.js.map +1 -0
  358. package/dist/converters/oscal-to-hdf/typescript/fingerprint.d.ts +12 -0
  359. package/dist/converters/oscal-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  360. package/dist/converters/oscal-to-hdf/typescript/fingerprint.js +57 -0
  361. package/dist/converters/oscal-to-hdf/typescript/fingerprint.js.map +1 -0
  362. package/dist/converters/oscal-to-hdf/typescript/index.d.ts +9 -0
  363. package/dist/converters/oscal-to-hdf/typescript/index.d.ts.map +1 -0
  364. package/dist/converters/oscal-to-hdf/typescript/index.js +9 -0
  365. package/dist/converters/oscal-to-hdf/typescript/index.js.map +1 -0
  366. package/dist/converters/oscal-to-hdf/typescript/shared.d.ts +85 -0
  367. package/dist/converters/oscal-to-hdf/typescript/shared.d.ts.map +1 -0
  368. package/dist/converters/oscal-to-hdf/typescript/shared.js +251 -0
  369. package/dist/converters/oscal-to-hdf/typescript/shared.js.map +1 -0
  370. package/dist/converters/oscal-to-hdf/typescript/types.d.ts +5372 -0
  371. package/dist/converters/oscal-to-hdf/typescript/types.d.ts.map +1 -0
  372. package/dist/converters/oscal-to-hdf/typescript/types.js +2340 -0
  373. package/dist/converters/oscal-to-hdf/typescript/types.js.map +1 -0
  374. package/dist/converters/prisma-to-hdf/typescript/converter.d.ts +16 -0
  375. package/dist/converters/prisma-to-hdf/typescript/converter.d.ts.map +1 -0
  376. package/dist/converters/prisma-to-hdf/typescript/converter.js +197 -0
  377. package/dist/converters/prisma-to-hdf/typescript/converter.js.map +1 -0
  378. package/dist/converters/prisma-to-hdf/typescript/fingerprint.d.ts +10 -0
  379. package/dist/converters/prisma-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  380. package/dist/converters/prisma-to-hdf/typescript/fingerprint.js +39 -0
  381. package/dist/converters/prisma-to-hdf/typescript/fingerprint.js.map +1 -0
  382. package/dist/converters/prisma-to-hdf/typescript/index.d.ts +2 -0
  383. package/dist/converters/prisma-to-hdf/typescript/index.d.ts.map +1 -0
  384. package/dist/converters/prisma-to-hdf/typescript/index.js +2 -0
  385. package/dist/converters/prisma-to-hdf/typescript/index.js.map +1 -0
  386. package/dist/converters/sarif-to-hdf/typescript/converter.d.ts +2 -0
  387. package/dist/converters/sarif-to-hdf/typescript/converter.d.ts.map +1 -0
  388. package/dist/converters/sarif-to-hdf/typescript/converter.js +406 -0
  389. package/dist/converters/sarif-to-hdf/typescript/converter.js.map +1 -0
  390. package/dist/converters/sarif-to-hdf/typescript/fingerprint.d.ts +10 -0
  391. package/dist/converters/sarif-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  392. package/dist/converters/sarif-to-hdf/typescript/fingerprint.js +34 -0
  393. package/dist/converters/sarif-to-hdf/typescript/fingerprint.js.map +1 -0
  394. package/dist/converters/sarif-to-hdf/typescript/index.d.ts +2 -0
  395. package/dist/converters/sarif-to-hdf/typescript/index.d.ts.map +1 -0
  396. package/dist/converters/sarif-to-hdf/typescript/index.js +2 -0
  397. package/dist/converters/sarif-to-hdf/typescript/index.js.map +1 -0
  398. package/dist/converters/scoutsuite-to-hdf/typescript/converter.d.ts +9 -0
  399. package/dist/converters/scoutsuite-to-hdf/typescript/converter.d.ts.map +1 -0
  400. package/dist/converters/scoutsuite-to-hdf/typescript/converter.js +173 -0
  401. package/dist/converters/scoutsuite-to-hdf/typescript/converter.js.map +1 -0
  402. package/dist/converters/scoutsuite-to-hdf/typescript/fingerprint.d.ts +10 -0
  403. package/dist/converters/scoutsuite-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  404. package/dist/converters/scoutsuite-to-hdf/typescript/fingerprint.js +29 -0
  405. package/dist/converters/scoutsuite-to-hdf/typescript/fingerprint.js.map +1 -0
  406. package/dist/converters/scoutsuite-to-hdf/typescript/index.d.ts +2 -0
  407. package/dist/converters/scoutsuite-to-hdf/typescript/index.d.ts.map +1 -0
  408. package/dist/converters/scoutsuite-to-hdf/typescript/index.js +2 -0
  409. package/dist/converters/scoutsuite-to-hdf/typescript/index.js.map +1 -0
  410. package/dist/converters/snyk-to-hdf/typescript/converter.d.ts +11 -0
  411. package/dist/converters/snyk-to-hdf/typescript/converter.d.ts.map +1 -0
  412. package/dist/converters/snyk-to-hdf/typescript/converter.js +131 -0
  413. package/dist/converters/snyk-to-hdf/typescript/converter.js.map +1 -0
  414. package/dist/converters/snyk-to-hdf/typescript/fingerprint.d.ts +12 -0
  415. package/dist/converters/snyk-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  416. package/dist/converters/snyk-to-hdf/typescript/fingerprint.js +44 -0
  417. package/dist/converters/snyk-to-hdf/typescript/fingerprint.js.map +1 -0
  418. package/dist/converters/snyk-to-hdf/typescript/index.d.ts +2 -0
  419. package/dist/converters/snyk-to-hdf/typescript/index.d.ts.map +1 -0
  420. package/dist/converters/snyk-to-hdf/typescript/index.js +2 -0
  421. package/dist/converters/snyk-to-hdf/typescript/index.js.map +1 -0
  422. package/dist/converters/sonarqube-to-hdf/typescript/converter.d.ts +8 -0
  423. package/dist/converters/sonarqube-to-hdf/typescript/converter.d.ts.map +1 -0
  424. package/dist/converters/sonarqube-to-hdf/typescript/converter.js +266 -0
  425. package/dist/converters/sonarqube-to-hdf/typescript/converter.js.map +1 -0
  426. package/dist/converters/sonarqube-to-hdf/typescript/fingerprint.d.ts +10 -0
  427. package/dist/converters/sonarqube-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  428. package/dist/converters/sonarqube-to-hdf/typescript/fingerprint.js +35 -0
  429. package/dist/converters/sonarqube-to-hdf/typescript/fingerprint.js.map +1 -0
  430. package/dist/converters/sonarqube-to-hdf/typescript/index.d.ts +2 -0
  431. package/dist/converters/sonarqube-to-hdf/typescript/index.d.ts.map +1 -0
  432. package/dist/converters/sonarqube-to-hdf/typescript/index.js +2 -0
  433. package/dist/converters/sonarqube-to-hdf/typescript/index.js.map +1 -0
  434. package/dist/converters/splunk-to-hdf/typescript/converter.d.ts +13 -0
  435. package/dist/converters/splunk-to-hdf/typescript/converter.d.ts.map +1 -0
  436. package/dist/converters/splunk-to-hdf/typescript/converter.js +165 -0
  437. package/dist/converters/splunk-to-hdf/typescript/converter.js.map +1 -0
  438. package/dist/converters/splunk-to-hdf/typescript/fingerprint.d.ts +11 -0
  439. package/dist/converters/splunk-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  440. package/dist/converters/splunk-to-hdf/typescript/fingerprint.js +36 -0
  441. package/dist/converters/splunk-to-hdf/typescript/fingerprint.js.map +1 -0
  442. package/dist/converters/splunk-to-hdf/typescript/index.d.ts +2 -0
  443. package/dist/converters/splunk-to-hdf/typescript/index.d.ts.map +1 -0
  444. package/dist/converters/splunk-to-hdf/typescript/index.js +2 -0
  445. package/dist/converters/splunk-to-hdf/typescript/index.js.map +1 -0
  446. package/dist/converters/trufflehog-to-hdf/typescript/converter.d.ts +9 -0
  447. package/dist/converters/trufflehog-to-hdf/typescript/converter.d.ts.map +1 -0
  448. package/dist/converters/trufflehog-to-hdf/typescript/converter.js +189 -0
  449. package/dist/converters/trufflehog-to-hdf/typescript/converter.js.map +1 -0
  450. package/dist/converters/trufflehog-to-hdf/typescript/fingerprint.d.ts +18 -0
  451. package/dist/converters/trufflehog-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  452. package/dist/converters/trufflehog-to-hdf/typescript/fingerprint.js +50 -0
  453. package/dist/converters/trufflehog-to-hdf/typescript/fingerprint.js.map +1 -0
  454. package/dist/converters/trufflehog-to-hdf/typescript/index.d.ts +2 -0
  455. package/dist/converters/trufflehog-to-hdf/typescript/index.d.ts.map +1 -0
  456. package/dist/converters/trufflehog-to-hdf/typescript/index.js +2 -0
  457. package/dist/converters/trufflehog-to-hdf/typescript/index.js.map +1 -0
  458. package/dist/converters/twistlock-to-hdf/typescript/converter.d.ts +11 -0
  459. package/dist/converters/twistlock-to-hdf/typescript/converter.d.ts.map +1 -0
  460. package/dist/converters/twistlock-to-hdf/typescript/converter.js +153 -0
  461. package/dist/converters/twistlock-to-hdf/typescript/converter.js.map +1 -0
  462. package/dist/converters/twistlock-to-hdf/typescript/fingerprint.d.ts +18 -0
  463. package/dist/converters/twistlock-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  464. package/dist/converters/twistlock-to-hdf/typescript/fingerprint.js +49 -0
  465. package/dist/converters/twistlock-to-hdf/typescript/fingerprint.js.map +1 -0
  466. package/dist/converters/twistlock-to-hdf/typescript/index.d.ts +2 -0
  467. package/dist/converters/twistlock-to-hdf/typescript/index.d.ts.map +1 -0
  468. package/dist/converters/twistlock-to-hdf/typescript/index.js +2 -0
  469. package/dist/converters/twistlock-to-hdf/typescript/index.js.map +1 -0
  470. package/dist/converters/veracode-to-hdf/typescript/converter.d.ts +20 -0
  471. package/dist/converters/veracode-to-hdf/typescript/converter.d.ts.map +1 -0
  472. package/dist/converters/veracode-to-hdf/typescript/converter.js +350 -0
  473. package/dist/converters/veracode-to-hdf/typescript/converter.js.map +1 -0
  474. package/dist/converters/veracode-to-hdf/typescript/fingerprint.d.ts +16 -0
  475. package/dist/converters/veracode-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  476. package/dist/converters/veracode-to-hdf/typescript/fingerprint.js +35 -0
  477. package/dist/converters/veracode-to-hdf/typescript/fingerprint.js.map +1 -0
  478. package/dist/converters/veracode-to-hdf/typescript/index.d.ts +2 -0
  479. package/dist/converters/veracode-to-hdf/typescript/index.d.ts.map +1 -0
  480. package/dist/converters/veracode-to-hdf/typescript/index.js +2 -0
  481. package/dist/converters/veracode-to-hdf/typescript/index.js.map +1 -0
  482. package/dist/converters/xccdf-results-to-hdf/typescript/converter.d.ts +29 -0
  483. package/dist/converters/xccdf-results-to-hdf/typescript/converter.d.ts.map +1 -0
  484. package/dist/converters/xccdf-results-to-hdf/typescript/converter.js +604 -0
  485. package/dist/converters/xccdf-results-to-hdf/typescript/converter.js.map +1 -0
  486. package/dist/converters/xccdf-results-to-hdf/typescript/fingerprint.d.ts +12 -0
  487. package/dist/converters/xccdf-results-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  488. package/dist/converters/xccdf-results-to-hdf/typescript/fingerprint.js +33 -0
  489. package/dist/converters/xccdf-results-to-hdf/typescript/fingerprint.js.map +1 -0
  490. package/dist/converters/xccdf-results-to-hdf/typescript/index.d.ts +2 -0
  491. package/dist/converters/xccdf-results-to-hdf/typescript/index.d.ts.map +1 -0
  492. package/dist/converters/xccdf-results-to-hdf/typescript/index.js +2 -0
  493. package/dist/converters/xccdf-results-to-hdf/typescript/index.js.map +1 -0
  494. package/dist/converters/zap-to-hdf/typescript/converter.d.ts +2 -0
  495. package/dist/converters/zap-to-hdf/typescript/converter.d.ts.map +1 -0
  496. package/dist/converters/zap-to-hdf/typescript/converter.js +237 -0
  497. package/dist/converters/zap-to-hdf/typescript/converter.js.map +1 -0
  498. package/dist/converters/zap-to-hdf/typescript/fingerprint.d.ts +11 -0
  499. package/dist/converters/zap-to-hdf/typescript/fingerprint.d.ts.map +1 -0
  500. package/dist/converters/zap-to-hdf/typescript/fingerprint.js +34 -0
  501. package/dist/converters/zap-to-hdf/typescript/fingerprint.js.map +1 -0
  502. package/dist/converters/zap-to-hdf/typescript/index.d.ts +2 -0
  503. package/dist/converters/zap-to-hdf/typescript/index.d.ts.map +1 -0
  504. package/dist/converters/zap-to-hdf/typescript/index.js +2 -0
  505. package/dist/converters/zap-to-hdf/typescript/index.js.map +1 -0
  506. package/dist/package.json +71 -0
  507. package/dist/shared/typescript/compare.d.ts +14 -0
  508. package/dist/shared/typescript/compare.d.ts.map +1 -0
  509. package/dist/shared/typescript/compare.js +91 -0
  510. package/dist/shared/typescript/compare.js.map +1 -0
  511. package/dist/shared/typescript/converter-contract.d.ts +20 -0
  512. package/dist/shared/typescript/converter-contract.d.ts.map +1 -0
  513. package/dist/shared/typescript/converter-contract.js +35 -0
  514. package/dist/shared/typescript/converter-contract.js.map +1 -0
  515. package/dist/shared/typescript/converterutil.d.ts +166 -0
  516. package/dist/shared/typescript/converterutil.d.ts.map +1 -0
  517. package/dist/shared/typescript/converterutil.js +230 -0
  518. package/dist/shared/typescript/converterutil.js.map +1 -0
  519. package/dist/shared/typescript/fingerprint.d.ts +17 -0
  520. package/dist/shared/typescript/fingerprint.d.ts.map +1 -0
  521. package/dist/shared/typescript/fingerprint.js +85 -0
  522. package/dist/shared/typescript/fingerprint.js.map +1 -0
  523. package/dist/shared/typescript/fptest.d.ts +40 -0
  524. package/dist/shared/typescript/fptest.d.ts.map +1 -0
  525. package/dist/shared/typescript/fptest.js +70 -0
  526. package/dist/shared/typescript/fptest.js.map +1 -0
  527. package/dist/shared/typescript/hdf-version.d.ts +20 -0
  528. package/dist/shared/typescript/hdf-version.d.ts.map +1 -0
  529. package/dist/shared/typescript/hdf-version.js +206 -0
  530. package/dist/shared/typescript/hdf-version.js.map +1 -0
  531. package/dist/shared/typescript/register-all.d.ts +12 -0
  532. package/dist/shared/typescript/register-all.d.ts.map +1 -0
  533. package/dist/shared/typescript/register-all.js +111 -0
  534. package/dist/shared/typescript/register-all.js.map +1 -0
  535. package/dist/shared/typescript/registry.d.ts +35 -0
  536. package/dist/shared/typescript/registry.d.ts.map +1 -0
  537. package/dist/shared/typescript/registry.js +27 -0
  538. package/dist/shared/typescript/registry.js.map +1 -0
  539. package/dist/shared/typescript/xml-utils.d.ts +16 -0
  540. package/dist/shared/typescript/xml-utils.d.ts.map +1 -0
  541. package/dist/shared/typescript/xml-utils.js +66 -0
  542. package/dist/shared/typescript/xml-utils.js.map +1 -0
  543. package/dist/src/detect.d.ts +15 -0
  544. package/dist/src/detect.d.ts.map +1 -0
  545. package/dist/src/detect.js +15 -0
  546. package/dist/src/detect.js.map +1 -0
  547. package/dist/src/index.d.ts +52 -0
  548. package/dist/src/index.d.ts.map +1 -0
  549. package/dist/src/index.js +91 -0
  550. package/dist/src/index.js.map +1 -0
  551. package/package.json +60 -86
  552. package/LICENSE.md +0 -9
  553. package/lib/data/converters/csv2json.d.ts +0 -1
  554. package/lib/data/converters/csv2json.js +0 -36
  555. package/lib/data/converters/csv2json.js.map +0 -1
  556. package/lib/data/converters/csv2json.ts +0 -36
  557. package/lib/data/converters/xml2json.d.ts +0 -14
  558. package/lib/data/converters/xml2json.js +0 -65
  559. package/lib/data/converters/xml2json.js.map +0 -1
  560. package/lib/data/converters/xml2json.ts +0 -57
  561. package/lib/index.d.ts +0 -48
  562. package/lib/index.js +0 -79
  563. package/lib/index.js.map +0 -1
  564. package/lib/package.json +0 -97
  565. package/lib/src/anchore-grype-mapper.d.ts +0 -11
  566. package/lib/src/anchore-grype-mapper.js +0 -172
  567. package/lib/src/anchore-grype-mapper.js.map +0 -1
  568. package/lib/src/asff-mapper/asff-mapper.d.ts +0 -111
  569. package/lib/src/asff-mapper/asff-mapper.js +0 -512
  570. package/lib/src/asff-mapper/asff-mapper.js.map +0 -1
  571. package/lib/src/asff-mapper/case-cms-inspec.d.ts +0 -1
  572. package/lib/src/asff-mapper/case-cms-inspec.js +0 -74
  573. package/lib/src/asff-mapper/case-cms-inspec.js.map +0 -1
  574. package/lib/src/asff-mapper/case-firewall-manager.d.ts +0 -1
  575. package/lib/src/asff-mapper/case-firewall-manager.js +0 -47
  576. package/lib/src/asff-mapper/case-firewall-manager.js.map +0 -1
  577. package/lib/src/asff-mapper/case-guardduty.d.ts +0 -1
  578. package/lib/src/asff-mapper/case-guardduty.js +0 -38
  579. package/lib/src/asff-mapper/case-guardduty.js.map +0 -1
  580. package/lib/src/asff-mapper/case-inspector.d.ts +0 -1
  581. package/lib/src/asff-mapper/case-inspector.js +0 -38
  582. package/lib/src/asff-mapper/case-inspector.js.map +0 -1
  583. package/lib/src/asff-mapper/case-previously-hdf.d.ts +0 -1
  584. package/lib/src/asff-mapper/case-previously-hdf.js +0 -228
  585. package/lib/src/asff-mapper/case-previously-hdf.js.map +0 -1
  586. package/lib/src/asff-mapper/case-prowler.d.ts +0 -1
  587. package/lib/src/asff-mapper/case-prowler.js +0 -59
  588. package/lib/src/asff-mapper/case-prowler.js.map +0 -1
  589. package/lib/src/asff-mapper/case-security-hub.d.ts +0 -1
  590. package/lib/src/asff-mapper/case-security-hub.js +0 -158
  591. package/lib/src/asff-mapper/case-security-hub.js.map +0 -1
  592. package/lib/src/asff-mapper/case-trivy.d.ts +0 -1
  593. package/lib/src/asff-mapper/case-trivy.js +0 -92
  594. package/lib/src/asff-mapper/case-trivy.js.map +0 -1
  595. package/lib/src/aws-config-mapper.d.ts +0 -26
  596. package/lib/src/aws-config-mapper.js +0 -373
  597. package/lib/src/aws-config-mapper.js.map +0 -1
  598. package/lib/src/base-converter.d.ts +0 -39
  599. package/lib/src/base-converter.js +0 -315
  600. package/lib/src/base-converter.js.map +0 -1
  601. package/lib/src/burpsuite-mapper.d.ts +0 -9
  602. package/lib/src/burpsuite-mapper.js +0 -168
  603. package/lib/src/burpsuite-mapper.js.map +0 -1
  604. package/lib/src/ckl-mapper/checklist-jsonix-converter.d.ts +0 -114
  605. package/lib/src/ckl-mapper/checklist-jsonix-converter.js +0 -570
  606. package/lib/src/ckl-mapper/checklist-jsonix-converter.js.map +0 -1
  607. package/lib/src/ckl-mapper/checklist-mapper.d.ts +0 -22
  608. package/lib/src/ckl-mapper/checklist-mapper.js +0 -407
  609. package/lib/src/ckl-mapper/checklist-mapper.js.map +0 -1
  610. package/lib/src/ckl-mapper/checklist-metadata-utils.d.ts +0 -19
  611. package/lib/src/ckl-mapper/checklist-metadata-utils.js +0 -164
  612. package/lib/src/ckl-mapper/checklist-metadata-utils.js.map +0 -1
  613. package/lib/src/ckl-mapper/checklistJsonix.d.ts +0 -204
  614. package/lib/src/ckl-mapper/checklistJsonix.js +0 -131
  615. package/lib/src/ckl-mapper/checklistJsonix.js.map +0 -1
  616. package/lib/src/ckl-mapper/jsonixMapping.d.ts +0 -110
  617. package/lib/src/ckl-mapper/jsonixMapping.js +0 -586
  618. package/lib/src/ckl-mapper/jsonixMapping.js.map +0 -1
  619. package/lib/src/converters-from-hdf/asff/asff-types.d.ts +0 -89
  620. package/lib/src/converters-from-hdf/asff/asff-types.js +0 -3
  621. package/lib/src/converters-from-hdf/asff/asff-types.js.map +0 -1
  622. package/lib/src/converters-from-hdf/asff/reverse-asff-mapper.d.ts +0 -38
  623. package/lib/src/converters-from-hdf/asff/reverse-asff-mapper.js +0 -267
  624. package/lib/src/converters-from-hdf/asff/reverse-asff-mapper.js.map +0 -1
  625. package/lib/src/converters-from-hdf/asff/transformers.d.ts +0 -43
  626. package/lib/src/converters-from-hdf/asff/transformers.js +0 -483
  627. package/lib/src/converters-from-hdf/asff/transformers.js.map +0 -1
  628. package/lib/src/converters-from-hdf/caat/reverse-caat-mapper.d.ts +0 -31
  629. package/lib/src/converters-from-hdf/caat/reverse-caat-mapper.js +0 -201
  630. package/lib/src/converters-from-hdf/caat/reverse-caat-mapper.js.map +0 -1
  631. package/lib/src/converters-from-hdf/html/html-types.d.ts +0 -74
  632. package/lib/src/converters-from-hdf/html/html-types.js +0 -3
  633. package/lib/src/converters-from-hdf/html/html-types.js.map +0 -1
  634. package/lib/src/converters-from-hdf/html/reverse-html-mapper.d.ts +0 -41
  635. package/lib/src/converters-from-hdf/html/reverse-html-mapper.js +0 -394
  636. package/lib/src/converters-from-hdf/html/reverse-html-mapper.js.map +0 -1
  637. package/lib/src/converters-from-hdf/reverse-any-base-converter.d.ts +0 -10
  638. package/lib/src/converters-from-hdf/reverse-any-base-converter.js +0 -17
  639. package/lib/src/converters-from-hdf/reverse-any-base-converter.js.map +0 -1
  640. package/lib/src/converters-from-hdf/reverse-base-converter.d.ts +0 -25
  641. package/lib/src/converters-from-hdf/reverse-base-converter.js +0 -139
  642. package/lib/src/converters-from-hdf/reverse-base-converter.js.map +0 -1
  643. package/lib/src/converters-from-hdf/splunk/reverse-splunk-mapper.d.ts +0 -42
  644. package/lib/src/converters-from-hdf/splunk/reverse-splunk-mapper.js +0 -334
  645. package/lib/src/converters-from-hdf/splunk/reverse-splunk-mapper.js.map +0 -1
  646. package/lib/src/converters-from-hdf/xccdf/reverse-xccdf-mapper.d.ts +0 -36
  647. package/lib/src/converters-from-hdf/xccdf/reverse-xccdf-mapper.js +0 -262
  648. package/lib/src/converters-from-hdf/xccdf/reverse-xccdf-mapper.js.map +0 -1
  649. package/lib/src/conveyor-mapper.d.ts +0 -14
  650. package/lib/src/conveyor-mapper.js +0 -210
  651. package/lib/src/conveyor-mapper.js.map +0 -1
  652. package/lib/src/cyclonedx-sbom-mapper.d.ts +0 -34
  653. package/lib/src/cyclonedx-sbom-mapper.js +0 -449
  654. package/lib/src/cyclonedx-sbom-mapper.js.map +0 -1
  655. package/lib/src/dbprotect-mapper.d.ts +0 -9
  656. package/lib/src/dbprotect-mapper.js +0 -174
  657. package/lib/src/dbprotect-mapper.js.map +0 -1
  658. package/lib/src/dependency-track-mapper.d.ts +0 -9
  659. package/lib/src/dependency-track-mapper.js +0 -197
  660. package/lib/src/dependency-track-mapper.js.map +0 -1
  661. package/lib/src/fortify-mapper.d.ts +0 -10
  662. package/lib/src/fortify-mapper.js +0 -209
  663. package/lib/src/fortify-mapper.js.map +0 -1
  664. package/lib/src/gosec-mapper.d.ts +0 -9
  665. package/lib/src/gosec-mapper.js +0 -141
  666. package/lib/src/gosec-mapper.js.map +0 -1
  667. package/lib/src/ionchannel-mapper.d.ts +0 -26
  668. package/lib/src/ionchannel-mapper.js +0 -291
  669. package/lib/src/ionchannel-mapper.js.map +0 -1
  670. package/lib/src/jfrog-xray-mapper.d.ts +0 -9
  671. package/lib/src/jfrog-xray-mapper.js +0 -189
  672. package/lib/src/jfrog-xray-mapper.js.map +0 -1
  673. package/lib/src/jsonix-converter.d.ts +0 -7
  674. package/lib/src/jsonix-converter.js +0 -19
  675. package/lib/src/jsonix-converter.js.map +0 -1
  676. package/lib/src/jsonix-intermediate-converter.d.ts +0 -5
  677. package/lib/src/jsonix-intermediate-converter.js +0 -8
  678. package/lib/src/jsonix-intermediate-converter.js.map +0 -1
  679. package/lib/src/mappings/AwsConfigMapping.d.ts +0 -6
  680. package/lib/src/mappings/AwsConfigMapping.js +0 -66
  681. package/lib/src/mappings/AwsConfigMapping.js.map +0 -1
  682. package/lib/src/mappings/AwsConfigMappingData.d.ts +0 -6
  683. package/lib/src/mappings/AwsConfigMappingData.js +0 -642
  684. package/lib/src/mappings/AwsConfigMappingData.js.map +0 -1
  685. package/lib/src/mappings/CciNistMapping.d.ts +0 -55
  686. package/lib/src/mappings/CciNistMapping.js +0 -123
  687. package/lib/src/mappings/CciNistMapping.js.map +0 -1
  688. package/lib/src/mappings/CciNistMappingData.d.ts +0 -5100
  689. package/lib/src/mappings/CciNistMappingData.js +0 -5104
  690. package/lib/src/mappings/CciNistMappingData.js.map +0 -1
  691. package/lib/src/mappings/CciNistMappingItem.d.ts +0 -5
  692. package/lib/src/mappings/CciNistMappingItem.js +0 -11
  693. package/lib/src/mappings/CciNistMappingItem.js.map +0 -1
  694. package/lib/src/mappings/CweNistMapping.d.ts +0 -13
  695. package/lib/src/mappings/CweNistMapping.js +0 -48
  696. package/lib/src/mappings/CweNistMapping.js.map +0 -1
  697. package/lib/src/mappings/CweNistMappingData.d.ts +0 -7
  698. package/lib/src/mappings/CweNistMappingData.js +0 -1420
  699. package/lib/src/mappings/CweNistMappingData.js.map +0 -1
  700. package/lib/src/mappings/CweNistMappingItem.d.ts +0 -9
  701. package/lib/src/mappings/CweNistMappingItem.js +0 -34
  702. package/lib/src/mappings/CweNistMappingItem.js.map +0 -1
  703. package/lib/src/mappings/NessusPluginNistMappingData.d.ts +0 -9
  704. package/lib/src/mappings/NessusPluginNistMappingData.js +0 -436
  705. package/lib/src/mappings/NessusPluginNistMappingData.js.map +0 -1
  706. package/lib/src/mappings/NessusPluginsNistMapping.d.ts +0 -11
  707. package/lib/src/mappings/NessusPluginsNistMapping.js +0 -38
  708. package/lib/src/mappings/NessusPluginsNistMapping.js.map +0 -1
  709. package/lib/src/mappings/NessusPluginsNistMappingItem.d.ts +0 -7
  710. package/lib/src/mappings/NessusPluginsNistMappingItem.js +0 -27
  711. package/lib/src/mappings/NessusPluginsNistMappingItem.js.map +0 -1
  712. package/lib/src/mappings/NiktoNistMapping.d.ts +0 -9
  713. package/lib/src/mappings/NiktoNistMapping.js +0 -22
  714. package/lib/src/mappings/NiktoNistMapping.js.map +0 -1
  715. package/lib/src/mappings/NiktoNistMappingData.d.ts +0 -8943
  716. package/lib/src/mappings/NiktoNistMappingData.js +0 -8947
  717. package/lib/src/mappings/NiktoNistMappingData.js.map +0 -1
  718. package/lib/src/mappings/NiktoNistMappingItem.d.ts +0 -8
  719. package/lib/src/mappings/NiktoNistMappingItem.js +0 -28
  720. package/lib/src/mappings/NiktoNistMappingItem.js.map +0 -1
  721. package/lib/src/mappings/NistCciMappingData.d.ts +0 -1
  722. package/lib/src/mappings/NistCciMappingData.js +0 -27
  723. package/lib/src/mappings/NistCciMappingData.js.map +0 -1
  724. package/lib/src/mappings/OwaspNistMapping.d.ts +0 -13
  725. package/lib/src/mappings/OwaspNistMapping.js +0 -46
  726. package/lib/src/mappings/OwaspNistMapping.js.map +0 -1
  727. package/lib/src/mappings/OwaspNistMappingData.d.ts +0 -7
  728. package/lib/src/mappings/OwaspNistMappingData.js +0 -76
  729. package/lib/src/mappings/OwaspNistMappingData.js.map +0 -1
  730. package/lib/src/mappings/OwaspNistMappingItem.d.ts +0 -9
  731. package/lib/src/mappings/OwaspNistMappingItem.js +0 -34
  732. package/lib/src/mappings/OwaspNistMappingItem.js.map +0 -1
  733. package/lib/src/mappings/ScoutsuiteNistMapping.d.ts +0 -10
  734. package/lib/src/mappings/ScoutsuiteNistMapping.js +0 -30
  735. package/lib/src/mappings/ScoutsuiteNistMapping.js.map +0 -1
  736. package/lib/src/mappings/ScoutsuiteNistMappingData.d.ts +0 -4
  737. package/lib/src/mappings/ScoutsuiteNistMappingData.js +0 -562
  738. package/lib/src/mappings/ScoutsuiteNistMappingData.js.map +0 -1
  739. package/lib/src/mappings/ScoutsuiteNistMappingItem.d.ts +0 -6
  740. package/lib/src/mappings/ScoutsuiteNistMappingItem.js +0 -21
  741. package/lib/src/mappings/ScoutsuiteNistMappingItem.js.map +0 -1
  742. package/lib/src/msft-secure-score-mapper.d.ts +0 -33
  743. package/lib/src/msft-secure-score-mapper.js +0 -254
  744. package/lib/src/msft-secure-score-mapper.js.map +0 -1
  745. package/lib/src/nessus-mapper.d.ts +0 -16
  746. package/lib/src/nessus-mapper.js +0 -353
  747. package/lib/src/nessus-mapper.js.map +0 -1
  748. package/lib/src/netsparker-mapper.d.ts +0 -9
  749. package/lib/src/netsparker-mapper.js +0 -260
  750. package/lib/src/netsparker-mapper.js.map +0 -1
  751. package/lib/src/neuvector-mapper.d.ts +0 -13
  752. package/lib/src/neuvector-mapper.js +0 -167
  753. package/lib/src/neuvector-mapper.js.map +0 -1
  754. package/lib/src/nikto-mapper.d.ts +0 -9
  755. package/lib/src/nikto-mapper.js +0 -122
  756. package/lib/src/nikto-mapper.js.map +0 -1
  757. package/lib/src/prisma-mapper.d.ts +0 -24
  758. package/lib/src/prisma-mapper.js +0 -201
  759. package/lib/src/prisma-mapper.js.map +0 -1
  760. package/lib/src/sarif-mapper.d.ts +0 -9
  761. package/lib/src/sarif-mapper.js +0 -179
  762. package/lib/src/sarif-mapper.js.map +0 -1
  763. package/lib/src/scoutsuite-mapper.d.ts +0 -9
  764. package/lib/src/scoutsuite-mapper.js +0 -291
  765. package/lib/src/scoutsuite-mapper.js.map +0 -1
  766. package/lib/src/snyk-mapper.d.ts +0 -14
  767. package/lib/src/snyk-mapper.js +0 -185
  768. package/lib/src/snyk-mapper.js.map +0 -1
  769. package/lib/src/sonarqube-mapper.d.ts +0 -263
  770. package/lib/src/sonarqube-mapper.js +0 -572
  771. package/lib/src/sonarqube-mapper.js.map +0 -1
  772. package/lib/src/splunk-mapper.d.ts +0 -48
  773. package/lib/src/splunk-mapper.js +0 -260
  774. package/lib/src/splunk-mapper.js.map +0 -1
  775. package/lib/src/trufflehog-mapper.d.ts +0 -15
  776. package/lib/src/trufflehog-mapper.js +0 -112
  777. package/lib/src/trufflehog-mapper.js.map +0 -1
  778. package/lib/src/twistlock-mapper.d.ts +0 -15
  779. package/lib/src/twistlock-mapper.js +0 -184
  780. package/lib/src/twistlock-mapper.js.map +0 -1
  781. package/lib/src/utils/CCI_List.d.ts +0 -1
  782. package/lib/src/utils/CCI_List.js +0 -56259
  783. package/lib/src/utils/CCI_List.js.map +0 -1
  784. package/lib/src/utils/attestations.d.ts +0 -11
  785. package/lib/src/utils/attestations.js +0 -219
  786. package/lib/src/utils/attestations.js.map +0 -1
  787. package/lib/src/utils/compliance.d.ts +0 -3
  788. package/lib/src/utils/compliance.js +0 -27
  789. package/lib/src/utils/compliance.js.map +0 -1
  790. package/lib/src/utils/fingerprinting.d.ts +0 -33
  791. package/lib/src/utils/fingerprinting.js +0 -203
  792. package/lib/src/utils/fingerprinting.js.map +0 -1
  793. package/lib/src/utils/global.d.ts +0 -14
  794. package/lib/src/utils/global.js +0 -92
  795. package/lib/src/utils/global.js.map +0 -1
  796. package/lib/src/utils/parseJson.d.ts +0 -5
  797. package/lib/src/utils/parseJson.js +0 -13
  798. package/lib/src/utils/parseJson.js.map +0 -1
  799. package/lib/src/utils/result.d.ts +0 -7
  800. package/lib/src/utils/result.js +0 -3
  801. package/lib/src/utils/result.js.map +0 -1
  802. package/lib/src/utils/splunk-tools.d.ts +0 -5
  803. package/lib/src/utils/splunk-tools.js +0 -96
  804. package/lib/src/utils/splunk-tools.js.map +0 -1
  805. package/lib/src/veracode-mapper.d.ts +0 -9
  806. package/lib/src/veracode-mapper.js +0 -448
  807. package/lib/src/veracode-mapper.js.map +0 -1
  808. package/lib/src/xccdf-results-mapper.d.ts +0 -9
  809. package/lib/src/xccdf-results-mapper.js +0 -474
  810. package/lib/src/xccdf-results-mapper.js.map +0 -1
  811. package/lib/src/zap-mapper.d.ts +0 -10
  812. package/lib/src/zap-mapper.js +0 -209
  813. package/lib/src/zap-mapper.js.map +0 -1
  814. package/lib/types/neuvector-types.d.ts +0 -104
  815. package/lib/types/neuvector-types.js +0 -3
  816. package/lib/types/neuvector-types.js.map +0 -1
  817. package/lib/types/splunk-config-types.d.ts +0 -13
  818. package/lib/types/splunk-config-types.js +0 -3
  819. package/lib/types/splunk-config-types.js.map +0 -1
  820. package/lib/types/splunk-control-types.d.ts +0 -43
  821. package/lib/types/splunk-control-types.js +0 -3
  822. package/lib/types/splunk-control-types.js.map +0 -1
  823. package/lib/types/splunk-profile-types.d.ts +0 -53
  824. package/lib/types/splunk-profile-types.js +0 -3
  825. package/lib/types/splunk-profile-types.js.map +0 -1
  826. package/lib/types/splunk-report-types.d.ts +0 -20
  827. package/lib/types/splunk-report-types.js +0 -3
  828. package/lib/types/splunk-report-types.js.map +0 -1
@@ -0,0 +1,329 @@
1
+ import { parseXmlWithArrays } from '@mitre/hdf-utilities';
2
+ import { getNessusNistControl, getCCINistMappings } from '@mitre/hdf-mappings';
3
+ import { inputChecksum, limitArray, validateInputSize } from '../../../shared/typescript/converterutil.js';
4
+ import { ResultStatus, Copyright as TargetType, createMinimalBaseline } from '@mitre/hdf-schema';
5
+ import { version as converterVersion } from '@mitre/hdf-converters/package.json';
6
+ // Severity to impact mapping from heimdall2
7
+ const IMPACT_MAPPING = {
8
+ '4': 0.9, // Critical
9
+ '3': 0.7, // High
10
+ 'i': 0.7,
11
+ '2': 0.5, // Medium
12
+ 'ii': 0.5,
13
+ '1': 0.3, // Low
14
+ 'iii': 0.3,
15
+ '0': 0.0, // Info
16
+ };
17
+ /**
18
+ * Strip HTML tags from a string
19
+ */
20
+ function parseHtml(html) {
21
+ return html.replace(/<[^>]*>/g, '').trim();
22
+ }
23
+ /**
24
+ * Convert Nessus XML scan results to HDF format
25
+ */
26
+ export async function convertNessusToHdf(nessusXml) {
27
+ validateInputSize(nessusXml, 'nessus');
28
+ // Calculate checksum of source scan data for integrity verification
29
+ const resultsChecksum = await inputChecksum(nessusXml);
30
+ const parsed = parseXmlWithArrays(nessusXml, ['preference', 'tag', 'ReportItem', 'ReportHost']);
31
+ const policyName = parsed.NessusClientData_v2.Policy.policyName;
32
+ const version = extractVersion(parsed);
33
+ // parseXmlWithArrays ensures ReportHost is always an array
34
+ const reportHosts = parsed.NessusClientData_v2.Report.ReportHost;
35
+ const { items: limitedHosts, truncated: truncatedHosts } = limitArray(reportHosts);
36
+ /* v8 ignore next -- truncation only triggers with >100K items */
37
+ if (truncatedHosts) {
38
+ // eslint-disable-next-line no-console
39
+ console.warn(`WARNING: Input truncated at ${limitedHosts.length} ReportHost items (original: ${reportHosts.length})`);
40
+ }
41
+ // Calculate start and end times from first and last host
42
+ const { startTime, duration } = calculateTiming(limitedHosts);
43
+ const baselines = [];
44
+ const components = [];
45
+ // Process each ReportHost
46
+ limitedHosts.forEach(host => {
47
+ const baseline = convertReportHostToBaseline(host, policyName, version, resultsChecksum);
48
+ baselines.push(baseline);
49
+ const target = convertReportHostToTarget(host);
50
+ components.push(target);
51
+ });
52
+ const tool = { name: 'Nessus' };
53
+ const result = {
54
+ baselines,
55
+ components,
56
+ statistics: {
57
+ duration,
58
+ },
59
+ generator: {
60
+ name: 'hdf-converters',
61
+ version: converterVersion,
62
+ },
63
+ tool,
64
+ timestamp: startTime,
65
+ };
66
+ return result;
67
+ }
68
+ function extractVersion(parsed) {
69
+ const prefs = parsed.NessusClientData_v2.Policy.Preferences?.ServerPreferences?.preference;
70
+ if (!prefs)
71
+ return '';
72
+ // parseXmlWithArrays ensures preference is always an array
73
+ const scVersion = prefs.find(p => p.name === 'sc_version');
74
+ return scVersion?.value || '';
75
+ }
76
+ function calculateTiming(hosts) {
77
+ if (hosts.length === 0) {
78
+ const now = new Date();
79
+ return { startTime: now, endTime: now, duration: 0 };
80
+ }
81
+ const firstHost = hosts[0];
82
+ const lastHost = hosts[hosts.length - 1];
83
+ const startTimeStr = getHostPropertyValue(firstHost, 'HOST_START');
84
+ const endTimeStr = getHostPropertyValue(lastHost, 'HOST_END') || getHostPropertyValue(lastHost, 'HOST_START');
85
+ const startTime = startTimeStr ? new Date(startTimeStr) : new Date();
86
+ const endTime = endTimeStr ? new Date(endTimeStr) : startTime;
87
+ const duration = (endTime.getTime() - startTime.getTime()) / 1000; // seconds
88
+ return { startTime, endTime, duration };
89
+ }
90
+ function getHostPropertyValue(host, name) {
91
+ const tags = host.HostProperties?.tag;
92
+ if (!tags)
93
+ return undefined;
94
+ // parseXmlWithArrays ensures tag is always an array
95
+ const tag = tags.find(t => t['name'] === name);
96
+ return tag?.['#text'];
97
+ }
98
+ function convertReportHostToBaseline(host, policyName, version, resultsChecksum) {
99
+ const items = host.ReportItem;
100
+ // parseXmlWithArrays ensures ReportItem is always an array
101
+ let requirements;
102
+ if (items) {
103
+ const { items: limitedItems, truncated: truncatedItems } = limitArray(items);
104
+ /* v8 ignore next -- truncation only triggers with >100K items */
105
+ if (truncatedItems) {
106
+ // eslint-disable-next-line no-console
107
+ console.warn(`WARNING: Input truncated at ${limitedItems.length} ReportItem items (original: ${items.length})`);
108
+ }
109
+ requirements = limitedItems.map(item => convertReportItemToRequirement(item, host));
110
+ }
111
+ else {
112
+ requirements = [];
113
+ }
114
+ return createMinimalBaseline(`Nessus ${policyName}`, requirements, {
115
+ title: `Nessus ${policyName}`,
116
+ version,
117
+ resultsChecksum,
118
+ status: 'loaded',
119
+ summary: `Nessus ${policyName}`,
120
+ });
121
+ }
122
+ function convertReportItemToRequirement(item, host) {
123
+ const isCompliance = !!item['compliance-reference'];
124
+ const id = isCompliance
125
+ ? parseComplianceRef(item['compliance-reference'], 'Vuln-ID')[0] || item['pluginID']
126
+ : item['pluginID'];
127
+ const title = isCompliance
128
+ ? (item['compliance-check-name'] || item['pluginName'])
129
+ : item['pluginName'];
130
+ const descriptions = buildDescriptions(item, isCompliance);
131
+ const impact = calculateImpact(item, isCompliance);
132
+ const tags = buildTags(item, isCompliance);
133
+ const refs = buildRefs(item);
134
+ const results = [buildResult(item, host, isCompliance)];
135
+ const code = JSON.stringify(item, null, 2);
136
+ return {
137
+ id,
138
+ title,
139
+ descriptions,
140
+ impact,
141
+ tags,
142
+ refs,
143
+ results,
144
+ code,
145
+ };
146
+ }
147
+ function buildDescriptions(item, isCompliance) {
148
+ const descriptions = [];
149
+ // Default description
150
+ if (isCompliance && item['compliance-info']) {
151
+ descriptions.push({
152
+ label: 'default',
153
+ data: parseHtml(item['compliance-info']),
154
+ });
155
+ }
156
+ else {
157
+ // Non-compliance: create description from metadata
158
+ const parts = [
159
+ `Plugin Family: ${item['pluginFamily']}`,
160
+ `Port: ${item['port']}`,
161
+ `Protocol: ${item['protocol']}`,
162
+ ];
163
+ descriptions.push({
164
+ label: 'default',
165
+ data: parts.join('; ') + ';',
166
+ });
167
+ }
168
+ // Fix/solution description
169
+ const solution = isCompliance ? item['compliance-solution'] : item.solution;
170
+ if (solution && solution !== 'n/a') {
171
+ descriptions.push({
172
+ label: 'fix',
173
+ data: parseHtml(solution),
174
+ });
175
+ }
176
+ else if (solution === 'n/a') {
177
+ descriptions.push({
178
+ label: 'fix',
179
+ data: 'n/a',
180
+ });
181
+ }
182
+ return descriptions;
183
+ }
184
+ function calculateImpact(item, isCompliance) {
185
+ if (isCompliance && item['compliance-reference']) {
186
+ const cat = parseComplianceRef(item['compliance-reference'], 'CAT')[0];
187
+ const catKey = cat?.toLowerCase();
188
+ return catKey ? (IMPACT_MAPPING[catKey] ?? 0.5) : 0.5;
189
+ }
190
+ return IMPACT_MAPPING[item['severity']] ?? 0.0;
191
+ }
192
+ function buildTags(item, isCompliance) {
193
+ const tags = {
194
+ rid: isCompliance
195
+ ? parseComplianceRef(item['compliance-reference'], 'Rule-ID').join(',')
196
+ : item['pluginID'],
197
+ };
198
+ // NIST tags
199
+ if (isCompliance && item['compliance-reference']) {
200
+ const cciTags = parseComplianceRef(item['compliance-reference'], 'CCI');
201
+ tags.cci = cciTags;
202
+ // Map CCI IDs to NIST controls using hdf-mappings
203
+ // Pattern: Extract source IDs → Map each ID → Flatten results → Deduplicate
204
+ const mappedControls = cciTags.flatMap(cci => getCCINistMappings(cci) ?? []);
205
+ tags.nist = [...new Set(mappedControls)];
206
+ }
207
+ else {
208
+ const nistControls = getNessusNistControl(item['pluginFamily'], item['pluginID']);
209
+ tags.nist = nistControls ? nistControls.split('|') : [];
210
+ }
211
+ // STIG ID for compliance
212
+ if (isCompliance && item['compliance-reference']) {
213
+ const stigId = parseComplianceRef(item['compliance-reference'], 'STIG-ID').join(',');
214
+ if (stigId) {
215
+ tags.stig_id = stigId;
216
+ }
217
+ }
218
+ // Additional Nessus metadata tags
219
+ if (item.risk_factor)
220
+ tags.risk_factor = item.risk_factor;
221
+ if (item.plugin_type)
222
+ tags.plugin_type = item.plugin_type;
223
+ if (item.plugin_publication_date)
224
+ tags.plugin_publication_date = item.plugin_publication_date;
225
+ if (item.fname)
226
+ tags.fname = item.fname;
227
+ if (item.cvss3_base_score)
228
+ tags.cvss3_base_score = item.cvss3_base_score;
229
+ if (item.cvss_base_score)
230
+ tags.cvss_base_score = item.cvss_base_score;
231
+ return tags;
232
+ }
233
+ function buildRefs(item) {
234
+ const refs = [];
235
+ if (item.see_also) {
236
+ refs.push({ url: item.see_also });
237
+ }
238
+ return refs.length > 0 ? refs : undefined;
239
+ }
240
+ function buildResult(item, host, isCompliance) {
241
+ const status = getStatus(item, isCompliance);
242
+ const codeDesc = getCodeDesc(item);
243
+ const message = item.plugin_output || item['compliance-actual-value'];
244
+ const startTimeStr = getHostPropertyValue(host, 'HOST_START');
245
+ const startTime = startTimeStr ? new Date(startTimeStr) : new Date();
246
+ return {
247
+ status,
248
+ codeDesc,
249
+ message: message || undefined,
250
+ startTime,
251
+ };
252
+ }
253
+ function getStatus(item, isCompliance) {
254
+ if (isCompliance && item['compliance-result']) {
255
+ const result = item['compliance-result'];
256
+ switch (result) {
257
+ case 'PASSED':
258
+ return ResultStatus.Passed;
259
+ case 'WARNING':
260
+ return ResultStatus.NotApplicable; // Heimdall2 maps WARNING to skipped
261
+ case 'ERROR':
262
+ return ResultStatus.Error;
263
+ default:
264
+ return ResultStatus.Failed;
265
+ }
266
+ }
267
+ // Non-compliance items are always failed (informational findings)
268
+ return ResultStatus.Failed;
269
+ }
270
+ function getCodeDesc(item) {
271
+ const desc = item.description || item.plugin_output || 'This Nessus Plugin does not provide output message.';
272
+ return parseHtml(desc);
273
+ }
274
+ function parseComplianceRef(ref, key) {
275
+ const matches = ref.split(',').filter(element => element.startsWith(key));
276
+ return matches.map(element => element.split('|')[1] || '');
277
+ }
278
+ function convertReportHostToTarget(host) {
279
+ const hostName = host['name'];
280
+ // Extract host properties into a lookup map
281
+ const hostProps = {};
282
+ const tags = host.HostProperties?.tag;
283
+ if (tags) {
284
+ // parseXmlWithArrays ensures tag is always an array
285
+ tags.forEach(tag => {
286
+ const name = tag['name'];
287
+ const value = tag['#text'];
288
+ if (name && value) {
289
+ hostProps[name] = value;
290
+ }
291
+ });
292
+ }
293
+ const target = {
294
+ name: hostName,
295
+ type: TargetType.Host,
296
+ };
297
+ // Map host properties to typed Component fields
298
+ if (isFQDN(hostName)) {
299
+ target.fqdn = hostName;
300
+ }
301
+ const hostIp = hostProps['host-ip'];
302
+ if (hostIp) {
303
+ target.ipAddress = hostIp;
304
+ }
305
+ else if (isIPAddress(hostName)) {
306
+ target.ipAddress = hostName;
307
+ }
308
+ if (hostProps['operating-system']) {
309
+ target.osName = hostProps['operating-system'];
310
+ }
311
+ if (hostProps['os']) {
312
+ target.osVersion = hostProps['os'];
313
+ }
314
+ if (hostProps['mac-address']) {
315
+ target.macAddress = hostProps['mac-address'].split('\n')[0];
316
+ }
317
+ if (hostProps['host-fqdn']) {
318
+ target.fqdn = hostProps['host-fqdn'];
319
+ }
320
+ target.labels = {};
321
+ return target;
322
+ }
323
+ function isFQDN(s) {
324
+ return s.includes('.') && !/^\d+\.\d+\.\d+\.\d+$/.test(s);
325
+ }
326
+ function isIPAddress(s) {
327
+ return /^\d+\.\d+\.\d+\.\d+$/.test(s) || s.includes(':');
328
+ }
329
+ //# sourceMappingURL=converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"converter.js","sourceRoot":"","sources":["../../../../converters/nessus-to-hdf/typescript/converter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Nessus format fingerprint.
3
+ *
4
+ * Detects Nessus XML files by checking for <NessusClientData_v2> root element.
5
+ */
6
+ import { type ConverterFingerprint } from '../../../shared/typescript/registry.js';
7
+ export declare const nessusFingerprint: ConverterFingerprint;
8
+ export declare function register(): void;
9
+ //# sourceMappingURL=fingerprint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.d.ts","sourceRoot":"","sources":["../../../../converters/nessus-to-hdf/typescript/fingerprint.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAuC,KAAK,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAGxH,eAAO,MAAM,iBAAiB,EAAE,oBAiB/B,CAAC;AAEF,wBAAgB,QAAQ,IAAI,IAAI,CAG/B"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Nessus format fingerprint.
3
+ *
4
+ * Detects Nessus XML files by checking for <NessusClientData_v2> root element.
5
+ */
6
+ import { registerFingerprint, getFingerprint } from '../../../shared/typescript/registry.js';
7
+ import { extractXmlRootElement } from '../../../shared/typescript/xml-utils.js';
8
+ export const nessusFingerprint = {
9
+ id: 'nessus-to-hdf',
10
+ label: 'Nessus',
11
+ direction: 'ingest',
12
+ inputFamily: 'xml',
13
+ outputType: 'results',
14
+ fingerprint: (input) => {
15
+ if (typeof input !== 'string')
16
+ return 0;
17
+ const root = extractXmlRootElement(input);
18
+ if (!root)
19
+ return 0;
20
+ return root === 'NessusClientData_v2' ? 1.0 : 0;
21
+ },
22
+ detectVersion: (input) => {
23
+ if (typeof input !== 'string')
24
+ return '';
25
+ const root = extractXmlRootElement(input);
26
+ return root === 'NessusClientData_v2' ? '2' : '';
27
+ },
28
+ };
29
+ export function register() {
30
+ if (getFingerprint('nessus-to-hdf'))
31
+ return;
32
+ registerFingerprint(nessusFingerprint);
33
+ }
34
+ //# sourceMappingURL=fingerprint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.js","sourceRoot":"","sources":["../../../../converters/nessus-to-hdf/typescript/fingerprint.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAA6B,MAAM,wCAAwC,CAAC;AACxH,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAEhF,MAAM,CAAC,MAAM,iBAAiB,GAAyB;IACrD,EAAE,EAAE,eAAe;IACnB,KAAK,EAAE,QAAQ;IACf,SAAS,EAAE,QAAQ;IACnB,WAAW,EAAE,KAAK;IAClB,UAAU,EAAE,SAAS;IACrB,WAAW,EAAE,CAAC,KAAc,EAAU,EAAE;QACtC,IAAI,OAAO,KAAK,KAAK,QAAQ;YAAE,OAAO,CAAC,CAAC;QACxC,MAAM,IAAI,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,IAAI;YAAE,OAAO,CAAC,CAAC;QACpB,OAAO,IAAI,KAAK,qBAAqB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC;IACD,aAAa,EAAE,CAAC,KAAc,EAAU,EAAE;QACxC,IAAI,OAAO,KAAK,KAAK,QAAQ;YAAE,OAAO,EAAE,CAAC;QACzC,MAAM,IAAI,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC1C,OAAO,IAAI,KAAK,qBAAqB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACnD,CAAC;CACF,CAAC;AAEF,MAAM,UAAU,QAAQ;IACtB,IAAI,cAAc,CAAC,eAAe,CAAC;QAAE,OAAO;IAC5C,mBAAmB,CAAC,iBAAiB,CAAC,CAAC;AACzC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { convertNessusToHdf } from './converter.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../converters/nessus-to-hdf/typescript/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { convertNessusToHdf } from './converter.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../converters/nessus-to-hdf/typescript/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Converts Netsparker/Invicti XML scan results to HDF format.
3
+ * Handles both <netsparker-enterprise> and <invicti-enterprise> root elements.
4
+ *
5
+ * @param input - Netsparker/Invicti XML string
6
+ * @returns HDF JSON string
7
+ */
8
+ export declare function convertNetsparkerToHdf(input: string): Promise<string>;
9
+ //# sourceMappingURL=converter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"converter.d.ts","sourceRoot":"","sources":["../../../../converters/netsparker-to-hdf/typescript/converter.ts"],"names":[],"mappings":"AAgRA;;;;;;GAMG;AACH,wBAAsB,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CA8D3E"}
@@ -0,0 +1,211 @@
1
+ import { parseXmlWithArrays } from '@mitre/hdf-utilities';
2
+ import { nistToCci, DEFAULT_STATIC_ANALYSIS_NIST_TAGS, getOwaspNistControl, getCweNistControl, } from '@mitre/hdf-mappings';
3
+ import { inputChecksum, buildNistCciTags, limitArray, stripHTML, validateInputSize, buildHdfResults, } from '../../../shared/typescript/converterutil.js';
4
+ import { ResultStatus, Copyright, createMinimalBaseline, } from '@mitre/hdf-schema';
5
+ // --- Severity to impact mapping ---
6
+ const IMPACT_MAPPING = {
7
+ 'critical': 1.0,
8
+ 'high': 0.7,
9
+ 'medium': 0.5,
10
+ 'low': 0.3,
11
+ 'best_practice': 0.0,
12
+ 'information': 0.0,
13
+ };
14
+ function getImpact(severity) {
15
+ return IMPACT_MAPPING[severity.toLowerCase()] ?? 0.5;
16
+ }
17
+ // --- Format helpers ---
18
+ function formatCodeDesc(request) {
19
+ const parts = [];
20
+ parts.push(`http-request : ${request?.content ?? ''}`);
21
+ parts.push(`method : ${request?.method ?? ''}`);
22
+ return parts.join('\n');
23
+ }
24
+ function formatMessage(response) {
25
+ const parts = [];
26
+ parts.push(`http-response : ${response?.content ?? ''}`);
27
+ parts.push(`duration : ${response?.duration ?? ''}`);
28
+ parts.push(`status-code : ${response?.['status-code'] ?? ''}`);
29
+ return parts.join('\n');
30
+ }
31
+ function formatControlDesc(vuln) {
32
+ const parts = [];
33
+ if (vuln.description) {
34
+ parts.push(stripHTML(vuln.description));
35
+ }
36
+ if (vuln['exploitation-skills']) {
37
+ parts.push(`Exploitation-skills: ${vuln['exploitation-skills']}`);
38
+ }
39
+ const cweVal = vuln.classification?.cwe ?? '';
40
+ const owaspVal = vuln.classification?.owasp ?? '';
41
+ if (cweVal || owaspVal) {
42
+ parts.push(`Classification: cwe=>${cweVal}, owasp=>${owaspVal}`);
43
+ }
44
+ if (vuln.impact) {
45
+ parts.push(`Impact: ${stripHTML(vuln.impact)}`);
46
+ }
47
+ if (vuln.FirstSeenDate) {
48
+ parts.push(`FirstSeenDate: ${vuln.FirstSeenDate}`);
49
+ }
50
+ if (vuln.LastSeenDate) {
51
+ parts.push(`LastSeenDate: ${vuln.LastSeenDate}`);
52
+ }
53
+ if (vuln.certainty) {
54
+ parts.push(`Certainty: ${vuln.certainty}`);
55
+ }
56
+ if (vuln.type) {
57
+ parts.push(`Type: ${vuln.type}`);
58
+ }
59
+ if (vuln.confirmed) {
60
+ parts.push(`Confirmed: ${vuln.confirmed}`);
61
+ }
62
+ return parts.join('\n');
63
+ }
64
+ /**
65
+ * Performs dual NIST mapping from both CWE and OWASP IDs.
66
+ * Returns a deduplicated sorted list of NIST controls, falling back to
67
+ * DEFAULT_STATIC_ANALYSIS_NIST_TAGS if no mappings are found.
68
+ */
69
+ function mapNISTFromCWEAndOWASP(cweID, owaspID) {
70
+ const controls = new Set();
71
+ // CWE -> NIST
72
+ if (cweID) {
73
+ const numericId = parseInt(cweID, 10);
74
+ if (!isNaN(numericId)) {
75
+ const nistControl = getCweNistControl(numericId);
76
+ if (nistControl) {
77
+ controls.add(nistControl);
78
+ }
79
+ }
80
+ }
81
+ // OWASP -> NIST
82
+ if (owaspID) {
83
+ const nistControl = getOwaspNistControl(owaspID);
84
+ if (nistControl) {
85
+ controls.add(nistControl);
86
+ }
87
+ }
88
+ return controls.size > 0
89
+ ? [...controls].sort()
90
+ : [...DEFAULT_STATIC_ANALYSIS_NIST_TAGS];
91
+ }
92
+ /**
93
+ * Builds a single EvaluatedRequirement from a vulnerability.
94
+ */
95
+ function buildRequirement(vuln, initiated) {
96
+ const cweID = vuln.classification?.cwe ?? '';
97
+ const owaspID = vuln.classification?.owasp ?? '';
98
+ const nist = mapNISTFromCWEAndOWASP(cweID, owaspID);
99
+ const cciTags = nistToCci(nist);
100
+ const extras = {};
101
+ if (cweID) {
102
+ extras.cweid = cweID;
103
+ }
104
+ if (owaspID) {
105
+ extras.owasp = owaspID;
106
+ }
107
+ const tags = buildNistCciTags(nist, cciTags, Object.keys(extras).length > 0 ? extras : undefined);
108
+ // Default description
109
+ const defaultDesc = formatControlDesc(vuln);
110
+ const descriptions = [
111
+ { label: 'default', data: defaultDesc || vuln.name || '' },
112
+ ];
113
+ // Check description
114
+ const checkParts = [];
115
+ if (vuln['exploitation-skills']) {
116
+ checkParts.push(`Exploitation-skills: ${vuln['exploitation-skills']}`);
117
+ }
118
+ if (vuln['proof-of-concept']) {
119
+ checkParts.push(`Proof-of-concept: ${stripHTML(vuln['proof-of-concept'])}`);
120
+ }
121
+ if (checkParts.length > 0) {
122
+ descriptions.push({ label: 'check', data: stripHTML(checkParts.join('\n')) });
123
+ }
124
+ // Fix description
125
+ const fixParts = [];
126
+ if (vuln['remedial-actions']) {
127
+ fixParts.push(`Remedial-actions: ${stripHTML(vuln['remedial-actions'])}`);
128
+ }
129
+ if (vuln['remedial-procedure']) {
130
+ fixParts.push(`Remedial-procedure: ${stripHTML(vuln['remedial-procedure'])}`);
131
+ }
132
+ if (vuln['remedy-references']) {
133
+ fixParts.push(`Remedy-references: ${stripHTML(vuln['remedy-references'])}`);
134
+ }
135
+ if (fixParts.length > 0) {
136
+ descriptions.push({ label: 'fix', data: fixParts.join('\n') });
137
+ }
138
+ // Result
139
+ const codeDesc = formatCodeDesc(vuln['http-request']);
140
+ const message = formatMessage(vuln['http-response']);
141
+ const startTime = initiated ? new Date(initiated) : new Date('0001-01-01T00:00:00Z');
142
+ const results = [{
143
+ status: ResultStatus.Failed,
144
+ codeDesc,
145
+ message,
146
+ startTime,
147
+ }];
148
+ const impact = getImpact(vuln.severity ?? '');
149
+ return {
150
+ id: vuln.LookupId ?? '',
151
+ title: vuln.name ?? undefined,
152
+ impact,
153
+ tags,
154
+ descriptions,
155
+ results,
156
+ };
157
+ }
158
+ /**
159
+ * Converts Netsparker/Invicti XML scan results to HDF format.
160
+ * Handles both <netsparker-enterprise> and <invicti-enterprise> root elements.
161
+ *
162
+ * @param input - Netsparker/Invicti XML string
163
+ * @returns HDF JSON string
164
+ */
165
+ export async function convertNetsparkerToHdf(input) {
166
+ if (!input || input.trim().length === 0) {
167
+ throw new Error('netsparker: empty input');
168
+ }
169
+ validateInputSize(input, 'netsparker');
170
+ const resultsChecksum = await inputChecksum(input);
171
+ // Parse XML — ensure vulnerability is always treated as array
172
+ const parsed = parseXmlWithArrays(input, ['vulnerability']);
173
+ // Detect root element
174
+ const isInvicti = !!parsed['invicti-enterprise'];
175
+ const data = parsed['invicti-enterprise'] ?? parsed['netsparker-enterprise'] ?? {};
176
+ if (!data.vulnerabilities && !data.target) {
177
+ throw new Error('netsparker: invalid XML — missing expected root element');
178
+ }
179
+ const toolName = isInvicti ? 'Invicti' : 'Netsparker';
180
+ const vulns = data.vulnerabilities?.vulnerability ?? [];
181
+ const target = data.target ?? {};
182
+ const initiated = target.initiated ?? '';
183
+ const { items: limitedVulns, truncated } = limitArray(vulns);
184
+ /* v8 ignore next -- truncation only triggers with >100K items */
185
+ if (truncated) {
186
+ // eslint-disable-next-line no-console
187
+ console.warn(`WARNING: Input truncated at ${limitedVulns.length} vulnerability items (original: ${vulns.length})`);
188
+ }
189
+ // Build one requirement per vulnerability
190
+ const requirements = limitedVulns.map(vuln => buildRequirement(vuln, initiated));
191
+ const title = `${toolName} Enterprise Scan ID: ${target['scan-id'] ?? ''} URL: ${target.url ?? ''}`;
192
+ const baseline = createMinimalBaseline('Netsparker Scan', requirements, {
193
+ resultsChecksum,
194
+ title,
195
+ });
196
+ const targetName = target.url ?? 'Unknown';
197
+ return buildHdfResults({
198
+ generatorName: 'netsparker-to-hdf',
199
+ converterVersion: '1.0.0',
200
+ toolName,
201
+ toolFormat: 'XML',
202
+ baselines: [baseline],
203
+ components: [
204
+ {
205
+ name: targetName,
206
+ type: Copyright.Application,
207
+ },
208
+ ],
209
+ });
210
+ }
211
+ //# sourceMappingURL=converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"converter.js","sourceRoot":"","sources":["../../../../converters/netsparker-to-hdf/typescript/converter.ts"],"names":[],"mappings":"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"}