@cccsaurora/howler-ui 2.18.0-dev.710 → 2.18.0-dev.722

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 (251) hide show
  1. package/api/index.d.ts +0 -2
  2. package/api/index.js +2 -4
  3. package/api/search/facet/hit.d.ts +3 -1
  4. package/api/search/facet/index.d.ts +1 -3
  5. package/api/search/index.d.ts +1 -2
  6. package/api/search/index.js +1 -2
  7. package/commons/components/leftnav/LeftNavDrawer.js +1 -1
  8. package/components/app/App.js +7 -39
  9. package/components/app/hooks/useMatchers.js +2 -2
  10. package/components/app/hooks/useMatchers.test.js +22 -22
  11. package/components/app/hooks/useTitle.js +3 -3
  12. package/components/app/providers/FavouritesProvider.js +2 -2
  13. package/components/app/providers/HitProvider.d.ts +22 -0
  14. package/components/app/providers/{RecordProvider.js → HitProvider.js} +41 -41
  15. package/components/app/providers/{RecordSearchProvider.d.ts → HitSearchProvider.d.ts} +6 -6
  16. package/components/app/providers/{RecordSearchProvider.js → HitSearchProvider.js} +17 -12
  17. package/components/app/providers/{RecordSearchProvider.test.js → HitSearchProvider.test.js} +70 -51
  18. package/components/app/providers/ModalProvider.d.ts +0 -1
  19. package/components/app/providers/ParameterProvider.d.ts +2 -9
  20. package/components/app/providers/ParameterProvider.js +240 -165
  21. package/components/app/providers/ParameterProvider.test.js +14 -307
  22. package/components/elements/PluginTypography.d.ts +1 -2
  23. package/components/elements/PluginTypography.js +2 -3
  24. package/components/elements/UserList.d.ts +2 -5
  25. package/components/elements/UserList.js +5 -14
  26. package/components/elements/addons/search/phrase/Phrase.js +1 -1
  27. package/components/elements/display/ChipPopper.d.ts +1 -1
  28. package/components/elements/display/HowlerCard.js +1 -1
  29. package/components/elements/display/Modal.js +0 -2
  30. package/components/elements/display/icons/BundleButton.d.ts +6 -0
  31. package/components/elements/display/icons/BundleButton.js +32 -0
  32. package/components/elements/hit/HitActions.js +4 -4
  33. package/components/elements/hit/HitBanner.js +48 -28
  34. package/components/elements/hit/HitCard.js +5 -5
  35. package/components/elements/{record/RecordComments.d.ts → hit/HitComments.d.ts} +4 -5
  36. package/components/elements/{record/RecordComments.js → hit/HitComments.js} +28 -29
  37. package/components/elements/{ObjectDetails.js → hit/HitDetails.js} +17 -17
  38. package/components/elements/hit/HitLabels.js +2 -2
  39. package/components/elements/hit/{HitPreview.d.ts → HitQuickSearch.d.ts} +3 -3
  40. package/components/elements/hit/{HitPreview.js → HitQuickSearch.js} +4 -10
  41. package/components/elements/hit/HitRelated.d.ts +6 -0
  42. package/components/elements/hit/HitRelated.js +7 -0
  43. package/components/elements/hit/HitSummary.d.ts +1 -2
  44. package/components/elements/hit/HitSummary.js +5 -6
  45. package/components/elements/{record/RecordWorklog.d.ts → hit/HitWorklog.d.ts} +3 -4
  46. package/components/elements/{record/RecordWorklog.js → hit/HitWorklog.js} +13 -15
  47. package/components/elements/hit/aggregate/HitGraph.js +8 -8
  48. package/components/elements/hit/outlines/DefaultOutline.js +1 -1
  49. package/components/elements/view/ViewTitle.d.ts +0 -1
  50. package/components/elements/view/ViewTitle.js +2 -9
  51. package/components/hooks/useHitActions.d.ts +1 -1
  52. package/components/hooks/useHitActions.js +4 -4
  53. package/components/hooks/{useRecordSelection.d.ts → useHitSelection.d.ts} +2 -2
  54. package/components/hooks/{useRecordSelection.js → useHitSelection.js} +33 -12
  55. package/components/hooks/useMyPreferences.js +1 -10
  56. package/components/hooks/useMySearch.js +2 -2
  57. package/components/hooks/useMySitemap.js +1 -4
  58. package/components/hooks/useMyTheme.js +2 -9
  59. package/components/hooks/useParamState.test.js +4 -3
  60. package/components/routes/action/edit/ActionEditor.js +2 -2
  61. package/components/routes/action/view/ActionSearch.js +1 -1
  62. package/components/routes/advanced/QueryBuilder.js +1 -1
  63. package/components/routes/advanced/QueryEditor.js +3 -3
  64. package/components/routes/advanced/historyCompletionProvider.js +3 -3
  65. package/components/routes/analytics/AnalyticDetails.js +2 -2
  66. package/components/routes/analytics/AnalyticSearch.js +1 -1
  67. package/components/routes/dossiers/DossierEditor.js +2 -2
  68. package/components/routes/dossiers/DossierEditor.test.js +1 -1
  69. package/components/routes/help/ApiDocumentation.js +1 -1
  70. package/components/routes/help/BundleDocumentation.d.ts +3 -0
  71. package/components/routes/help/BundleDocumentation.js +12 -0
  72. package/components/routes/help/HitBannerDocumentation.js +0 -1
  73. package/components/routes/help/HitDocumentation.js +3 -1
  74. package/components/routes/help/markdown/en/bundles.md.js +1 -0
  75. package/components/routes/help/markdown/fr/bundles.md.js +1 -0
  76. package/components/routes/hits/search/BundleParentMenu.d.ts +6 -0
  77. package/components/routes/hits/search/BundleParentMenu.js +32 -0
  78. package/components/routes/hits/search/BundleScroller.d.ts +2 -0
  79. package/components/routes/hits/search/BundleScroller.js +6 -0
  80. package/components/routes/hits/search/{RecordBrowser.js → HitBrowser.js} +9 -9
  81. package/components/{elements/record/RecordContextMenu.d.ts → routes/hits/search/HitContextMenu.d.ts} +3 -3
  82. package/components/routes/hits/search/HitContextMenu.js +227 -0
  83. package/components/{elements/record/RecordContextMenu.test.js → routes/hits/search/HitContextMenu.test.js} +39 -94
  84. package/components/routes/hits/search/{RecordQuery.d.ts → HitQuery.d.ts} +2 -2
  85. package/components/routes/hits/search/{RecordQuery.js → HitQuery.js} +6 -6
  86. package/components/routes/hits/search/InformationPane.d.ts +0 -1
  87. package/components/routes/hits/search/InformationPane.js +60 -47
  88. package/components/routes/hits/search/LayoutSettings.js +3 -3
  89. package/components/routes/hits/search/QuerySettings.js +1 -2
  90. package/components/routes/hits/search/QuerySettings.test.js +9 -14
  91. package/components/routes/hits/search/SearchPane.js +49 -26
  92. package/components/routes/hits/search/ViewLink.js +3 -3
  93. package/components/routes/hits/search/ViewLink.test.js +8 -8
  94. package/components/routes/hits/search/grid/AddColumnModal.js +4 -5
  95. package/components/routes/hits/search/grid/EnhancedCell.d.ts +1 -2
  96. package/components/routes/hits/search/grid/EnhancedCell.js +2 -2
  97. package/components/routes/hits/search/grid/HitGrid.js +18 -20
  98. package/components/routes/hits/search/grid/{RecordRow.d.ts → HitRow.d.ts} +2 -3
  99. package/components/routes/hits/search/grid/{RecordRow.js → HitRow.js} +8 -10
  100. package/components/routes/hits/view/HitViewer.js +13 -12
  101. package/components/routes/home/ViewCard.js +41 -47
  102. package/components/{elements/MarkdownEditor.js → routes/overviews/OverviewEditor.js} +3 -3
  103. package/components/routes/overviews/OverviewViewer.js +2 -2
  104. package/components/routes/views/ViewComposer.js +19 -46
  105. package/locales/en/translation.json +3 -87
  106. package/locales/fr/translation.json +3 -85
  107. package/models/WithMetadata.d.ts +1 -2
  108. package/models/entities/generated/{ThreatEnrichment.d.ts → Enrichment.d.ts} +1 -1
  109. package/models/entities/generated/Hit.d.ts +0 -1
  110. package/models/entities/generated/Howler.d.ts +4 -0
  111. package/models/entities/generated/Rule.d.ts +10 -2
  112. package/models/entities/generated/Threat.d.ts +2 -2
  113. package/models/entities/generated/View.d.ts +0 -1
  114. package/package.json +1 -18
  115. package/plugins/clue/components/ClueTypography.js +2 -2
  116. package/plugins/clue/utils.d.ts +1 -2
  117. package/tests/server-handlers.js +1 -6
  118. package/tests/utils.d.ts +0 -4
  119. package/tests/utils.js +0 -20
  120. package/utils/constants.d.ts +3 -3
  121. package/utils/hitFunctions.d.ts +1 -2
  122. package/utils/hitFunctions.js +4 -4
  123. package/utils/viewUtils.js +0 -3
  124. package/api/search/case.d.ts +0 -4
  125. package/api/search/case.js +0 -8
  126. package/api/v2/case/index.d.ts +0 -8
  127. package/api/v2/case/index.js +0 -20
  128. package/api/v2/case/items.d.ts +0 -6
  129. package/api/v2/case/items.js +0 -18
  130. package/api/v2/index.d.ts +0 -4
  131. package/api/v2/index.js +0 -6
  132. package/api/v2/search/facet.d.ts +0 -3
  133. package/api/v2/search/facet.js +0 -12
  134. package/api/v2/search/index.d.ts +0 -5
  135. package/api/v2/search/index.js +0 -24
  136. package/components/app/providers/RecordProvider.d.ts +0 -23
  137. package/components/elements/ContextMenu.d.ts +0 -56
  138. package/components/elements/ContextMenu.js +0 -109
  139. package/components/elements/ContextMenu.test.js +0 -215
  140. package/components/elements/ObjectDetails.d.ts +0 -6
  141. package/components/elements/case/CaseCard.d.ts +0 -12
  142. package/components/elements/case/CaseCard.js +0 -42
  143. package/components/elements/case/CasePreview.d.ts +0 -6
  144. package/components/elements/case/CasePreview.js +0 -17
  145. package/components/elements/case/StatusIcon.d.ts +0 -5
  146. package/components/elements/case/StatusIcon.js +0 -13
  147. package/components/elements/hit/elements/AnalyticLink.d.ts +0 -8
  148. package/components/elements/hit/elements/AnalyticLink.js +0 -22
  149. package/components/elements/hit/related/RelatedRecords.js +0 -63
  150. package/components/elements/observable/ObservableCard.d.ts +0 -6
  151. package/components/elements/observable/ObservableCard.js +0 -22
  152. package/components/elements/observable/ObservablePreview.d.ts +0 -6
  153. package/components/elements/observable/ObservablePreview.js +0 -12
  154. package/components/elements/record/RecordContextMenu.js +0 -247
  155. package/components/elements/record/RecordContextMenu.test.d.ts +0 -1
  156. package/components/elements/record/RecordRelated.d.ts +0 -7
  157. package/components/elements/record/RecordRelated.js +0 -34
  158. package/components/hooks/useRelatedRecords.d.ts +0 -13
  159. package/components/hooks/useRelatedRecords.js +0 -32
  160. package/components/routes/cases/CaseViewer.d.ts +0 -2
  161. package/components/routes/cases/CaseViewer.js +0 -22
  162. package/components/routes/cases/Cases.d.ts +0 -2
  163. package/components/routes/cases/Cases.js +0 -101
  164. package/components/routes/cases/constants.d.ts +0 -5
  165. package/components/routes/cases/constants.js +0 -5
  166. package/components/routes/cases/detail/AlertPanel.d.ts +0 -6
  167. package/components/routes/cases/detail/AlertPanel.js +0 -33
  168. package/components/routes/cases/detail/CaseAssets.d.ts +0 -11
  169. package/components/routes/cases/detail/CaseAssets.js +0 -104
  170. package/components/routes/cases/detail/CaseAssets.test.d.ts +0 -1
  171. package/components/routes/cases/detail/CaseAssets.test.js +0 -167
  172. package/components/routes/cases/detail/CaseDashboard.d.ts +0 -7
  173. package/components/routes/cases/detail/CaseDashboard.js +0 -54
  174. package/components/routes/cases/detail/CaseDetails.d.ts +0 -6
  175. package/components/routes/cases/detail/CaseDetails.js +0 -61
  176. package/components/routes/cases/detail/CaseOverview.d.ts +0 -7
  177. package/components/routes/cases/detail/CaseOverview.js +0 -43
  178. package/components/routes/cases/detail/CaseSidebar.d.ts +0 -8
  179. package/components/routes/cases/detail/CaseSidebar.js +0 -50
  180. package/components/routes/cases/detail/CaseTask.d.ts +0 -11
  181. package/components/routes/cases/detail/CaseTask.js +0 -57
  182. package/components/routes/cases/detail/CaseTimeline.d.ts +0 -12
  183. package/components/routes/cases/detail/CaseTimeline.js +0 -106
  184. package/components/routes/cases/detail/CaseTimeline.test.d.ts +0 -1
  185. package/components/routes/cases/detail/CaseTimeline.test.js +0 -227
  186. package/components/routes/cases/detail/ItemPage.d.ts +0 -6
  187. package/components/routes/cases/detail/ItemPage.js +0 -99
  188. package/components/routes/cases/detail/RelatedCasePanel.d.ts +0 -6
  189. package/components/routes/cases/detail/RelatedCasePanel.js +0 -31
  190. package/components/routes/cases/detail/TaskPanel.d.ts +0 -7
  191. package/components/routes/cases/detail/TaskPanel.js +0 -52
  192. package/components/routes/cases/detail/aggregates/CaseAggregate.d.ts +0 -12
  193. package/components/routes/cases/detail/aggregates/CaseAggregate.js +0 -19
  194. package/components/routes/cases/detail/aggregates/SourceAggregate.d.ts +0 -6
  195. package/components/routes/cases/detail/aggregates/SourceAggregate.js +0 -30
  196. package/components/routes/cases/detail/assets/Asset.d.ts +0 -14
  197. package/components/routes/cases/detail/assets/Asset.js +0 -12
  198. package/components/routes/cases/detail/assets/Asset.test.d.ts +0 -1
  199. package/components/routes/cases/detail/assets/Asset.test.js +0 -72
  200. package/components/routes/cases/detail/sidebar/CaseFolder.d.ts +0 -14
  201. package/components/routes/cases/detail/sidebar/CaseFolder.js +0 -133
  202. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.d.ts +0 -34
  203. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.js +0 -105
  204. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.test.d.ts +0 -1
  205. package/components/routes/cases/detail/sidebar/CaseFolderContextMenu.test.js +0 -351
  206. package/components/routes/cases/detail/sidebar/types.d.ts +0 -3
  207. package/components/routes/cases/detail/sidebar/utils.d.ts +0 -3
  208. package/components/routes/cases/detail/sidebar/utils.js +0 -25
  209. package/components/routes/cases/hooks/useCase.d.ts +0 -13
  210. package/components/routes/cases/hooks/useCase.js +0 -51
  211. package/components/routes/cases/modals/AddToCaseModal.d.ts +0 -7
  212. package/components/routes/cases/modals/AddToCaseModal.js +0 -62
  213. package/components/routes/cases/modals/RenameItemModal.d.ts +0 -9
  214. package/components/routes/cases/modals/RenameItemModal.js +0 -48
  215. package/components/routes/cases/modals/ResolveModal.d.ts +0 -7
  216. package/components/routes/cases/modals/ResolveModal.js +0 -62
  217. package/components/routes/hits/search/shared/IndexPicker.d.ts +0 -2
  218. package/components/routes/hits/search/shared/IndexPicker.js +0 -20
  219. package/components/routes/observables/ObservableViewer.d.ts +0 -7
  220. package/components/routes/observables/ObservableViewer.js +0 -27
  221. package/models/entities/generated/AttachmentsFile.d.ts +0 -12
  222. package/models/entities/generated/Case.d.ts +0 -28
  223. package/models/entities/generated/DestinationOriginal.d.ts +0 -19
  224. package/models/entities/generated/EmailAttachment.d.ts +0 -8
  225. package/models/entities/generated/EmailParent.d.ts +0 -19
  226. package/models/entities/generated/Enrichments.d.ts +0 -7
  227. package/models/entities/generated/EnrichmentsIndicator.d.ts +0 -21
  228. package/models/entities/generated/HttpResponse.d.ts +0 -11
  229. package/models/entities/generated/Item.d.ts +0 -9
  230. package/models/entities/generated/Observable.d.ts +0 -85
  231. package/models/entities/generated/ObservableCloud.d.ts +0 -20
  232. package/models/entities/generated/ObservableDestination.d.ts +0 -23
  233. package/models/entities/generated/ObservableEmail.d.ts +0 -30
  234. package/models/entities/generated/ObservableFile.d.ts +0 -36
  235. package/models/entities/generated/ObservableHowler.d.ts +0 -43
  236. package/models/entities/generated/ObservableHttp.d.ts +0 -11
  237. package/models/entities/generated/ObservableObserver.d.ts +0 -21
  238. package/models/entities/generated/ObservableOrganization.d.ts +0 -7
  239. package/models/entities/generated/ObservableProcess.d.ts +0 -34
  240. package/models/entities/generated/ObservableSource.d.ts +0 -23
  241. package/models/entities/generated/ObservableThreat.d.ts +0 -21
  242. package/models/entities/generated/ObservableTls.d.ts +0 -12
  243. package/models/entities/generated/ObserverIngress.d.ts +0 -9
  244. package/models/entities/generated/Task.d.ts +0 -10
  245. package/utils/typeUtils.d.ts +0 -7
  246. package/utils/typeUtils.js +0 -27
  247. /package/components/app/providers/{RecordSearchProvider.test.d.ts → HitSearchProvider.test.d.ts} +0 -0
  248. /package/components/elements/hit/{related/RelatedRecords.d.ts → HitDetails.d.ts} +0 -0
  249. /package/components/routes/hits/search/{RecordBrowser.d.ts → HitBrowser.d.ts} +0 -0
  250. /package/components/{elements/ContextMenu.test.d.ts → routes/hits/search/HitContextMenu.test.d.ts} +0 -0
  251. /package/components/{elements/MarkdownEditor.d.ts → routes/overviews/OverviewEditor.d.ts} +0 -0
@@ -1,13 +0,0 @@
1
- import type { Case } from '@cccsaurora/howler-ui/models/entities/generated/Case';
2
- interface CaseArguments {
3
- case?: Case;
4
- caseId?: string;
5
- }
6
- interface CaseResult {
7
- case: Case;
8
- update: (update: Partial<Case>, publish?: boolean) => Promise<void>;
9
- loading: boolean;
10
- missing: boolean;
11
- }
12
- declare const useCase: (args: CaseArguments) => CaseResult;
13
- export default useCase;
@@ -1,51 +0,0 @@
1
- import api from '@cccsaurora/howler-ui/api';
2
- import useMyApi from '@cccsaurora/howler-ui/components/hooks/useMyApi';
3
- import { useCallback, useEffect, useState } from 'react';
4
- const useCase = ({ caseId, case: providedCase }) => {
5
- const { dispatchApi } = useMyApi();
6
- const [loading, setLoading] = useState(false);
7
- const [missing, setMissing] = useState(false);
8
- const [_case, setCase] = useState(providedCase);
9
- useEffect(() => {
10
- if (providedCase) {
11
- setCase(providedCase);
12
- }
13
- }, [providedCase]);
14
- useEffect(() => {
15
- if (caseId) {
16
- setLoading(true);
17
- dispatchApi(api.v2.case.get(caseId), { throwError: false })
18
- .then(setCase)
19
- .finally(() => setLoading(false));
20
- }
21
- }, [caseId, dispatchApi]);
22
- const update = useCallback(async (_updatedCase, publish = true) => {
23
- if (!_case?.case_id) {
24
- return;
25
- }
26
- try {
27
- if (publish) {
28
- setCase(await dispatchApi(api.v2.case.put(_case.case_id, _updatedCase)));
29
- }
30
- else {
31
- setCase(prevCase => {
32
- if (!prevCase) {
33
- return prevCase;
34
- }
35
- return {
36
- ...prevCase,
37
- ..._updatedCase
38
- };
39
- });
40
- }
41
- }
42
- catch (e) {
43
- setMissing(true);
44
- }
45
- finally {
46
- return;
47
- }
48
- }, [_case?.case_id, dispatchApi]);
49
- return { case: _case, update, loading, missing };
50
- };
51
- export default useCase;
@@ -1,7 +0,0 @@
1
- import type { Hit } from '@cccsaurora/howler-ui/models/entities/generated/Hit';
2
- import type { Observable } from '@cccsaurora/howler-ui/models/entities/generated/Observable';
3
- import { type FC } from 'react';
4
- declare const AddToCaseModal: FC<{
5
- records: (Hit | Observable)[];
6
- }>;
7
- export default AddToCaseModal;
@@ -1,62 +0,0 @@
1
- import { createElement as _createElement } from "react";
2
- import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
- import { Autocomplete, Button, Stack, TextField, Typography } from '@mui/material';
4
- import api from '@cccsaurora/howler-ui/api';
5
- import { ModalContext } from '@cccsaurora/howler-ui/components/app/providers/ModalProvider';
6
- import CaseCard from '@cccsaurora/howler-ui/components/elements/case/CaseCard';
7
- import useMyApi from '@cccsaurora/howler-ui/components/hooks/useMyApi';
8
- import { useContext, useEffect, useMemo, useState } from 'react';
9
- import { useTranslation } from 'react-i18next';
10
- const AddToCaseModal = ({ records }) => {
11
- const { t } = useTranslation();
12
- const { dispatchApi } = useMyApi();
13
- const { close } = useContext(ModalContext);
14
- const [cases, setCases] = useState([]);
15
- const [selectedCase, setSelectedCase] = useState(null);
16
- const [path, setPath] = useState('');
17
- const [title, setTitle] = useState('');
18
- useEffect(() => {
19
- dispatchApi(api.search.case.post({ query: 'case_id:*', rows: 100 }), { throwError: false }).then(result => {
20
- if (result) {
21
- setCases(result.items);
22
- }
23
- });
24
- }, [dispatchApi]);
25
- const folderOptions = useMemo(() => {
26
- if (!selectedCase?.items) {
27
- return [];
28
- }
29
- const paths = new Set();
30
- for (const item of selectedCase.items) {
31
- if (!item.path) {
32
- continue;
33
- }
34
- const parts = item.path.split('/');
35
- parts.pop();
36
- for (let i = 1; i <= parts.length; i++) {
37
- paths.add(parts.slice(0, i).join('/'));
38
- }
39
- }
40
- return Array.from(paths).sort();
41
- }, [selectedCase]);
42
- const fullPath = path ? `${path}/${title}` : title;
43
- const isValid = !!selectedCase && !!title;
44
- const onSubmit = async () => {
45
- if (!selectedCase || records?.length < 1) {
46
- return;
47
- }
48
- await dispatchApi(api.v2.case.items.post(selectedCase.case_id, {
49
- path: fullPath,
50
- value: records[0].howler.id,
51
- type: records[0].__index
52
- }));
53
- close();
54
- };
55
- // TODO: No support currently for multiple records
56
- return (_jsxs(Stack, { spacing: 2, p: 2, sx: { minWidth: 'min(800px, 60vw)', height: '100%' }, children: [_jsx(Typography, { variant: "h4", children: t('modal.cases.add_to_case') }), _jsx(Autocomplete, { options: cases, getOptionLabel: option => option.title ?? option.case_id ?? '', isOptionEqualToValue: (option, value) => option.case_id === value.case_id, value: selectedCase, disablePortal: true, onChange: (_ev, newVal) => {
57
- setSelectedCase(newVal);
58
- setPath('');
59
- }, renderOption: (props, option) => (_createElement("li", { ...props, key: option.case_id, style: { ...props.style, display: 'flex', justifyContent: 'stretch', alignItems: 'stretch' } },
60
- _jsx(CaseCard, { case: option, slotProps: { card: { sx: { width: '100%' } } } }))), renderInput: params => (_jsx(TextField, { ...params, size: "small", placeholder: t('modal.cases.add_to_case.select_case'), fullWidth: true })) }), selectedCase && (_jsxs(_Fragment, { children: [_jsx(Autocomplete, { freeSolo: true, disablePortal: true, options: folderOptions, value: path, onInputChange: (_ev, newVal) => setPath(newVal), renderInput: params => (_jsx(TextField, { ...params, size: "small", placeholder: t('modal.cases.add_to_case.select_path'), fullWidth: true })) }), _jsx(TextField, { size: "small", placeholder: t('modal.cases.add_to_case.title'), value: title, onChange: ev => setTitle(ev.target.value), fullWidth: true }), title && (_jsx(Typography, { variant: "caption", color: "textSecondary", children: t('modal.cases.add_to_case.full_path', { path: fullPath }) }))] })), _jsx("div", { style: { flex: 1 } }), _jsxs(Stack, { direction: "row", spacing: 1, alignSelf: "end", children: [_jsx(Button, { variant: "outlined", color: "error", onClick: close, children: t('cancel') }), _jsx(Button, { variant: "outlined", color: "success", disabled: !isValid, onClick: onSubmit, children: t('confirm') })] })] }));
61
- };
62
- export default AddToCaseModal;
@@ -1,9 +0,0 @@
1
- import type { Case } from '@cccsaurora/howler-ui/models/entities/generated/Case';
2
- import type { Item } from '@cccsaurora/howler-ui/models/entities/generated/Item';
3
- import { type FC } from 'react';
4
- declare const RenameItemModal: FC<{
5
- _case: Case;
6
- leaf: Item;
7
- onRenamed?: (updatedCase: Case) => void;
8
- }>;
9
- export default RenameItemModal;
@@ -1,48 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Button, Stack, TextField, Typography } from '@mui/material';
3
- import api from '@cccsaurora/howler-ui/api';
4
- import { ModalContext } from '@cccsaurora/howler-ui/components/app/providers/ModalProvider';
5
- import useMyApi from '@cccsaurora/howler-ui/components/hooks/useMyApi';
6
- import { useContext, useMemo, useState } from 'react';
7
- import { useTranslation } from 'react-i18next';
8
- const RenameItemModal = ({ _case, leaf, onRenamed }) => {
9
- const { t } = useTranslation();
10
- const { dispatchApi } = useMyApi();
11
- const { close } = useContext(ModalContext);
12
- const currentPath = leaf.path ?? '';
13
- const lastSlash = currentPath.lastIndexOf('/');
14
- const folderPrefix = lastSlash >= 0 ? currentPath.slice(0, lastSlash) : '';
15
- const currentName = lastSlash >= 0 ? currentPath.slice(lastSlash + 1) : currentPath;
16
- const [name, setName] = useState(currentName);
17
- const newPath = folderPrefix ? `${folderPrefix}/${name}` : name;
18
- const existingPaths = useMemo(() => new Set((_case.items ?? []).filter(item => item.value !== leaf.value).map(item => item.path)), [_case.items, leaf.value]);
19
- const nameError = useMemo(() => {
20
- if (!name.trim()) {
21
- return t('modal.cases.rename_item.error.empty');
22
- }
23
- if (name.includes('/')) {
24
- return t('modal.cases.rename_item.error.slash');
25
- }
26
- if (existingPaths.has(newPath)) {
27
- return t('modal.cases.rename_item.error.taken');
28
- }
29
- return null;
30
- }, [name, newPath, existingPaths, t]);
31
- const isValid = !nameError;
32
- const onSubmit = async () => {
33
- if (!isValid || !_case.case_id || !leaf.value) {
34
- return;
35
- }
36
- const updatedCase = await dispatchApi(api.v2.case.items.patch(_case.case_id, leaf.value, newPath));
37
- if (updatedCase) {
38
- onRenamed?.(updatedCase);
39
- close();
40
- }
41
- };
42
- return (_jsxs(Stack, { spacing: 2, p: 2, sx: { minWidth: 'min(600px, 60vw)' }, children: [_jsx(Typography, { variant: "h4", children: t('modal.cases.rename_item') }), folderPrefix && (_jsx(Typography, { variant: "body2", color: "textSecondary", children: t('modal.cases.rename_item.folder_path', { path: folderPrefix }) })), _jsx(TextField, { size: "small", label: t('modal.cases.rename_item.new_name'), value: name, onChange: ev => setName(ev.target.value), error: !!nameError, helperText: nameError ?? ' ', fullWidth: true, autoFocus: true, onKeyDown: ev => {
43
- if (ev.key === 'Enter' && isValid) {
44
- onSubmit();
45
- }
46
- } }), _jsxs(Stack, { direction: "row", justifyContent: "flex-end", spacing: 1, children: [_jsx(Button, { onClick: close, color: "error", variant: "outlined", children: t('button.cancel') }), _jsx(Button, { onClick: onSubmit, color: "success", variant: "outlined", disabled: !isValid, children: t('button.confirm') })] })] }));
47
- };
48
- export default RenameItemModal;
@@ -1,7 +0,0 @@
1
- import type { Case } from '@cccsaurora/howler-ui/models/entities/generated/Case';
2
- import { type FC } from 'react';
3
- declare const ResolveModal: FC<{
4
- case: Case;
5
- onConfirm: () => void;
6
- }>;
7
- export default ResolveModal;
@@ -1,62 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { OpenInNew } from '@mui/icons-material';
3
- import { Autocomplete, Box, Button, Card, Chip, Divider, IconButton, LinearProgress, Skeleton, Stack, TextField, Typography } from '@mui/material';
4
- import api from '@cccsaurora/howler-ui/api';
5
- import { ApiConfigContext } from '@cccsaurora/howler-ui/components/app/providers/ApiConfigProvider';
6
- import { ModalContext } from '@cccsaurora/howler-ui/components/app/providers/ModalProvider';
7
- import AnalyticLink from '@cccsaurora/howler-ui/components/elements/hit/elements/AnalyticLink';
8
- import EscalationChip from '@cccsaurora/howler-ui/components/elements/hit/elements/EscalationChip';
9
- import { HitLayout } from '@cccsaurora/howler-ui/components/elements/hit/HitLayout';
10
- import useHitActions from '@cccsaurora/howler-ui/components/hooks/useHitActions';
11
- import useMyApi from '@cccsaurora/howler-ui/components/hooks/useMyApi';
12
- import { uniq } from 'lodash-es';
13
- import { useContext, useEffect, useMemo, useState } from 'react';
14
- import { useTranslation } from 'react-i18next';
15
- import { Link } from 'react-router-dom';
16
- import useCase from '../hooks/useCase';
17
- const ResolveModal = ({ case: _case, onConfirm }) => {
18
- const { t } = useTranslation();
19
- const { dispatchApi } = useMyApi();
20
- const { close } = useContext(ModalContext);
21
- const { config } = useContext(ApiConfigContext);
22
- const { update: updateCase } = useCase({ case: _case });
23
- const [loading, setLoading] = useState(true);
24
- const [rationale, setRationale] = useState('');
25
- const [assessment, setAssessment] = useState(null);
26
- const [hits, setHits] = useState([]);
27
- const hitIds = useMemo(() => uniq((_case?.items ?? [])
28
- .filter(item => item.type === 'hit')
29
- .map(item => item.value)
30
- .filter(Boolean)), [_case?.items]);
31
- const { assess } = useHitActions(hits);
32
- useEffect(() => {
33
- (async () => {
34
- try {
35
- const result = await dispatchApi(api.search.hit.post({
36
- query: `howler.id:(${hitIds.join(' OR ')}) AND -howler.status:resolved`,
37
- metadata: ['analytic']
38
- }));
39
- setHits(result.items);
40
- }
41
- finally {
42
- setLoading(false);
43
- }
44
- })();
45
- }, [dispatchApi, hitIds]);
46
- const handleConfirm = async () => {
47
- setLoading(true);
48
- try {
49
- await assess(assessment, true, rationale);
50
- await updateCase({ status: 'resolved' });
51
- onConfirm();
52
- close();
53
- }
54
- finally {
55
- setLoading(false);
56
- }
57
- };
58
- return (_jsxs(Stack, { spacing: 2, p: 2, alignItems: "start", sx: { minWidth: 'min(1000px, 60vw)', maxHeight: '100%', height: '100%' }, children: [_jsx(Typography, { variant: "h4", children: t('modal.cases.resolve') }), _jsx(Typography, { children: t('modal.cases.resolve.description') }), _jsxs(Stack, { spacing: 1, overflow: "auto", width: "100%", flex: 1, children: [_jsxs(Stack, { direction: "row", spacing: 1, children: [_jsx(Box, { flex: 1, children: _jsx(TextField, { size: "small", fullWidth: true, placeholder: t('modal.rationale.label'), value: rationale, onChange: ev => setRationale(ev.target.value) }) }), _jsx(Box, { flex: 1, children: _jsx(Autocomplete, { size: "small", value: assessment, onChange: (_ev, _assessment) => setAssessment(_assessment), options: config.lookups['howler.assessment'], disablePortal: true, renderInput: params => (_jsx(TextField, { ...params, placeholder: t('hit.details.actions.assessment'), fullWidth: true })) }) })] }), _jsxs(Stack, { position: "relative", children: [_jsx(Divider, {}), _jsx(LinearProgress, { sx: { opacity: +loading } })] }), loading
59
- ? hitIds.map(id => _jsx(Skeleton, { variant: "rounded", height: "40px", width: "100%" }, id))
60
- : hits.map(hit => (_jsx(Card, { sx: { p: 1, flexShrink: 0 }, children: _jsxs(Stack, { direction: "row", alignItems: "center", spacing: 1, width: "100%", children: [_jsx(AnalyticLink, { hit: hit, compressed: true, alignSelf: "center" }), _jsx(EscalationChip, { hit: hit, layout: HitLayout.DENSE }), _jsx(Chip, { sx: { width: 'fit-content', display: 'inline-flex' }, label: hit.howler.status, size: "small", color: "primary" }), _jsx("div", { style: { flex: 1 } }), _jsx(IconButton, { size: "small", component: Link, to: `/hits/${hit.howler.id}`, children: _jsx(OpenInNew, { fontSize: "small" }) })] }) }, hit.howler.id)))] }), _jsxs(Stack, { direction: "row", spacing: 1, alignSelf: "end", children: [_jsx(Button, { variant: "outlined", color: "error", onClick: close, children: t('cancel') }), _jsx(Button, { variant: "outlined", color: "success", disabled: loading || !assessment || !rationale, onClick: handleConfirm, children: t('confirm') })] })] }));
61
- };
62
- export default ResolveModal;
@@ -1,2 +0,0 @@
1
- declare const _default: import("react").NamedExoticComponent<{}>;
2
- export default _default;
@@ -1,20 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { FilterList } from '@mui/icons-material';
3
- import { Autocomplete, TextField } from '@mui/material';
4
- import { ParameterContext } from '@cccsaurora/howler-ui/components/app/providers/ParameterProvider';
5
- import ChipPopper from '@cccsaurora/howler-ui/components/elements/display/ChipPopper';
6
- import { memo } from 'react';
7
- import { useTranslation } from 'react-i18next';
8
- import { useContextSelector } from 'use-context-selector';
9
- const FILTER_OPTIONS = [
10
- { label: 'hit.search.index.hit', value: 'hit' },
11
- { label: 'hit.search.index.observable', value: 'observable' }
12
- ];
13
- const IndexPicker = () => {
14
- const { t } = useTranslation();
15
- const indexes = useContextSelector(ParameterContext, ctx => ctx.indexes);
16
- const setIndexes = useContextSelector(ParameterContext, ctx => ctx.setIndexes);
17
- const selectedOptions = FILTER_OPTIONS.filter(opt => indexes.includes(opt.value));
18
- return (_jsx(ChipPopper, { icon: _jsx(FilterList, { fontSize: "small" }), label: selectedOptions.map(opt => t(opt.label)).join(', '), minWidth: "225px", slotProps: { chip: { size: 'small' } }, children: _jsx(Autocomplete, { size: "small", multiple: true, options: FILTER_OPTIONS, value: selectedOptions, onChange: (_ev, values) => values.length > 0 && setIndexes(values.map(val => val.value)), isOptionEqualToValue: (opt, val) => opt.value === val.value, getOptionLabel: opt => t(opt.label), renderInput: params => _jsx(TextField, { ...params }) }) }));
19
- };
20
- export default memo(IndexPicker);
@@ -1,7 +0,0 @@
1
- import type { Observable } from '@cccsaurora/howler-ui/models/entities/generated/Observable';
2
- import { type FC } from 'react';
3
- declare const ObservableViewer: FC<{
4
- observable?: Observable;
5
- observableId?: string;
6
- }>;
7
- export default ObservableViewer;
@@ -1,27 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Box, Skeleton } from '@mui/material';
3
- import api from '@cccsaurora/howler-ui/api';
4
- import ObjectDetails from '@cccsaurora/howler-ui/components/elements/ObjectDetails';
5
- import useMyApi from '@cccsaurora/howler-ui/components/hooks/useMyApi';
6
- import { useEffect, useState } from 'react';
7
- const ObservableViewer = ({ observable: provided, observableId }) => {
8
- const { dispatchApi } = useMyApi();
9
- const [observable, setObservable] = useState(null);
10
- useEffect(() => {
11
- if (provided) {
12
- setObservable(provided);
13
- }
14
- }, [provided]);
15
- useEffect(() => {
16
- if (observableId) {
17
- dispatchApi(api.v2.search.post('observable', { query: `howler.id:${observableId}`, rows: 1 }), {
18
- throwError: false
19
- }).then(res => setObservable(res.items[0]));
20
- }
21
- }, [dispatchApi, observableId]);
22
- if (!observable) {
23
- return;
24
- }
25
- return _jsx(Box, { p: 1, children: observable ? _jsx(ObjectDetails, { obj: observable }) : _jsx(Skeleton, { height: 120 }) });
26
- };
27
- export default ObservableViewer;
@@ -1,12 +0,0 @@
1
- import type { FileHash } from './FileHash';
2
-
3
- /**
4
- * NOTE: This is an auto-generated file. Don't edit this manually.
5
- */
6
- export interface AttachmentsFile {
7
- extension?: string;
8
- hash?: FileHash;
9
- mime_type?: string;
10
- name?: string;
11
- size?: number;
12
- }
@@ -1,28 +0,0 @@
1
- import type { Enrichments } from './Enrichments';
2
- import type { Item } from './Item';
3
- import type { Rule } from './Rule';
4
- import type { Task } from './Task';
5
-
6
- /**
7
- * NOTE: This is an auto-generated file. Don't edit this manually.
8
- */
9
- export interface Case {
10
- case_id?: string;
11
- created?: string;
12
- end?: string;
13
- enrichments?: Enrichments;
14
- escalation?: string;
15
- indicators?: string[];
16
- items?: Item[];
17
- overview?: string;
18
- participants?: string[];
19
- rules?: Rule[];
20
- status?: string;
21
- start?: string;
22
- summary?: string;
23
- targets?: string[];
24
- tasks?: Task[];
25
- threats?: string[];
26
- title?: string;
27
- updated?: string;
28
- }
@@ -1,19 +0,0 @@
1
- import type { AutonomousSystems } from './AutonomousSystems';
2
- import type { Geo } from './Geo';
3
- import type { Nat } from './Nat';
4
-
5
- /**
6
- * NOTE: This is an auto-generated file. Don't edit this manually.
7
- */
8
- export interface DestinationOriginal {
9
- address?: string;
10
- autonomous_systems?: AutonomousSystems;
11
- bytes?: number;
12
- domain?: string;
13
- geo?: Geo;
14
- ip?: string;
15
- mac?: string;
16
- nat?: Nat;
17
- packets?: number;
18
- port?: number;
19
- }
@@ -1,8 +0,0 @@
1
- import type { AttachmentsFile } from './AttachmentsFile';
2
-
3
- /**
4
- * NOTE: This is an auto-generated file. Don't edit this manually.
5
- */
6
- export interface EmailAttachment {
7
- file?: AttachmentsFile;
8
- }
@@ -1,19 +0,0 @@
1
- import type { Bcc } from './Bcc';
2
- import type { Cc } from './Cc';
3
- import type { From } from './From';
4
- import type { To } from './To';
5
-
6
- /**
7
- * NOTE: This is an auto-generated file. Don't edit this manually.
8
- */
9
- export interface EmailParent {
10
- bcc?: Bcc;
11
- cc?: Cc;
12
- destination?: string;
13
- from?: From;
14
- message_id?: string;
15
- origination_timestamp?: string;
16
- source?: string;
17
- subject?: string;
18
- to?: To;
19
- }
@@ -1,7 +0,0 @@
1
- /**
2
- * NOTE: This is an auto-generated file. Don't edit this manually.
3
- */
4
- export interface Enrichments {
5
- annotations?: string;
6
- path?: string;
7
- }
@@ -1,21 +0,0 @@
1
- import type { IndicatorEmail } from './IndicatorEmail';
2
- import type { IndicatorFile } from './IndicatorFile';
3
-
4
- /**
5
- * NOTE: This is an auto-generated file. Don't edit this manually.
6
- */
7
- export interface EnrichmentsIndicator {
8
- confidence?: string;
9
- description?: string;
10
- email?: IndicatorEmail;
11
- file?: IndicatorFile;
12
- first_seen?: string;
13
- ip?: string;
14
- last_seen?: string;
15
- port?: number;
16
- provider?: string;
17
- reference?: string;
18
- scanner_stats?: number;
19
- sightings?: number;
20
- type?: string;
21
- }
@@ -1,11 +0,0 @@
1
- import type { Body } from './Body';
2
-
3
- /**
4
- * NOTE: This is an auto-generated file. Don't edit this manually.
5
- */
6
- export interface HttpResponse {
7
- body?: Body;
8
- bytes?: number;
9
- mime_type?: string;
10
- status_code?: number;
11
- }
@@ -1,9 +0,0 @@
1
- /**
2
- * NOTE: This is an auto-generated file. Don't edit this manually.
3
- */
4
- export interface Item {
5
- path?: string;
6
- type?: string;
7
- value?: string;
8
- visible?: boolean;
9
- }
@@ -1,85 +0,0 @@
1
- import type { Agent } from './Agent';
2
- import type { Assemblyline } from './Assemblyline';
3
- import type { Aws } from './Aws';
4
- import type { Azure } from './Azure';
5
- import type { Cbs } from './Cbs';
6
- import type { Clue } from './Clue';
7
- import type { Container } from './Container';
8
- import type { Dns } from './Dns';
9
- import type { Ecs } from './Ecs';
10
- import type { Error } from './Error';
11
- import type { Event } from './Event';
12
- import type { Faas } from './Faas';
13
- import type { Gcp } from './Gcp';
14
- import type { Group } from './Group';
15
- import type { Host } from './Host';
16
- import type { Interface } from './Interface';
17
- import type { Network } from './Network';
18
- import type { ObservableCloud } from './ObservableCloud';
19
- import type { ObservableDestination } from './ObservableDestination';
20
- import type { ObservableEmail } from './ObservableEmail';
21
- import type { ObservableFile } from './ObservableFile';
22
- import type { ObservableHowler } from './ObservableHowler';
23
- import type { ObservableHttp } from './ObservableHttp';
24
- import type { ObservableObserver } from './ObservableObserver';
25
- import type { ObservableOrganization } from './ObservableOrganization';
26
- import type { ObservableProcess } from './ObservableProcess';
27
- import type { ObservableSource } from './ObservableSource';
28
- import type { ObservableThreat } from './ObservableThreat';
29
- import type { ObservableTls } from './ObservableTls';
30
- import type { Registry } from './Registry';
31
- import type { Related } from './Related';
32
- import type { Rule } from './Rule';
33
- import type { Server } from './Server';
34
- import type { Url } from './Url';
35
- import type { User } from './User';
36
- import type { UserAgent } from './UserAgent';
37
- import type { Vulnerability } from './Vulnerability';
38
-
39
- /**
40
- * NOTE: This is an auto-generated file. Don't edit this manually.
41
- */
42
- export interface Observable {
43
- __index: 'observable';
44
- agent?: Agent;
45
- assemblyline?: Assemblyline;
46
- aws?: Aws;
47
- azure?: Azure;
48
- cbs?: Cbs;
49
- cloud?: ObservableCloud;
50
- clue?: Clue;
51
- container?: Container;
52
- destination?: ObservableDestination;
53
- dns?: Dns;
54
- ecs?: Ecs;
55
- email?: ObservableEmail;
56
- error?: Error;
57
- event?: Event;
58
- faas?: Faas;
59
- file?: ObservableFile;
60
- gcp?: Gcp;
61
- group?: Group;
62
- host?: Host;
63
- howler: ObservableHowler;
64
- http?: ObservableHttp;
65
- interface?: Interface;
66
- labels?: { [index: string]: string };
67
- message?: string;
68
- network?: Network;
69
- observer?: ObservableObserver;
70
- organization?: ObservableOrganization;
71
- process?: ObservableProcess;
72
- registry?: Registry;
73
- related?: Related;
74
- rule?: Rule;
75
- server?: Server;
76
- source?: ObservableSource;
77
- tags?: string[];
78
- threat?: ObservableThreat;
79
- timestamp: string;
80
- tls?: ObservableTls;
81
- url?: Url;
82
- user?: User;
83
- user_agent?: UserAgent;
84
- vulnerability?: Vulnerability;
85
- }
@@ -1,20 +0,0 @@
1
- import type { CloudAccount } from './CloudAccount';
2
- import type { Instance } from './Instance';
3
- import type { Machine } from './Machine';
4
- import type { Project } from './Project';
5
- import type { Service } from './Service';
6
-
7
- /**
8
- * NOTE: This is an auto-generated file. Don't edit this manually.
9
- */
10
- export interface ObservableCloud {
11
- account?: CloudAccount;
12
- availability_zone?: string;
13
- instance?: Instance;
14
- machine?: Machine;
15
- project?: Project;
16
- provider?: string;
17
- region?: string;
18
- service?: Service;
19
- tenant_id?: string;
20
- }
@@ -1,23 +0,0 @@
1
- import type { AutonomousSystems } from './AutonomousSystems';
2
- import type { DestinationOriginal } from './DestinationOriginal';
3
- import type { Geo } from './Geo';
4
- import type { Nat } from './Nat';
5
- import type { User } from './User';
6
-
7
- /**
8
- * NOTE: This is an auto-generated file. Don't edit this manually.
9
- */
10
- export interface ObservableDestination {
11
- address?: string;
12
- autonomous_systems?: AutonomousSystems;
13
- bytes?: number;
14
- domain?: string;
15
- geo?: Geo;
16
- ip?: string;
17
- mac?: string;
18
- nat?: Nat;
19
- original?: DestinationOriginal;
20
- packets?: number;
21
- port?: number;
22
- user?: User;
23
- }
@@ -1,30 +0,0 @@
1
- import type { Bcc } from './Bcc';
2
- import type { Cc } from './Cc';
3
- import type { EmailAttachment } from './EmailAttachment';
4
- import type { EmailParent } from './EmailParent';
5
- import type { From } from './From';
6
- import type { ReplyTo } from './ReplyTo';
7
- import type { Sender } from './Sender';
8
- import type { To } from './To';
9
-
10
- /**
11
- * NOTE: This is an auto-generated file. Don't edit this manually.
12
- */
13
- export interface ObservableEmail {
14
- attachments?: EmailAttachment[];
15
- bcc?: Bcc;
16
- cc?: Cc;
17
- content_type?: string;
18
- delivery_timestamp?: string;
19
- direction?: string;
20
- from?: From;
21
- local_id?: string;
22
- message_id?: string;
23
- origination_timestamp?: string;
24
- parent?: EmailParent;
25
- reply_to?: ReplyTo;
26
- sender?: Sender;
27
- subject?: string;
28
- to?: To;
29
- x_mailer?: string;
30
- }