X-Git-Url: https://git.openstreetmap.org/chef.git/blobdiff_plain/b7d4583c770392b26c7dd20346b35db2d02f2440..39e9c0f23c2c459285df473de8011221f429dbad:/cookbooks/prometheus/resources/collector.rb diff --git a/cookbooks/prometheus/resources/collector.rb b/cookbooks/prometheus/resources/collector.rb index e82984b14..0ae8320f7 100644 --- a/cookbooks/prometheus/resources/collector.rb +++ b/cookbooks/prometheus/resources/collector.rb @@ -23,23 +23,33 @@ default_action :create property :collector, :kind_of => String, :name_property => true property :interval, :kind_of => [Integer, String], :required => [:create] +property :user, :kind_of => String property :options, :kind_of => [String, Array] property :environment, :kind_of => Hash, :default => {} +property :proc_subset, String +property :capability_bounding_set, [String, Array] +property :private_devices, [true, false] +property :private_users, [true, false] +property :protect_clock, [true, false] action :create do systemd_service service_name do description "Prometheus #{new_resource.collector} collector" - user "root" + user new_resource.user + dynamic_user new_resource.user.nil? + group "adm" environment new_resource.environment standard_output "file:/var/lib/prometheus/node-exporter/#{new_resource.collector}.new" standard_error "journal" exec_start "#{executable_path} #{executable_options}" exec_start_post "/bin/mv /var/lib/prometheus/node-exporter/#{new_resource.collector}.new /var/lib/prometheus/node-exporter/#{new_resource.collector}.prom" - private_tmp true - protect_system "strict" - protect_home true + sandbox true + proc_subset new_resource.proc_subset if new_resource.property_is_set?(:proc_subset) + capability_bounding_set new_resource.capability_bounding_set if new_resource.property_is_set?(:capability_bounding_set) + private_devices new_resource.private_devices if new_resource.property_is_set?(:private_devices) + private_users new_resource.private_users if new_resource.property_is_set?(:private_users) + protect_clock new_resource.protect_clock if new_resource.property_is_set?(:protect_clock) read_write_paths ["/var/lib/prometheus/node-exporter", "/var/lock", "/var/log"] - no_new_privileges true end systemd_timer service_name do