+if node[:prometheus][:promscale]
+ service "promscale" do
+ action [:enable, :start]
+ subscribes :restart, "remote_file[/opt/promscale/bin/promscale]"
+ subscribes :restart, "systemd_service[promscale]"
+ end
+
+ service "promscale-maintenance.timer" do
+ action [:enable, :start]
+ end
+else
+ service "promscale" do
+ action [:disable, :stop]
+ end
+
+ service "promscale-maintenance.timer" do
+ action [:disable, :stop]
+ end
+end
+
+search(:node, "roles:gateway") do |gateway|
+ allowed_ips = gateway.interfaces(:role => :internal).map do |interface|
+ "#{interface[:network]}/#{interface[:prefix]}"
+ end
+
+ node.default[:networking][:wireguard][:peers] << {
+ :public_key => gateway[:networking][:wireguard][:public_key],
+ :allowed_ips => allowed_ips,
+ :endpoint => "#{gateway.name}:51820"
+ }
+end
+