summaryrefslogtreecommitdiffstats
path: root/schema/mysql/upgrades
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 12:36:04 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 12:36:04 +0000
commitb09c6d56832eb1718c07d74abf3bc6ae3fe4e030 (patch)
treed2caec2610d4ea887803ec9e9c3cd77136c448ba /schema/mysql/upgrades
parentInitial commit. (diff)
downloadicingadb-b09c6d56832eb1718c07d74abf3bc6ae3fe4e030.tar.xz
icingadb-b09c6d56832eb1718c07d74abf3bc6ae3fe4e030.zip
Adding upstream version 1.1.0.upstream/1.1.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'schema/mysql/upgrades')
-rw-r--r--schema/mysql/upgrades/1.0.0-rc2.sql468
-rw-r--r--schema/mysql/upgrades/1.0.0.sql291
2 files changed, 759 insertions, 0 deletions
diff --git a/schema/mysql/upgrades/1.0.0-rc2.sql b/schema/mysql/upgrades/1.0.0-rc2.sql
new file mode 100644
index 0000000..50fb2f9
--- /dev/null
+++ b/schema/mysql/upgrades/1.0.0-rc2.sql
@@ -0,0 +1,468 @@
+ALTER TABLE host_state DROP PRIMARY KEY;
+ALTER TABLE host_state ADD COLUMN id binary(20) NOT NULL COMMENT 'host.id' FIRST;
+UPDATE host_state SET id = host_id;
+ALTER TABLE host_state ADD PRIMARY KEY (id);
+ALTER TABLE host_state ADD COLUMN properties_checksum binary(20) AFTER environment_id;
+UPDATE host_state SET properties_checksum = 0;
+ALTER TABLE host_state MODIFY COLUMN properties_checksum binary(20) COMMENT 'sha1(all properties)' NOT NULL;
+ALTER TABLE host_state ADD UNIQUE INDEX idx_host_state_host_id (host_id);
+
+ALTER TABLE service_state DROP PRIMARY KEY;
+ALTER TABLE service_state ADD COLUMN id binary(20) NOT NULL COMMENT 'service.id' FIRST;
+UPDATE service_state SET id = service_id;
+ALTER TABLE service_state ADD PRIMARY KEY (id);
+ALTER TABLE service_state ADD COLUMN properties_checksum binary(20) AFTER environment_id;
+UPDATE service_state SET properties_checksum = 0;
+ALTER TABLE service_state MODIFY COLUMN properties_checksum binary(20) COMMENT 'sha1(all properties)' NOT NULL;
+ALTER TABLE service_state ADD UNIQUE INDEX idx_service_state_service_id (service_id);
+
+ALTER TABLE downtime
+ ADD COLUMN parent_id binary(20) COMMENT 'For service downtimes, the ID of the host downtime that created this downtime by using the "all_services" flag of the schedule-downtime API.' AFTER triggered_by_id,
+ MODIFY COLUMN triggered_by_id binary(20) COMMENT 'The ID of the downtime that triggered this downtime. This is set when creating downtimes on a host or service higher up in the dependency chain using the "child_option" "DowntimeTriggeredChildren" and can also be set manually via the API.';
+ALTER TABLE downtime_history
+ ADD COLUMN parent_id binary(20) COMMENT 'For service downtimes, the ID of the host downtime that created this downtime by using the "all_services" flag of the schedule-downtime API.' AFTER triggered_by_id,
+ MODIFY COLUMN triggered_by_id binary(20) COMMENT 'The ID of the downtime that triggered this downtime. This is set when creating downtimes on a host or service higher up in the dependency chain using the "child_option" "DowntimeTriggeredChildren" and can also be set manually via the API.';
+
+ALTER TABLE checkcommand_argument MODIFY COLUMN argument_order smallint DEFAULT NULL;
+ALTER TABLE eventcommand_argument MODIFY COLUMN argument_order smallint DEFAULT NULL;
+ALTER TABLE notificationcommand_argument MODIFY COLUMN argument_order smallint DEFAULT NULL;
+
+ALTER TABLE acknowledgement_history MODIFY COLUMN id binary(20) NOT NULL COMMENT 'sha1(environment.name + "Host"|"Service" + host|service.name + set_time)';
+ALTER TABLE flapping_history MODIFY COLUMN id binary(20) NOT NULL COMMENT 'sha1(environment.name + "Host"|"Service" + host|service.name + start_time)';
+
+ALTER TABLE host ADD INDEX idx_host_name_ci (name_ci) COMMENT 'Host list filtered using quick search';
+ALTER TABLE service ADD INDEX idx_service_name_ci (name_ci) COMMENT 'Service list filtered using quick search';
+
+ALTER TABLE user ADD INDEX idx_user_name_ci (name_ci) COMMENT 'User list filtered using quick search';
+ALTER TABLE user ADD INDEX idx_user_name (name) COMMENT 'User list filtered/ordered by name; User detail filter';
+
+ALTER TABLE usergroup ADD INDEX `idx_usergroup_display_name` (`display_name`) COMMENT 'Usergroup list filtered/ordered by display_name';
+ALTER TABLE usergroup ADD INDEX idx_usergroup_name_ci (name_ci) COMMENT 'Usergroup list filtered using quick search';
+ALTER TABLE usergroup ADD INDEX idx_usergroup_name (name) COMMENT 'Usergroup list filtered/ordered by name; Usergroup detail filter';
+
+ALTER TABLE hostgroup_customvar
+ ADD INDEX idx_hostgroup_customvar_hostgroup_id (hostgroup_id, customvar_id),
+ ADD INDEX idx_hostgroup_customvar_customvar_id (customvar_id, hostgroup_id);
+ALTER TABLE servicegroup_customvar
+ ADD INDEX idx_servicegroup_customvar_servicegroup_id (servicegroup_id, customvar_id),
+ ADD INDEX idx_servicegroup_customvar_customvar_id (customvar_id, servicegroup_id);
+ALTER TABLE checkcommand_customvar
+ ADD INDEX idx_checkcommand_customvar_command_id (command_id, customvar_id),
+ ADD INDEX idx_checkcommand_customvar_customvar_id (customvar_id, command_id);
+ALTER TABLE eventcommand_customvar
+ ADD INDEX idx_eventcommand_customvar_command_id (command_id, customvar_id),
+ ADD INDEX idx_eventcommand_customvar_customvar_id (customvar_id, command_id);
+ALTER TABLE notificationcommand_customvar
+ ADD INDEX idx_notificationcommand_customvar_command_id (command_id, customvar_id),
+ ADD INDEX idx_notificationcommand_customvar_customvar_id (customvar_id, command_id);
+ALTER TABLE notification_customvar
+ ADD INDEX idx_notification_customvar_notification_id (notification_id, customvar_id),
+ ADD INDEX idx_notification_customvar_customvar_id (customvar_id, notification_id);
+ALTER TABLE timeperiod_customvar
+ ADD INDEX idx_timeperiod_customvar_timeperiod_id (timeperiod_id, customvar_id),
+ ADD INDEX idx_timeperiod_customvar_customvar_id (customvar_id, timeperiod_id);
+ALTER TABLE user_customvar
+ ADD INDEX idx_user_customvar_user_id (user_id, customvar_id),
+ ADD INDEX idx_user_customvar_customvar_id (customvar_id, user_id);
+ALTER TABLE usergroup_customvar
+ ADD INDEX idx_usergroup_customvar_usergroup_id (usergroup_id, customvar_id),
+ ADD INDEX idx_usergroup_customvar_customvar_id (customvar_id, usergroup_id);
+
+ALTER TABLE host
+ MODIFY active_checks_enabled enum('n','y') NOT NULL,
+ MODIFY passive_checks_enabled enum('n','y') NOT NULL,
+ MODIFY event_handler_enabled enum('n','y') NOT NULL,
+ MODIFY notifications_enabled enum('n','y') NOT NULL,
+ MODIFY flapping_enabled enum('n','y') NOT NULL,
+ MODIFY perfdata_enabled enum('n','y') NOT NULL,
+ MODIFY is_volatile enum('n','y') NOT NULL;
+ALTER TABLE host_state
+ ADD COLUMN normalized_performance_data longtext DEFAULT NULL AFTER performance_data,
+ ADD COLUMN last_comment_id binary(20) DEFAULT NULL COMMENT 'comment.id' AFTER acknowledgement_comment_id,
+ ADD COLUMN scheduling_source text DEFAULT NULL AFTER check_source,
+ MODIFY is_problem enum('n','y') NOT NULL,
+ MODIFY is_handled enum('n','y') NOT NULL,
+ MODIFY is_reachable enum('n','y') NOT NULL,
+ MODIFY is_flapping enum('n','y') NOT NULL,
+ MODIFY is_overdue enum('n','y') NOT NULL,
+ MODIFY is_acknowledged enum('n','y','sticky') NOT NULL,
+ MODIFY in_downtime enum('n','y') NOT NULL;
+ALTER TABLE service
+ MODIFY active_checks_enabled enum('n','y') NOT NULL,
+ MODIFY passive_checks_enabled enum('n','y') NOT NULL,
+ MODIFY event_handler_enabled enum('n','y') NOT NULL,
+ MODIFY notifications_enabled enum('n','y') NOT NULL,
+ MODIFY flapping_enabled enum('n','y') NOT NULL,
+ MODIFY perfdata_enabled enum('n','y') NOT NULL,
+ MODIFY is_volatile enum('n','y') NOT NULL;
+ALTER TABLE service_state
+ ADD COLUMN normalized_performance_data longtext DEFAULT NULL AFTER performance_data,
+ ADD COLUMN last_comment_id binary(20) DEFAULT NULL COMMENT 'comment.id' AFTER acknowledgement_comment_id,
+ ADD COLUMN scheduling_source text DEFAULT NULL AFTER check_source,
+ MODIFY is_problem enum('n','y') NOT NULL,
+ MODIFY is_handled enum('n','y') NOT NULL,
+ MODIFY is_reachable enum('n','y') NOT NULL,
+ MODIFY is_flapping enum('n','y') NOT NULL,
+ MODIFY is_overdue enum('n','y') NOT NULL,
+ MODIFY is_acknowledged enum('n','y','sticky') NOT NULL,
+ MODIFY in_downtime enum('n','y') NOT NULL;
+ALTER TABLE icingadb_instance
+ MODIFY responsible enum('n','y') NOT NULL,
+ MODIFY icinga2_notifications_enabled enum('n','y') NOT NULL,
+ MODIFY icinga2_active_service_checks_enabled enum('n','y') NOT NULL,
+ MODIFY icinga2_active_host_checks_enabled enum('n','y') NOT NULL,
+ MODIFY icinga2_event_handlers_enabled enum('n','y') NOT NULL,
+ MODIFY icinga2_flap_detection_enabled enum('n','y') NOT NULL,
+ MODIFY icinga2_performance_data_enabled enum('n','y') NOT NULL;
+ALTER TABLE checkcommand_argument
+ MODIFY repeat_key enum('n','y') NOT NULL,
+ MODIFY required enum('n','y') NOT NULL,
+ MODIFY skip_key enum('n','y') NOT NULL;
+ALTER TABLE eventcommand_argument
+ MODIFY repeat_key enum('n','y') NOT NULL,
+ MODIFY required enum('n','y') NOT NULL,
+ MODIFY skip_key enum('n','y') NOT NULL;
+ALTER TABLE notificationcommand_argument
+ MODIFY repeat_key enum('n','y') NOT NULL,
+ MODIFY required enum('n','y') NOT NULL,
+ MODIFY skip_key enum('n','y') NOT NULL;
+ALTER TABLE comment
+ MODIFY name varchar(548) NOT NULL COMMENT '255+1+255+1+36, i.e. "host.name!service.name!UUID"',
+ MODIFY is_persistent enum('n','y') NOT NULL,
+ MODIFY is_sticky enum('n','y') NOT NULL;
+ALTER TABLE downtime
+ ADD COLUMN scheduled_by varchar(767) DEFAULT NULL COMMENT 'Name of the ScheduledDowntime which created this Downtime. 255+1+255+1+255, i.e. "host.name!service.name!scheduled-downtime-name"' AFTER end_time,
+ MODIFY name varchar(548) NOT NULL COMMENT '255+1+255+1+36, i.e. "host.name!service.name!UUID"',
+ MODIFY is_flexible enum('n','y') NOT NULL,
+ MODIFY is_in_effect enum('n','y') NOT NULL;
+ALTER TABLE timeperiod
+ MODIFY prefer_includes enum('n','y') NOT NULL;
+ALTER TABLE user
+ MODIFY notifications_enabled enum('n','y') NOT NULL;
+ALTER TABLE zone
+ MODIFY is_global enum('n','y') NOT NULL;
+ALTER TABLE downtime_history
+ ADD COLUMN scheduled_by varchar(767) DEFAULT NULL COMMENT 'Name of the ScheduledDowntime which created this Downtime. 255+1+255+1+255, i.e. "host.name!service.name!scheduled-downtime-name"' AFTER end_time,
+ MODIFY is_flexible enum('n','y') NOT NULL,
+ MODIFY has_been_cancelled enum('n','y') NOT NULL;
+ALTER TABLE comment_history
+ MODIFY is_persistent enum('n','y') NOT NULL,
+ MODIFY is_sticky enum('n','y') NOT NULL,
+ MODIFY has_been_removed enum('n','y') NOT NULL;
+ALTER TABLE acknowledgement_history
+ MODIFY author varchar(255) DEFAULT NULL COLLATE utf8mb4_unicode_ci COMMENT 'NULL if ack_set event happened before Icinga DB history recording',
+ MODIFY comment text DEFAULT NULL COMMENT 'NULL if ack_set event happened before Icinga DB history recording',
+ MODIFY is_sticky enum('n','y') DEFAULT NULL COMMENT 'NULL if ack_set event happened before Icinga DB history recording',
+ MODIFY is_persistent enum('n','y') DEFAULT NULL COMMENT 'NULL if ack_set event happened before Icinga DB history recording';
+
+INSERT INTO icingadb_schema (version, timestamp)
+ VALUES (2, CURRENT_TIMESTAMP() * 1000);
+
+ALTER TABLE host_state
+ MODIFY output longtext DEFAULT NULL,
+ MODIFY long_output longtext DEFAULT NULL,
+ MODIFY performance_data longtext DEFAULT NULL;
+
+ALTER TABLE state_history
+ ADD COLUMN scheduling_source text DEFAULT NULL AFTER check_source,
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.name + host|service.name + event_time)',
+ MODIFY output longtext DEFAULT NULL,
+ MODIFY long_output longtext DEFAULT NULL;
+
+ALTER TABLE service_state
+ MODIFY output longtext DEFAULT NULL,
+ MODIFY long_output longtext DEFAULT NULL,
+ MODIFY performance_data longtext DEFAULT NULL;
+
+ALTER TABLE notification_history
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.name + notification.name + type + send_time)';
+
+ALTER TABLE user_notification_history
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(notification_history_id + user_id)',
+ MODIFY notification_history_id binary(20) NOT NULL COMMENT 'UUID notification_history.id';
+
+ALTER TABLE history
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.name + event_type + x...) given that sha1(environment.name + x...) = *_history_id',
+ MODIFY notification_history_id binary(20) DEFAULT NULL COMMENT 'notification_history.id',
+ MODIFY state_history_id binary(20) DEFAULT NULL COMMENT 'state_history.id',
+ ADD CONSTRAINT fk_history_acknowledgement_history FOREIGN KEY (acknowledgement_history_id) REFERENCES acknowledgement_history (id) ON DELETE CASCADE,
+ ADD CONSTRAINT fk_history_comment_history FOREIGN KEY (comment_history_id) REFERENCES comment_history (comment_id) ON DELETE CASCADE,
+ ADD CONSTRAINT fk_history_downtime_history FOREIGN KEY (downtime_history_id) REFERENCES downtime_history (downtime_id) ON DELETE CASCADE,
+ ADD CONSTRAINT fk_history_flapping_history FOREIGN KEY (flapping_history_id) REFERENCES flapping_history (id) ON DELETE CASCADE,
+ ADD CONSTRAINT fk_history_notification_history FOREIGN KEY (notification_history_id) REFERENCES notification_history (id) ON DELETE CASCADE,
+ ADD CONSTRAINT fk_history_state_history FOREIGN KEY (state_history_id) REFERENCES state_history (id) ON DELETE CASCADE;
+
+ALTER TABLE user_notification_history
+ ADD CONSTRAINT fk_user_notification_history_notification_history FOREIGN KEY (notification_history_id) REFERENCES notification_history (id) ON DELETE CASCADE;
+
+ALTER TABLE host
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE hostgroup
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE hostgroup_member
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + host_id + hostgroup_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE host_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + host_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE hostgroup_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + hostgroup_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE host_state
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE service
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE servicegroup
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE servicegroup_member
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + servicegroup_id + service_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE service_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + service_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE servicegroup_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + servicegroup_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE service_state
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE endpoint
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE environment
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(Icinga CA public key)';
+ALTER TABLE checkcommand
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + type + name)';
+ALTER TABLE checkcommand_argument
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + argument_key)';
+ALTER TABLE checkcommand_envvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + envvar_key)';
+ALTER TABLE checkcommand_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE eventcommand
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + type + name)';
+ALTER TABLE eventcommand_argument
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + argument_key)';
+ALTER TABLE eventcommand_envvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + envvar_key)';
+ALTER TABLE eventcommand_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE notificationcommand
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + type + name)';
+ALTER TABLE notificationcommand_argument
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + argument_key)';
+ALTER TABLE notificationcommand_envvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + envvar_key)';
+ALTER TABLE notificationcommand_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + command_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE comment
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)';
+ALTER TABLE downtime
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)';
+ALTER TABLE notification
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE notification_user
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notification_id + user_id)';
+ALTER TABLE notification_usergroup
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notification_id + usergroup_id)';
+ALTER TABLE notification_recipient
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notification_id + (user_id | usergroup_id))';
+ALTER TABLE notification_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notification_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE icon_image
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE action_url
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE notes_url
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE timeperiod
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)';
+ALTER TABLE timeperiod_range
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + range_id + timeperiod_id)';
+ALTER TABLE timeperiod_override_include
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + include_id + timeperiod_id)';
+ALTER TABLE timeperiod_override_exclude
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + exclude_id + timeperiod_id)';
+ALTER TABLE timeperiod_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + timeperiod_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name + value)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE customvar_flat
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + flatname + flatvalue)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE user
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE usergroup
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE usergroup_member
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + usergroup_id + user_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE user_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + user_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE usergroup_customvar
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + usergroup_id + customvar_id)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE zone
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + name)',
+ MODIFY environment_id binary(20) NOT NULL COMMENT 'environment.id';
+ALTER TABLE flapping_history
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + "Host"|"Service" + host|service.name + start_time)';
+ALTER TABLE acknowledgement_history
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + "Host"|"Service" + host|service.name + set_time)';
+
+/*
+ * Schema changes after https://github.com/Icinga/icingadb/pull/403:
+ */
+
+ALTER TABLE checkcommand_customvar
+ DROP INDEX idx_checkcommand_customvar_command_id,
+ DROP INDEX idx_checkcommand_customvar_customvar_id;
+
+ALTER TABLE eventcommand_customvar
+ DROP INDEX idx_eventcommand_customvar_command_id,
+ DROP INDEX idx_eventcommand_customvar_customvar_id;
+
+ALTER TABLE notificationcommand_customvar
+ DROP INDEX idx_notificationcommand_customvar_command_id,
+ DROP INDEX idx_notificationcommand_customvar_customvar_id;
+
+ALTER TABLE notification
+ RENAME COLUMN command_id TO notificationcommand_id;
+ALTER TABLE notification
+ MODIFY notificationcommand_id binary(20) NOT NULL COMMENT 'notificationcommand.id';
+
+ALTER TABLE checkcommand_argument
+ RENAME COLUMN command_id TO checkcommand_id;
+ALTER TABLE checkcommand_argument
+ MODIFY checkcommand_id binary(20) NOT NULL COMMENT 'checkcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + checkcommand_id + argument_key)';
+
+ALTER TABLE checkcommand_envvar
+ RENAME COLUMN command_id TO checkcommand_id;
+ALTER TABLE checkcommand_envvar
+ MODIFY checkcommand_id binary(20) NOT NULL COMMENT 'checkcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + checkcommand_id + envvar_key)';
+
+ALTER TABLE checkcommand_customvar
+ RENAME COLUMN command_id TO checkcommand_id;
+ALTER TABLE checkcommand_customvar
+ MODIFY checkcommand_id binary(20) NOT NULL COMMENT 'checkcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + checkcommand_id + customvar_id)';
+
+ALTER TABLE eventcommand_argument
+ RENAME COLUMN command_id TO eventcommand_id;
+ALTER TABLE eventcommand_argument
+ MODIFY eventcommand_id binary(20) NOT NULL COMMENT 'eventcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + eventcommand_id + argument_key)';
+
+ALTER TABLE eventcommand_envvar
+ RENAME COLUMN command_id TO eventcommand_id;
+ALTER TABLE eventcommand_envvar
+ MODIFY eventcommand_id binary(20) NOT NULL COMMENT 'eventcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + eventcommand_id + envvar_key)';
+
+ALTER TABLE eventcommand_customvar
+ RENAME COLUMN command_id TO eventcommand_id;
+ALTER TABLE eventcommand_customvar
+ MODIFY eventcommand_id binary(20) NOT NULL COMMENT 'eventcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + eventcommand_id + customvar_id)';
+
+ALTER TABLE notificationcommand_argument
+ RENAME COLUMN command_id TO notificationcommand_id;
+ALTER TABLE notificationcommand_argument
+ MODIFY notificationcommand_id binary(20) NOT NULL COMMENT 'notificationcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notificationcommand_id + argument_key)';
+
+ALTER TABLE notificationcommand_envvar
+ RENAME COLUMN command_id TO notificationcommand_id;
+ALTER TABLE notificationcommand_envvar
+ MODIFY notificationcommand_id binary(20) NOT NULL COMMENT 'notificationcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notificationcommand_id + envvar_key)';
+
+ALTER TABLE notificationcommand_customvar
+ RENAME COLUMN command_id TO notificationcommand_id;
+ALTER TABLE notificationcommand_customvar
+ MODIFY notificationcommand_id binary(20) NOT NULL COMMENT 'notificationcommand.id',
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notificationcommand_id + customvar_id)';
+
+ALTER TABLE checkcommand_customvar
+ ADD INDEX idx_checkcommand_customvar_checkcommand_id (checkcommand_id, customvar_id),
+ ADD INDEX idx_checkcommand_customvar_customvar_id (customvar_id, checkcommand_id);
+
+ALTER TABLE eventcommand_customvar
+ ADD INDEX idx_eventcommand_customvar_eventcommand_id (eventcommand_id, customvar_id),
+ ADD INDEX idx_eventcommand_customvar_customvar_id (customvar_id, eventcommand_id);
+
+ALTER TABLE notificationcommand_customvar
+ ADD INDEX idx_notificationcommand_customvar_notificationcommand_id (notificationcommand_id, customvar_id),
+ ADD INDEX idx_notificationcommand_customvar_customvar_id (customvar_id, notificationcommand_id);
+
+ALTER TABLE downtime
+ ADD COLUMN scheduled_duration bigint unsigned NOT NULL AFTER scheduled_end_time,
+ ADD COLUMN duration bigint unsigned NOT NULL COMMENT 'Duration of the downtime: When the downtime is flexible, this is the same as flexible_duration otherwise scheduled_duration' AFTER end_time,
+ MODIFY COLUMN flexible_duration bigint unsigned NOT NULL AFTER is_flexible;
+UPDATE downtime SET scheduled_duration = scheduled_end_time - scheduled_start_time, duration = (CASE WHEN is_flexible = 'y' THEN flexible_duration ELSE scheduled_end_time - scheduled_start_time END) WHERE scheduled_duration = 0;
+
+ALTER TABLE service_state ADD COLUMN host_id binary(20) NOT NULL COMMENT 'host.id' AFTER id;
+UPDATE service_state INNER JOIN service ON service.id = service_state.service_id SET service_state.host_id = service.host_id WHERE service_state.host_id = REPEAT('\0', 20);
+
+ALTER TABLE comment
+ ADD INDEX idx_comment_author (author) COMMENT 'Comment list filtered/ordered by author',
+ ADD INDEX idx_comment_expire_time (expire_time) COMMENT 'Comment list filtered/ordered by expire_time';
+
+ALTER TABLE downtime
+ ADD INDEX idx_downtime_entry_time (entry_time) COMMENT 'Downtime list filtered/ordered by entry_time',
+ ADD INDEX idx_downtime_start_time (start_time) COMMENT 'Downtime list filtered/ordered by start_time',
+ ADD INDEX idx_downtime_end_time (end_time) COMMENT 'Downtime list filtered/ordered by end_time',
+ ADD INDEX idx_downtime_scheduled_start_time (scheduled_start_time) COMMENT 'Downtime list filtered/ordered by scheduled_start_time',
+ ADD INDEX idx_downtime_scheduled_end_time (scheduled_end_time) COMMENT 'Downtime list filtered/ordered by scheduled_end_time',
+ ADD INDEX idx_downtime_author (author) COMMENT 'Downtime list filtered/ordered by author',
+ ADD INDEX idx_downtime_duration (duration) COMMENT 'Downtime list filtered/ordered by duration';
+
+ALTER TABLE service_state
+ ADD INDEX idx_service_state_is_problem (is_problem, severity) COMMENT 'Service list filtered by is_problem ordered by severity',
+ ADD INDEX idx_service_state_severity (severity) COMMENT 'Service list filtered/ordered by severity',
+ ADD INDEX idx_service_state_soft_state (soft_state, last_state_change) COMMENT 'Service list filtered/ordered by soft_state; recently recovered filter',
+ ADD INDEX idx_service_state_last_state_change (last_state_change) COMMENT 'Service list filtered/ordered by last_state_change';
+
+ALTER TABLE host_state
+ ADD INDEX idx_host_state_is_problem (is_problem, severity) COMMENT 'Host list filtered by is_problem ordered by severity',
+ ADD INDEX idx_host_state_severity (severity) COMMENT 'Host list filtered/ordered by severity',
+ ADD INDEX idx_host_state_soft_state (soft_state, last_state_change) COMMENT 'Host list filtered/ordered by soft_state; recently recovered filter',
+ ADD INDEX idx_host_state_last_state_change (last_state_change) COMMENT 'Host list filtered/ordered by last_state_change';
+
+ALTER TABLE hostgroup
+ ADD INDEX idx_hostroup_name (name) COMMENT 'Host/service/host group list filtered by host group name';
+
+ALTER TABLE servicegroup
+ ADD INDEX idx_servicegroup_name (name) COMMENT 'Host/service/service group list filtered by service group name';
+
+ALTER TABLE notification
+ DROP INDEX idx_host_id,
+ DROP INDEX idx_service_id,
+ ADD INDEX idx_notification_host_id (host_id),
+ ADD INDEX idx_notification_service_id (service_id);
+
+ALTER TABLE zone
+ DROP INDEX idx_parent_id,
+ ADD INDEX idx_zone_parent_id (parent_id);
+
+ALTER TABLE history
+ ADD INDEX idx_history_host_service_id (host_id, service_id, event_time) COMMENT 'Host/service history detail filter';
+
+ALTER TABLE notification_history
+ DROP INDEX idx_notification_history_event_time,
+ ADD INDEX idx_notification_history_send_time (send_time) COMMENT 'Notification list filtered/ordered by send_time';
diff --git a/schema/mysql/upgrades/1.0.0.sql b/schema/mysql/upgrades/1.0.0.sql
new file mode 100644
index 0000000..16bb45e
--- /dev/null
+++ b/schema/mysql/upgrades/1.0.0.sql
@@ -0,0 +1,291 @@
+DROP FUNCTION IF EXISTS get_sla_ok_percent;
+DELIMITER //
+CREATE FUNCTION get_sla_ok_percent(
+ in_host_id binary(20),
+ in_service_id binary(20),
+ in_start_time bigint unsigned,
+ in_end_time bigint unsigned
+)
+RETURNS decimal(7, 4)
+READS SQL DATA
+BEGIN
+ DECLARE result decimal(7, 4);
+ DECLARE row_event_time bigint unsigned;
+ DECLARE row_event_type enum('state_change', 'downtime_start', 'downtime_end', 'end');
+ DECLARE row_event_prio int;
+ DECLARE row_hard_state tinyint unsigned;
+ DECLARE row_previous_hard_state tinyint unsigned;
+ DECLARE last_event_time bigint unsigned;
+ DECLARE last_hard_state tinyint unsigned;
+ DECLARE active_downtimes int unsigned;
+ DECLARE problem_time bigint unsigned;
+ DECLARE total_time bigint unsigned;
+ DECLARE done int;
+ DECLARE cur CURSOR FOR
+ (
+ -- all downtime_start events before the end of the SLA interval
+ -- for downtimes that overlap the SLA interval in any way
+ SELECT
+ GREATEST(downtime_start, in_start_time) AS event_time,
+ 'downtime_start' AS event_type,
+ 1 AS event_prio,
+ NULL AS hard_state,
+ NULL AS previous_hard_state
+ FROM sla_history_downtime d
+ WHERE d.host_id = in_host_id
+ AND ((in_service_id IS NULL AND d.service_id IS NULL) OR d.service_id = in_service_id)
+ AND d.downtime_start < in_end_time
+ AND d.downtime_end >= in_start_time
+ ) UNION ALL (
+ -- all downtime_end events before the end of the SLA interval
+ -- for downtimes that overlap the SLA interval in any way
+ SELECT
+ downtime_end AS event_time,
+ 'downtime_end' AS event_type,
+ 2 AS event_prio,
+ NULL AS hard_state,
+ NULL AS previous_hard_state
+ FROM sla_history_downtime d
+ WHERE d.host_id = in_host_id
+ AND ((in_service_id IS NULL AND d.service_id IS NULL) OR d.service_id = in_service_id)
+ AND d.downtime_start < in_end_time
+ AND d.downtime_end >= in_start_time
+ AND d.downtime_end < in_end_time
+ ) UNION ALL (
+ -- all state events strictly in interval
+ SELECT
+ event_time,
+ 'state_change' AS event_type,
+ 0 AS event_prio,
+ hard_state,
+ previous_hard_state
+ FROM sla_history_state s
+ WHERE s.host_id = in_host_id
+ AND ((in_service_id IS NULL AND s.service_id IS NULL) OR s.service_id = in_service_id)
+ AND s.event_time > in_start_time
+ AND s.event_time < in_end_time
+ ) UNION ALL (
+ -- end event to keep loop simple, values are not used
+ SELECT
+ in_end_time AS event_time,
+ 'end' AS event_type,
+ 3 AS event_prio,
+ NULL AS hard_state,
+ NULL AS previous_hard_state
+ )
+ ORDER BY event_time, event_prio;
+ DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
+
+ IF in_end_time <= in_start_time THEN
+ SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'end time must be greater than start time';
+ END IF;
+
+ -- Use the latest event at or before the beginning of the SLA interval as the initial state.
+ SELECT hard_state INTO last_hard_state
+ FROM sla_history_state s
+ WHERE s.host_id = in_host_id
+ AND ((in_service_id IS NULL AND s.service_id IS NULL) OR s.service_id = in_service_id)
+ AND s.event_time <= in_start_time
+ ORDER BY s.event_time DESC
+ LIMIT 1;
+
+ -- If this does not exist, use the previous state from the first event after the beginning of the SLA interval.
+ IF last_hard_state IS NULL THEN
+ SELECT previous_hard_state INTO last_hard_state
+ FROM sla_history_state s
+ WHERE s.host_id = in_host_id
+ AND ((in_service_id IS NULL AND s.service_id IS NULL) OR s.service_id = in_service_id)
+ AND s.event_time > in_start_time
+ ORDER BY s.event_time ASC
+ LIMIT 1;
+ END IF;
+
+ -- If this also does not exist, use the current host/service state.
+ IF last_hard_state IS NULL THEN
+ IF in_service_id IS NULL THEN
+ SELECT hard_state INTO last_hard_state
+ FROM host_state s
+ WHERE s.host_id = in_host_id;
+ ELSE
+ SELECT hard_state INTO last_hard_state
+ FROM service_state s
+ WHERE s.host_id = in_host_id
+ AND s.service_id = in_service_id;
+ END IF;
+ END IF;
+
+ IF last_hard_state IS NULL THEN
+ SET last_hard_state = 0;
+ END IF;
+
+ SET problem_time = 0;
+ SET total_time = in_end_time - in_start_time;
+ SET last_event_time = in_start_time;
+ SET active_downtimes = 0;
+
+ SET done = 0;
+ OPEN cur;
+ read_loop: LOOP
+ FETCH cur INTO row_event_time, row_event_type, row_event_prio, row_hard_state, row_previous_hard_state;
+ IF done THEN
+ LEAVE read_loop;
+ END IF;
+
+ IF row_previous_hard_state = 99 THEN
+ SET total_time = total_time - (row_event_time - last_event_time);
+ ELSEIF ((in_service_id IS NULL AND last_hard_state > 0) OR (in_service_id IS NOT NULL AND last_hard_state > 1))
+ AND last_hard_state != 99
+ AND active_downtimes = 0
+ THEN
+ SET problem_time = problem_time + row_event_time - last_event_time;
+ END IF;
+
+ SET last_event_time = row_event_time;
+ IF row_event_type = 'state_change' THEN
+ SET last_hard_state = row_hard_state;
+ ELSEIF row_event_type = 'downtime_start' THEN
+ SET active_downtimes = active_downtimes + 1;
+ ELSEIF row_event_type = 'downtime_end' THEN
+ SET active_downtimes = active_downtimes - 1;
+ END IF;
+ END LOOP;
+ CLOSE cur;
+
+ SET result = 100 * (total_time - problem_time) / total_time;
+ RETURN result;
+END//
+DELIMITER ;
+
+ALTER TABLE hostgroup
+ DROP INDEX idx_hostroup_name,
+ ADD INDEX idx_hostgroup_name (name) COMMENT 'Host/service/host group list filtered by host group name';
+
+ALTER TABLE notification_history
+ MODIFY `text` longtext NOT NULL;
+
+ALTER TABLE host_state
+ ADD COLUMN previous_soft_state tinyint unsigned NOT NULL AFTER hard_state,
+ CHANGE attempt check_attempt tinyint unsigned NOT NULL,
+ CHANGE timeout check_timeout int unsigned DEFAULT NULL;
+
+ALTER TABLE service_state
+ ADD COLUMN previous_soft_state tinyint unsigned NOT NULL AFTER hard_state,
+ CHANGE attempt check_attempt tinyint unsigned NOT NULL,
+ CHANGE timeout check_timeout int unsigned DEFAULT NULL;
+
+ALTER TABLE checkcommand_argument
+ ADD COLUMN `separator` varchar(255) DEFAULT NULL AFTER set_if;
+
+ALTER TABLE eventcommand_argument
+ ADD COLUMN `separator` varchar(255) DEFAULT NULL AFTER set_if;
+
+ALTER TABLE notificationcommand_argument
+ ADD COLUMN `separator` varchar(255) DEFAULT NULL AFTER set_if;
+
+ALTER TABLE notification_history
+ ADD INDEX idx_notification_history_env_send_time (environment_id, send_time) COMMENT 'Filter for history retention';
+
+ALTER TABLE acknowledgement_history
+ ADD INDEX idx_acknowledgement_history_env_clear_time (environment_id, clear_time) COMMENT 'Filter for history retention';
+
+ALTER TABLE comment_history
+ ADD INDEX idx_comment_history_env_remove_time (environment_id, remove_time) COMMENT 'Filter for history retention';
+
+ALTER TABLE downtime_history
+ ADD INDEX idx_downtime_history_env_end_time (environment_id, end_time) COMMENT 'Filter for history retention';
+
+ALTER TABLE flapping_history
+ ADD INDEX idx_flapping_history_env_end_time (environment_id, end_time) COMMENT 'Filter for history retention';
+
+ALTER TABLE state_history
+ ADD INDEX idx_state_history_env_event_time (environment_id, event_time) COMMENT 'Filter for history retention',
+ CHANGE attempt check_attempt tinyint unsigned NOT NULL;
+
+ALTER TABLE icon_image
+ DROP PRIMARY KEY,
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + icon_image)',
+ ADD PRIMARY KEY (id);
+
+ALTER TABLE action_url
+ DROP PRIMARY KEY,
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + action_url)',
+ ADD PRIMARY KEY (id);
+
+ALTER TABLE notes_url
+ DROP PRIMARY KEY,
+ MODIFY id binary(20) NOT NULL COMMENT 'sha1(environment.id + notes_url)',
+ ADD PRIMARY KEY (id);
+
+ALTER TABLE customvar
+ MODIFY name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL;
+
+ALTER TABLE customvar_flat
+ MODIFY flatname varchar(512) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'Path converted with `.` and `[ ]`';
+
+ALTER TABLE host
+ CHANGE checkcommand checkcommand_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'checkcommand.name',
+ CHANGE check_timeperiod
+ check_timeperiod_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'timeperiod.name',
+ CHANGE eventcommand eventcommand_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'eventcommand.name',
+ CHANGE zone zone_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'zone.name',
+ CHANGE command_endpoint command_endpoint_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'endpoint.name';
+
+ALTER TABLE service
+ CHANGE checkcommand checkcommand_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'checkcommand.name',
+ CHANGE check_timeperiod
+ check_timeperiod_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'timeperiod.name',
+ CHANGE eventcommand eventcommand_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'eventcommand.name',
+ CHANGE zone zone_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'zone.name',
+ CHANGE command_endpoint command_endpoint_name varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'endpoint.name';
+
+CREATE TABLE sla_history_state (
+ id binary(20) NOT NULL COMMENT 'state_history.id (may reference already deleted rows)',
+ environment_id binary(20) NOT NULL COMMENT 'environment.id',
+ endpoint_id binary(20) DEFAULT NULL COMMENT 'endpoint.id',
+ object_type enum('host', 'service') NOT NULL,
+ host_id binary(20) NOT NULL COMMENT 'host.id',
+ service_id binary(20) DEFAULT NULL COMMENT 'service.id',
+
+ event_time bigint unsigned NOT NULL COMMENT 'unix timestamp the event occurred',
+ hard_state TINYINT UNSIGNED NOT NULL COMMENT 'hard state after this event',
+ previous_hard_state TINYINT UNSIGNED NOT NULL COMMENT 'hard state before this event',
+
+ PRIMARY KEY (id),
+
+ INDEX idx_sla_history_state_event (host_id, service_id, event_time) COMMENT 'Filter for calculating the sla reports',
+ INDEX idx_sla_history_state_env_event_time (environment_id, event_time) COMMENT 'Filter for sla history retention'
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin ROW_FORMAT=DYNAMIC;
+
+INSERT INTO sla_history_state
+ (id, environment_id, endpoint_id, object_type, host_id, service_id, event_time, hard_state, previous_hard_state)
+ SELECT id, environment_id, endpoint_id, object_type, host_id, service_id, event_time, hard_state, previous_hard_state
+ FROM state_history
+ WHERE state_type = 'hard'
+ ON DUPLICATE KEY UPDATE sla_history_state.id = sla_history_state.id;
+
+CREATE TABLE sla_history_downtime (
+ environment_id binary(20) NOT NULL COMMENT 'environment.id',
+ endpoint_id binary(20) DEFAULT NULL COMMENT 'endpoint.id',
+ object_type enum('host', 'service') NOT NULL,
+ host_id binary(20) NOT NULL COMMENT 'host.id',
+ service_id binary(20) DEFAULT NULL COMMENT 'service.id',
+
+ downtime_id binary(20) NOT NULL COMMENT 'downtime.id (may reference already deleted rows)',
+ downtime_start BIGINT UNSIGNED NOT NULL COMMENT 'start time of the downtime',
+ downtime_end BIGINT UNSIGNED NOT NULL COMMENT 'end time of the downtime',
+
+ PRIMARY KEY (downtime_id),
+
+ INDEX idx_sla_history_downtime_event (host_id, service_id, downtime_start, downtime_end) COMMENT 'Filter for calculating the sla reports',
+ INDEX idx_sla_history_downtime_env_downtime_end (environment_id, downtime_end) COMMENT 'Filter for sla history retention'
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin ROW_FORMAT=DYNAMIC;
+
+INSERT INTO sla_history_downtime
+ (environment_id, endpoint_id, object_type, host_id, service_id, downtime_id, downtime_start, downtime_end)
+ SELECT environment_id, endpoint_id, object_type, host_id, service_id, downtime_id,
+ start_time AS downtime_start, IF(has_been_cancelled = 'y', cancel_time, end_time) AS downtime_end
+ FROM downtime_history
+ ON DUPLICATE KEY UPDATE sla_history_downtime.downtime_id = sla_history_downtime.downtime_id;
+
+INSERT INTO icingadb_schema (version, TIMESTAMP)
+ VALUES (3, CURRENT_TIMESTAMP() * 1000);