]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/prometheus/resources/exporter.rb
Update interface names for thorn-04 and thorn-05
[chef.git] / cookbooks / prometheus / resources / exporter.rb
index 5896a1b46cd530d36ce0f5919ddc4817b717a336..82c2957c020a6235e76885380802c75c423169c5 100644 (file)
@@ -22,6 +22,8 @@ default_action :create
 property :exporter, :kind_of => String, :name_property => true
 property :port, :kind_of => Integer, :required => [:create]
 property :listen_switch, :kind_of => String, :default => "web.listen-address"
+property :listen_type, :kind_of => String, :default => "address"
+property :user, :kind_of => String, :default => "root"
 property :options, :kind_of => [String, Array]
 property :environment, :kind_of => Hash, :default => {}
 
@@ -29,7 +31,7 @@ action :create do
   systemd_service service_name do
     description "Prometheus #{new_resource.exporter} exporter"
     type "simple"
-    user "root"
+    user new_resource.user
     environment new_resource.environment
     exec_start "#{executable_path} #{executable_options}"
     private_tmp true
@@ -81,7 +83,14 @@ action_class do
   end
 
   def executable_options
-    "--#{new_resource.listen_switch}=#{listen_address} #{Array(new_resource.options).join(' ')}"
+    "--#{new_resource.listen_switch}=#{listen_argument} #{Array(new_resource.options).join(' ')}"
+  end
+
+  def listen_argument
+    case new_resource.listen_type
+    when "address" then listen_address
+    when "url" then "http://#{listen_address}/metrics"
+    end
   end
 
   def listen_address