@x12i/memorix-retrieval 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (232) hide show
  1. package/README.md +124 -0
  2. package/catalox-seeds/inputs/entity-descriptors/assets.json +296 -0
  3. package/catalox-seeds/inputs/entity-descriptors/variabilities-groups.json +312 -0
  4. package/catalox-seeds/inputs/entity-descriptors/vulnerabilities.json +419 -0
  5. package/catalox-seeds/inputs/item-descriptors/asset-detail-item.json +85 -0
  6. package/catalox-seeds/inputs/item-descriptors/variabilities-group-detail-item.json +87 -0
  7. package/catalox-seeds/inputs/item-descriptors/vulnerability-detail-item.json +106 -0
  8. package/catalox-seeds/inputs/list-descriptors/assets-main-list.json +46 -0
  9. package/catalox-seeds/inputs/list-descriptors/critical-vulnerabilities-list.json +44 -0
  10. package/catalox-seeds/inputs/list-descriptors/variabilities-groups-main-list.json +43 -0
  11. package/catalox-seeds/inputs/list-descriptors/vulnerabilities-main-list.json +47 -0
  12. package/catalox-seeds/inputs/manifest.json +44 -0
  13. package/catalox-seeds/inputs/memorix-catalog-ids.json +8 -0
  14. package/catalox-seeds/inputs/memorix-descriptors.bundle.json +1502 -0
  15. package/catalox-seeds/inputs/memorix-entity-descriptors.catalog.json +1029 -0
  16. package/catalox-seeds/inputs/memorix-entity-descriptors.items.json +1026 -0
  17. package/catalox-seeds/inputs/memorix-item-descriptors.catalog.json +283 -0
  18. package/catalox-seeds/inputs/memorix-item-descriptors.items.json +280 -0
  19. package/catalox-seeds/inputs/memorix-list-descriptors.catalog.json +185 -0
  20. package/catalox-seeds/inputs/memorix-list-descriptors.items.json +182 -0
  21. package/catalox-seeds/inputs/scope.json +4 -0
  22. package/catalox-seeds/memorix-retrieval-descriptors.manifest.json +1844 -0
  23. package/dist/client/catalox-like.d.ts +16 -0
  24. package/dist/client/catalox-like.d.ts.map +1 -0
  25. package/dist/client/catalox-like.js +2 -0
  26. package/dist/client/catalox-like.js.map +1 -0
  27. package/dist/client/create-client.d.ts +3 -0
  28. package/dist/client/create-client.d.ts.map +1 -0
  29. package/dist/client/create-client.js +50 -0
  30. package/dist/client/create-client.js.map +1 -0
  31. package/dist/client/create-from-env.d.ts +3 -0
  32. package/dist/client/create-from-env.d.ts.map +1 -0
  33. package/dist/client/create-from-env.js +10 -0
  34. package/dist/client/create-from-env.js.map +1 -0
  35. package/dist/client/types.d.ts +109 -0
  36. package/dist/client/types.d.ts.map +1 -0
  37. package/dist/client/types.js +2 -0
  38. package/dist/client/types.js.map +1 -0
  39. package/dist/client/xronox-like.d.ts +18 -0
  40. package/dist/client/xronox-like.d.ts.map +1 -0
  41. package/dist/client/xronox-like.js +2 -0
  42. package/dist/client/xronox-like.js.map +1 -0
  43. package/dist/content/fetch-content-object.d.ts +16 -0
  44. package/dist/content/fetch-content-object.d.ts.map +1 -0
  45. package/dist/content/fetch-content-object.js +54 -0
  46. package/dist/content/fetch-content-object.js.map +1 -0
  47. package/dist/content/map-content-errors.d.ts +5 -0
  48. package/dist/content/map-content-errors.d.ts.map +1 -0
  49. package/dist/content/map-content-errors.js +39 -0
  50. package/dist/content/map-content-errors.js.map +1 -0
  51. package/dist/content/memorix-content-object.d.ts +21 -0
  52. package/dist/content/memorix-content-object.d.ts.map +1 -0
  53. package/dist/content/memorix-content-object.js +54 -0
  54. package/dist/content/memorix-content-object.js.map +1 -0
  55. package/dist/content/resolve-content-config.d.ts +19 -0
  56. package/dist/content/resolve-content-config.d.ts.map +1 -0
  57. package/dist/content/resolve-content-config.js +37 -0
  58. package/dist/content/resolve-content-config.js.map +1 -0
  59. package/dist/data/collection-name.d.ts +4 -0
  60. package/dist/data/collection-name.d.ts.map +1 -0
  61. package/dist/data/collection-name.js +23 -0
  62. package/dist/data/collection-name.js.map +1 -0
  63. package/dist/data/identity.d.ts +36 -0
  64. package/dist/data/identity.d.ts.map +1 -0
  65. package/dist/data/identity.js +68 -0
  66. package/dist/data/identity.js.map +1 -0
  67. package/dist/data/memorix-read.d.ts +17 -0
  68. package/dist/data/memorix-read.d.ts.map +1 -0
  69. package/dist/data/memorix-read.js +55 -0
  70. package/dist/data/memorix-read.js.map +1 -0
  71. package/dist/data/multi-match.d.ts +16 -0
  72. package/dist/data/multi-match.d.ts.map +1 -0
  73. package/dist/data/multi-match.js +65 -0
  74. package/dist/data/multi-match.js.map +1 -0
  75. package/dist/data/path.d.ts +3 -0
  76. package/dist/data/path.d.ts.map +1 -0
  77. package/dist/data/path.js +23 -0
  78. package/dist/data/path.js.map +1 -0
  79. package/dist/data/xronox-read.d.ts +13 -0
  80. package/dist/data/xronox-read.d.ts.map +1 -0
  81. package/dist/data/xronox-read.js +34 -0
  82. package/dist/data/xronox-read.js.map +1 -0
  83. package/dist/descriptors/catalog-ids.d.ts +5 -0
  84. package/dist/descriptors/catalog-ids.d.ts.map +1 -0
  85. package/dist/descriptors/catalog-ids.js +5 -0
  86. package/dist/descriptors/catalog-ids.js.map +1 -0
  87. package/dist/descriptors/descriptor-types.d.ts +187 -0
  88. package/dist/descriptors/descriptor-types.d.ts.map +1 -0
  89. package/dist/descriptors/descriptor-types.js +2 -0
  90. package/dist/descriptors/descriptor-types.js.map +1 -0
  91. package/dist/descriptors/load-entity-descriptor.d.ts +4 -0
  92. package/dist/descriptors/load-entity-descriptor.d.ts.map +1 -0
  93. package/dist/descriptors/load-entity-descriptor.js +15 -0
  94. package/dist/descriptors/load-entity-descriptor.js.map +1 -0
  95. package/dist/descriptors/load-item-descriptor.d.ts +4 -0
  96. package/dist/descriptors/load-item-descriptor.d.ts.map +1 -0
  97. package/dist/descriptors/load-item-descriptor.js +15 -0
  98. package/dist/descriptors/load-item-descriptor.js.map +1 -0
  99. package/dist/descriptors/load-list-descriptor.d.ts +4 -0
  100. package/dist/descriptors/load-list-descriptor.d.ts.map +1 -0
  101. package/dist/descriptors/load-list-descriptor.js +15 -0
  102. package/dist/descriptors/load-list-descriptor.js.map +1 -0
  103. package/dist/descriptors/validate-descriptor.d.ts +7 -0
  104. package/dist/descriptors/validate-descriptor.d.ts.map +1 -0
  105. package/dist/descriptors/validate-descriptor.js +80 -0
  106. package/dist/descriptors/validate-descriptor.js.map +1 -0
  107. package/dist/errors/errors.d.ts +6 -0
  108. package/dist/errors/errors.d.ts.map +1 -0
  109. package/dist/errors/errors.js +12 -0
  110. package/dist/errors/errors.js.map +1 -0
  111. package/dist/errors/issues.d.ts +14 -0
  112. package/dist/errors/issues.d.ts.map +1 -0
  113. package/dist/errors/issues.js +7 -0
  114. package/dist/errors/issues.js.map +1 -0
  115. package/dist/index.d.ts +22 -0
  116. package/dist/index.d.ts.map +1 -0
  117. package/dist/index.js +18 -0
  118. package/dist/index.js.map +1 -0
  119. package/dist/mongo/connection.d.ts +3 -0
  120. package/dist/mongo/connection.d.ts.map +1 -0
  121. package/dist/mongo/connection.js +8 -0
  122. package/dist/mongo/connection.js.map +1 -0
  123. package/dist/mongo/env.d.ts +6 -0
  124. package/dist/mongo/env.d.ts.map +1 -0
  125. package/dist/mongo/env.js +33 -0
  126. package/dist/mongo/env.js.map +1 -0
  127. package/dist/mongo/read-collection.d.ts +14 -0
  128. package/dist/mongo/read-collection.d.ts.map +1 -0
  129. package/dist/mongo/read-collection.js +45 -0
  130. package/dist/mongo/read-collection.js.map +1 -0
  131. package/dist/mongo/resolve-db.d.ts +6 -0
  132. package/dist/mongo/resolve-db.d.ts.map +1 -0
  133. package/dist/mongo/resolve-db.js +9 -0
  134. package/dist/mongo/resolve-db.js.map +1 -0
  135. package/dist/mongo/types.d.ts +2 -0
  136. package/dist/mongo/types.d.ts.map +1 -0
  137. package/dist/mongo/types.js +2 -0
  138. package/dist/mongo/types.js.map +1 -0
  139. package/dist/relations/fetch-relation.d.ts +5 -0
  140. package/dist/relations/fetch-relation.d.ts.map +1 -0
  141. package/dist/relations/fetch-relation.js +57 -0
  142. package/dist/relations/fetch-relation.js.map +1 -0
  143. package/dist/relations/resolve-relations.d.ts +6 -0
  144. package/dist/relations/resolve-relations.d.ts.map +1 -0
  145. package/dist/relations/resolve-relations.js +20 -0
  146. package/dist/relations/resolve-relations.js.map +1 -0
  147. package/dist/retrieval/batch-fetch.d.ts +11 -0
  148. package/dist/retrieval/batch-fetch.d.ts.map +1 -0
  149. package/dist/retrieval/batch-fetch.js +80 -0
  150. package/dist/retrieval/batch-fetch.js.map +1 -0
  151. package/dist/retrieval/compose-item.d.ts +11 -0
  152. package/dist/retrieval/compose-item.d.ts.map +1 -0
  153. package/dist/retrieval/compose-item.js +18 -0
  154. package/dist/retrieval/compose-item.js.map +1 -0
  155. package/dist/retrieval/compose-row.d.ts +4 -0
  156. package/dist/retrieval/compose-row.d.ts.map +1 -0
  157. package/dist/retrieval/compose-row.js +14 -0
  158. package/dist/retrieval/compose-row.js.map +1 -0
  159. package/dist/retrieval/fetch-item.d.ts +3 -0
  160. package/dist/retrieval/fetch-item.d.ts.map +1 -0
  161. package/dist/retrieval/fetch-item.js +107 -0
  162. package/dist/retrieval/fetch-item.js.map +1 -0
  163. package/dist/retrieval/fetch-list.d.ts +3 -0
  164. package/dist/retrieval/fetch-list.d.ts.map +1 -0
  165. package/dist/retrieval/fetch-list.js +148 -0
  166. package/dist/retrieval/fetch-list.js.map +1 -0
  167. package/dist/retrieval/resolve-fields.d.ts +10 -0
  168. package/dist/retrieval/resolve-fields.d.ts.map +1 -0
  169. package/dist/retrieval/resolve-fields.js +52 -0
  170. package/dist/retrieval/resolve-fields.js.map +1 -0
  171. package/dist/retrieval/resolve-filters.d.ts +3 -0
  172. package/dist/retrieval/resolve-filters.d.ts.map +1 -0
  173. package/dist/retrieval/resolve-filters.js +57 -0
  174. package/dist/retrieval/resolve-filters.js.map +1 -0
  175. package/dist/retrieval/resolve-pagination-driver.d.ts +6 -0
  176. package/dist/retrieval/resolve-pagination-driver.d.ts.map +1 -0
  177. package/dist/retrieval/resolve-pagination-driver.js +22 -0
  178. package/dist/retrieval/resolve-pagination-driver.js.map +1 -0
  179. package/dist/retrieval/resolve-property-source.d.ts +10 -0
  180. package/dist/retrieval/resolve-property-source.d.ts.map +1 -0
  181. package/dist/retrieval/resolve-property-source.js +48 -0
  182. package/dist/retrieval/resolve-property-source.js.map +1 -0
  183. package/dist/retrieval/resolve-sort.d.ts +14 -0
  184. package/dist/retrieval/resolve-sort.d.ts.map +1 -0
  185. package/dist/retrieval/resolve-sort.js +28 -0
  186. package/dist/retrieval/resolve-sort.js.map +1 -0
  187. package/dist/tests/collection-env.test.d.ts +2 -0
  188. package/dist/tests/collection-env.test.d.ts.map +1 -0
  189. package/dist/tests/collection-env.test.js +44 -0
  190. package/dist/tests/collection-env.test.js.map +1 -0
  191. package/dist/tests/content-object.test.d.ts +2 -0
  192. package/dist/tests/content-object.test.d.ts.map +1 -0
  193. package/dist/tests/content-object.test.js +39 -0
  194. package/dist/tests/content-object.test.js.map +1 -0
  195. package/dist/tests/descriptor-validation.test.d.ts +2 -0
  196. package/dist/tests/descriptor-validation.test.d.ts.map +1 -0
  197. package/dist/tests/descriptor-validation.test.js +25 -0
  198. package/dist/tests/descriptor-validation.test.js.map +1 -0
  199. package/dist/tests/env.test.d.ts +2 -0
  200. package/dist/tests/env.test.d.ts.map +1 -0
  201. package/dist/tests/env.test.js +17 -0
  202. package/dist/tests/env.test.js.map +1 -0
  203. package/dist/tests/fetch-item.test.d.ts +2 -0
  204. package/dist/tests/fetch-item.test.d.ts.map +1 -0
  205. package/dist/tests/fetch-item.test.js +86 -0
  206. package/dist/tests/fetch-item.test.js.map +1 -0
  207. package/dist/tests/fetch-list.test.d.ts +2 -0
  208. package/dist/tests/fetch-list.test.d.ts.map +1 -0
  209. package/dist/tests/fetch-list.test.js +85 -0
  210. package/dist/tests/fetch-list.test.js.map +1 -0
  211. package/dist/tests/fixtures.d.ts +5 -0
  212. package/dist/tests/fixtures.d.ts.map +1 -0
  213. package/dist/tests/fixtures.js +137 -0
  214. package/dist/tests/fixtures.js.map +1 -0
  215. package/dist/tests/identity.test.d.ts +2 -0
  216. package/dist/tests/identity.test.d.ts.map +1 -0
  217. package/dist/tests/identity.test.js +32 -0
  218. package/dist/tests/identity.test.js.map +1 -0
  219. package/dist/tests/multi-match.test.d.ts +2 -0
  220. package/dist/tests/multi-match.test.d.ts.map +1 -0
  221. package/dist/tests/multi-match.test.js +31 -0
  222. package/dist/tests/multi-match.test.js.map +1 -0
  223. package/dist/tests/read-collection.test.d.ts +2 -0
  224. package/dist/tests/read-collection.test.d.ts.map +1 -0
  225. package/dist/tests/read-collection.test.js +19 -0
  226. package/dist/tests/read-collection.test.js.map +1 -0
  227. package/dist/tests/relations.test.d.ts +2 -0
  228. package/dist/tests/relations.test.d.ts.map +1 -0
  229. package/dist/tests/relations.test.js +77 -0
  230. package/dist/tests/relations.test.js.map +1 -0
  231. package/docs/MEMORIX-DATABASE-CONVENTIONS.md +325 -0
  232. package/package.json +52 -0
@@ -0,0 +1,419 @@
1
+ {
2
+ "id": "vulnerabilities",
3
+ "entityName": "vulnerabilities",
4
+ "target": "event",
5
+ "collectionPrefix": "vulnerabilities",
6
+ "identity": {
7
+ "allowedIdFields": [
8
+ "entityId",
9
+ "eventId"
10
+ ],
11
+ "requiredExactlyOne": true,
12
+ "defaultIdField": "entityId"
13
+ },
14
+ "defaults": {
15
+ "canonicalContentType": "snapshots",
16
+ "dataRoot": "data",
17
+ "effectiveDatePath": "capturedAt",
18
+ "fallbackEffectiveDatePaths": [
19
+ "snapshot.capturedAt",
20
+ "data.enrichment.enrichedAt"
21
+ ]
22
+ },
23
+ "contentTypes": {
24
+ "snapshots": {
25
+ "postfix": "snapshots",
26
+ "collection": "vulnerabilities-snapshots",
27
+ "dataRoot": "data",
28
+ "isCanonical": true,
29
+ "effectiveDatePath": "capturedAt",
30
+ "fallbackEffectiveDatePaths": [
31
+ "snapshot.capturedAt",
32
+ "data.enrichment.enrichedAt"
33
+ ]
34
+ }
35
+ },
36
+ "properties": {
37
+ "vulnerabilityId": {
38
+ "label": "Vulnerability ID",
39
+ "source": {
40
+ "contentType": "snapshots",
41
+ "path": "data.vulnerabilityId"
42
+ },
43
+ "humanReadable": true,
44
+ "sortable": true,
45
+ "filterable": true,
46
+ "list": true,
47
+ "item": true,
48
+ "valueType": "string"
49
+ },
50
+ "assetIp": {
51
+ "label": "Asset IP",
52
+ "source": {
53
+ "contentType": "snapshots",
54
+ "path": "data.assetIp"
55
+ },
56
+ "humanReadable": true,
57
+ "sortable": true,
58
+ "filterable": true,
59
+ "list": true,
60
+ "item": true,
61
+ "valueType": "string"
62
+ },
63
+ "assetType": {
64
+ "label": "Asset Type",
65
+ "source": {
66
+ "contentType": "snapshots",
67
+ "path": "data.assetType"
68
+ },
69
+ "humanReadable": true,
70
+ "sortable": true,
71
+ "filterable": true,
72
+ "list": true,
73
+ "item": true,
74
+ "valueType": "string"
75
+ },
76
+ "assetZone": {
77
+ "label": "Asset Zone",
78
+ "source": {
79
+ "contentType": "snapshots",
80
+ "path": "data.assetZone"
81
+ },
82
+ "humanReadable": true,
83
+ "sortable": true,
84
+ "filterable": true,
85
+ "list": true,
86
+ "item": true,
87
+ "valueType": "string"
88
+ },
89
+ "assetHostname": {
90
+ "label": "Asset Hostname",
91
+ "source": {
92
+ "contentType": "snapshots",
93
+ "path": "data.assetHostname"
94
+ },
95
+ "humanReadable": true,
96
+ "sortable": true,
97
+ "filterable": true,
98
+ "list": true,
99
+ "item": true,
100
+ "valueType": "string"
101
+ },
102
+ "pluginId": {
103
+ "label": "Plugin ID",
104
+ "source": {
105
+ "contentType": "snapshots",
106
+ "path": "data.pluginId"
107
+ },
108
+ "humanReadable": true,
109
+ "sortable": true,
110
+ "filterable": true,
111
+ "list": true,
112
+ "item": true,
113
+ "valueType": "number"
114
+ },
115
+ "pluginName": {
116
+ "label": "Plugin Name",
117
+ "source": {
118
+ "contentType": "snapshots",
119
+ "path": "data.pluginName"
120
+ },
121
+ "humanReadable": true,
122
+ "sortable": true,
123
+ "filterable": true,
124
+ "list": true,
125
+ "item": true,
126
+ "valueType": "string"
127
+ },
128
+ "pluginFamily": {
129
+ "label": "Plugin Family",
130
+ "source": {
131
+ "contentType": "snapshots",
132
+ "path": "data.pluginFamily"
133
+ },
134
+ "humanReadable": true,
135
+ "sortable": true,
136
+ "filterable": true,
137
+ "list": true,
138
+ "item": true,
139
+ "valueType": "string"
140
+ },
141
+ "severity": {
142
+ "label": "Severity",
143
+ "source": {
144
+ "contentType": "snapshots",
145
+ "path": "data.severity"
146
+ },
147
+ "humanReadable": true,
148
+ "sortable": true,
149
+ "filterable": true,
150
+ "list": true,
151
+ "item": true,
152
+ "valueType": "string"
153
+ },
154
+ "severityLevel": {
155
+ "label": "Severity Level",
156
+ "source": {
157
+ "contentType": "snapshots",
158
+ "path": "data.severityLevel"
159
+ },
160
+ "humanReadable": true,
161
+ "sortable": true,
162
+ "filterable": true,
163
+ "list": true,
164
+ "item": true,
165
+ "valueType": "number"
166
+ },
167
+ "cveIds": {
168
+ "label": "CVEs",
169
+ "source": {
170
+ "contentType": "snapshots",
171
+ "path": "data.cveIds"
172
+ },
173
+ "humanReadable": true,
174
+ "sortable": false,
175
+ "filterable": true,
176
+ "list": true,
177
+ "item": true,
178
+ "valueType": "array"
179
+ },
180
+ "riskLevel": {
181
+ "label": "Risk Level",
182
+ "source": {
183
+ "contentType": "snapshots",
184
+ "path": "data.enrichment.riskLevel"
185
+ },
186
+ "humanReadable": true,
187
+ "sortable": true,
188
+ "filterable": true,
189
+ "list": true,
190
+ "item": true,
191
+ "valueType": "string"
192
+ },
193
+ "priorityScore": {
194
+ "label": "Priority Score",
195
+ "source": {
196
+ "contentType": "snapshots",
197
+ "path": "data.enrichment.priorityScore"
198
+ },
199
+ "humanReadable": true,
200
+ "sortable": true,
201
+ "filterable": true,
202
+ "list": true,
203
+ "item": true,
204
+ "valueType": "number"
205
+ },
206
+ "compositeScore": {
207
+ "label": "Composite Score",
208
+ "source": {
209
+ "contentType": "snapshots",
210
+ "path": "data.enrichment.compositeScore"
211
+ },
212
+ "humanReadable": true,
213
+ "sortable": true,
214
+ "filterable": true,
215
+ "list": true,
216
+ "item": true,
217
+ "valueType": "number"
218
+ },
219
+ "epss": {
220
+ "label": "EPSS",
221
+ "source": {
222
+ "contentType": "snapshots",
223
+ "path": "data.enrichment.epss.epss"
224
+ },
225
+ "humanReadable": true,
226
+ "sortable": true,
227
+ "filterable": true,
228
+ "list": true,
229
+ "item": true,
230
+ "valueType": "number"
231
+ },
232
+ "epssPercentile": {
233
+ "label": "EPSS Percentile",
234
+ "source": {
235
+ "contentType": "snapshots",
236
+ "path": "data.enrichment.epss.percentile"
237
+ },
238
+ "humanReadable": true,
239
+ "sortable": true,
240
+ "filterable": true,
241
+ "list": true,
242
+ "item": true,
243
+ "valueType": "number"
244
+ },
245
+ "knownExploited": {
246
+ "label": "Known Exploited",
247
+ "source": {
248
+ "contentType": "snapshots",
249
+ "path": "data.enrichment.kev.isKnownExploited"
250
+ },
251
+ "humanReadable": true,
252
+ "sortable": true,
253
+ "filterable": true,
254
+ "list": true,
255
+ "item": true,
256
+ "valueType": "boolean"
257
+ },
258
+ "cvssBaseScore": {
259
+ "label": "CVSS Base Score",
260
+ "source": {
261
+ "contentType": "snapshots",
262
+ "path": "data.enrichment.cvss.baseScore"
263
+ },
264
+ "humanReadable": true,
265
+ "sortable": true,
266
+ "filterable": true,
267
+ "list": true,
268
+ "item": true,
269
+ "valueType": "number"
270
+ },
271
+ "cvssVector": {
272
+ "label": "CVSS Vector",
273
+ "source": {
274
+ "contentType": "snapshots",
275
+ "path": "data.enrichment.cvss.cvssVector"
276
+ },
277
+ "humanReadable": true,
278
+ "sortable": false,
279
+ "filterable": true,
280
+ "list": false,
281
+ "item": true,
282
+ "valueType": "string"
283
+ },
284
+ "exploitabilityScore": {
285
+ "label": "Exploitability Score",
286
+ "source": {
287
+ "contentType": "snapshots",
288
+ "path": "data.exploitabilityScore"
289
+ },
290
+ "humanReadable": true,
291
+ "sortable": true,
292
+ "filterable": true,
293
+ "list": true,
294
+ "item": true,
295
+ "valueType": "number"
296
+ },
297
+ "exploitabilityLevel": {
298
+ "label": "Exploitability Level",
299
+ "source": {
300
+ "contentType": "snapshots",
301
+ "path": "data.exploitabilityLevel"
302
+ },
303
+ "humanReadable": true,
304
+ "sortable": true,
305
+ "filterable": true,
306
+ "list": true,
307
+ "item": true,
308
+ "valueType": "string"
309
+ },
310
+ "assetMatched": {
311
+ "label": "Asset Matched",
312
+ "source": {
313
+ "contentType": "snapshots",
314
+ "path": "data.assetMatched"
315
+ },
316
+ "humanReadable": true,
317
+ "sortable": true,
318
+ "filterable": true,
319
+ "list": false,
320
+ "item": true,
321
+ "valueType": "boolean"
322
+ },
323
+ "networkExposure": {
324
+ "label": "Network Exposure",
325
+ "source": {
326
+ "contentType": "snapshots",
327
+ "path": "data.mitreAnalysis.networkContext.exposure"
328
+ },
329
+ "humanReadable": true,
330
+ "sortable": true,
331
+ "filterable": true,
332
+ "list": true,
333
+ "item": true,
334
+ "valueType": "string"
335
+ },
336
+ "attackPathCount": {
337
+ "label": "Attack Path Count",
338
+ "source": {
339
+ "contentType": "snapshots",
340
+ "path": "data.mitreAnalysis.networkContext.paths.paths"
341
+ },
342
+ "humanReadable": true,
343
+ "sortable": false,
344
+ "filterable": false,
345
+ "list": false,
346
+ "item": true,
347
+ "valueType": "array"
348
+ },
349
+ "mitreTechniques": {
350
+ "label": "MITRE Techniques",
351
+ "source": {
352
+ "contentType": "snapshots",
353
+ "path": "data.mitreAnalysis.techniques"
354
+ },
355
+ "humanReadable": true,
356
+ "sortable": false,
357
+ "filterable": true,
358
+ "list": false,
359
+ "item": true,
360
+ "valueType": "array"
361
+ },
362
+ "mitreAnalysis": {
363
+ "label": "MITRE Analysis",
364
+ "source": {
365
+ "contentType": "snapshots",
366
+ "path": "data.mitreAnalysis"
367
+ },
368
+ "humanReadable": false,
369
+ "sortable": false,
370
+ "filterable": false,
371
+ "list": false,
372
+ "item": true,
373
+ "valueType": "object"
374
+ }
375
+ },
376
+ "relations": {
377
+ "affectedAsset": {
378
+ "targetEntity": "assets",
379
+ "type": "manyToOne",
380
+ "source": {
381
+ "contentType": "snapshots",
382
+ "path": "data.assetIp"
383
+ },
384
+ "target": {
385
+ "contentType": "snapshots",
386
+ "path": "data.ip_address"
387
+ },
388
+ "defaultMode": "extendFields",
389
+ "targetFields": [
390
+ "ipAddress",
391
+ "hostName",
392
+ "xdrOperationalStatus",
393
+ "xdrAgentStatus",
394
+ "potentialImpactLevel"
395
+ ]
396
+ },
397
+ "vulnerabilityGroup": {
398
+ "targetEntity": "variabilities-groups",
399
+ "type": "manyToOne",
400
+ "source": {
401
+ "contentType": "snapshots",
402
+ "path": "data.pluginId"
403
+ },
404
+ "target": {
405
+ "contentType": "snapshots",
406
+ "path": "data.plugin_id"
407
+ },
408
+ "defaultMode": "extendFields",
409
+ "targetFields": [
410
+ "groupId",
411
+ "pluginName",
412
+ "severityLevel",
413
+ "affectedEntitiesCount",
414
+ "riskLevel",
415
+ "priorityScore"
416
+ ]
417
+ }
418
+ }
419
+ }
@@ -0,0 +1,85 @@
1
+ {
2
+ "id": "asset-detail-item",
3
+ "entity": "assets",
4
+ "title": "Asset Detail",
5
+ "identity": {
6
+ "idField": "entityId"
7
+ },
8
+ "contentTypes": [
9
+ {
10
+ "contentType": "snapshots",
11
+ "required": true,
12
+ "multiMatch": {
13
+ "strategy": "last",
14
+ "effectiveDatePath": "capturedAt",
15
+ "fallbackEffectiveDatePaths": [
16
+ "snapshot.capturedAt",
17
+ "data.xdr.last_seen"
18
+ ]
19
+ }
20
+ }
21
+ ],
22
+ "sections": [
23
+ {
24
+ "id": "summary",
25
+ "title": "Summary",
26
+ "fields": [
27
+ "ipAddress",
28
+ "hostName",
29
+ "source",
30
+ "agentType",
31
+ "xdrOperationalStatus",
32
+ "xdrAgentStatus",
33
+ "lastSeen",
34
+ "pathsCount"
35
+ ]
36
+ },
37
+ {
38
+ "id": "vulnerabilitySummary",
39
+ "title": "Vulnerability Summary",
40
+ "fields": [
41
+ "hasVulnerabilities",
42
+ "criticalVulnerabilities",
43
+ "highVulnerabilities",
44
+ "mediumVulnerabilities",
45
+ "lowVulnerabilities"
46
+ ]
47
+ },
48
+ {
49
+ "id": "impact",
50
+ "title": "Potential Impact",
51
+ "fields": [
52
+ "potentialImpactLevel",
53
+ "potentialImpactConfidence",
54
+ "potentialImpactStory"
55
+ ]
56
+ },
57
+ {
58
+ "id": "xdr",
59
+ "title": "XDR",
60
+ "fields": [
61
+ "users",
62
+ "rawXdr"
63
+ ]
64
+ }
65
+ ],
66
+ "includeRelations": [
67
+ {
68
+ "relation": "assetVulnerabilities",
69
+ "mode": "array",
70
+ "arrayProperty": "vulnerabilities",
71
+ "limit": 100,
72
+ "fields": [
73
+ "vulnerabilityId",
74
+ "pluginName",
75
+ "severityLevel",
76
+ "riskLevel",
77
+ "priorityScore",
78
+ "cveIds"
79
+ ]
80
+ }
81
+ ],
82
+ "content": {
83
+ "allowed": false
84
+ }
85
+ }
@@ -0,0 +1,87 @@
1
+ {
2
+ "id": "variabilities-group-detail-item",
3
+ "entity": "variabilities-groups",
4
+ "title": "Vulnerability Group Detail",
5
+ "identity": {
6
+ "idField": "entityId"
7
+ },
8
+ "contentTypes": [
9
+ {
10
+ "contentType": "snapshots",
11
+ "required": true,
12
+ "multiMatch": {
13
+ "strategy": "last",
14
+ "effectiveDatePath": "capturedAt",
15
+ "fallbackEffectiveDatePaths": [
16
+ "snapshot.capturedAt",
17
+ "data.enrichedAt",
18
+ "data.enrichment.enrichedAt"
19
+ ]
20
+ }
21
+ }
22
+ ],
23
+ "sections": [
24
+ {
25
+ "id": "summary",
26
+ "title": "Summary",
27
+ "fields": [
28
+ "groupId",
29
+ "type",
30
+ "pluginId",
31
+ "pluginName",
32
+ "pluginFamily",
33
+ "severity",
34
+ "severityLevel",
35
+ "cveIds",
36
+ "source"
37
+ ]
38
+ },
39
+ {
40
+ "id": "affectedEntities",
41
+ "title": "Affected Entities",
42
+ "fields": [
43
+ "affectedEntities",
44
+ "affectedEntitiesCount"
45
+ ]
46
+ },
47
+ {
48
+ "id": "risk",
49
+ "title": "Risk",
50
+ "fields": [
51
+ "riskLevel",
52
+ "priorityScore",
53
+ "compositeScore"
54
+ ]
55
+ },
56
+ {
57
+ "id": "threatIntelligence",
58
+ "title": "Threat Intelligence",
59
+ "fields": [
60
+ "epss",
61
+ "knownExploited",
62
+ "cvssBaseScore",
63
+ "cvssVector",
64
+ "enrichedAt"
65
+ ]
66
+ }
67
+ ],
68
+ "includeRelations": [
69
+ {
70
+ "relation": "groupVulnerabilities",
71
+ "mode": "array",
72
+ "arrayProperty": "vulnerabilities",
73
+ "limit": 200,
74
+ "fields": [
75
+ "vulnerabilityId",
76
+ "assetIp",
77
+ "pluginName",
78
+ "severityLevel",
79
+ "riskLevel",
80
+ "priorityScore"
81
+ ]
82
+ }
83
+ ],
84
+ "content": {
85
+ "allowed": false
86
+ }
87
+ }
@@ -0,0 +1,106 @@
1
+ {
2
+ "id": "vulnerability-detail-item",
3
+ "entity": "vulnerabilities",
4
+ "title": "Vulnerability Detail",
5
+ "identity": {
6
+ "idField": "entityId"
7
+ },
8
+ "contentTypes": [
9
+ {
10
+ "contentType": "snapshots",
11
+ "required": true,
12
+ "multiMatch": {
13
+ "strategy": "last",
14
+ "effectiveDatePath": "capturedAt",
15
+ "fallbackEffectiveDatePaths": [
16
+ "snapshot.capturedAt",
17
+ "data.enrichment.enrichedAt"
18
+ ]
19
+ }
20
+ }
21
+ ],
22
+ "sections": [
23
+ {
24
+ "id": "summary",
25
+ "title": "Summary",
26
+ "fields": [
27
+ "vulnerabilityId",
28
+ "pluginName",
29
+ "pluginFamily",
30
+ "severity",
31
+ "severityLevel",
32
+ "cveIds"
33
+ ]
34
+ },
35
+ {
36
+ "id": "asset",
37
+ "title": "Affected Asset",
38
+ "fields": [
39
+ "assetIp",
40
+ "assetType",
41
+ "assetZone",
42
+ "assetHostname",
43
+ "assetMatched"
44
+ ]
45
+ },
46
+ {
47
+ "id": "risk",
48
+ "title": "Risk",
49
+ "fields": [
50
+ "riskLevel",
51
+ "priorityScore",
52
+ "compositeScore",
53
+ "exploitabilityScore",
54
+ "exploitabilityLevel"
55
+ ]
56
+ },
57
+ {
58
+ "id": "threatIntelligence",
59
+ "title": "Threat Intelligence",
60
+ "fields": [
61
+ "epss",
62
+ "epssPercentile",
63
+ "knownExploited",
64
+ "cvssBaseScore",
65
+ "cvssVector"
66
+ ]
67
+ },
68
+ {
69
+ "id": "networkAndMitre",
70
+ "title": "Network & MITRE",
71
+ "fields": [
72
+ "networkExposure",
73
+ "mitreTechniques",
74
+ "mitreAnalysis"
75
+ ]
76
+ }
77
+ ],
78
+ "includeRelations": [
79
+ {
80
+ "relation": "affectedAsset",
81
+ "mode": "extendFields",
82
+ "fields": [
83
+ "ipAddress",
84
+ "hostName",
85
+ "xdrOperationalStatus",
86
+ "xdrAgentStatus",
87
+ "potentialImpactLevel"
88
+ ]
89
+ },
90
+ {
91
+ "relation": "vulnerabilityGroup",
92
+ "mode": "extendFields",
93
+ "fields": [
94
+ "groupId",
95
+ "pluginName",
96
+ "severityLevel",
97
+ "affectedEntitiesCount",
98
+ "riskLevel",
99
+ "priorityScore"
100
+ ]
101
+ }
102
+ ],
103
+ "content": {
104
+ "allowed": false
105
+ }
106
+ }