Core APIs in Siren Investigate
The following classes are available:
- ActionRegistry
-
A registry to store custom actions that are registered from plug-ins for Siren Investigate.
- BasicEmitter
-
A basic event emitter class that is used by sirenAPI. It calls handlers synchronously and implements a chainable API.
- Chart
-
Class representing a chart object
- Charts
-
Utility class - provides static methods to create charts.
- Collection
-
A class that represents a collection.
- Dashboard ⇐
BasicEmitter
-
The class that represents a dashboard.
- Dataspace
-
The class that represents a dataspace.
- DataModelEntity
-
A class representing a data model entity, such as a Search or an Entity identifier. It contains the field definitions necessary to extract, interpret and format the data stored in the records. It also allows users to extract records satisfying an input query.
- DataModelLink ⇐
BasicEmitter
-
The class that represents a data model link.
- DataRecord
-
A class that represents either an actual data record or a virtual "entity identifier". The record is associated to a list of data model entities, which interpret the data as a data model-enabled node able to connect to other nodes through relations.
- Eid ⇐
BasicEmitter
-
The class that represents an eid.
- Graph
-
A class that represents a graph.
- Highlighting
-
APIs to process the highlights and present the matching snippets.
- Notify
-
A class that allows scripts to trigger notifications at the top of the screen
- RecordViewer
-
APIs to access the Record Viewer.
- Relation
-
A class that represents a relation connecting two data model entities. Relations can be used to retrieve new records linked to some known record.
- Reporting
-
Provides methods for report generation.
- Revisions
-
APIs to facilitate document editing (Target Search must have editing enabled)
- Search ⇐
BasicEmitter
-
The class that represents a search.
- SearchApp
-
A class that represents a search app.
- SearchSource
-
Allows scripts to query data model searches. State of the SearchSource can be modified by the property methods (chainable).
- SirenAPI ⇐
BasicEmitter
-
The API for interacting with Siren Investigate, which is exposed at window.sirenapi.
- Visualization ⇐
BasicEmitter
-
The class that represents a visualization.
Instances of this class will also expose methods registered by visualizations. These methods vary per visualization type. See Visualization APIs in Siren section.
Functions
getFields()
⇒Promise<Array<Field>>
-
Returns fields metadata from the entity.
Typedefs
APIDefinition
:Object
-
The definition of an API as per the scripting interfaces.
DataModelRecordId
:Object
-
Object representing a record
EsRecordId
:Object
-
Id of an Elasticsearch record.
DataModelEntityType
:string
-
Possible types of a Data Model Entity.
CountOptions
:Object
-
Options applied when counting records.
QueryOptions
:Object
-
Options applied when querying a data model entity for records.
Order
:Object
-
Order specification applied when retrieving records.
DataModelEntitiesSpecs
:string
-
Specifies how retrieved records should implicitly associate to data model entities.
RichDocs
:RichDocsConfig
|RichDocsConfigBySearch
-
Configuration for enriching documents.
RichDocsConfig
:Object
-
Configuration for enriching documents. Will be applied documents originating from all searches.
RichDocsConfigBySearch
:Object<string, RichDocsConfig>
-
Configuration for enriching documents by search.
VisScreenshot
:Object
-
A screenshot obtained from a dashboard visualization.
Interfaces
Field
-
Interface representing a Field.
RelationCondition
-
The interface representing a relation condition.
HighlightParsingOptions
-
Options necessary to parse a highlighted string.
HighlightItem
-
Part of a highlighted string.
When parsing highlights for a string, the string is subdivided into substrings that alternate between highlighted and normal text. Each substring is represented by a HighlightItem object.
Field
Interface representing a Field.
Kind: global interface
Properties
Name | Type | Description |
---|---|---|
name |
|
The name of the field. |
esType |
|
The Elasticsearch type of the field. |
type |
|
The type of the field. |
label |
|
The label of the field. |
description |
|
A description of the field. |
scripted |
|
Indicates whether the field is scripted. |
searchable |
|
Indicates whether the field is searchable. |
aggregatable |
|
Indicates whether the field is aggregatable. |
primaryKey |
|
Indicates whether the field is a primary key. |
singleValue |
|
Indicates whether the field can have only one value. |
globalSearchEnabled |
|
(Optional) Indicates whether global search is enabled for the field. |
globalSearchBoost |
|
(Optional) The boost value for global search. |
mainField |
|
Indicates whether the field is selected as a main field. |
RelationCondition
The interface representing a relation condition.
Kind: global interface
Properties
Name | Type | Description |
---|---|---|
clause |
|
'must' |
operator |
|
The condition operator such as eq, lte, gte, gt, lt, intersects, contains |
domainField |
|
The domain field name of the condition. The value is undefined if this side of the relation is an Entity Identifier. |
rangeField |
|
The range field name of the condition. The value is undefined if this side of the relation is an Entity Identifier. |
HighlightParsingOptions
Options necessary to parse a highlighted string.
Kind: global interface
Properties
Name | Type | Description |
---|---|---|
pre_tags |
|
Tags used to represent the start of a highlight. Only one tag is supported (array of a single element). |
post_tags |
|
Tags used to represent the end of a highlight. Only one tag is supported (array of a single element). |
HighlightItem
Part of a highlighted string.
When parsing highlights for a string, the string is subdivided into substrings that alternate between highlighted and normal text. Each substring is represented by a HighlightItem object.
Kind: global interface
Properties
Name | Type | Description |
---|---|---|
type |
|
Whether the item represents normal or highlighted text. |
text |
|
The text represented by this item. |
ActionRegistry
A registry to store custom actions that are registered from plug-ins for Siren Investigate.
Kind: global class
new ActionRegistry(supportedVersions)
Creates an instance of the action registry.
Parameter | Type | Description |
---|---|---|
supportedVersions |
|
A list of Siren API versions supported |
actionRegistry.register(version, uuid, actionName, action)
Registers an action against an action name.
Kind: instance method of ActionRegistry
Parameter | Type | Description |
---|---|---|
version |
|
Siren API version |
uuid |
|
a unique id, preferably a UUID, against which the actions are registered |
actionName |
|
name of the action |
action |
|
call back function mapped to the action name |
actionRegistry.getActions(version, uuid)
⇒ Object
Returns a object with all action names mapped to the registered actions.
Kind: instance method of ActionRegistry
Returns: Object
- an object of all action names mapped to actions
Parameter | Type | Description |
---|---|---|
version |
|
Siren API version |
uuid |
|
the id under which the actions are registered |
actionRegistry.getActionByName(version, uuid, actionName)
⇒ function
Returns a registed action based on its action name.
Kind: instance method of ActionRegistry
Returns: function
- the registered action
Parameter | Type | Description |
---|---|---|
version |
|
Siren API version |
uuid |
|
the id under which the actions are registered |
actionName |
|
name of the registered action |
actionRegistry.registerInterfaceForType(version, type, InterfaceClass)
Register the interface class based on which the APIs are registered on the action registry.
Kind: instance method of ActionRegistry
Parameter | Type | Description |
---|---|---|
version |
|
Siren API version |
type |
|
the name of the plug-in |
InterfaceClass |
|
A javascript class to describe the exposed methods |
actionRegistry.getActionDefinitionsForType(version, type)
⇒ Array<APIDefinition>
Get a list of API definitions as per the scripting interface of a plug-in.
Kind: instance method of ActionRegistry
Returns: Array<APIDefinition>
- Array of API definitions
Parameter | Type | Description |
---|---|---|
version |
|
Siren API version |
type |
|
the name of the plug-in |
BasicEmitter
A basic event emitter class that is used by sirenAPI. It calls handlers synchronously and implements a chainable API.
Kind: global class
basicEmitter.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of BasicEmitter
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
basicEmitter.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of BasicEmitter
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
basicEmitter.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of BasicEmitter
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
basicEmitter.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of BasicEmitter
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
Chart
Class representing a chart object
Kind: global class
chart.getHtmlElement()
Get the htmlWrapper element of a chart. Example: The wrapped html can be then attached to the panel in Scripted Panel visualization
Kind: instance method of Chart
Charts
Utility class - provides static methods to create charts.
Kind: global class
-
-
.getBarChartBasicOptions(options)
⇒Promise<object>
Charts.createApexChart(options)
⇒ Promise<Chart>
Creates an Apex Chart element
Kind: static method of Charts
Returns: Promise<Chart>
- Promise to an instance of a Chart object
Parameter | Type | Description |
---|---|---|
options |
|
ApexChart options. |
Charts.getBarChartBasicOptions(options)
⇒ Promise<object>
Returns a basic configuration for a bar chart. The passed options will override the default ones.
Kind: static method of Charts
Returns: Promise<object>
- Promise to the basic options for an ApexChart bar chart
Parameter | Type | Description |
---|---|---|
options |
|
Apex Chart options |
Collection
A class that represents a collection.
Kind: global class
Collection.addCollectionRecords(options)
⇒ Promise<void>
Add records passed via option.recordIds to collection specified via options.collectionId. If options.collectionId is not specified then the method will display a modal where the user can create a new collection or select from existing ones.
Kind: static method of Collection
Throws:
-
EID records are not supported at the moment and can not be added using this method. You can use
Graph.addRecordsWithModal
instead.
Parameter | Type | Default | Description |
---|---|---|---|
options |
|
Options for adding records to a collection. |
|
options.recordIds |
An array of objects representing the records to add. |
||
[options.collectionId] |
|
The Id of the collection to which to add records. If not provided, the method will display a modal in which a user can create a new collection or pick an existing one. (optional) |
|
[options.allowCreate] |
|
|
Setting to false will hide modal functionality for creating a new collection. Defaults to |
[options.openAfterAdd] |
|
|
Setting to true will redirect to the collection page. If |
Dashboard ⇐ BasicEmitter
The class that represents a dashboard.
Kind: global class
Extends: BasicEmitter
-
-
instance
-
.getQueryString()
⇒QueryString
-
.getSavedQueryString()
⇒QueryString
-
.setQueryString(queryString)
⇒this
-
.getId()
⇒string
-
.getTitle()
⇒string
-
.setTitle(title)
⇒this
-
.getDescription()
⇒string
-
.setDescription(description)
⇒this
-
.getFilters()
⇒Array<Filter>
-
.getSavedFilters()
⇒Array<Filter>
-
.setFilters(filters)
⇒this
-
.addFilters(filters)
⇒this
-
.getDashboardDataModelRootSearch()
⇒Promise
-
.getDashboardDataModelTree()
⇒Promise
-
.getDashboardDataModelNodeIndexpattern(focusNodeId)
⇒Promise
-
.applyState()
⇒Promise
-
.open(options)
⇒Promise
-
.openModal(modalConfig)
⇒Promise<void>
-
.openFlyout(flyoutConfig)
⇒Promise<void>
-
-
static
-
.fetchDashboardById(dashboardID)
⇒Promise
-
.getCurrentDashboard()
⇒Promise
-
.fetchAllDashboards()
⇒Promise
-
dashboard.getQueryString()
⇒ QueryString
The query string currently applied to the dashboard.
Kind: instance method of Dashboard
dashboard.getSavedQueryString()
⇒ QueryString
The dashboard’s saved query string.
Kind: instance method of Dashboard
dashboard.setQueryString(queryString)
⇒ this
Sets the dashboard’s query string.
Kind: instance method of Dashboard
Parameter | Type |
---|---|
queryString |
|
dashboard.setTitle(title)
⇒ this
Sets the title of the dashboard.
Kind: instance method of Dashboard
Parameter | Type |
---|---|
title |
|
dashboard.setDescription(description)
⇒ this
Sets the description of the dashboard.
Kind: instance method of Dashboard
Parameter | Type |
---|---|
description |
|
dashboard.getSearchSource()
⇒ Promise<SearchSource>
Get the SearchSource associated to this Dashboard. You can use the search source to run queries on the dashboard.
Kind: instance method of Dashboard
Throws:
-
Error
If the dashboard is not attached to a data model entity.
dashboard.getFilters()
⇒ Array<Filter>
The filters currently applied to the dashboard.
Kind: instance method of Dashboard
dashboard.getSavedFilters()
⇒ Array<Filter>
The filters saved with the dashboard.
Kind: instance method of Dashboard
dashboard.setFilters(filters)
⇒ this
Specify a single filter or an array of filters to replace in the dashboard.
Kind: instance method of Dashboard
Parameter | Type |
---|---|
filters |
|
dashboard.addFilters(filters)
⇒ this
Specify a single filter or an array of filters to add to the dashboard.
Kind: instance method of Dashboard
Parameter | Type |
---|---|
filters |
|
dashboard.getTime()
⇒
The time currently applied to the dashboard.
Kind: instance method of Dashboard
Returns: a time object with properties from
, to
and mode
. Returns a null
value if the time filter is not visible in the dashboard.
dashboard.getSavedTime()
⇒
The time saved with the dashboard.
Kind: instance method of Dashboard
Returns: a time object with properties from
, to
and mode
. Returns a null
value if the time is not saved with the dashboard or the
time filter is not visible in the dashboard.
dashboard.getVisualizationByTitle(title)
⇒ Array<Visualization>
Gets visualizations by title
Kind: instance method of Dashboard
Parameter | Type | Description |
---|---|---|
title |
|
title of visualization to return |
dashboard.getVisualizationById(title)
⇒ Array<Visualization>
Gets visualizations by id
Kind: instance method of Dashboard
Parameter | Type | Description |
---|---|---|
title |
|
id of visualization to return |
dashboard.getDashboardDataModelRootSearch()
⇒ Promise
Gets the dashboard data model root Search
Kind: instance method of Dashboard
Returns: Promise
- Resolved with {
dashboard.getDashboardDataModelTree()
⇒ Promise
Gets the dashboard data model tree
Kind: instance method of Dashboard
Returns: Promise
- Resolved with {Array<Search | Eid | DataModelLink>}
dashboard.getDashboardDataModelSearchByTitle(title)
⇒ Promise
Gets a dashboard data model search by title This method returns an array as the same search could be associated more than one data model nodeId
Kind: instance method of Dashboard
Returns: Promise
- Resolved with {Array
Parameter | Type | Description |
---|---|---|
title |
|
title of the search from dashboard datamodel |
dashboard.getDashboardDataModelSearchByNodeId(nodeid)
⇒ Promise
Gets a search by node id
Kind: instance method of Dashboard
Returns: Promise
- Resolved with {Search}
Parameter | Type | Description |
---|---|---|
nodeid |
|
nodeid of a search from dashboard datamodel |
dashboard.getDashboardDataModelNodeIndexpattern(focusNodeId)
⇒ Promise
Gets an index for particular search in the Dashboard datamodel. We assume that it is a current dashboard on view
Kind: instance method of Dashboard
Returns: Promise
- Resolved with an elasticsearch index pattern as a string
Parameter | Type | Description |
---|---|---|
focusNodeId |
|
nodeid of a node from dashboard datamodel |
dashboard.getDashboardDataModelNodeQuery(focusNodeId)
⇒ Promise
Gets a query to fetch documents present on a dashboard for particular search in the Dashboard datamodel We assume that it is a current dashboard on view On Dashboard 360 there could be multiple searches in the model and there is a different query behind each search which depends on Data model settings and the position of the search in the datamodel
Kind: instance method of Dashboard
Returns: Promise
- Resolved with a query as a JSON object
Parameter | Type | Description |
---|---|---|
focusNodeId |
|
nodeid of a node from dashboard datamodel |
dashboard.applyState()
⇒ Promise
Applies any modification to the dashboard query and filters to the state of the application.
Kind: instance method of Dashboard
Returns: Promise
- Resolves with this
dashboard.open(options)
⇒ Promise
Open the browser with this dashboard with state applied.
Kind: instance method of Dashboard
Returns: Promise
- Resolves once the dashboard is open.
Parameter | Type | Description |
---|---|---|
options |
|
currently only one option is available, options.timeout - to specify how long to wait (in milliseconds) for dashboard to be loaded before rejecting |
dashboard.openModal(modalConfig)
⇒ Promise<void>
Renders a modal with react element as its content on the dashboard.
Kind: instance method of Dashboard
Parameter | Type | Description |
---|---|---|
modalConfig |
|
configuration object of the modal |
modalConfig.Element |
|
React element rendered inside the modal |
modalConfig.primaryBtnText |
|
text displayed on primary button |
modalConfig.onPrimaryClick |
|
callback called when primary button is clicked |
[modalConfig.secondaryBtnText] |
|
text displayed on secondary button |
[modalConfig.onSecondaryClick] |
|
callback called when secondary button is clicked |
[modalConfig.cancelBtnText] |
|
text displayed on secondary button |
[modalConfig.onCancel] |
|
callback called when cancel button is clicked |
[modalConfig.titleText] |
|
title of the modal |
dashboard.openFlyout(flyoutConfig)
⇒ Promise<void>
Renders a flyout with react element as its content on the dashboard.
Kind: instance method of Dashboard
Parameter | Type | Description |
---|---|---|
flyoutConfig |
|
configuration object of the modal |
flyoutConfig.Element |
|
React element rendered inside the flyout |
[flyoutConfig.titleText] |
|
title of the flyout |
[flyoutConfig.footer] |
|
React element rendered inside the footer of the flyout |
[flyoutConfig.size] |
|
Size of the flyout (default: 'm') |
dashboard.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of Dashboard
Overrides: on
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
dashboard.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of Dashboard
Overrides: off
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
dashboard.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of Dashboard
Overrides: removeAllListeners
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
dashboard.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of Dashboard
Overrides: emit
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
Dashboard.EVENTS
Return a map of events that can be registered on dashboard object
Kind: static property of Dashboard
Properties
Name | Type | Description |
---|---|---|
DASH_AUTOREFRESHED |
|
event fired when dashboard autorefresh option is enabled and dashboard was refreshed |
SEARCH_COUNT_CHANGED |
|
event fired when count on any search associated with the dashboard changes |
Example
Event returned when dashboard emits DASH_AUTOREFRESHED has a data parameter in the following form { refreshInterval: { value: {integer} - autorefresh time in milliseconds display: {string} - a human readable string describing the value } } Event returned when dashboard emits SEARCH_COUNT_CHANGED has an extra parameter in the following form { node: { id: {string} }, search: { id: {string} }, count: {number} }
Dashboard.fetchDashboardById(dashboardID)
⇒ Promise
Fetch the saved dashboard with id dashboardID.
Parameter | Type |
---|---|
dashboardID |
|
Dataspace
The class that represents a dataspace.
Kind: global class
-
-
instance
-
.shortCode
⇒string
-
.title
⇒string
-
.description
⇒string
-
.colorCode
⇒string
-
.icon
⇒string
-
-
static
-
.getAvailableDataspaces()
⇒Promise<Array<Dataspace>>
-
dataspace.colorCode
⇒ string
Colour code of the dataspace. This is in hex format (#000000
)
Kind: instance property of Dataspace
dataspace.icon
⇒ string
Icon of the dataspace. This is in the form of FontAwesome CSS classes (e.g. fas fa-search
)
Kind: instance property of Dataspace
dataspace.switch()
Switch to the dataspace represented by the dataspace object. This will cause the page to reload, which will interrupt any running scripts.
Kind: instance method of Dataspace
Dataspace.getByShortCode(shortCode)
⇒ Promise<Dataspace>
Fetches a dataspace object with the specified short code.
Kind: static method of Dataspace
Parameter | Type | Description |
---|---|---|
shortCode |
|
The short code of the dataspace to fetch |
Dataspace.getCurrentDataspace()
⇒ Promise<Dataspace>
Fetches a dataspace object which represents the current dataspace.
Kind: static method of Dataspace
Dataspace.getAvailableDataspaces()
⇒ Promise<Array<Dataspace>>
Fetches a list of the available dataspaces that the user can switch to.
Kind: static method of Dataspace
Returns: Promise<Array<Dataspace>>
- Objects representing the available dataspaces
DataModelEntity
A class representing a data model entity, such as a Search or an Entity identifier. It contains the field definitions necessary to extract, interpret and format the data stored in the records. It also allows users to extract records satisfying an input query.
Kind: global class
-
-
instance
-
.getId()
⇒Promise<string>
-
.getLabel()
⇒Promise<string>
-
.getIcon()
⇒Promise<string>
-
.getColor()
⇒Promise<string>
-
.getIndexPattern()
⇒Promise<string>
-
.getTimeFieldName()
⇒Promise<(string\|undefined)>
-
.getParent()
⇒Promise<(DataModelEntity\|null)>
-
.getRecordHit(record)
⇒Promise<EsHit>
-
.getRecordLabel(record)
⇒Promise<string>
-
.openRecordView(record)
⇒Promise<void>
-
.getRecordRawFieldValues(record, field)
⇒Promise<Array<unknown>>
-
.getRecordFormattedFieldValues(record, field)
⇒Promise<Array<string>>
-
.getOutgoingRelations()
⇒Promise<Array<Relation>>
-
.getOutgoingRelationsByLabel(label)
⇒Promise<Array<Relation>>
-
.getRecords(options)
⇒Promise<Array<DataRecord>>
-
-
static
-
.getDataModelEntitiesByLabel(label)
⇒Promise<Array<DataModelEntity>>
-
.getDataModelEntitiesByPath(labelsPath)
⇒Promise<Array<DataModelEntity>>
-
-
dataModelEntity.getId()
⇒ Promise<string>
Gets the id of the data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getType()
⇒ Promise<DataModelEntityType>
Gets the type of the data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getLabel()
⇒ Promise<string>
Gets the label of the data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getIcon()
⇒ Promise<string>
Gets the icon of the data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getColor()
⇒ Promise<string>
Gets the color of the data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getIndexPattern()
⇒ Promise<string>
Returns the index pattern of a Search entity.
Kind: instance method of DataModelEntity
Throws:
-
If the entity represents an entity identifier.
dataModelEntity.getTimeFieldName()
⇒ Promise<(string\|undefined)>
Returns the name of the time field of a Search entity, or undefined
if the entity has no time field.
Kind: instance method of DataModelEntity
Throws:
-
If the entity represents an entity identifier.
dataModelEntity.getRoot()
⇒ Promise<DataModelEntity>
Gets the root entity for the current data model entity if any, otherwise returns itself.
Kind: instance method of DataModelEntity
dataModelEntity.getParent()
⇒ Promise<(DataModelEntity\|null)>
Gets the parent entity for the current data model entity if any.
Kind: instance method of DataModelEntity
dataModelEntity.getChildren()
⇒ Promise<DataModelEntity>
Gets the list of child entities associated to the current data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getRecordHit(record)
⇒ Promise<EsHit>
Gets the hit for given record associated to the current data model entity.
Kind: instance method of DataModelEntity
Throws:
-
If the entity represents an entity identifier.
Parameter | Type | Description |
---|---|---|
record |
Given record to retrieve its label. |
dataModelEntity.getRecordLabel(record)
⇒ Promise<string>
Gets the label for given record associated to the current data model entity.
Kind: instance method of DataModelEntity
Parameter | Type | Description |
---|---|---|
record |
Given record to retrieve its label |
dataModelEntity.openRecordView(record)
⇒ Promise<void>
Opens the record viewer for given record associated to the current data model entity.
Kind: instance method of DataModelEntity
Parameter | Type | Description |
---|---|---|
record |
Given record to open on the record viewer |
dataModelEntity.getRecordRawFieldValues(record, field)
⇒ Promise<Array<unknown>>
Gets the raw values for the specified field in the input record.
Kind: instance method of DataModelEntity
Parameter | Type | Description |
---|---|---|
record |
Given record to retrieve its field values |
|
field |
|
The field name to retrieve its values from the record |
dataModelEntity.getRecordFormattedFieldValues(record, field)
⇒ Promise<Array<string>>
Gets the values for the specified field in the input record. The returned values are expressed in a user-readable format.
Kind: instance method of DataModelEntity
Parameter | Type | Description |
---|---|---|
record |
The record to retrieve values from. |
|
field |
|
The field name to retrieve values for. |
dataModelEntity.getOutgoingRelations()
⇒ Promise<Array<Relation>>
Gets the list of all outgoing relations associated to the current data model entity.
Kind: instance method of DataModelEntity
dataModelEntity.getOutgoingRelationsByLabel(label)
⇒ Promise<Array<Relation>>
Gets the list of outgoing relations associated to the current data model entity based on given label.
Kind: instance method of DataModelEntity
Parameter | Type | Description |
---|---|---|
label |
|
The label to match in returned relations. (Case insensitive) |
dataModelEntity.getRecords(options)
⇒ Promise<Array<DataRecord>>
Queries the current data model entity for records.
Kind: instance method of DataModelEntity
Parameter | Type | Description |
---|---|---|
options |
(Optional) Additional search request options. |
DataModelEntity.getDataModelEntitiesByLabel(label)
⇒ Promise<Array<DataModelEntity>>
Returns a list of Data Model Entities matching the specified label. The match is case insensitive.
Kind: static method of DataModelEntity
Parameter | Type | Description |
---|---|---|
label |
|
Label of the Data Model Entities to return. |
DataModelEntity.getDataModelEntityById(id)
⇒ Promise<DataModelEntity>
Returns the Data Model Entity matching the specified saved object id.
Typing saved object ids explicitly in a script is discouraged. Ids are opaque and dataspace-specific, so a script with explicit ids inside wouldn’t work when cloned to a different dataspace. Prefer using method getDataModelEntitiesByLabel if possible. |
Kind: static method of DataModelEntity
Parameter | Type | Description |
---|---|---|
id |
|
Id of the Data Model Entity to return. |
DataModelEntity.getDataModelEntitiesByPath(labelsPath)
⇒ Promise<Array<DataModelEntity>>
Fetches the Data Model Entities in the hierarchical sub-tree identified by a path of Data Model Entity labels (case insensitive).
Kind: static method of DataModelEntity
Parameter | Type | Description |
---|---|---|
labelsPath |
|
Sequence of Data Model Entity labels identifying the sub-tree to list. |
Example
// Criminal Boat // / / // Person Vehicle - Airplane // \ \ // Witness Car const allEntities = await DataModelEntity.getDataModelEntitiesByPath([]); // All the data model entities const personEntities = await DataModelEntity.getDataModelEntitiesByPath(['person']); // [Person, Criminal, Witness] const vehicleEntities = await DataModelEntity.getDataModelEntitiesByPath(['vehicle']); // [Vehicle, Boat, Airplane, Car] const criminalEntities = await DataModelEntity.getDataModelEntitiesByPath(['person', 'criminal']); // [Criminal]
DataModelLink ⇐ BasicEmitter
The class that represents a data model link.
Kind: global class
Extends: BasicEmitter
Properties
Name | Description |
---|---|
id |
id of associated object in investigate |
inverseId |
id of the inverse object in investigate |
linkId |
id of associated link id in Dashboard datamodel |
id1 |
id of the starting node |
id2 |
id of the ending node |
dataModelLink.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of DataModelLink
Overrides: on
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
dataModelLink.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of DataModelLink
Overrides: off
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
dataModelLink.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of DataModelLink
Overrides: removeAllListeners
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
dataModelLink.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of DataModelLink
Overrides: emit
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
DataRecord
A class that represents either an actual data record or a virtual "entity identifier". The record is associated to a list of data model entities, which interpret the data as a data model-enabled node able to connect to other nodes through relations.
Kind: global class
-
-
instance
-
.getId()
⇒Promise<(EsRecordId\|string)>
-
.getDataModelEntities()
⇒Promise<Array<DataModelEntity>>
-
.getHit()
⇒Promise<EsHit>
-
.getLabel()
⇒Promise<string>
-
.getRawFieldValuesArray(field, [options])
⇒Promise<Array<unknown>>
-
.getFirstRawFieldValue(field)
⇒Promise<(unknown\|null)>
-
.getFormattedFieldValuesArray(field, [options])
⇒Promise<Array<string>>
-
.getFirstFormattedFieldValue(field)
⇒Promise<(string\|null)>
-
.getReactElementsFromFieldValuesArray(field)
⇒Promise<Array<JSX.Element>>
-
.getReactElementFromFirstFieldValue(field)
⇒Promise<(JSX.Element\|null)>
-
.getOutgoingRelations()
⇒Promise<Array<Relation>>
-
.getLinkedRecords(relation, options)
⇒Promise<Array<DataRecord>>
-
.getLinkedRecordsCount(relation, options)
⇒Promise<number>
-
.openRecordViewer()
⇒Promise<void>
-
.getEquivalentRecords([options])
⇒Promise<Array<DataRecord>>
-
-
static
-
dataRecord.getId()
⇒ Promise<(EsRecordId\|string)>
Gets the id of the record. This can be an _id/_index EsRecordId pair for actual data records or a string value for entity identifiers.
Kind: instance method of DataRecord
dataRecord.getDataModelEntities()
⇒ Promise<Array<DataModelEntity>>
Gets the data model entities associated to the record.
Kind: instance method of DataRecord
dataRecord.getHit()
⇒ Promise<EsHit>
Gets the hit associated to the record.
Kind: instance method of DataRecord
Throws:
-
If the record represents an entity identifier value.
dataRecord.getLabel()
⇒ Promise<string>
Gets the label of the record.
Kind: instance method of DataRecord
dataRecord.getRawFieldValuesArray(field, [options])
⇒ Promise<Array<unknown>>
Gets the raw values for specified field of the record.
Kind: instance method of DataRecord
Parameter | Type | Default | Description |
---|---|---|---|
field |
|
The field name to get values for. |
|
[options] |
|
(Optional) Options that affect how values for the field are resolved. |
|
[options.useEr] |
|
|
(Optional) Whether to also include field values for all equivalent records (requires entity resolution enabled). |
dataRecord.getFirstRawFieldValue(field)
⇒ Promise<(unknown\|null)>
Gets the first raw value for specified field of the record, or null if there is no value for the field.
Kind: instance method of DataRecord
See: getRawFieldValuesArray
Parameter | Type | Description |
---|---|---|
field |
|
The field name to get values for. |
dataRecord.getFormattedFieldValuesArray(field, [options])
⇒ Promise<Array<string>>
Gets the formatted values for specified field of the record. For example, raw dates will be formatted to be user-readable.
Kind: instance method of DataRecord
Parameter | Type | Default | Description |
---|---|---|---|
field |
|
The field name to get values of. |
|
[options] |
|
(Optional) Options that affect how values for the field are resolved. |
|
[options.useEr] |
|
|
(Optional) Whether to also include field values for all equivalent records (requires entity resolution enabled). |
dataRecord.getFirstFormattedFieldValue(field)
⇒ Promise<(string\|null)>
Gets the first formatted value for specified field of the record, or null if there is no value for the field.
Kind: instance method of DataRecord
See: getFormattedFieldValuesArray
Parameter | Type | Description |
---|---|---|
field |
|
The field name to get values of. |
dataRecord.getReactElementsFromFieldValuesArray(field)
⇒ Promise<Array<JSX.Element>>
Converts HTML snippets stored in a given field into React elements. The HTML snippets are properly sanitized before being rendered, so this function can be used safely. The HTML snippet is always wrapped in a <div> element.
Kind: instance method of DataRecord
Parameter | Type | Description |
---|---|---|
field |
|
The field name to get values for. |
dataRecord.getReactElementFromFirstFieldValue(field)
⇒ Promise<(JSX.Element\|null)>
Converts the first HTML snippet stored in a given field into a React element. Returns null if there is no value for the field.
Kind: instance method of DataRecord
See: getReactElementsFromFieldValuesArray
Parameter | Type | Description |
---|---|---|
field |
|
The field name to get values for. |
dataRecord.getOutgoingRelations()
⇒ Promise<Array<Relation>>
Gets the outgoing relations based on associated data model entities.
Kind: instance method of DataRecord
dataRecord.getLinkedRecords(relation, options)
⇒ Promise<Array<DataRecord>>
Gets the linked records associated to the current record.
Kind: instance method of DataRecord
Parameter | Type | Description |
---|---|---|
relation |
The relation to use in searching for linked items. |
|
options |
(Optional) Options for the query operation. |
dataRecord.getLinkedRecordsCount(relation, options)
⇒ Promise<number>
Gets the total count of linked records associated to the current record.
Kind: instance method of DataRecord
Parameter | Type | Description |
---|---|---|
relation |
The relation to use in searching for linked items. |
|
options |
(Optional) Options for the count operation. |
dataRecord.openRecordViewer()
⇒ Promise<void>
Opens a Record Viewer on this record. This will replace the currently viewed record if the Record Viewer is already open.
Kind: instance method of DataRecord
dataRecord.getEquivalentRecords([options])
⇒ Promise<Array<DataRecord>>
Retrieves equivalent records associated to the current record. The equivalent DataRecords found will only contain fields or _source values defined in richDocs.
Kind: instance method of DataRecord
Parameter | Type | Default | Description |
---|---|---|---|
[options] |
|
(Optional) Options that affect how the equivalent records are fetched. |
|
[options.size] |
|
|
(Optional) The maximum number of equivalent records to return. |
[options.richDocs] |
(Optional) Configuration used to determine how to enrich documents retrieved from Elasticsearch. |
DataRecord.getRecordById(id, dataModelEntities)
⇒ Promise<DataRecord>
Retrieves the record given its id.
Kind: static method of DataRecord
Parameter | Type | Description |
---|---|---|
id |
|
The id of the required record. |
dataModelEntities |
(Optional) Known list of data model entities to associate to the record. These input data model entities must be known to contain the record. |
DataRecord.fetchDataModelEntities(records, dataModelEntities)
⇒ Promise<DataRecord>
Retrieves the list of data model entities associated to the given list of records.
Kind: static method of DataRecord
Parameter | Type | Description |
---|---|---|
records |
The list of records to fetch associated data model entities for. |
|
dataModelEntities |
(Optional) The specification for the data model entities to associate. |
Eid ⇐ BasicEmitter
The class that represents an eid.
Kind: global class
Extends: BasicEmitter
Properties
Name | Description |
---|---|
id |
id of associated object in investigate |
title |
title of associated object in investigate |
nodeid |
id of associated node id in Dashboard datamodel |
eid.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of Eid
Overrides: on
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
eid.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of Eid
Overrides: off
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
eid.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of Eid
Overrides: removeAllListeners
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
eid.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of Eid
Overrides: emit
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
Graph
A class that represents a graph.
Kind: global class
-
-
instance
-
.getId()
⇒string
-
.getLabel()
⇒string
-
.getCount()
⇒number
-
.getLastSaveTime()
⇒Date
-
.getEsRecords()
⇒Promise<Array<DataRecord>>
-
.getEidRecords()
⇒Promise<Array<DataRecord>>
-
-
static
-
.getGraphsWithRecords(options)
⇒Promise<Array<Graph>>
-
.getGraphsByLabel(label)
⇒Promise<Array<Graph>>
-
.addRecordsWithModal(options)
⇒Promise<(Graph\|undefined)>
-
-
graph.getCount()
⇒ number
Get the count displayed in the Dashboards page about this graph. This roughly matches the number of records in the graph, excluding Entity Identifiers and ignoring ACL restrictions.
Kind: instance method of Graph
graph.getLastSaveTime()
⇒ Date
Get the time the graph was last saved.
Kind: instance method of Graph
graph.getEsRecords()
⇒ Promise<Array<DataRecord>>
Get all Elasticsearch records in the graph.
Kind: instance method of Graph
graph.getEidRecords()
⇒ Promise<Array<DataRecord>>
Get all EIDs in the graph.
Kind: instance method of Graph
graph.open()
Open the graph in a visualizer on the Dashboard page.
Kind: instance method of Graph
Parameter | Type | Description |
---|---|---|
options.newTab |
|
(Optional) Whether to open the graph in a new browser tab, defaults to false. |
Graph.getGraphsWithRecords(options)
⇒ Promise<Array<Graph>>
Returns a list of all graphs that contain a given list of record IDs.
Kind: static method of Graph
Returns: Promise<Array<Graph>>
- - An array of graphs containing the relevant record IDs
Throws:
-
EID records are not supported at the moment.
Parameter | Type | Description |
---|---|---|
options |
|
Options for getting graphs from a list of records |
[options.recordIds] |
|
An array of records to search by. |
[options.containing] |
|
Return graphs that return either all or any of the record IDs |
Graph.getGraphsByLabel(label)
⇒ Promise<Array<Graph>>
Get graph instance by label.
Kind: static method of Graph
Returns: Promise<Array<Graph>>
- Returns an array of graph instances found matching the label.
Parameter | Type | Description |
---|---|---|
label |
|
Graph label to search for. |
Graph.addRecordsWithModal(options)
⇒ Promise<(Graph\|undefined)>
Add records passed via option.recordIds to the graph specified by options.graphId. If options.graphId not specified then the method will display a modal where the user can create a new graph or select from existing ones.
Kind: static method of Graph
Returns: Promise<(Graph\|undefined)>
- Either a resolved graph instance with added records or undefined
when no records could be added, for example, because the user canceled the operation.
Parameter | Type | Default | Description |
---|---|---|---|
options |
|
Options for adding records to a graph. |
|
options.recordIds |
An array of objects representing the records to add. |
||
[options.graphId] |
|
The Id of the graph to which to add records. If not provided, the method will display a modal in which a user can create a new graph or pick an existing one. (optional) |
|
[options.allowCreate] |
|
|
Setting to false will hide modal functionality for creating a new graph. Defaults to |
[options.openAfterAdd] |
|
|
Setting to true will redirect to the graph page. If |
Graph.getGraphById(id)
⇒ Promise<Graph>
Get graph instance by ID.
Kind: static method of Graph
Returns: Promise<Graph>
- Resolves with graph matching the id.
Parameter | Type | Description |
---|---|---|
id |
|
Graph ID to search for. |
Highlighting
APIs to process the highlights and present the matching snippets.
Kind: global class
Highlighting.parseString(snippet, options)
⇒ Array<HighlightItem>
Splits a highlighted text snippet into the list of its normal and highlighted parts.
Kind: static method of Highlighting
Throws:
-
If the "pre_tags" or "post_tags" property is defined with either more than one tag or no tag.
Parameter | Type | Description |
---|---|---|
snippet |
|
The highlighted text snippet to break up into highlighted items. |
options |
(Optional) Options object specifying the highlight tags to use to process the text. If not specified, the default Investigate highlighting tags will be used for parsing. |
Example
const items = sirenapi.Highlighting.parseString('some <tag>highlighted</tag> text', { pre_tags: ['<tag>'], post_tags: ['</tag>'] }); // [ // { type: 'text', text: 'some ' }, // { type: 'highlight', text: 'highlighted' }, // { type: 'text', text: ' text' } // ]
Highlighting.itemsToReactElement(items)
⇒ JSX.Element
Transforms a list of highlight items into a React element that can be properly displayed in the UI.
Kind: static method of Highlighting
Parameter | Type | Description |
---|---|---|
items |
Highlight items to transform into a React element. |
Notify
A class that allows scripts to trigger notifications at the top of the screen
Kind: global class
notify.info(error)
Kind: instance method of Notify
Parameter | Type | Description |
---|---|---|
error |
|
error to report as a blue info notification on top of the screen |
notify.warning(error)
Kind: instance method of Notify
Parameter | Type | Description |
---|---|---|
error |
|
error to report as a yellow warning notification on top of the screen |
notify.error(error)
Kind: instance method of Notify
Parameter | Type | Description |
---|---|---|
error |
|
error to report as a red error notification on top of the screen |
RecordViewer
APIs to access the Record Viewer.
Kind: global class
-
-
.close()
⇒Promise<boolean>
RecordViewer.openRecord(id, dataModelEntity)
⇒ void
Opens the Record Viewer on the record with the specified id. This method translates to
sirenapi.DataRecord.getRecordById(<args>).openRecordViewer()
, and is provided as a convenience.
Kind: static method of RecordViewer
Parameter | Type | Description |
---|---|---|
id |
|
Id of the record to open. |
dataModelEntity |
(Optional) A data model entity to associate to the record. |
RecordViewer.close()
⇒ Promise<boolean>
Closes any open Record Viewer.
Kind: static method of RecordViewer
Returns: Promise<boolean>
- Whether the record was closed. A record could be prevented from closing, for example, if a user edited the
record but didn’t save the changes yet. When prompted about saving changes, the user refused.
Relation
A class that represents a relation connecting two data model entities. Relations can be used to retrieve new records linked to some known record.
Kind: global class
-
-
instance
-
.getId()
⇒Promise<string>
-
.getLabel()
⇒Promise<string>
-
.isDirectionPreferred()
⇒Promise<boolean>
-
.getSourceField()
⇒Promise<(string\|null)>
-
.getTargetField()
⇒Promise<(string\|null)>
-
.getConditions()
⇒Promise<Array<RelationCondition>>
-
-
static
-
.getRelationByEndpoints(sourceDataModelEntity, sourceField, targetDataModelEntity, targetField)
⇒Promise<Relation>
-
.getRelationsByLabel(label)
⇒Promise<Array<Relation>>
-
.getOutgoingRelationsFromDataModelEntities(dataModelEntities)
⇒Promise<Array<Relation>>
-
-
relation.getLabel()
⇒ Promise<string>
Gets the label of the relation.
Kind: instance method of Relation
relation.getInverseRelation()
⇒ Promise<Relation>
Gets the inverse of this relation.
Kind: instance method of Relation
relation.isDirectionPreferred()
⇒ Promise<boolean>
Returns whether this relation has the direction that is preferred between the two entities.
Kind: instance method of Relation
relation.getSourceDataModelEntity()
⇒ Promise<DataModelEntity>
Gets the data model entity used as source endpoint of the relation.
Kind: instance method of Relation
relation.getSourceField()
⇒ Promise<(string\|null)>
Deprecated
Gets the name of the matched field in the source endpoint if the relation has a single condition
Kind: instance method of Relation
relation.getTargetDataModelEntity()
⇒ Promise<DataModelEntity>
Gets the data model entity used as target endpoint of the relation.
Kind: instance method of Relation
relation.getTargetField()
⇒ Promise<(string\|null)>
Deprecated
Gets the name of the matched field in the target endpoint if the relation has a single condition
Kind: instance method of Relation
relation.getConditions()
⇒ Promise<Array<RelationCondition>>
Gets the entire conditions array for the relation.
Kind: instance method of Relation
Relation.getRelationByEndpoints(sourceDataModelEntity, sourceField, targetDataModelEntity, targetField)
⇒ Promise<Relation>
Deprecated
Retrieves a relation given its endpoints. The order in which the endpoints are specified determines the direction of the returned relation. The specified endpoints must match an existing relation with a single condition in the data model, otherwise an exception will be thrown.
Kind: static method of Relation
Parameter | Type | Description |
---|---|---|
sourceDataModelEntity |
The data model entity used as source of relation, |
|
sourceField |
|
The field name of relation’s source ( |
targetDataModelEntity |
The data model entity used as target of relation. |
|
targetField |
|
The field name of relation’s target ( |
Relation.getRelationsByLabel(label)
⇒ Promise<Array<Relation>>
Retrieves all relations with the given label.
Kind: static method of Relation
Parameter | Type | Description |
---|---|---|
label |
|
The label of the relations to retrieve. |
Relation.getOutgoingRelationsFromDataModelEntities(dataModelEntities)
⇒ Promise<Array<Relation>>
Returns all relations that have as source any element in the input list of data model entities.
Kind: static method of Relation
Parameter | Type | Description |
---|---|---|
dataModelEntities |
The list of data model entities that are source of the returned relations. |
Reporting
Provides methods for report generation.
Kind: global class
reporting.render(templateId, data)
⇒ Promise<string>
Renders a report and returns the result as a string.
Kind: instance method of Reporting
Returns: Promise<string>
- the result of the rendering as a string.
Parameter | Type | Description |
---|---|---|
templateId |
|
The identifier of a reporting template. |
data |
|
An object containing the data to be passed to the template. |
reporting.renderToElement(templateId, data)
⇒ Promise<string>
Renders a report and wraps the resulting string as the inner HTML of a JSX element without performing any kind of sanitization.
Kind: instance method of Reporting
Returns: Promise<string>
- a JSX element containing the report as its inner HTML.
Parameter | Type | Description |
---|---|---|
templateId |
|
The identifier of a reporting template. |
data |
|
An object containing the data to be passed to the template. |
reporting.downloadString(content, fileName)
Downloads a string as a file.
Kind: instance method of Reporting
Parameter | Type | Description |
---|---|---|
content |
|
The string which will be included in the downloaded file. |
fileName |
|
The downloaded file’s name, including its file extension. |
reporting.downloadBlob(blob, fileName)
Downloads a blob object as a file.
Kind: instance method of Reporting
Parameter | Type | Description |
---|---|---|
blob |
|
The blob object which will be the contents of the downloaded file. |
fileName |
|
The downloaded file’s name, including its file extension. |
reporting.download(templateId, data, filename)
Renders a report and triggers the download of the resulting file as an attachment.
Kind: instance method of Reporting
Parameter | Type | Description |
---|---|---|
templateId |
|
The identifier of a reporting template. |
data |
|
An object containing the data to be passed to the template. |
filename |
|
The name of the target file. |
Revisions
APIs to facilitate document editing (Target Search must have editing enabled)
Kind: global class
revisions.reviseRow(entityTableId, hit)
⇒ Promise<void>
Replaces a document with the specified one.
Kind: instance method of Revisions
Returns: Promise<void>
- A promise which gets resolved upon completion
Parameter | Type | Description |
---|---|---|
entityTableId |
|
Id of the entity table that contains the document to change. |
hit |
|
The replacement document. |
hit._id |
|
Id of the document to replace. |
hit._index |
|
Index of the document to replace. |
hit._seq_no |
|
Part of the document versioning information. |
hit._primary_term |
|
Part of the document versioning information. |
hit._source |
|
Data of the document. This data will replace the original document’s data. |
hit._siren_revision.notes |
|
A note to store with the document about the edit. |
Search ⇐ BasicEmitter
The class that represents a search.
Kind: global class
Extends: BasicEmitter
Properties
Name | Type | Description |
---|---|---|
id |
id of associated object in investigate |
|
title |
title of associated object in investigate |
|
nodeid |
id of associated node id in Dashboard datamodel |
|
isMain |
|
indicated if the search is a main search in in Dashboard datamodel |
search.getSearchSource()
⇒ SearchSource
Get SearchSource behind this Search
Kind: instance method of Search
search.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of Search
Overrides: on
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
search.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of Search
Overrides: off
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
search.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of Search
Overrides: removeAllListeners
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
search.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of Search
Overrides: emit
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
SearchApp
A class that represents a search app.
Kind: global class
SearchApp.openSearchModal(searchModalOptions)
⇒ Promise<SearchModalResult>
Opens a search modal, a simplified search app user interface. Invoking the method without arguments or an empty recordIds array will initialize a new search session.
Kind: static method of SearchApp
Returns: Promise<SearchModalResult>
- Selected search result hits when confirm button clicked, else undefined
if closed.
Parameter | Type | Description |
---|---|---|
searchModalOptions |
|
(Optional) Options to initiate a search modal session. |
searchModalOptions.recordIds |
(Optional) An array of objects representing the records to open in the modal. |
|
searchModalOptions.modalTitle |
|
(Optional) The modal title. |
searchModalOptions.confirmButtonLabel |
|
(Optional) Label for the confirm button, confirm button does not render when undefined. |
searchModalOptions.showEquivalentResults |
|
(Optional) Show equivalent entity records when entity resolution enabled. |
Example
Awaited return value - { type: 'confirm', globalSearchHits: [{ _id: 1, _index: 'article', _source: {} }] }
SearchSource
Allows scripts to query data model searches. State of the SearchSource can be modified by the property methods (chainable).
Kind: global class
Properties
Name | Type | Description |
---|---|---|
type |
|
Chainable state setter, |
query |
|
Chainable state setter, |
filter |
|
Chainable state setter, |
sort |
|
Chainable state setter, |
highlight |
|
Chainable state setter, |
highlightAll |
|
Chainable state setter, |
aggs |
|
Chainable state setter, |
from |
|
Chainable state setter, |
searchAfter |
|
Chainable state setter, |
size |
|
Chainable state setter, |
source |
|
Chainable state setter, |
version |
|
Chainable state setter, |
seqNoPrimaryTerm |
|
Chainable state setter, |
inject |
|
Chainable state setter, |
-
-
.fetch()
⇒Promise<EsSearchResponse>
-
.getSearchRequest()
⇒Promise<EsSearchRequest>
searchSource.getDataModelEntity()
⇒ Promise<DataModelEntity>
Returns the DataModelEntity associated to this search source.
Kind: instance method of SearchSource
Returns: Promise<DataModelEntity>
- Resolved with the data model entity associated to this search source.
searchSource.fetch()
⇒ Promise<EsSearchResponse>
Fetch response for current search source parameters.
Kind: instance method of SearchSource
Returns: Promise<EsSearchResponse>
- Resolved with an Elasticsearch response for the given SearchSource
searchSource.getSearchRequest()
⇒ Promise<EsSearchRequest>
Translates current search parameters into a search request. The request can be manipulated by users before being used
for a search. The returned object can be used with sirenapi.es.search()
.
Kind: instance method of SearchSource
Returns: Promise<EsSearchRequest>
- Resolved with the Elasticsearch search request for current search source parameters.
Example
const request = await searchSource.getSearchRequest(); const response = await sirenapi.es.search(request);
SirenAPI ⇐ BasicEmitter
The API for interacting with Siren Investigate, which is exposed at window.sirenapi.
Kind: global class
Extends: BasicEmitter
Version: 1.0.0
Properties
Name | Type | Description |
---|---|---|
version |
The version of the API. |
|
Dashboard |
The prototype of the Dashboard class. |
|
Dataspace |
The prototype of the Dataspace class. |
|
Visualization |
The prototype of the Visualization class. |
|
DataRecord |
The prototype of the DataRecord class. |
|
DataModelEntity |
The prototype of the DataModelEntity class. |
|
Relation |
The prototype of the Relation class. |
|
RecordViewer |
The prototype of the RecordViewer class. |
|
Collection |
The prototype of the Collection class. |
|
Highlighting |
The prototype of the Highlighting class. |
|
Search |
The prototype of the Search class. |
|
SearchApp |
The prototype of the SearchApp class. |
|
notify |
The utility class that allows scripts to trigger notifications at the top of the screen. |
|
Charts |
The utility Charts class, provides methods to create ApexCharts |
|
es |
-
-
.invokeWebService(groupName, serviceName, params, [options])
⇒Promise
-
.getTimeFilter(time, searchId)
⇒Promise
-
.resolveIdFromCurrentDataspace(id)
⇒Promise
-
.importScriptById(id)
⇒Promise
-
.importScriptByTitle(title)
⇒Promise
sirenAPI.EVENTS
Return a map of events that can be registered on sirenapi object
Kind: instance property of SirenAPI
Properties
Name | Type | Description |
---|---|---|
APP_STATE_CHANGED |
|
event fired when app state changes, (filter or query was added or removed) |
CUSTOM |
|
reserved for passing custom events, visualization can emit any custom event this way |
Example
Event returned in handler on APP_STATE_CHANGED has no extra parameters. Event returned in handler on CUSTOM has custom parameters, depends on what was passed when it was emitted.
sirenAPI.Revisions
⇒ Revisions
sirenAPI.Reporting
⇒ Reporting
Kind: instance property of SirenAPI
Returns: Reporting
- API to invoke reporting generation methods.
sirenAPI.invokeWebService(groupName, serviceName, params, [options])
⇒ Promise
Calls a Web service.
Kind: instance method of SirenAPI
Returns: Promise
- Resolved with data that is returned by a Web service. Depending on the passed options, it can
return the actual results or the invocation id.
Rejects when a user does not have the permissions to invoke a service.
Parameter | Type | Default | Description |
---|---|---|---|
groupName |
|
The group name of the webservice. |
|
serviceName |
|
The name of the webservice. |
|
params |
|
JSON data that will be sent to a Web service. |
|
[options] |
|
|
Options to indicate how the call should be invoked. |
sirenAPI.getTimeFilter(time, searchId)
⇒ Promise
Utility method to convert a time into a time range filter.
Kind: instance method of SirenAPI
Returns: Promise
- Resolved with time range filter on a time field from a given index pattern.
Parameter | Type | Description |
---|---|---|
time |
|
object with three properties from, to and mode |
searchId |
|
ID of a search |
sirenAPI.resolveIdFromCurrentDataspace(id)
⇒ Promise
Utility method to resolve object ID to current dataspace
Kind: instance method of SirenAPI
Returns: Promise
- Resolved promise with the migrated saved object id
Parameter | Type | Description |
---|---|---|
id |
|
id of the saved object |
sirenAPI.importScriptById(id)
⇒ Promise
Imports the contents of another script. An imported script must declare contents to be exported using one or more
context.export({ <contents> })
calls.
Kind: instance method of SirenAPI
Returns: Promise
- Promise to the exported content of the loaded script
Throws:
-
If the script could not be found.
Parameter | Type | Description |
---|---|---|
id |
|
id of the script to load |
Example
Script with id "myId":
context.export({ myVar: 123 });
Importer script:
async function asyncWrapper() { const { myVar } = await sirenapi.importScriptById('myId'); console.log(myVar); // Prints 123 }
sirenAPI.importScriptByTitle(title)
⇒ Promise
Imports the contents of another script. An imported script must declare contents to be exported using one or more
context.export({ <contents> })
calls.
Kind: instance method of SirenAPI
Returns: Promise
- Promise to the exported content of the loaded script
Throws:
-
If the script could not be found.
-
If multiple scripts with the same title were found.
Parameter | Type | Description |
---|---|---|
title |
|
title of the script to load |
Example
Script with title "My script":
context.export({ myVar: 123 });
Importer script:
async function asyncWrapper() { const { myVar } = await sirenapi.importScriptByTitle('My script'); console.log(myVar); // Prints 123 }
sirenAPI.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of SirenAPI
Overrides: on
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
sirenAPI.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of SirenAPI
Overrides: off
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
sirenAPI.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of SirenAPI
Overrides: removeAllListeners
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
sirenAPI.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of SirenAPI
Overrides: emit
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
Visualization ⇐ BasicEmitter
The class that represents a visualization.
Instances of this class will also expose methods registered by visualizations. These methods vary per visualization type. See Visualization APIs in Siren section.
Kind: global class
Extends: BasicEmitter
Properties
Name | Description |
---|---|
id |
id of associated object in investigate |
panelIndex |
index of the panel containing the visualization on dashboard |
title |
title of associated object in investigate |
type |
type of associated object in investigate |
description |
description of associated object in investigate |
-
-
instance
-
.openModal(modalConfig)
⇒Promise<void>
-
.openFlyout(flyoutConfig)
⇒Promise<void>
-
.getDataModelEntity()
⇒Promise<(DataModelEntity\|undefined)>
-
.getLastRequest()
⇒EsSearchRequest
|undefined
-
.getLastResponse()
⇒EsSearchResponse
|undefined
-
.getScreenshot([options])
⇒Promise<(VisScreenshot\|undefined)>
-
static
-
visualization.waitUntilLoaded(timeout)
Resolves when visualization reported status ready on the dashboard
Kind: instance method of Visualization
Parameter | Type | Default | Description |
---|---|---|---|
timeout |
|
|
default 5000 ms |
visualization.openModal(modalConfig)
⇒ Promise<void>
Renders a modal with react element as its content on the visualization.
Kind: instance method of Visualization
Parameter | Type | Description |
---|---|---|
modalConfig |
|
configuration object of the modal |
modalConfig.Element |
|
React element rendered inside the modal |
modalConfig.primaryBtnText |
|
text displayed on primary button |
modalConfig.onPrimaryClick |
|
callback called when primary button is clicked |
[modalConfig.secondaryBtnText] |
|
text displayed on secondary button |
[modalConfig.onSecondaryClick] |
|
callback called when secondary button is clicked |
[modalConfig.cancelBtnText] |
|
text displayed on secondary button |
[modalConfig.onCancel] |
|
callback called when cancel button is clicked |
[modalConfig.titleText] |
|
title of the modal |
visualization.openFlyout(flyoutConfig)
⇒ Promise<void>
Renders a flyout with react element as its content on the visualization.
Kind: instance method of Visualization
Parameter | Type | Description |
---|---|---|
flyoutConfig |
|
configuration object of the flyout |
flyoutConfig.Element |
|
React element rendered inside the flyout |
[flyoutConfig.titleText] |
|
title of the flyout |
[flyoutConfig.footer] |
|
React element rendered inside the footer of the flyout |
[flyoutConfig.size] |
|
Size of the flyout (default: 'm') |
visualization.getDataModelEntity()
⇒ Promise<(DataModelEntity\|undefined)>
Kind: instance method of Visualization
Returns: Promise<(DataModelEntity\|undefined)>
- Resolved with the data model entity associated to this visualization if one exists.
visualization.getSearchSource()
Returns the search source used by the visualization. The search source can be used to search for related data.
Kind: instance method of Visualization
visualization.getLastRequest()
⇒ EsSearchRequest
| undefined
Returns the last raw request made by this visualization. The request body can be modified to search for related data.
NOTE: Only simple visualizations that retrieve data using a single request will expose this information.
This includes histograms, pie charts and all other visualizations that expose the "Request" and "Response" properties
under the caret-like ^
icon in the lower-left corner of their panel. Other complex visualizations will not expose this
information.
Kind: instance method of Visualization
Returns: EsSearchRequest
| undefined
- The last request made by this visualization, or undefined if no request was made yet.
visualization.getLastResponse()
⇒ EsSearchResponse
| undefined
Returns the last response returned to this visualization.
NOTE: The same remark in getLastRequest applies here.
Kind: instance method of Visualization
Returns: EsSearchResponse
| undefined
- The last response returned to this visualization, or undefined if the response was not received yet
or the request errored out.
visualization.getScreenshot([options])
⇒ Promise<(VisScreenshot\|undefined)>
Makes a screenshot of the visualization as a png image.
Kind: instance method of Visualization
Returns: Promise<(VisScreenshot\|undefined)>
- Resolves to a VisScreenshot object or undefined if the screenshot could not be acquired.
Parameter | Type | Default | Description |
---|---|---|---|
[options] |
|
(Optional) Supports options from html2canvas. |
|
[options.title] |
|
|
(Optional) Whether the screenshot should have the visualization name as title in the upper-left corner of the image. Defaults to |
[options.scale] |
|
|
(Optional) The scale to use for rendering. Defaults to the browser’s device pixel ratio. |
visualization.on(eventName, instanceId, handler)
⇒ BasicEmitter
Add an event handler
Kind: instance method of Visualization
Overrides: on
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Default | Description |
---|---|---|---|
eventName |
|
Name of the event |
|
instanceId |
|
|
ID of the instance ( |
handler |
|
Handler for the event |
visualization.off(name, [handler], instanceId)
⇒ BasicEmitter
Remove an event handler.
Kind: instance method of Visualization
Overrides: off
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
name |
|
|
[handler] |
|
An optional handler to remove. If no handler is passed, then all are removed. |
instanceId |
|
ID of the instance ( |
visualization.removeAllListeners(instanceId)
⇒ BasicEmitter
If instanceId is specified, remove all event handlers bound to given instanceId Otherwise remove all the listeners.
Kind: instance method of Visualization
Overrides: removeAllListeners
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
instanceId |
|
ID of the instance ( |
visualization.emit(eventName, instanceId)
⇒ BasicEmitter
Emit an event and all arguments to all listeners for an event name.
Kind: instance method of Visualization
Overrides: emit
Returns: BasicEmitter
- this
, for chaining
Parameter | Type | Description |
---|---|---|
eventName |
|
|
instanceId |
|
ID of the instance ( |
[arg…] |
|
Any number of arguments that will be applied to each handler |
Visualization.get(id, panelIndex, type, title, description)
⇒ Visualization
For given id-panelIndex combination finds a registered visualization instance and returns it. If not found, creates a new instance and returns it.
Kind: static method of Visualization
Returns: Visualization
- A visualization instance
Parameter | Description |
---|---|
id |
id of associated object in investigate |
panelIndex |
index of the panel containing the visualization on dashboard |
type |
type of associated object in investigate |
title |
title of associated object in investigate |
description |
description of associated object in investigate |
Visualization.getCurrentVisualizer()
⇒ Visualization
Find the visualization instance currently used as the visualizer and return it.
Kind: static method of Visualization
Returns: Visualization
- A visualization instance
QueryOptions
: Object
Options applied when querying a data model entity for records.
Kind: global typedef
Properties
Name | Type | Description |
---|---|---|
query |
|
(Optional) Elasticsearch query applied for records retrieval. |
size |
|
(Optional) The maximum number of records retrieved. Default: 10 |
from |
|
(Optional) Index of the record to start retrieval from. The value can’t exceed 10,000. Default: 0 |
orderBy |
(Optional) Order in which the linked records will be returned. Records discarded due to the limit property will be the ones at the end of the ordered list. |
|
setDataModelEntities |
|
(Optional) Specifies the data model entities associated with the retrieved records. |
highlight |
|
(Optional) Highlighting to apply in the query. |
cancelPromise |
|
(Optional) Fulfilling this promise cancels the query and stops script execution. |
RichDocs
: RichDocsConfig
| RichDocsConfigBySearch
RichDocsConfig
: Object
Configuration for enriching documents. Will be applied documents originating from all searches.
Kind: global typedef
Properties
Name | Type | Description |
---|---|---|
[fields] |
|
Fields to include in the document. |
[_source] |
|
Source configuration for the document. |
[_source.includes] |
|
Fields to include in the source. |
[_source.excludes] |
|
Fields to exclude from the source. |
[size] |
|
Maximum number of documents enrich. |
VisScreenshot
: Object
A screenshot obtained from a dashboard visualization.
Kind: global typedef
Properties
Name | Type | Description |
---|---|---|
title |
|
The title of the screenshot. |
imgSrc |
|
The screenshot image data, in data URL format. |
width |
|
The screenshot’s width. |
height |
|
The screenshot’s height. |