module Meroku module CLI class Session include Meroku::CLI include Meroku::Infrastructure attr_accessor :ec2_client, :token def initialize(*args) case args.join(" ") when "signup" signup when "create" Meroku::CLI::User.load_secrets(self) || exit create when "keys:add" Meroku::CLI::User.load_secrets(self) || exit keys_add(self) when "infrastructure spawn" Meroku::CLI::AdminUser.load_secrets(self) || exit spawn(self) when "infrastructure despawn" Meroku::CLI::AdminUser.load_secrets(self) || exit despawn else puts "Unknown command #{args.join(" ")}\n\n" puts help end #case args.join(" ") # when "infrastructure spawn" # load_secrets || exit # node = Meroku::Infrastructure::Node.new.associate_address.install_packages.install_frontend_app # puts "spawned #{node.instance.try(:instance_id)}" # when "infrastructure despawn" # load_secrets || exit # Meroku::Infrastructure.despawn # when "signup" # signup # when "keys:add" # token_check || exit # keys_add # when "create" # token_check || exit # create # else # puts HELP #end end def ec2_client @ec2_client ||= ::Aws::EC2::Client.new( region: 'us-east-1', credentials: ::Aws::Credentials.new(ENV['AWS_ACCESS_KEY'], ENV['AWS_SECRET']) ) @ec2_client end end end end