From 6008237e67af4fc8bba7c54c99703fd7353c8277 Mon Sep 17 00:00:00 2001 From: Jimmy Ngo Date: Fri, 7 Apr 2017 10:15:39 -0700 Subject: [PATCH] Allow additional options to be passed to monitor API calls Datadog will occasionally add new parameters to their API. Instead of requiring a code change for each additional parameter, this change allows any additional option to be passed to the API. --- lib/dogapi/v1/monitor.rb | 29 ++++++----------------------- 1 file changed, 6 insertions(+), 23 deletions(-) diff --git a/lib/dogapi/v1/monitor.rb b/lib/dogapi/v1/monitor.rb index e656ce4b..e98d38fe 100644 --- a/lib/dogapi/v1/monitor.rb +++ b/lib/dogapi/v1/monitor.rb @@ -25,11 +25,11 @@ def update_monitor(monitor_id, query, options) end def get_monitor(monitor_id, options = {}) + extra_params = options.clone # :group_states is an optional list of statuses to filter returned # groups. If no value is given then no group states will be returned. # Possible values are: "all", "ok", "warn", "alert", "no data". - extra_params = {} - extra_params[:group_states] = options[:group_states].join(',') if options[:group_states] + extra_params[:group_states] = extra_params[:group_states].join(',') if extra_params[:group_states] request(Net::HTTP::Get, "/api/#{API_VERSION}/monitor/#{monitor_id}", extra_params, nil, false) end @@ -39,27 +39,16 @@ def delete_monitor(monitor_id) end def get_all_monitors(options = {}) - extra_params = {} + extra_params = options.clone # :group_states is an optional list of statuses to filter returned # groups. If no value is given then no group states will be returned. # Possible values are: "all", "ok", "warn", "alert", "no data". - if options[:group_states] - extra_params[:group_states] = options[:group_states] - extra_params[:group_states] = extra_params[:group_states].join(',') if extra_params[:group_states].respond_to?(:join) - end + extra_params[:group_states] = extra_params[:group_states].join(',') if extra_params[:group_states].respond_to?(:join) # :tags is an optional list of scope tags to filter the list of monitors # returned. If no value is given, then all monitors, regardless of # scope, will be returned. - if options[:tags] - extra_params[:tags] = options[:tags] - extra_params[:tags] = extra_params[:tags].join(',') if extra_params[:tags].respond_to?(:join) - end - - # :name is a string to filter monitors by name - if options[:name] - extra_params[:name] = options[:name] - end + extra_params[:tags] = extra_params[:tags].join(',') if extra_params[:tags].respond_to?(:join) request(Net::HTTP::Get, "/api/#{API_VERSION}/monitor", extra_params, nil, false) end @@ -104,13 +93,7 @@ def cancel_downtime(downtime_id) end def get_all_downtimes(options = {}) - extra_params = {} - if options[:current_only] - extra_params[:current_only] = options[:current_only] - options.delete :current_only - end - - request(Net::HTTP::Get, "/api/#{API_VERSION}/downtime", extra_params, nil, false) + request(Net::HTTP::Get, "/api/#{API_VERSION}/downtime", options, nil, false) end #