-- ----------------------------------------------------- -- Table `active_monitoring_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `active_monitoring_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, -- e.g., historical [0], acknowledged [1], engaged (TBD) `resolved_ip` TEXT NULL, `resolved_name` TEXT NULL, `interface_id` INTEGER NULL, `measurement` TEXT NULL, `measure_threshold` INTEGER NULL DEFAULT 0, `measure_value` REAL NULL DEFAULT 0, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, -- A label that can be set by the user `user_label_tstamp` DATETIME NULL DEFAULT 0 -- Timestamp of the last user_label change ); CREATE INDEX IF NOT EXISTS `am_alerts_i_id` ON `active_monitoring_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `am_alerts_i_alert_status` ON `active_monitoring_alerts`(alert_status); CREATE INDEX IF NOT EXISTS `am_alerts_i_severity` ON `active_monitoring_alerts`(severity); CREATE INDEX IF NOT EXISTS `am_alerts_i_tstamp` ON `active_monitoring_alerts`(tstamp); -- ----------------------------------------------------- -- Table `flow_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `flow_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `json` TEXT NULL, `ip_version` INTEGER NOT NULL DEFAULT 0 CHECK(`ip_version` = 4 OR `ip_version` = 6), `cli_ip` TEXT NOT NULL, `srv_ip` TEXT NOT NULL, `cli_port` INTEGER NOT NULL DEFAULT 0 CHECK(`cli_port` BETWEEN 0 AND 65535), `srv_port` INTEGER NOT NULL DEFAULT 0 CHECK(`srv_port` BETWEEN 0 AND 65535), `vlan_id` INTEGER NOT NULL DEFAULT 0 CHECK(`vlan_id` >= 0), `is_cli_attacker` INTEGER NOT NULL DEFAULT 0 CHECK(`is_cli_attacker` IN (0,1)), `is_cli_victim` INTEGER NOT NULL DEFAULT 0 CHECK(`is_cli_victim` IN (0,1)), `is_srv_attacker` INTEGER NOT NULL DEFAULT 0 CHECK(`is_srv_attacker` IN (0,1)), `is_srv_victim` INTEGER NOT NULL DEFAULT 0 CHECK(`is_srv_victim` IN (0,1)), `proto` INTEGER NOT NULL DEFAULT 0 CHECK(`proto` >= 0), `l7_proto` INTEGER NOT NULL DEFAULT 0 CHECK(`l7_proto` >= 0), `l7_master_proto` INTEGER NOT NULL DEFAULT 0 CHECK(`l7_master_proto` >= 0), `l7_cat` INTEGER NOT NULL DEFAULT 0 CHECK(`l7_cat` >= 0), `cli_name` TEXT NULL, `srv_name` TEXT NULL, `cli_country` TEXT NULL, `srv_country` TEXT NULL, `cli_blacklisted` INTEGER NOT NULL DEFAULT 0 CHECK(`cli_blacklisted` IN (0,1)), `srv_blacklisted` INTEGER NOT NULL DEFAULT 0 CHECK(`srv_blacklisted` IN (0,1)), `cli2srv_bytes` INTEGER NOT NULL DEFAULT 0 CHECK(`cli2srv_bytes` >= 0), `srv2cli_bytes` INTEGER NOT NULL DEFAULT 0 CHECK(`srv2cli_bytes` >= 0), `cli2srv_pkts` INTEGER NOT NULL DEFAULT 0 CHECK(`cli2srv_pkts` >= 0), `srv2cli_pkts` INTEGER NOT NULL DEFAULT 0 CHECK(`srv2cli_pkts` >= 0), `first_seen` DATETIME NOT NULL DEFAULT 0, `community_id` TEXT NULL, `alerts_map` BLOB DEFAULT 0, -- An HEX bitmap of all flow statuses `flow_risk_bitmap` INTEGER NOT NULL DEFAULT 0, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `flow_alerts_i_id` ON `flow_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `flow_alerts_i_alert_status` ON `flow_alerts`(alert_status); CREATE INDEX IF NOT EXISTS `flow_alerts_i_severity` ON `flow_alerts`(severity); CREATE INDEX IF NOT EXISTS `flow_alerts_i_tstamp` ON `flow_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `flow_alerts_i_cli_ip` ON `flow_alerts`(`vlan_id`,`cli_ip`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_srv_ip` ON `flow_alerts`(`vlan_id`,`srv_ip`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_cli_port` ON `flow_alerts`(`cli_port`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_srv_port` ON `flow_alerts`(`srv_port`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_l7_proto` ON `flow_alerts`(`l7_proto`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_l7_master_proto` ON `flow_alerts`(`l7_master_proto`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_l7_cat` ON `flow_alerts`(`l7_cat`); CREATE INDEX IF NOT EXISTS `flow_alerts_i_flow_risk_bitmap` ON `flow_alerts`(`flow_risk_bitmap`); -- ----------------------------------------------------- -- Table `host_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `host_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `ip_version` INTEGER NOT NULL DEFAULT 0 CHECK(`ip_version` = 4 OR `ip_version` = 6), `ip` TEXT NOT NULL, `vlan_id` INTEGER NULL DEFAULT 0 CHECK(`vlan_id` >= 0), `name` TEXT NULL, `is_attacker` INTEGER NULL CHECK(`is_attacker` IN (0,1)), `is_victim` INTEGER NULL CHECK(`is_victim` IN (0,1)), `is_client` INTEGER NULL CHECK(`is_client` IN (0,1)), `is_server` INTEGER NULL CHECK(`is_server` IN (0,1)), `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `host_alerts_i_id` ON `host_alerts`(`alert_id`); CREATE INDEX IF NOT EXISTS `host_alerts_i_alert_status` ON `host_alerts`(`alert_status`); CREATE INDEX IF NOT EXISTS `host_alerts_i_severity` ON `host_alerts`(`severity`); CREATE INDEX IF NOT EXISTS `host_alerts_i_tstamp` ON `host_alerts`(`tstamp`); CREATE INDEX IF NOT EXISTS `host_alerts_i_ip` ON `host_alerts`(`vlan_id`,`ip`); CREATE INDEX IF NOT EXISTS `host_alerts_i_is_attacker` ON `host_alerts`(`is_attacker`); CREATE INDEX IF NOT EXISTS `host_alerts_i_is_victim` ON `host_alerts`(`is_victim`); CREATE INDEX IF NOT EXISTS `host_alerts_i_is_client` ON `host_alerts`(`is_client`); CREATE INDEX IF NOT EXISTS `host_alerts_i_is_victim` ON `host_alerts`(`is_victim`); CREATE INDEX IF NOT EXISTS `host_alerts_i_is_server` ON `host_alerts`(`is_server`); -- ----------------------------------------------------- -- Table `mac_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `mac_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `address` TEXT NULL DEFAULT 0, `device_type` INTEGER NULL CHECK(`device_type` >= 0), `name` TEXT NULL, `is_attacker` INTEGER NULL CHECK(`is_attacker` IN (0,1)), `is_victim` INTEGER NULL CHECK(`is_victim` IN (0,1)), `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `mac_alerts_i_id` ON `mac_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `mac_alerts_i_alert_status` ON `mac_alerts`(alert_status); CREATE INDEX IF NOT EXISTS `mac_alerts_i_severity` ON `mac_alerts`(severity); CREATE INDEX IF NOT EXISTS `mac_alerts_i_tstamp` ON `mac_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `mac_alerts_i_address` ON `mac_alerts`(`address`); CREATE INDEX IF NOT EXISTS `mac_alerts_i_is_attacker` ON `mac_alerts`(`is_attacker`); CREATE INDEX IF NOT EXISTS `mac_alerts_i_is_victim` ON `mac_alerts`(`is_victim`); -- ----------------------------------------------------- -- Table `snmp_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `snmp_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `ip` TEXT NOT NULL, `port` INTEGER NULL, `name` TEXT NULL, `port_name` TEXT NULL, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `snmp_alerts_i_id` ON `snmp_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `snmp_alerts_i_alert_status` ON `snmp_alerts`(alert_status); CREATE INDEX IF NOT EXISTS `snmp_alerts_i_severity` ON `snmp_alerts`(severity); CREATE INDEX IF NOT EXISTS `snmp_alerts_i_tstamp` ON `snmp_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `snmp_alerts_i_ip` ON `snmp_alerts`(`ip`); -- ----------------------------------------------------- -- Table `network_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `network_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `local_network_id` INTEGER NOT NULL CHECK(`local_network_id` >= 0), `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `name` TEXT NULL, `alias` TEXT NULL, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `network_alerts_i_id` ON `network_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `network_alerts_i_severity` ON `network_alerts`(severity); CREATE INDEX IF NOT EXISTS `network_alerts_i_tstamp` ON `network_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `network_alerts_i_alert_status` ON `network_alerts`(alert_status); -- ----------------------------------------------------- -- Table `interface_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `interface_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `ifid` INTEGER NOT NULL CHECK(`ifid` >= -1), `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `subtype` TEXT NULL, `name` TEXT NULL, `alias` TEXT NULL, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `interface_alerts_i_id` ON `interface_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `interface_alerts_i_severity` ON `interface_alerts`(severity); CREATE INDEX IF NOT EXISTS `interface_alerts_i_tstamp` ON `interface_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `interface_alerts_i_alert_status` ON `interface_alerts`(alert_status); -- ----------------------------------------------------- -- Table `user_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `user_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `user` TEXT NULL, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `user_alerts_i_id` ON `user_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `user_alerts_i_severity` ON `user_alerts`(severity); CREATE INDEX IF NOT EXISTS `user_alerts_i_tstamp` ON `user_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `user_alerts_i_alert_status` ON `user_alerts`(alert_status); -- ----------------------------------------------------- -- Table `system_alerts` -- ----------------------------------------------------- CREATE TABLE IF NOT EXISTS `system_alerts` ( `rowid` INTEGER PRIMARY KEY AUTOINCREMENT, `alert_id` INTEGER NOT NULL CHECK(`alert_id` >= 0), `alert_status` INTEGER NOT NULL CHECK(`alert_status` >= 0) DEFAULT 0, `interface_id` INTEGER NULL, `name` TEXT NULL, `tstamp` DATETIME NOT NULL, `tstamp_end` DATETIME NULL DEFAULT 0, `severity` INTEGER NOT NULL CHECK(`severity` >= 0), `score` INTEGER NOT NULL DEFAULT 0 CHECK(`score` >= 0), `granularity` INTEGER NOT NULL DEFAULT 0 CHECK(`granularity` >= 0), `counter` INTEGER NOT NULL DEFAULT 0 CHECK(`counter` >= 0), `description` TEXT NULL, `json` TEXT NULL, `user_label` TEXT NULL, `user_label_tstamp` DATETIME NULL DEFAULT 0 ); CREATE INDEX IF NOT EXISTS `system_alerts_i_id` ON `system_alerts`(alert_id); CREATE INDEX IF NOT EXISTS `system_alerts_i_severity` ON `system_alerts`(severity); CREATE INDEX IF NOT EXISTS `system_alerts_i_tstamp` ON `system_alerts`(tstamp); CREATE INDEX IF NOT EXISTS `system_alerts_i_alert_status` ON `system_alerts`(alert_status); /* NOTE: add new ALTER TABLE statements before any pre existing ALTER TABLE statement, * this because SQLite does not support IF NOT EXISTS on ALTER TABLE, thus they will fail * on the second execution, preventing any subsequent statement to be executed. */ ALTER TABLE `flow_alerts` ADD `output_snmp` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `input_snmp` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `probe_ip` TEXT NULL; ALTER TABLE `flow_alerts` ADD `cli_location` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `srv_location` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `info` TEXT NULL; ALTER TABLE `flow_alerts` ADD `cli_host_pool_id` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `srv_host_pool_id` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `cli_network` INTEGER NULL; ALTER TABLE `flow_alerts` ADD `srv_network` INTEGER NULL; ALTER TABLE `host_alerts` ADD `host_pool_id` INTEGER NULL; ALTER TABLE `host_alerts` ADD `network` INTEGER NULL; ALTER TABLE `host_alerts` ADD `country` TEXT NULL; -- New field not present in the original table added for compatibility reasons but not used by SQLite -- IMPORTANT: leave them at the end and remove in future versions and update SQLiteAlertStore::openStore() ALTER TABLE `flow_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `host_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `mac_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `snmp_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `network_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `interface_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `user_alerts` ADD `interface_id` INTEGER NULL; ALTER TABLE `system_alerts` ADD `interface_id` INTEGER NULL;