diff --git a/doc/08-advanced-topics.md b/doc/08-advanced-topics.md index c51a303d7..0e450a59d 100644 --- a/doc/08-advanced-topics.md +++ b/doc/08-advanced-topics.md @@ -206,14 +206,6 @@ the `check_period` attribute. Or a notification should be sent to users or not, filtered by the `period` and `notification_period` configuration attributes for `Notification` and `User` objects. -> **Note** -> -> If you are familiar with Icinga 1.x, these time period definitions -> are called `legacy timeperiods` in Icinga 2. -> -> An Icinga 2 legacy timeperiod requires the `ITL` provided template ->`legacy-timeperiod`. - The `TimePeriod` attribute `ranges` may contain multiple directives, including weekdays, days of the month, and calendar dates. These types may overlap/override other types in your ranges dictionary. @@ -231,78 +223,80 @@ If you don't set any `check_period` or `notification_period` attribute on your configuration objects, Icinga 2 assumes `24x7` as time period as shown below. - object TimePeriod "24x7" { - import "legacy-timeperiod" - - display_name = "Icinga 2 24x7 TimePeriod" - ranges = { - "monday" = "00:00-24:00" - "tuesday" = "00:00-24:00" - "wednesday" = "00:00-24:00" - "thursday" = "00:00-24:00" - "friday" = "00:00-24:00" - "saturday" = "00:00-24:00" - "sunday" = "00:00-24:00" - } - } +``` +object TimePeriod "24x7" { + display_name = "Icinga 2 24x7 TimePeriod" + ranges = { + "monday" = "00:00-24:00" + "tuesday" = "00:00-24:00" + "wednesday" = "00:00-24:00" + "thursday" = "00:00-24:00" + "friday" = "00:00-24:00" + "saturday" = "00:00-24:00" + "sunday" = "00:00-24:00" + } +} +``` If your operation staff should only be notified during workhours, create a new timeperiod named `workhours` defining a work day from 09:00 to 17:00. - object TimePeriod "workhours" { - import "legacy-timeperiod" +``` +object TimePeriod "workhours" { + display_name = "Icinga 2 8x5 TimePeriod" + ranges = { + "monday" = "09:00-17:00" + "tuesday" = "09:00-17:00" + "wednesday" = "09:00-17:00" + "thursday" = "09:00-17:00" + "friday" = "09:00-17:00" + } +} +``` - display_name = "Icinga 2 8x5 TimePeriod" - ranges = { - "monday" = "09:00-17:00" - "tuesday" = "09:00-17:00" - "wednesday" = "09:00-17:00" - "thursday" = "09:00-17:00" - "friday" = "09:00-17:00" - } - } - -Furthermore if you wish to specify a notification period across midnight, +If you want to specify a notification period across midnight, you can define it the following way: - object Timeperiod "across-midnight" { - import "legacy-timeperiod" - - display_name = "Nightly Notification" - ranges = { - "saturday" = "22:00-24:00" - "sunday" = "00:00-03:00" - } - } +``` +object Timeperiod "across-midnight" { + display_name = "Nightly Notification" + ranges = { + "saturday" = "22:00-24:00" + "sunday" = "00:00-03:00" + } +} +``` Below you can see another example for configuring timeperiods across several days, weeks or months. This can be useful when taking components offline for a distinct period of time. - object Timeperiod "standby" { - import "legacy-timeperiod" - - display_name = "Standby" - ranges = { - "2016-09-30 - 2016-10-30" = "00:00-24:00" - } - } +``` +object Timeperiod "standby" { + display_name = "Standby" + ranges = { + "2016-09-30 - 2016-10-30" = "00:00-24:00" + } +} +``` Please note that the spaces before and after the dash are mandatory. Once your time period is configured you can Use the `period` attribute to assign time periods to `Notification` and `Dependency` objects: - object Notification "mail" { - import "generic-notification" +``` +apply Notification "mail-icingaadmin" to Service { + import "mail-service-notification" + user_groups = host.vars.notification.mail.groups + users = host.vars.notification.mail.users - host_name = "localhost" + period = "workhours" - command = "mail-notification" - users = [ "icingaadmin" ] - period = "workhours" - } + assign where host.vars.notification.mail +} +``` ### Time Periods Inclusion and Exclusion @@ -319,51 +313,51 @@ preferred. The following example defines a time period called `holidays` where notifications should be suppressed: - object TimePeriod "holidays" { - import "legacy-timeperiod" - - ranges = { - "january 1" = "00:00-24:00" //new year's day - "july 4" = "00:00-24:00" //independence day - "december 25" = "00:00-24:00" //christmas - "december 31" = "18:00-24:00" //new year's eve (6pm+) - "2017-04-16" = "00:00-24:00" //easter 2017 - "monday -1 may" = "00:00-24:00" //memorial day (last monday in may) - "monday 1 september" = "00:00-24:00" //labor day (1st monday in september) - "thursday 4 november" = "00:00-24:00" //thanksgiving (4th thursday in november) - } - } +``` +object TimePeriod "holidays" { + ranges = { + "january 1" = "00:00-24:00" //new year's day + "july 4" = "00:00-24:00" //independence day + "december 25" = "00:00-24:00" //christmas + "december 31" = "18:00-24:00" //new year's eve (6pm+) + "2017-04-16" = "00:00-24:00" //easter 2017 + "monday -1 may" = "00:00-24:00" //memorial day (last monday in may) + "monday 1 september" = "00:00-24:00" //labor day (1st monday in september) + "thursday 4 november" = "00:00-24:00" //thanksgiving (4th thursday in november) + } +} +``` In addition to that the time period `weekends` defines an additional time window which should be excluded from notifications: - object TimePeriod "weekends-excluded" { - import "legacy-timeperiod" - - ranges = { - "saturday" = "00:00-09:00,18:00-24:00" - "sunday" = "00:00-09:00,18:00-24:00" - } - } +``` +object TimePeriod "weekends-excluded" { + ranges = { + "saturday" = "00:00-09:00,18:00-24:00" + "sunday" = "00:00-09:00,18:00-24:00" + } +} +``` The time period `prod-notification` defines the default time ranges and adds the excluded time period names as an array. - object TimePeriod "prod-notification" { - import "legacy-timeperiod" +``` +object TimePeriod "prod-notification" { + excludes = [ "holidays", "weekends-excluded" ] - excludes = [ "holidays", "weekends-excluded" ] - - ranges = { - "monday" = "00:00-24:00" - "tuesday" = "00:00-24:00" - "wednesday" = "00:00-24:00" - "thursday" = "00:00-24:00" - "friday" = "00:00-24:00" - "saturday" = "00:00-24:00" - "sunday" = "00:00-24:00" - } - } + ranges = { + "monday" = "00:00-24:00" + "tuesday" = "00:00-24:00" + "wednesday" = "00:00-24:00" + "thursday" = "00:00-24:00" + "friday" = "00:00-24:00" + "saturday" = "00:00-24:00" + "sunday" = "00:00-24:00" + } +} +``` ## External Check Results @@ -1077,8 +1071,6 @@ time of the day compared to the defined time period. ``` object TimePeriod "backup" { - import "legacy-timeperiod" - ranges = { monday = "02:00-03:00" tuesday = "02:00-03:00" diff --git a/doc/09-object-types.md b/doc/09-object-types.md index 17b3444e1..0ba3ff05e 100644 --- a/doc/09-object-types.md +++ b/doc/09-object-types.md @@ -1602,10 +1602,6 @@ Facility Constants: Time periods can be used to specify when hosts/services should be checked or to limit when notifications should be sent out. -> **Note** -> -> Icinga 2 versions < 2.6.0 require the import of the [legacy-timeperiod](10-icinga-template-library.md#itl-legacy-timeperiod) template. - Examples: ```