Skip to content

Commit

Permalink
[SIEM] fix circular dependency (elastic#57729)
Browse files Browse the repository at this point in the history
* fix Timeline url dependency

* fix circular dependency

* rename ColumnHeader to ColumnHeaderOptions
  • Loading branch information
XavierM committed Feb 18, 2020
1 parent f85839f commit 2d1e758
Show file tree
Hide file tree
Showing 80 changed files with 465 additions and 398 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,7 @@ run(
);

const circularFound = result.circular();
// We can only care about SIEM code, we should not be penalyze for others
if (circularFound.filter(cf => cf.includes('siem')).length !== 0) {
if (circularFound.length !== 0) {
throw createFailError(
`SIEM circular dependencies of imports has been found:\n - ${circularFound.join('\n - ')}`
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,15 @@
* you may not use this file except in compliance with the Elastic License.
*/

import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { defaultColumnHeaderType } from '../timeline/body/column_headers/default_headers';
import { DEFAULT_COLUMN_MIN_WIDTH, DEFAULT_DATE_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import { timelineDefaults, SubsetTimelineModel } from '../../store/timeline/model';
import {
DEFAULT_COLUMN_MIN_WIDTH,
DEFAULT_DATE_COLUMN_MIN_WIDTH,
} from '../timeline/body/constants';
import { ColumnHeaderOptions, SubsetTimelineModel } from '../../store/timeline/model';
import { timelineDefaults } from '../../store/timeline/defaults';

export const alertsHeaders: ColumnHeader[] = [
export const alertsHeaders: ColumnHeaderOptions[] = [
{
columnHeaderType: defaultColumnHeaderType,
id: '@timestamp',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,8 @@ import { ActionCreator } from 'typescript-fsa';

import { BrowserFields, getAllFieldsByName } from '../../containers/source';
import { IdToDataProvider } from '../../store/drag_and_drop/model';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/constants';

import { DataProvider } from '../timeline/data_providers/data_provider';
import { dragAndDropActions, timelineActions } from '../../store/actions';
Expand Down Expand Up @@ -124,7 +124,7 @@ interface AddProviderToTimelineParams {

interface AddFieldToTimelineColumnsParams {
upsertColumn?: ActionCreator<{
column: ColumnHeader;
column: ColumnHeaderOptions;
id: string;
index: number;
}>;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,16 +22,16 @@ import styled from 'styled-components';
import { BrowserFields } from '../../containers/source';
import { ToStringArray } from '../../graphql/types';
import { WithCopyToClipboard } from '../../lib/clipboard/with_copy_to_clipboard';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { DragEffects } from '../drag_and_drop/draggable_wrapper';
import { DroppableWrapper } from '../drag_and_drop/droppable_wrapper';
import { getDroppableId, getDraggableFieldId, DRAG_TYPE_FIELD } from '../drag_and_drop/helpers';
import { DraggableFieldBadge } from '../draggables/field_badge';
import { FieldName } from '../fields_browser/field_name';
import { SelectableText } from '../selectable_text';
import { OverflowField } from '../tables/helpers';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { defaultColumnHeaderType } from '../timeline/body/column_headers/default_headers';
import { DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import { DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/constants';
import { MESSAGE_FIELD_NAME } from '../timeline/body/renderers/constants';
import { FormattedFieldValue } from '../timeline/body/renderers/formatted_field';
import { OnUpdateColumns } from '../timeline/events';
Expand Down Expand Up @@ -63,11 +63,11 @@ export const getColumns = ({
toggleColumn,
}: {
browserFields: BrowserFields;
columnHeaders: ColumnHeader[];
columnHeaders: ColumnHeaderOptions[];
eventId: string;
onUpdateColumns: OnUpdateColumns;
contextId: string;
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
}) => [
{
field: 'field',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import styled from 'styled-components';

import { BrowserFields } from '../../containers/source';
import { DetailItem } from '../../graphql/types';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { OnUpdateColumns } from '../timeline/events';
import { EventFieldsBrowser } from './event_fields_browser';
import { JsonView } from './json_view';
Expand All @@ -20,14 +20,14 @@ export type View = 'table-view' | 'json-view';

interface Props {
browserFields: BrowserFields;
columnHeaders: ColumnHeader[];
columnHeaders: ColumnHeaderOptions[];
data: DetailItem[];
id: string;
view: View;
onUpdateColumns: OnUpdateColumns;
onViewSelected: (selected: View) => void;
timelineId: string;
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
}

const Details = styled.div`
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { sortBy } from 'lodash';
import { EuiInMemoryTable } from '@elastic/eui';
import React, { useMemo } from 'react';

import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { BrowserFields, getAllFieldsByName } from '../../containers/source';
import { DetailItem } from '../../graphql/types';
import { OnUpdateColumns } from '../timeline/events';
Expand All @@ -18,12 +18,12 @@ import { search } from './helpers';

interface Props {
browserFields: BrowserFields;
columnHeaders: ColumnHeader[];
columnHeaders: ColumnHeaderOptions[];
data: DetailItem[];
eventId: string;
onUpdateColumns: OnUpdateColumns;
timelineId: string;
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
}

/** Renders a table view or JSON view of the `ECS` `data` */
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,11 @@
import { get, getOr, isEmpty, uniqBy } from 'lodash/fp';

import { BrowserField, BrowserFields } from '../../containers/source';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { DEFAULT_DATE_COLUMN_MIN_WIDTH, DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import {
DEFAULT_DATE_COLUMN_MIN_WIDTH,
DEFAULT_COLUMN_MIN_WIDTH,
} from '../timeline/body/constants';
import { ToStringArray } from '../../graphql/types';

import * as i18n from './translations';
Expand Down Expand Up @@ -46,7 +49,7 @@ export const getColumnHeaderFromBrowserField = ({
}: {
browserField: Partial<BrowserField>;
width?: number;
}): ColumnHeader => ({
}): ColumnHeaderOptions => ({
category: browserField.category,
columnHeaderType: 'not-filtered',
description: browserField.description != null ? browserField.description : undefined,
Expand All @@ -68,7 +71,7 @@ export const getColumnsWithTimestamp = ({
}: {
browserFields: BrowserFields;
category: string;
}): ColumnHeader[] => {
}): ColumnHeaderOptions[] => {
const emptyFields: Record<string, Partial<BrowserField>> = {};
const timestamp = get('base.fields.@timestamp', browserFields);
const categoryFields: Array<Partial<BrowserField>> = [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,20 +7,20 @@
import React, { useCallback, useState } from 'react';

import { BrowserFields } from '../../containers/source';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { DetailItem } from '../../graphql/types';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { OnUpdateColumns } from '../timeline/events';

import { EventDetails, View } from './event_details';

interface Props {
browserFields: BrowserFields;
columnHeaders: ColumnHeader[];
columnHeaders: ColumnHeaderOptions[];
data: DetailItem[];
id: string;
onUpdateColumns: OnUpdateColumns;
timelineId: string;
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
}

export const StatefulEventDetails = React.memo<Props>(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,14 @@
* you may not use this file except in compliance with the Elastic License.
*/

import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { defaultColumnHeaderType } from '../timeline/body/column_headers/default_headers';
import { DEFAULT_COLUMN_MIN_WIDTH, DEFAULT_DATE_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import {
DEFAULT_COLUMN_MIN_WIDTH,
DEFAULT_DATE_COLUMN_MIN_WIDTH,
} from '../timeline/body/constants';

export const defaultHeaders: ColumnHeader[] = [
export const defaultHeaders: ColumnHeaderOptions[] = [
{
columnHeaderType: defaultColumnHeaderType,
id: '@timestamp',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@
*/

import { defaultHeaders } from './default_headers';
import { SubsetTimelineModel, timelineDefaults } from '../../store/timeline/model';
import { SubsetTimelineModel } from '../../store/timeline/model';
import { timelineDefaults } from '../../store/timeline/defaults';

export const eventsDefaultModel: SubsetTimelineModel = {
...timelineDefaults,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,9 @@ import { BrowserFields } from '../../containers/source';
import { TimelineQuery } from '../../containers/timeline';
import { Direction } from '../../graphql/types';
import { useKibana } from '../../lib/kibana';
import { KqlMode } from '../../store/timeline/model';
import { ColumnHeaderOptions, KqlMode } from '../../store/timeline/model';
import { AutoSizer } from '../auto_sizer';
import { HeaderSection } from '../header_section';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { defaultHeaders } from '../timeline/body/column_headers/default_headers';
import { Sort } from '../timeline/body/sort';
import { StatefulBody } from '../timeline/body/stateful_body';
Expand Down Expand Up @@ -50,7 +49,7 @@ const StyledEuiPanel = styled(EuiPanel)`

interface Props {
browserFields: BrowserFields;
columns: ColumnHeader[];
columns: ColumnHeaderOptions[];
dataProviders: DataProvider[];
deletedEventIds: Readonly<string[]>;
end: number;
Expand All @@ -68,7 +67,7 @@ interface Props {
start: number;
sort: Sort;
timelineTypeContext: TimelineTypeContextProps;
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
utilityBar?: (refetch: inputsModel.Refetch, totalCount: number) => React.ReactNode;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,12 @@ import { connect } from 'react-redux';
import { ActionCreator } from 'typescript-fsa';
import { inputsModel, inputsSelectors, State, timelineSelectors } from '../../store';
import { inputsActions, timelineActions } from '../../store/actions';
import { KqlMode, SubsetTimelineModel, TimelineModel } from '../../store/timeline/model';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import {
ColumnHeaderOptions,
KqlMode,
SubsetTimelineModel,
TimelineModel,
} from '../../store/timeline/model';
import { DataProvider } from '../timeline/data_providers/data_provider';
import { Sort } from '../timeline/body/sort';
import { OnChangeItemsPerPage } from '../timeline/events';
Expand Down Expand Up @@ -39,7 +43,7 @@ export interface OwnProps {
}

interface StateReduxProps {
columns: ColumnHeader[];
columns: ColumnHeaderOptions[];
dataProviders?: DataProvider[];
filters: esFilters.Filter[];
isLive: boolean;
Expand All @@ -57,7 +61,7 @@ interface StateReduxProps {
interface DispatchProps {
createTimeline: ActionCreator<{
id: string;
columns: ColumnHeader[];
columns: ColumnHeaderOptions[];
itemsPerPage?: number;
sort?: Sort;
showCheckboxes?: boolean;
Expand All @@ -76,7 +80,7 @@ interface DispatchProps {
itemsPerPage: number;
}>;
upsertColumn: ActionCreator<{
column: ColumnHeader;
column: ColumnHeaderOptions;
id: string;
index: number;
}>;
Expand Down Expand Up @@ -134,7 +138,7 @@ const StatefulEventsViewerComponent: React.FC<Props> = ({
);

const toggleColumn = useCallback(
(column: ColumnHeader) => {
(column: ColumnHeaderOptions) => {
const exists = columns.findIndex(c => c.id === column.id) !== -1;

if (!exists && upsertColumn != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { noop } from 'lodash/fp';
import styled from 'styled-components';

import { BrowserFields } from '../../containers/source';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { CategoriesPane } from './categories_pane';
import { FieldsPane } from './fields_pane';
import { Header } from './header';
Expand Down Expand Up @@ -57,7 +57,7 @@ type Props = Pick<
/**
* The current timeline column headers
*/
columnHeaders: ColumnHeader[];
columnHeaders: ColumnHeaderOptions[];
/**
* A map of categoryId -> metadata about the fields in that category,
* filtered such that the name of every field in the category includes
Expand Down Expand Up @@ -95,7 +95,7 @@ type Props = Pick<
/**
* Invoked to add or remove a column from the timeline
*/
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
};

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@ import React from 'react';

import { mockBrowserFields } from '../../containers/source/mock';
import { TestProviders } from '../../mock';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { defaultColumnHeaderType } from '../timeline/body/column_headers/default_headers';
import { DEFAULT_DATE_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import { DEFAULT_DATE_COLUMN_MIN_WIDTH } from '../timeline/body/constants';

import { Category } from './category';
import { getFieldColumns, getFieldItems } from './field_items';
Expand All @@ -21,7 +21,7 @@ import { useMountAppended } from '../../utils/use_mount_appended';
const selectedCategoryId = 'base';
const selectedCategoryFields = mockBrowserFields[selectedCategoryId].fields;
const timestampFieldId = '@timestamp';
const columnHeaders: ColumnHeader[] = [
const columnHeaders: ColumnHeaderOptions[] = [
{
category: 'base',
columnHeaderType: defaultColumnHeaderType,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,16 +13,16 @@ import { Draggable } from 'react-beautiful-dnd';
import styled from 'styled-components';

import { BrowserField, BrowserFields } from '../../containers/source';
import { ColumnHeaderOptions } from '../../store/timeline/model';
import { DragEffects } from '../drag_and_drop/draggable_wrapper';
import { DroppableWrapper } from '../drag_and_drop/droppable_wrapper';
import { getDraggableFieldId, getDroppableId, DRAG_TYPE_FIELD } from '../drag_and_drop/helpers';
import { DraggableFieldBadge } from '../draggables/field_badge';
import { getEmptyValue } from '../empty_value';
import { getColumnsWithTimestamp, getExampleText, getIconFromType } from '../event_details/helpers';
import { SelectableText } from '../selectable_text';
import { ColumnHeader } from '../timeline/body/column_headers/column_header';
import { defaultColumnHeaderType } from '../timeline/body/column_headers/default_headers';
import { DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/helpers';
import { DEFAULT_COLUMN_MIN_WIDTH } from '../timeline/body/constants';
import { OnUpdateColumns } from '../timeline/events';
import { TruncatableText } from '../truncatable_text';
import { FieldName } from './field_name';
Expand Down Expand Up @@ -68,10 +68,10 @@ export const getFieldItems = ({
browserFields: BrowserFields;
category: Partial<BrowserField>;
categoryId: string;
columnHeaders: ColumnHeader[];
columnHeaders: ColumnHeaderOptions[];
highlight?: string;
timelineId: string;
toggleColumn: (column: ColumnHeader) => void;
toggleColumn: (column: ColumnHeaderOptions) => void;
onUpdateColumns: OnUpdateColumns;
}): FieldItem[] =>
uniqBy('name', [
Expand Down
Loading

0 comments on commit 2d1e758

Please sign in to comment.