Class: Hotdog::Commands::Up
- Inherits:
-
BaseCommand
- Object
- BaseCommand
- Hotdog::Commands::Up
- Defined in:
- lib/hotdog/commands/up.rb
Instance Attribute Summary
Attributes inherited from BaseCommand
#application, #logger, #options, #persistent_db_path
Instance Method Summary collapse
Methods inherited from BaseCommand
#execute, #fixed_string?, #initialize, #parse_options, #reload
Constructor Details
This class inherits a constructor from Hotdog::Commands::BaseCommand
Instance Method Details
#define_options(optparse, options = {}) ⇒ Object
6 7 8 9 10 11 12 13 14 |
# File 'lib/hotdog/commands/up.rb', line 6 def (optparse, ={}) default_option(, :retry, 5) optparse.on("--retry NUM") do |v| [:retry] = v.to_i end optparse.on("--retry-delay SECONDS") do |v| [:retry_delay] = v.to_i end end |
#run(args = [], options = {}) ⇒ Object
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/hotdog/commands/up.rb', line 16 def run(args=[], ={}) scopes = args.map { |arg| if arg.index(":").nil? "host:#{arg}" else arg end } all_downtimes = nil with_retry() do all_downtimes = @source_provider.get_all_downtimes() end cancel_downtimes = all_downtimes.select { |downtime| downtime["active"] and downtime["id"] and scopes.map { |scope| downtime.fetch("scope", []).include?(scope) }.any? } cancel_downtimes.each do |downtime| with_retry() do @source_provider.cancel_downtime(downtime["id"], ) end end hosts = scopes.select { |scope| scope.start_with?("host:") }.map { |scope| scope.slice("host:".length, scope.length) } if 0 < hosts.length # Try reloading database after error as a workaround for nested transaction. with_retry(error_handler: ->(error) { reload }) do if open_db @db.transaction do sqlite_limit_compound_select = [:sqlite_limit_compound_select] || SQLITE_LIMIT_COMPOUND_SELECT hosts.each_slice(sqlite_limit_compound_select - 1) do |hosts| execute_db(@db, "DELETE FROM hosts_tags WHERE tag_id IN ( SELECT id FROM tags WHERE name = '@status' ) AND host_id IN ( SELECT id FROM hosts WHERE name IN (%s) );" % hosts.map { "?" }.join(", "), hosts) execute_db(@db, "UPDATE hosts SET status = ? WHERE name IN (%s);" % hosts.map { "?" }.join(", "), [STATUS_RUNNING] + hosts) end associate_tag_hosts(@db, "@status:#{application.status_name(STATUS_RUNNING)}", hosts) end end end end end |