@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,1502 @@
1
+ {
2
+ "appId": "memorix",
3
+ "catalogs": {
4
+ "entityDescriptors": {
5
+ "catalogId": "memorix-entity-descriptors",
6
+ "items": [
7
+ {
8
+ "id": "assets",
9
+ "entityName": "assets",
10
+ "collectionPrefix": "assets",
11
+ "identity": {
12
+ "allowedIdFields": [
13
+ "entityId",
14
+ "eventId"
15
+ ],
16
+ "requiredExactlyOne": true,
17
+ "defaultIdField": "entityId"
18
+ },
19
+ "defaults": {
20
+ "canonicalContentType": "snapshots",
21
+ "dataRoot": "data",
22
+ "effectiveDatePath": "capturedAt",
23
+ "fallbackEffectiveDatePaths": [
24
+ "snapshot.capturedAt",
25
+ "data.xdr.last_seen"
26
+ ]
27
+ },
28
+ "contentTypes": {
29
+ "snapshots": {
30
+ "postfix": "snapshots",
31
+ "collection": "assets-snapshots",
32
+ "dataRoot": "data",
33
+ "isCanonical": true,
34
+ "effectiveDatePath": "capturedAt",
35
+ "fallbackEffectiveDatePaths": [
36
+ "snapshot.capturedAt",
37
+ "data.xdr.last_seen"
38
+ ]
39
+ }
40
+ },
41
+ "properties": {
42
+ "ipAddress": {
43
+ "label": "IP Address",
44
+ "source": {
45
+ "contentType": "snapshots",
46
+ "path": "data.ip_address"
47
+ },
48
+ "humanReadable": true,
49
+ "sortable": true,
50
+ "filterable": true,
51
+ "list": true,
52
+ "item": true,
53
+ "valueType": "string"
54
+ },
55
+ "source": {
56
+ "label": "Source",
57
+ "source": {
58
+ "contentType": "snapshots",
59
+ "path": "data._source"
60
+ },
61
+ "humanReadable": true,
62
+ "sortable": true,
63
+ "filterable": true,
64
+ "list": true,
65
+ "item": true,
66
+ "valueType": "string"
67
+ },
68
+ "hostName": {
69
+ "label": "Host Name",
70
+ "source": {
71
+ "contentType": "snapshots",
72
+ "path": "data.xdr.host_name"
73
+ },
74
+ "humanReadable": true,
75
+ "sortable": true,
76
+ "filterable": true,
77
+ "list": true,
78
+ "item": true,
79
+ "valueType": "string"
80
+ },
81
+ "xdrOperationalStatus": {
82
+ "label": "XDR Operational Status",
83
+ "source": {
84
+ "contentType": "snapshots",
85
+ "path": "data.xdr.operational_status"
86
+ },
87
+ "humanReadable": true,
88
+ "sortable": true,
89
+ "filterable": true,
90
+ "list": true,
91
+ "item": true,
92
+ "valueType": "string"
93
+ },
94
+ "xdrAgentStatus": {
95
+ "label": "XDR Agent Status",
96
+ "source": {
97
+ "contentType": "snapshots",
98
+ "path": "data.xdr.agent_status"
99
+ },
100
+ "humanReadable": true,
101
+ "sortable": true,
102
+ "filterable": true,
103
+ "list": true,
104
+ "item": true,
105
+ "valueType": "string"
106
+ },
107
+ "agentType": {
108
+ "label": "Agent Type",
109
+ "source": {
110
+ "contentType": "snapshots",
111
+ "path": "data.xdr.agent_type"
112
+ },
113
+ "humanReadable": true,
114
+ "sortable": true,
115
+ "filterable": true,
116
+ "list": true,
117
+ "item": true,
118
+ "valueType": "string"
119
+ },
120
+ "lastSeen": {
121
+ "label": "Last Seen",
122
+ "source": {
123
+ "contentType": "snapshots",
124
+ "path": "data.xdr.last_seen"
125
+ },
126
+ "humanReadable": true,
127
+ "sortable": true,
128
+ "filterable": true,
129
+ "list": true,
130
+ "item": true,
131
+ "valueType": "datetime"
132
+ },
133
+ "users": {
134
+ "label": "Users",
135
+ "source": {
136
+ "contentType": "snapshots",
137
+ "path": "data.xdr.users"
138
+ },
139
+ "humanReadable": true,
140
+ "sortable": false,
141
+ "filterable": true,
142
+ "list": true,
143
+ "item": true,
144
+ "valueType": "array"
145
+ },
146
+ "hasVulnerabilities": {
147
+ "label": "Has Vulnerabilities",
148
+ "source": {
149
+ "contentType": "snapshots",
150
+ "path": "data.vulnerabilities.hasVulnerabilities"
151
+ },
152
+ "humanReadable": true,
153
+ "sortable": true,
154
+ "filterable": true,
155
+ "list": true,
156
+ "item": true,
157
+ "valueType": "boolean"
158
+ },
159
+ "criticalVulnerabilities": {
160
+ "label": "Critical Vulnerabilities",
161
+ "source": {
162
+ "contentType": "snapshots",
163
+ "path": "data.vulnerabilities.count.critical"
164
+ },
165
+ "humanReadable": true,
166
+ "sortable": true,
167
+ "filterable": true,
168
+ "list": true,
169
+ "item": true,
170
+ "valueType": "number"
171
+ },
172
+ "highVulnerabilities": {
173
+ "label": "High Vulnerabilities",
174
+ "source": {
175
+ "contentType": "snapshots",
176
+ "path": "data.vulnerabilities.count.high"
177
+ },
178
+ "humanReadable": true,
179
+ "sortable": true,
180
+ "filterable": true,
181
+ "list": true,
182
+ "item": true,
183
+ "valueType": "number"
184
+ },
185
+ "mediumVulnerabilities": {
186
+ "label": "Medium Vulnerabilities",
187
+ "source": {
188
+ "contentType": "snapshots",
189
+ "path": "data.vulnerabilities.count.medium"
190
+ },
191
+ "humanReadable": true,
192
+ "sortable": true,
193
+ "filterable": true,
194
+ "list": true,
195
+ "item": true,
196
+ "valueType": "number"
197
+ },
198
+ "lowVulnerabilities": {
199
+ "label": "Low Vulnerabilities",
200
+ "source": {
201
+ "contentType": "snapshots",
202
+ "path": "data.vulnerabilities.count.low"
203
+ },
204
+ "humanReadable": true,
205
+ "sortable": true,
206
+ "filterable": true,
207
+ "list": true,
208
+ "item": true,
209
+ "valueType": "number"
210
+ },
211
+ "potentialImpactLevel": {
212
+ "label": "Potential Impact",
213
+ "source": {
214
+ "contentType": "snapshots",
215
+ "path": "data.potentialImpact.level"
216
+ },
217
+ "humanReadable": true,
218
+ "sortable": true,
219
+ "filterable": true,
220
+ "list": true,
221
+ "item": true,
222
+ "valueType": "string"
223
+ },
224
+ "potentialImpactConfidence": {
225
+ "label": "Impact Confidence",
226
+ "source": {
227
+ "contentType": "snapshots",
228
+ "path": "data.potentialImpact.confidence"
229
+ },
230
+ "humanReadable": true,
231
+ "sortable": true,
232
+ "filterable": true,
233
+ "list": true,
234
+ "item": true,
235
+ "valueType": "number"
236
+ },
237
+ "potentialImpactStory": {
238
+ "label": "Potential Impact Story",
239
+ "source": {
240
+ "contentType": "snapshots",
241
+ "path": "data.potentialImpact.story"
242
+ },
243
+ "humanReadable": false,
244
+ "sortable": false,
245
+ "filterable": false,
246
+ "list": false,
247
+ "item": true,
248
+ "valueType": "array"
249
+ },
250
+ "pathsCount": {
251
+ "label": "Paths Count",
252
+ "source": {
253
+ "contentType": "snapshots",
254
+ "path": "data.pathsCount"
255
+ },
256
+ "humanReadable": true,
257
+ "sortable": true,
258
+ "filterable": true,
259
+ "list": true,
260
+ "item": true,
261
+ "valueType": "number"
262
+ },
263
+ "rawXdr": {
264
+ "label": "Raw XDR",
265
+ "source": {
266
+ "contentType": "snapshots",
267
+ "path": "data.xdr"
268
+ },
269
+ "humanReadable": false,
270
+ "sortable": false,
271
+ "filterable": false,
272
+ "list": false,
273
+ "item": true,
274
+ "valueType": "object"
275
+ }
276
+ },
277
+ "relations": {
278
+ "assetVulnerabilities": {
279
+ "targetEntity": "vulnerabilities",
280
+ "type": "oneToMany",
281
+ "source": {
282
+ "contentType": "snapshots",
283
+ "path": "data.ip_address"
284
+ },
285
+ "target": {
286
+ "contentType": "snapshots",
287
+ "path": "data.assetIp"
288
+ },
289
+ "defaultMode": "array",
290
+ "defaultArrayProperty": "vulnerabilities",
291
+ "targetFields": [
292
+ "vulnerabilityId",
293
+ "pluginName",
294
+ "severityLevel",
295
+ "riskLevel",
296
+ "priorityScore",
297
+ "cveIds"
298
+ ]
299
+ }
300
+ }
301
+ },
302
+ {
303
+ "id": "vulnerabilities",
304
+ "entityName": "vulnerabilities",
305
+ "collectionPrefix": "vulnerabilities",
306
+ "identity": {
307
+ "allowedIdFields": [
308
+ "entityId",
309
+ "eventId"
310
+ ],
311
+ "requiredExactlyOne": true,
312
+ "defaultIdField": "entityId"
313
+ },
314
+ "defaults": {
315
+ "canonicalContentType": "snapshots",
316
+ "dataRoot": "data",
317
+ "effectiveDatePath": "capturedAt",
318
+ "fallbackEffectiveDatePaths": [
319
+ "snapshot.capturedAt",
320
+ "data.enrichment.enrichedAt"
321
+ ]
322
+ },
323
+ "contentTypes": {
324
+ "snapshots": {
325
+ "postfix": "snapshots",
326
+ "collection": "vulnerabilities-snapshots",
327
+ "dataRoot": "data",
328
+ "isCanonical": true,
329
+ "effectiveDatePath": "capturedAt",
330
+ "fallbackEffectiveDatePaths": [
331
+ "snapshot.capturedAt",
332
+ "data.enrichment.enrichedAt"
333
+ ]
334
+ }
335
+ },
336
+ "properties": {
337
+ "vulnerabilityId": {
338
+ "label": "Vulnerability ID",
339
+ "source": {
340
+ "contentType": "snapshots",
341
+ "path": "data.vulnerabilityId"
342
+ },
343
+ "humanReadable": true,
344
+ "sortable": true,
345
+ "filterable": true,
346
+ "list": true,
347
+ "item": true,
348
+ "valueType": "string"
349
+ },
350
+ "assetIp": {
351
+ "label": "Asset IP",
352
+ "source": {
353
+ "contentType": "snapshots",
354
+ "path": "data.assetIp"
355
+ },
356
+ "humanReadable": true,
357
+ "sortable": true,
358
+ "filterable": true,
359
+ "list": true,
360
+ "item": true,
361
+ "valueType": "string"
362
+ },
363
+ "assetType": {
364
+ "label": "Asset Type",
365
+ "source": {
366
+ "contentType": "snapshots",
367
+ "path": "data.assetType"
368
+ },
369
+ "humanReadable": true,
370
+ "sortable": true,
371
+ "filterable": true,
372
+ "list": true,
373
+ "item": true,
374
+ "valueType": "string"
375
+ },
376
+ "assetZone": {
377
+ "label": "Asset Zone",
378
+ "source": {
379
+ "contentType": "snapshots",
380
+ "path": "data.assetZone"
381
+ },
382
+ "humanReadable": true,
383
+ "sortable": true,
384
+ "filterable": true,
385
+ "list": true,
386
+ "item": true,
387
+ "valueType": "string"
388
+ },
389
+ "assetHostname": {
390
+ "label": "Asset Hostname",
391
+ "source": {
392
+ "contentType": "snapshots",
393
+ "path": "data.assetHostname"
394
+ },
395
+ "humanReadable": true,
396
+ "sortable": true,
397
+ "filterable": true,
398
+ "list": true,
399
+ "item": true,
400
+ "valueType": "string"
401
+ },
402
+ "pluginId": {
403
+ "label": "Plugin ID",
404
+ "source": {
405
+ "contentType": "snapshots",
406
+ "path": "data.pluginId"
407
+ },
408
+ "humanReadable": true,
409
+ "sortable": true,
410
+ "filterable": true,
411
+ "list": true,
412
+ "item": true,
413
+ "valueType": "number"
414
+ },
415
+ "pluginName": {
416
+ "label": "Plugin Name",
417
+ "source": {
418
+ "contentType": "snapshots",
419
+ "path": "data.pluginName"
420
+ },
421
+ "humanReadable": true,
422
+ "sortable": true,
423
+ "filterable": true,
424
+ "list": true,
425
+ "item": true,
426
+ "valueType": "string"
427
+ },
428
+ "pluginFamily": {
429
+ "label": "Plugin Family",
430
+ "source": {
431
+ "contentType": "snapshots",
432
+ "path": "data.pluginFamily"
433
+ },
434
+ "humanReadable": true,
435
+ "sortable": true,
436
+ "filterable": true,
437
+ "list": true,
438
+ "item": true,
439
+ "valueType": "string"
440
+ },
441
+ "severity": {
442
+ "label": "Severity",
443
+ "source": {
444
+ "contentType": "snapshots",
445
+ "path": "data.severity"
446
+ },
447
+ "humanReadable": true,
448
+ "sortable": true,
449
+ "filterable": true,
450
+ "list": true,
451
+ "item": true,
452
+ "valueType": "string"
453
+ },
454
+ "severityLevel": {
455
+ "label": "Severity Level",
456
+ "source": {
457
+ "contentType": "snapshots",
458
+ "path": "data.severityLevel"
459
+ },
460
+ "humanReadable": true,
461
+ "sortable": true,
462
+ "filterable": true,
463
+ "list": true,
464
+ "item": true,
465
+ "valueType": "number"
466
+ },
467
+ "cveIds": {
468
+ "label": "CVEs",
469
+ "source": {
470
+ "contentType": "snapshots",
471
+ "path": "data.cveIds"
472
+ },
473
+ "humanReadable": true,
474
+ "sortable": false,
475
+ "filterable": true,
476
+ "list": true,
477
+ "item": true,
478
+ "valueType": "array"
479
+ },
480
+ "riskLevel": {
481
+ "label": "Risk Level",
482
+ "source": {
483
+ "contentType": "snapshots",
484
+ "path": "data.enrichment.riskLevel"
485
+ },
486
+ "humanReadable": true,
487
+ "sortable": true,
488
+ "filterable": true,
489
+ "list": true,
490
+ "item": true,
491
+ "valueType": "string"
492
+ },
493
+ "priorityScore": {
494
+ "label": "Priority Score",
495
+ "source": {
496
+ "contentType": "snapshots",
497
+ "path": "data.enrichment.priorityScore"
498
+ },
499
+ "humanReadable": true,
500
+ "sortable": true,
501
+ "filterable": true,
502
+ "list": true,
503
+ "item": true,
504
+ "valueType": "number"
505
+ },
506
+ "compositeScore": {
507
+ "label": "Composite Score",
508
+ "source": {
509
+ "contentType": "snapshots",
510
+ "path": "data.enrichment.compositeScore"
511
+ },
512
+ "humanReadable": true,
513
+ "sortable": true,
514
+ "filterable": true,
515
+ "list": true,
516
+ "item": true,
517
+ "valueType": "number"
518
+ },
519
+ "epss": {
520
+ "label": "EPSS",
521
+ "source": {
522
+ "contentType": "snapshots",
523
+ "path": "data.enrichment.epss.epss"
524
+ },
525
+ "humanReadable": true,
526
+ "sortable": true,
527
+ "filterable": true,
528
+ "list": true,
529
+ "item": true,
530
+ "valueType": "number"
531
+ },
532
+ "epssPercentile": {
533
+ "label": "EPSS Percentile",
534
+ "source": {
535
+ "contentType": "snapshots",
536
+ "path": "data.enrichment.epss.percentile"
537
+ },
538
+ "humanReadable": true,
539
+ "sortable": true,
540
+ "filterable": true,
541
+ "list": true,
542
+ "item": true,
543
+ "valueType": "number"
544
+ },
545
+ "knownExploited": {
546
+ "label": "Known Exploited",
547
+ "source": {
548
+ "contentType": "snapshots",
549
+ "path": "data.enrichment.kev.isKnownExploited"
550
+ },
551
+ "humanReadable": true,
552
+ "sortable": true,
553
+ "filterable": true,
554
+ "list": true,
555
+ "item": true,
556
+ "valueType": "boolean"
557
+ },
558
+ "cvssBaseScore": {
559
+ "label": "CVSS Base Score",
560
+ "source": {
561
+ "contentType": "snapshots",
562
+ "path": "data.enrichment.cvss.baseScore"
563
+ },
564
+ "humanReadable": true,
565
+ "sortable": true,
566
+ "filterable": true,
567
+ "list": true,
568
+ "item": true,
569
+ "valueType": "number"
570
+ },
571
+ "cvssVector": {
572
+ "label": "CVSS Vector",
573
+ "source": {
574
+ "contentType": "snapshots",
575
+ "path": "data.enrichment.cvss.cvssVector"
576
+ },
577
+ "humanReadable": true,
578
+ "sortable": false,
579
+ "filterable": true,
580
+ "list": false,
581
+ "item": true,
582
+ "valueType": "string"
583
+ },
584
+ "exploitabilityScore": {
585
+ "label": "Exploitability Score",
586
+ "source": {
587
+ "contentType": "snapshots",
588
+ "path": "data.exploitabilityScore"
589
+ },
590
+ "humanReadable": true,
591
+ "sortable": true,
592
+ "filterable": true,
593
+ "list": true,
594
+ "item": true,
595
+ "valueType": "number"
596
+ },
597
+ "exploitabilityLevel": {
598
+ "label": "Exploitability Level",
599
+ "source": {
600
+ "contentType": "snapshots",
601
+ "path": "data.exploitabilityLevel"
602
+ },
603
+ "humanReadable": true,
604
+ "sortable": true,
605
+ "filterable": true,
606
+ "list": true,
607
+ "item": true,
608
+ "valueType": "string"
609
+ },
610
+ "assetMatched": {
611
+ "label": "Asset Matched",
612
+ "source": {
613
+ "contentType": "snapshots",
614
+ "path": "data.assetMatched"
615
+ },
616
+ "humanReadable": true,
617
+ "sortable": true,
618
+ "filterable": true,
619
+ "list": false,
620
+ "item": true,
621
+ "valueType": "boolean"
622
+ },
623
+ "networkExposure": {
624
+ "label": "Network Exposure",
625
+ "source": {
626
+ "contentType": "snapshots",
627
+ "path": "data.mitreAnalysis.networkContext.exposure"
628
+ },
629
+ "humanReadable": true,
630
+ "sortable": true,
631
+ "filterable": true,
632
+ "list": true,
633
+ "item": true,
634
+ "valueType": "string"
635
+ },
636
+ "attackPathCount": {
637
+ "label": "Attack Path Count",
638
+ "source": {
639
+ "contentType": "snapshots",
640
+ "path": "data.mitreAnalysis.networkContext.paths.paths"
641
+ },
642
+ "humanReadable": true,
643
+ "sortable": false,
644
+ "filterable": false,
645
+ "list": false,
646
+ "item": true,
647
+ "valueType": "array"
648
+ },
649
+ "mitreTechniques": {
650
+ "label": "MITRE Techniques",
651
+ "source": {
652
+ "contentType": "snapshots",
653
+ "path": "data.mitreAnalysis.techniques"
654
+ },
655
+ "humanReadable": true,
656
+ "sortable": false,
657
+ "filterable": true,
658
+ "list": false,
659
+ "item": true,
660
+ "valueType": "array"
661
+ },
662
+ "mitreAnalysis": {
663
+ "label": "MITRE Analysis",
664
+ "source": {
665
+ "contentType": "snapshots",
666
+ "path": "data.mitreAnalysis"
667
+ },
668
+ "humanReadable": false,
669
+ "sortable": false,
670
+ "filterable": false,
671
+ "list": false,
672
+ "item": true,
673
+ "valueType": "object"
674
+ }
675
+ },
676
+ "relations": {
677
+ "affectedAsset": {
678
+ "targetEntity": "assets",
679
+ "type": "manyToOne",
680
+ "source": {
681
+ "contentType": "snapshots",
682
+ "path": "data.assetIp"
683
+ },
684
+ "target": {
685
+ "contentType": "snapshots",
686
+ "path": "data.ip_address"
687
+ },
688
+ "defaultMode": "extendFields",
689
+ "targetFields": [
690
+ "ipAddress",
691
+ "hostName",
692
+ "xdrOperationalStatus",
693
+ "xdrAgentStatus",
694
+ "potentialImpactLevel"
695
+ ]
696
+ },
697
+ "vulnerabilityGroup": {
698
+ "targetEntity": "variabilities-groups",
699
+ "type": "manyToOne",
700
+ "source": {
701
+ "contentType": "snapshots",
702
+ "path": "data.pluginId"
703
+ },
704
+ "target": {
705
+ "contentType": "snapshots",
706
+ "path": "data.plugin_id"
707
+ },
708
+ "defaultMode": "extendFields",
709
+ "targetFields": [
710
+ "groupId",
711
+ "pluginName",
712
+ "severityLevel",
713
+ "affectedEntitiesCount",
714
+ "riskLevel",
715
+ "priorityScore"
716
+ ]
717
+ }
718
+ }
719
+ },
720
+ {
721
+ "id": "variabilities-groups",
722
+ "entityName": "variabilities-groups",
723
+ "collectionPrefix": "variabilities-groups",
724
+ "identity": {
725
+ "allowedIdFields": [
726
+ "entityId",
727
+ "eventId"
728
+ ],
729
+ "requiredExactlyOne": true,
730
+ "defaultIdField": "entityId"
731
+ },
732
+ "defaults": {
733
+ "canonicalContentType": "snapshots",
734
+ "dataRoot": "data",
735
+ "effectiveDatePath": "capturedAt",
736
+ "fallbackEffectiveDatePaths": [
737
+ "snapshot.capturedAt",
738
+ "data.enrichedAt",
739
+ "data.enrichment.enrichedAt"
740
+ ]
741
+ },
742
+ "contentTypes": {
743
+ "snapshots": {
744
+ "postfix": "snapshots",
745
+ "collection": "variabilities-groups-snapshots",
746
+ "dataRoot": "data",
747
+ "isCanonical": true,
748
+ "effectiveDatePath": "capturedAt",
749
+ "fallbackEffectiveDatePaths": [
750
+ "snapshot.capturedAt",
751
+ "data.enrichedAt",
752
+ "data.enrichment.enrichedAt"
753
+ ]
754
+ }
755
+ },
756
+ "properties": {
757
+ "groupId": {
758
+ "label": "Group ID",
759
+ "source": {
760
+ "contentType": "snapshots",
761
+ "path": "data.id"
762
+ },
763
+ "humanReadable": true,
764
+ "sortable": true,
765
+ "filterable": true,
766
+ "list": true,
767
+ "item": true,
768
+ "valueType": "string"
769
+ },
770
+ "type": {
771
+ "label": "Type",
772
+ "source": {
773
+ "contentType": "snapshots",
774
+ "path": "data.type"
775
+ },
776
+ "humanReadable": true,
777
+ "sortable": true,
778
+ "filterable": true,
779
+ "list": true,
780
+ "item": true,
781
+ "valueType": "string"
782
+ },
783
+ "pluginId": {
784
+ "label": "Plugin ID",
785
+ "source": {
786
+ "contentType": "snapshots",
787
+ "path": "data.plugin_id"
788
+ },
789
+ "humanReadable": true,
790
+ "sortable": true,
791
+ "filterable": true,
792
+ "list": true,
793
+ "item": true,
794
+ "valueType": "number"
795
+ },
796
+ "pluginName": {
797
+ "label": "Plugin Name",
798
+ "source": {
799
+ "contentType": "snapshots",
800
+ "path": "data.plugin_name"
801
+ },
802
+ "humanReadable": true,
803
+ "sortable": true,
804
+ "filterable": true,
805
+ "list": true,
806
+ "item": true,
807
+ "valueType": "string"
808
+ },
809
+ "pluginFamily": {
810
+ "label": "Plugin Family",
811
+ "source": {
812
+ "contentType": "snapshots",
813
+ "path": "data.plugin_family"
814
+ },
815
+ "humanReadable": true,
816
+ "sortable": true,
817
+ "filterable": true,
818
+ "list": true,
819
+ "item": true,
820
+ "valueType": "string"
821
+ },
822
+ "severity": {
823
+ "label": "Severity",
824
+ "source": {
825
+ "contentType": "snapshots",
826
+ "path": "data.severity"
827
+ },
828
+ "humanReadable": true,
829
+ "sortable": true,
830
+ "filterable": true,
831
+ "list": true,
832
+ "item": true,
833
+ "valueType": "string"
834
+ },
835
+ "severityLevel": {
836
+ "label": "Severity Level",
837
+ "source": {
838
+ "contentType": "snapshots",
839
+ "path": "data.severity_level"
840
+ },
841
+ "humanReadable": true,
842
+ "sortable": true,
843
+ "filterable": true,
844
+ "list": true,
845
+ "item": true,
846
+ "valueType": "number"
847
+ },
848
+ "affectedEntities": {
849
+ "label": "Affected Entities",
850
+ "source": {
851
+ "contentType": "snapshots",
852
+ "path": "data.affected_entities"
853
+ },
854
+ "humanReadable": true,
855
+ "sortable": false,
856
+ "filterable": true,
857
+ "list": false,
858
+ "item": true,
859
+ "valueType": "array"
860
+ },
861
+ "affectedEntitiesCount": {
862
+ "label": "Affected Entities Count",
863
+ "source": {
864
+ "contentType": "snapshots",
865
+ "path": "data.affected_entities"
866
+ },
867
+ "humanReadable": true,
868
+ "sortable": false,
869
+ "filterable": false,
870
+ "list": true,
871
+ "item": true,
872
+ "valueType": "array",
873
+ "format": "count"
874
+ },
875
+ "source": {
876
+ "label": "Source",
877
+ "source": {
878
+ "contentType": "snapshots",
879
+ "path": "data.source"
880
+ },
881
+ "humanReadable": true,
882
+ "sortable": true,
883
+ "filterable": true,
884
+ "list": false,
885
+ "item": true,
886
+ "valueType": "string"
887
+ },
888
+ "cveIds": {
889
+ "label": "CVEs",
890
+ "source": {
891
+ "contentType": "snapshots",
892
+ "path": "data.cveIds"
893
+ },
894
+ "humanReadable": true,
895
+ "sortable": false,
896
+ "filterable": true,
897
+ "list": true,
898
+ "item": true,
899
+ "valueType": "array"
900
+ },
901
+ "riskLevel": {
902
+ "label": "Risk Level",
903
+ "source": {
904
+ "contentType": "snapshots",
905
+ "path": "data.enrichment.riskLevel"
906
+ },
907
+ "humanReadable": true,
908
+ "sortable": true,
909
+ "filterable": true,
910
+ "list": true,
911
+ "item": true,
912
+ "valueType": "string"
913
+ },
914
+ "priorityScore": {
915
+ "label": "Priority Score",
916
+ "source": {
917
+ "contentType": "snapshots",
918
+ "path": "data.enrichment.priorityScore"
919
+ },
920
+ "humanReadable": true,
921
+ "sortable": true,
922
+ "filterable": true,
923
+ "list": true,
924
+ "item": true,
925
+ "valueType": "number"
926
+ },
927
+ "compositeScore": {
928
+ "label": "Composite Score",
929
+ "source": {
930
+ "contentType": "snapshots",
931
+ "path": "data.enrichment.compositeScore"
932
+ },
933
+ "humanReadable": true,
934
+ "sortable": true,
935
+ "filterable": true,
936
+ "list": true,
937
+ "item": true,
938
+ "valueType": "number"
939
+ },
940
+ "epss": {
941
+ "label": "EPSS",
942
+ "source": {
943
+ "contentType": "snapshots",
944
+ "path": "data.enrichment.epss.epss"
945
+ },
946
+ "humanReadable": true,
947
+ "sortable": true,
948
+ "filterable": true,
949
+ "list": true,
950
+ "item": true,
951
+ "valueType": "number"
952
+ },
953
+ "knownExploited": {
954
+ "label": "Known Exploited",
955
+ "source": {
956
+ "contentType": "snapshots",
957
+ "path": "data.enrichment.kev.isKnownExploited"
958
+ },
959
+ "humanReadable": true,
960
+ "sortable": true,
961
+ "filterable": true,
962
+ "list": true,
963
+ "item": true,
964
+ "valueType": "boolean"
965
+ },
966
+ "cvssBaseScore": {
967
+ "label": "CVSS Base Score",
968
+ "source": {
969
+ "contentType": "snapshots",
970
+ "path": "data.enrichment.cvss.baseScore"
971
+ },
972
+ "humanReadable": true,
973
+ "sortable": true,
974
+ "filterable": true,
975
+ "list": true,
976
+ "item": true,
977
+ "valueType": "number"
978
+ },
979
+ "cvssVector": {
980
+ "label": "CVSS Vector",
981
+ "source": {
982
+ "contentType": "snapshots",
983
+ "path": "data.enrichment.cvss.cvssVector"
984
+ },
985
+ "humanReadable": true,
986
+ "sortable": false,
987
+ "filterable": true,
988
+ "list": false,
989
+ "item": true,
990
+ "valueType": "string"
991
+ },
992
+ "enrichedAt": {
993
+ "label": "Enriched At",
994
+ "source": {
995
+ "contentType": "snapshots",
996
+ "path": "data.enrichedAt"
997
+ },
998
+ "humanReadable": true,
999
+ "sortable": true,
1000
+ "filterable": true,
1001
+ "list": false,
1002
+ "item": true,
1003
+ "valueType": "datetime"
1004
+ }
1005
+ },
1006
+ "relations": {
1007
+ "groupVulnerabilities": {
1008
+ "targetEntity": "vulnerabilities",
1009
+ "type": "oneToMany",
1010
+ "source": {
1011
+ "contentType": "snapshots",
1012
+ "path": "data.plugin_id"
1013
+ },
1014
+ "target": {
1015
+ "contentType": "snapshots",
1016
+ "path": "data.pluginId"
1017
+ },
1018
+ "defaultMode": "array",
1019
+ "defaultArrayProperty": "vulnerabilities",
1020
+ "targetFields": [
1021
+ "vulnerabilityId",
1022
+ "assetIp",
1023
+ "pluginName",
1024
+ "severityLevel",
1025
+ "riskLevel",
1026
+ "priorityScore"
1027
+ ]
1028
+ }
1029
+ }
1030
+ }
1031
+ ]
1032
+ },
1033
+ "listDescriptors": {
1034
+ "catalogId": "memorix-list-descriptors",
1035
+ "items": [
1036
+ {
1037
+ "id": "assets-main-list",
1038
+ "entity": "assets",
1039
+ "title": "Assets",
1040
+ "leadingContentType": "snapshots",
1041
+ "pagination": {
1042
+ "enabled": true,
1043
+ "defaultLimit": 50,
1044
+ "maxLimit": 200
1045
+ },
1046
+ "filters": [],
1047
+ "fields": [
1048
+ "ipAddress",
1049
+ "hostName",
1050
+ "source",
1051
+ "agentType",
1052
+ "xdrOperationalStatus",
1053
+ "xdrAgentStatus",
1054
+ "hasVulnerabilities",
1055
+ "criticalVulnerabilities",
1056
+ "highVulnerabilities",
1057
+ "potentialImpactLevel",
1058
+ "pathsCount"
1059
+ ],
1060
+ "extensions": [],
1061
+ "includeRelations": [],
1062
+ "allowedSorts": [
1063
+ "ipAddress",
1064
+ "hostName",
1065
+ "source",
1066
+ "agentType",
1067
+ "xdrOperationalStatus",
1068
+ "xdrAgentStatus",
1069
+ "hasVulnerabilities",
1070
+ "criticalVulnerabilities",
1071
+ "highVulnerabilities",
1072
+ "potentialImpactLevel",
1073
+ "pathsCount",
1074
+ "lastSeen"
1075
+ ],
1076
+ "defaultSort": {
1077
+ "property": "ipAddress",
1078
+ "direction": "asc"
1079
+ },
1080
+ "allowSortDrivenLeadingOverride": false
1081
+ },
1082
+ {
1083
+ "id": "vulnerabilities-main-list",
1084
+ "entity": "vulnerabilities",
1085
+ "title": "Vulnerabilities",
1086
+ "leadingContentType": "snapshots",
1087
+ "pagination": {
1088
+ "enabled": true,
1089
+ "defaultLimit": 50,
1090
+ "maxLimit": 200
1091
+ },
1092
+ "filters": [],
1093
+ "fields": [
1094
+ "vulnerabilityId",
1095
+ "assetIp",
1096
+ "pluginName",
1097
+ "pluginFamily",
1098
+ "severityLevel",
1099
+ "cveIds",
1100
+ "riskLevel",
1101
+ "priorityScore",
1102
+ "epss",
1103
+ "knownExploited",
1104
+ "exploitabilityLevel",
1105
+ "networkExposure"
1106
+ ],
1107
+ "extensions": [],
1108
+ "includeRelations": [],
1109
+ "allowedSorts": [
1110
+ "vulnerabilityId",
1111
+ "assetIp",
1112
+ "pluginName",
1113
+ "pluginFamily",
1114
+ "severityLevel",
1115
+ "riskLevel",
1116
+ "priorityScore",
1117
+ "epss",
1118
+ "knownExploited",
1119
+ "exploitabilityScore",
1120
+ "exploitabilityLevel",
1121
+ "networkExposure"
1122
+ ],
1123
+ "defaultSort": {
1124
+ "property": "priorityScore",
1125
+ "direction": "desc"
1126
+ },
1127
+ "allowSortDrivenLeadingOverride": false
1128
+ },
1129
+ {
1130
+ "id": "critical-vulnerabilities-list",
1131
+ "entity": "vulnerabilities",
1132
+ "title": "Critical Vulnerabilities",
1133
+ "leadingContentType": "snapshots",
1134
+ "pagination": {
1135
+ "enabled": true,
1136
+ "defaultLimit": 50,
1137
+ "maxLimit": 200
1138
+ },
1139
+ "filters": [
1140
+ {
1141
+ "property": "severityLevel",
1142
+ "operator": "gte",
1143
+ "value": 4
1144
+ }
1145
+ ],
1146
+ "fields": [
1147
+ "vulnerabilityId",
1148
+ "assetIp",
1149
+ "pluginName",
1150
+ "severityLevel",
1151
+ "riskLevel",
1152
+ "priorityScore",
1153
+ "epss",
1154
+ "knownExploited",
1155
+ "exploitabilityLevel"
1156
+ ],
1157
+ "extensions": [],
1158
+ "includeRelations": [],
1159
+ "allowedSorts": [
1160
+ "severityLevel",
1161
+ "riskLevel",
1162
+ "priorityScore",
1163
+ "epss",
1164
+ "knownExploited",
1165
+ "exploitabilityScore"
1166
+ ],
1167
+ "defaultSort": {
1168
+ "property": "priorityScore",
1169
+ "direction": "desc"
1170
+ },
1171
+ "allowSortDrivenLeadingOverride": false
1172
+ },
1173
+ {
1174
+ "id": "variabilities-groups-main-list",
1175
+ "entity": "variabilities-groups",
1176
+ "title": "Vulnerability Groups",
1177
+ "leadingContentType": "snapshots",
1178
+ "pagination": {
1179
+ "enabled": true,
1180
+ "defaultLimit": 50,
1181
+ "maxLimit": 200
1182
+ },
1183
+ "filters": [],
1184
+ "fields": [
1185
+ "groupId",
1186
+ "pluginName",
1187
+ "pluginFamily",
1188
+ "severityLevel",
1189
+ "affectedEntitiesCount",
1190
+ "cveIds",
1191
+ "riskLevel",
1192
+ "priorityScore",
1193
+ "epss",
1194
+ "knownExploited"
1195
+ ],
1196
+ "extensions": [],
1197
+ "includeRelations": [],
1198
+ "allowedSorts": [
1199
+ "groupId",
1200
+ "pluginId",
1201
+ "pluginName",
1202
+ "pluginFamily",
1203
+ "severityLevel",
1204
+ "riskLevel",
1205
+ "priorityScore",
1206
+ "epss",
1207
+ "knownExploited",
1208
+ "cvssBaseScore"
1209
+ ],
1210
+ "defaultSort": {
1211
+ "property": "priorityScore",
1212
+ "direction": "desc"
1213
+ },
1214
+ "allowSortDrivenLeadingOverride": false
1215
+ }
1216
+ ]
1217
+ },
1218
+ "itemDescriptors": {
1219
+ "catalogId": "memorix-item-descriptors",
1220
+ "items": [
1221
+ {
1222
+ "id": "asset-detail-item",
1223
+ "entity": "assets",
1224
+ "title": "Asset Detail",
1225
+ "identity": {
1226
+ "idField": "entityId"
1227
+ },
1228
+ "contentTypes": [
1229
+ {
1230
+ "contentType": "snapshots",
1231
+ "required": true,
1232
+ "multiMatch": {
1233
+ "strategy": "last",
1234
+ "effectiveDatePath": "capturedAt",
1235
+ "fallbackEffectiveDatePaths": [
1236
+ "snapshot.capturedAt",
1237
+ "data.xdr.last_seen"
1238
+ ]
1239
+ }
1240
+ }
1241
+ ],
1242
+ "sections": [
1243
+ {
1244
+ "id": "summary",
1245
+ "title": "Summary",
1246
+ "fields": [
1247
+ "ipAddress",
1248
+ "hostName",
1249
+ "source",
1250
+ "agentType",
1251
+ "xdrOperationalStatus",
1252
+ "xdrAgentStatus",
1253
+ "lastSeen",
1254
+ "pathsCount"
1255
+ ]
1256
+ },
1257
+ {
1258
+ "id": "vulnerabilitySummary",
1259
+ "title": "Vulnerability Summary",
1260
+ "fields": [
1261
+ "hasVulnerabilities",
1262
+ "criticalVulnerabilities",
1263
+ "highVulnerabilities",
1264
+ "mediumVulnerabilities",
1265
+ "lowVulnerabilities"
1266
+ ]
1267
+ },
1268
+ {
1269
+ "id": "impact",
1270
+ "title": "Potential Impact",
1271
+ "fields": [
1272
+ "potentialImpactLevel",
1273
+ "potentialImpactConfidence",
1274
+ "potentialImpactStory"
1275
+ ]
1276
+ },
1277
+ {
1278
+ "id": "xdr",
1279
+ "title": "XDR",
1280
+ "fields": [
1281
+ "users",
1282
+ "rawXdr"
1283
+ ]
1284
+ }
1285
+ ],
1286
+ "includeRelations": [
1287
+ {
1288
+ "relation": "assetVulnerabilities",
1289
+ "mode": "array",
1290
+ "arrayProperty": "vulnerabilities",
1291
+ "limit": 100,
1292
+ "fields": [
1293
+ "vulnerabilityId",
1294
+ "pluginName",
1295
+ "severityLevel",
1296
+ "riskLevel",
1297
+ "priorityScore",
1298
+ "cveIds"
1299
+ ]
1300
+ }
1301
+ ],
1302
+ "content": {
1303
+ "allowed": false
1304
+ }
1305
+ },
1306
+ {
1307
+ "id": "vulnerability-detail-item",
1308
+ "entity": "vulnerabilities",
1309
+ "title": "Vulnerability Detail",
1310
+ "identity": {
1311
+ "idField": "entityId"
1312
+ },
1313
+ "contentTypes": [
1314
+ {
1315
+ "contentType": "snapshots",
1316
+ "required": true,
1317
+ "multiMatch": {
1318
+ "strategy": "last",
1319
+ "effectiveDatePath": "capturedAt",
1320
+ "fallbackEffectiveDatePaths": [
1321
+ "snapshot.capturedAt",
1322
+ "data.enrichment.enrichedAt"
1323
+ ]
1324
+ }
1325
+ }
1326
+ ],
1327
+ "sections": [
1328
+ {
1329
+ "id": "summary",
1330
+ "title": "Summary",
1331
+ "fields": [
1332
+ "vulnerabilityId",
1333
+ "pluginName",
1334
+ "pluginFamily",
1335
+ "severity",
1336
+ "severityLevel",
1337
+ "cveIds"
1338
+ ]
1339
+ },
1340
+ {
1341
+ "id": "asset",
1342
+ "title": "Affected Asset",
1343
+ "fields": [
1344
+ "assetIp",
1345
+ "assetType",
1346
+ "assetZone",
1347
+ "assetHostname",
1348
+ "assetMatched"
1349
+ ]
1350
+ },
1351
+ {
1352
+ "id": "risk",
1353
+ "title": "Risk",
1354
+ "fields": [
1355
+ "riskLevel",
1356
+ "priorityScore",
1357
+ "compositeScore",
1358
+ "exploitabilityScore",
1359
+ "exploitabilityLevel"
1360
+ ]
1361
+ },
1362
+ {
1363
+ "id": "threatIntelligence",
1364
+ "title": "Threat Intelligence",
1365
+ "fields": [
1366
+ "epss",
1367
+ "epssPercentile",
1368
+ "knownExploited",
1369
+ "cvssBaseScore",
1370
+ "cvssVector"
1371
+ ]
1372
+ },
1373
+ {
1374
+ "id": "networkAndMitre",
1375
+ "title": "Network & MITRE",
1376
+ "fields": [
1377
+ "networkExposure",
1378
+ "mitreTechniques",
1379
+ "mitreAnalysis"
1380
+ ]
1381
+ }
1382
+ ],
1383
+ "includeRelations": [
1384
+ {
1385
+ "relation": "affectedAsset",
1386
+ "mode": "extendFields",
1387
+ "fields": [
1388
+ "ipAddress",
1389
+ "hostName",
1390
+ "xdrOperationalStatus",
1391
+ "xdrAgentStatus",
1392
+ "potentialImpactLevel"
1393
+ ]
1394
+ },
1395
+ {
1396
+ "relation": "vulnerabilityGroup",
1397
+ "mode": "extendFields",
1398
+ "fields": [
1399
+ "groupId",
1400
+ "pluginName",
1401
+ "severityLevel",
1402
+ "affectedEntitiesCount",
1403
+ "riskLevel",
1404
+ "priorityScore"
1405
+ ]
1406
+ }
1407
+ ],
1408
+ "content": {
1409
+ "allowed": false
1410
+ }
1411
+ },
1412
+ {
1413
+ "id": "variabilities-group-detail-item",
1414
+ "entity": "variabilities-groups",
1415
+ "title": "Vulnerability Group Detail",
1416
+ "identity": {
1417
+ "idField": "entityId"
1418
+ },
1419
+ "contentTypes": [
1420
+ {
1421
+ "contentType": "snapshots",
1422
+ "required": true,
1423
+ "multiMatch": {
1424
+ "strategy": "last",
1425
+ "effectiveDatePath": "capturedAt",
1426
+ "fallbackEffectiveDatePaths": [
1427
+ "snapshot.capturedAt",
1428
+ "data.enrichedAt",
1429
+ "data.enrichment.enrichedAt"
1430
+ ]
1431
+ }
1432
+ }
1433
+ ],
1434
+ "sections": [
1435
+ {
1436
+ "id": "summary",
1437
+ "title": "Summary",
1438
+ "fields": [
1439
+ "groupId",
1440
+ "type",
1441
+ "pluginId",
1442
+ "pluginName",
1443
+ "pluginFamily",
1444
+ "severity",
1445
+ "severityLevel",
1446
+ "cveIds",
1447
+ "source"
1448
+ ]
1449
+ },
1450
+ {
1451
+ "id": "affectedEntities",
1452
+ "title": "Affected Entities",
1453
+ "fields": [
1454
+ "affectedEntities",
1455
+ "affectedEntitiesCount"
1456
+ ]
1457
+ },
1458
+ {
1459
+ "id": "risk",
1460
+ "title": "Risk",
1461
+ "fields": [
1462
+ "riskLevel",
1463
+ "priorityScore",
1464
+ "compositeScore"
1465
+ ]
1466
+ },
1467
+ {
1468
+ "id": "threatIntelligence",
1469
+ "title": "Threat Intelligence",
1470
+ "fields": [
1471
+ "epss",
1472
+ "knownExploited",
1473
+ "cvssBaseScore",
1474
+ "cvssVector",
1475
+ "enrichedAt"
1476
+ ]
1477
+ }
1478
+ ],
1479
+ "includeRelations": [
1480
+ {
1481
+ "relation": "groupVulnerabilities",
1482
+ "mode": "array",
1483
+ "arrayProperty": "vulnerabilities",
1484
+ "limit": 200,
1485
+ "fields": [
1486
+ "vulnerabilityId",
1487
+ "assetIp",
1488
+ "pluginName",
1489
+ "severityLevel",
1490
+ "riskLevel",
1491
+ "priorityScore"
1492
+ ]
1493
+ }
1494
+ ],
1495
+ "content": {
1496
+ "allowed": false
1497
+ }
1498
+ }
1499
+ ]
1500
+ }
1501
+ }
1502
+ }