Sha256: 29ced36e5d0ccced84fbf237f879e206b5566fa8cec3b42de98ee9f233954615

Contents?: true

Size: 1.88 KB

Versions: 25

Compression:

Stored size: 1.88 KB

Contents

require "aws-logs"

class Ufo::CLI
  class Logs < Base
    delegate :service, to: :info

    def run
      log = find_log_group_name
      puts "Showing logs for stack: #{@stack_name} log group: #{log["awslogs-group"]} and stream prefix: #{log["awslogs-stream-prefix"]}"
      if log
        cloudwatch_tail(log)
      else
        puts "Unable to find log group for service: #{service.service_name}"
      end
    end

    def find_log_group_name
      unless info.service
        logger.info "Cannot find stack: #{@stack_name}"
        exit 1
      end
      task_definition = info.service.task_definition
      resp = ecs.describe_task_definition(task_definition: task_definition)

      container_definitions = resp.task_definition.container_definitions

      unless container_definitions.size == 1
        puts "ERROR: ufo logs command only supports 1 container definition in the ECS task definition".color(:red)
        return
      end

      definition = container_definitions.first
      log_conf = definition.log_configuration

      if log_conf && log_conf.log_driver == "awslogs"
        # options["awslogs-group"]
        # options["awslogs-region"]
        # options["awslogs-stream-prefix"]
        log_conf.options
      else
        puts "Only supports awslogs driver. Detected log_driver: #{log_conf.log_driver}"
        return
      end
    end

    def cloudwatch_tail(log={})
      o = {
        log_group_name: log["awslogs-group"],
        log_stream_name_prefix: log["awslogs-stream-prefix"],
        since: @options[:since] || "10m", # by default, search only 10 mins in the past
        follow: @options[:follow],
        format: @options[:format],
      }
      o[:filter_pattern] = filter_pattern
      cw_tail = AwsLogs::Tail.new(o)
      cw_tail.run
    end

    def filter_pattern
      @options[:filter_pattern] ? @options[:filter_pattern] : Ufo.config.logs.filter_pattern
    end
  end
end

Version data entries

25 entries across 25 versions & 1 rubygems

Version Path
ufo-6.3.3 lib/ufo/cli/logs.rb
ufo-6.3.2 lib/ufo/cli/logs.rb
ufo-6.3.1 lib/ufo/cli/logs.rb
ufo-6.3.0 lib/ufo/cli/logs.rb
ufo-6.2.5 lib/ufo/cli/logs.rb
ufo-6.2.4 lib/ufo/cli/logs.rb
ufo-6.2.3 lib/ufo/cli/logs.rb
ufo-6.2.2 lib/ufo/cli/logs.rb
ufo-6.2.1 lib/ufo/cli/logs.rb
ufo-6.2.0 lib/ufo/cli/logs.rb
ufo-6.1.5 lib/ufo/cli/logs.rb
ufo-6.1.4 lib/ufo/cli/logs.rb
ufo-6.1.3 lib/ufo/cli/logs.rb
ufo-6.1.2 lib/ufo/cli/logs.rb
ufo-6.1.1 lib/ufo/cli/logs.rb
ufo-6.1.0 lib/ufo/cli/logs.rb
ufo-6.0.9 lib/ufo/cli/logs.rb
ufo-6.0.8 lib/ufo/cli/logs.rb
ufo-6.0.7 lib/ufo/cli/logs.rb
ufo-6.0.6 lib/ufo/cli/logs.rb