#!/usr/bin/env ruby $: << File.expand_path("#{File.dirname __FILE__}/../lib") require 'rubygems' require 'kumogata' require 'kumogata/argument_parser' options = nil parsed = Kumogata::ArgumentParser.parse! {|parser, cmd, args, opts| if (opts.access_key_id? and not opts.secret_access_key?) or (not opts.access_key_id? and opts.secret_access_key?) puts parser.help exit 1 end } begin command, arguments, options, output_result = parsed String.colorize = options.color? Diffy::Diff.default_format = options.color? ? :color : :text aws_opts = {} if options.config_profile or options.credentials_path credentials_opts = {} credentials_opts[:profile_name] = options.config_profile if options.config_profile credentials_opts[:path] = options.credentials_path if options.credentials_path provider = AWS::Core::CredentialProviders::SharedCredentialFileProvider.new(credentials_opts) aws_opts[:credential_provider] = provider end if File.exist?(options.config_path) and File.readable?(options.config_path) ini = AWS::Core::IniParser.parse(File.read(options.config_path)) profile = options.config_profile || 'default' profile = "profile #{profile}" unless profile == 'default' region = (ini[profile] || {})['region'] aws_opts[:region] = region if region end [:access_key_id, :secret_access_key, :region].each do |key| aws_opts[key] = options[key] if options[key] end AWS.config(aws_opts) unless aws_opts.empty? if options.debug? Kumogata.logger.set_debug(true) AWS.config({ :http_wire_trace => true, :logger => Kumogata.logger, }) end out = Kumogata::Client.new(options).send(command, *arguments) if [:create, :update, :delete].include?(command) and options.detach? puts '[detached]' elsif output_result and out puts out end rescue Exception => e $stderr.puts("[ERROR] #{e.message}".red) unless e.kind_of?(Interrupt) if options and options.debug? raise e else backtrace = Kumogata::Utils.filter_backtrace(e.backtrace) unless backtrace.empty? $stderr.puts " from #{backtrace.first}".red end end exit 1 end