hackedteam/rcs-common

View on GitHub
lib/rcs-common/component.rb

Summary

Maintainability
A
1 hr
Test Coverage
require 'rcs-common/trace'

module RCS
  module Component
    def self.included(base)
      base.__send__(:include, RCS::Tracer)
      base.__send__(:extend, RCS::Tracer)

      base.__send__(:extend, ClassMethods)

      base.__send__(:define_singleton_method, :component) do |value, name: nil|
        @_component = value.to_sym
        @_component_name = name || "RCS #{value.to_s.capitalize}"
      end
    end

    def component
      self.class.instance_variable_get('@_component')
    end

    def component_name
      self.class.instance_variable_get('@_component_name')
    end

    def full_component_version
      File.read(Dir.pwd + '/config/VERSION').strip
    end

    def component_version
      $version || full_component_version.split('-').first
    end

    def show_startup_message
      build = File.read(Dir.pwd + '/config/VERSION_BUILD')
      trace :fatal, "Starting the #{component_name} #{full_component_version} (#{build})..."
    end

    def database
      @_database ||= begin
        db_class =  RCS.const_get('Collector::DB') rescue RCS.const_get('DB::DB')
        db_class.instance
      end
    end

    def establish_database_connection(wait_until_connected: false)
      loop do
        connected = database.respond_to?(:connect!) ? database.connect!(component) : database.connect

        if connected
          trace :info, "Database connection succeeded"
          break
        end

        if wait_until_connected
          trace :warn, "Database connection failed, retry..."
          sleep 1
        else
          trace :error, "Database connection failed"
          break
        end
      end
    end

    def run_with_rescue
      $version = component_version
      trace_setup
      show_startup_message
      yield
      return 0
    rescue Interrupt
      # call the kill handler if defined
      kill if self.respond_to? :kill
      trace :info, "User asked to exit. Bye bye!"
      exit(0)
    rescue Exception => e
      trace :fatal, "FAILURE: " << e.message
      trace :fatal, "EXCEPTION: [#{e.class}] " << e.backtrace.join("\n")
      exit(1)
    end

    module ClassMethods
      def run!(*argv)
        return new.run(argv)
      end
    end
  end
end