timeperiod.pp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. # == Defined type: icinga2::object::timeperiod
  2. #
  3. # This is a defined type for Icinga 2 host objects.
  4. # See the following Icinga 2 doc page for more info:
  5. # http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/monitoring-basics#timeperiods
  6. #
  7. # === Parameters
  8. #
  9. # See the inline comments.
  10. #
  11. define icinga2::object::timeperiod (
  12. $object_name = $name,
  13. $timeperiod_template_to_import = 'legacy-timeperiod',
  14. $timeperiod_display_name = undef,
  15. $methods = undef,
  16. $ranges = {},
  17. $timeperiod_target_dir = '/etc/icinga2/objects/timeperiods',
  18. $timeperiod_target_file_name = "${name}.conf",
  19. $target_file_owner = 'root',
  20. $target_file_group = 'root',
  21. $target_file_mode = '0644',
  22. ) {
  23. # Do some validation of the class' parameters:
  24. validate_string($object_name)
  25. validate_string($timeperiod_template_to_import)
  26. validate_string($timeperiod_display_name)
  27. if $methods {
  28. validate_string($methods)
  29. }
  30. validate_hash($ranges)
  31. validate_string($timeperiod_target_dir)
  32. validate_string($target_file_name)
  33. validate_string($target_file_owner)
  34. validate_string($target_file_group)
  35. validate_re($target_file_mode, '^\d{4}$')
  36. file {"${timeperiod_target_dir}/${timeperiod_target_file_name}":
  37. ensure => file,
  38. owner => $target_file_owner,
  39. group => $target_file_group,
  40. mode => $target_file_mode,
  41. content => template('icinga2/object_timeperiod.conf.erb'),
  42. notify => Service['icinga2'],
  43. }
  44. }