#!/usr/bin/env ruby require File.join(File.dirname(__FILE__), '..', 'lib', 'fog') require 'irb' require 'yaml' module Fog module Credentials Fog.credential = (ARGV.first && :"#{ARGV.first}") || :default unless Fog.credentials exit end end end module AWS class << self credential = (ARGV.first && :"#{ARGV.first}") || :default if Fog.credentials[:aws_access_key_id] && Fog.credentials[:aws_secret_access_key] def [](service) @@connections ||= Hash.new do |hash, key| credentials = Fog.credentials.reject do |k, v| ![:aws_access_key_id, :aws_secret_access_key].include?(k) end hash[key] = case key when :ec2 Fog::AWS::EC2.new(credentials) when :s3 Fog::AWS::S3.new(credentials) end end @@connections[service] end def addresses self[:ec2].addresses end def directories self[:s3].directories end def flavors self[:ec2].flavors end def images self[:ec2].images end def servers self[:ec2].servers end def key_pairs self[:ec2].key_pairs end def security_groups self[:ec2].security_groups end def snapshots self[:ec2].snapshots end def volumes self[:ec2].volumes end end end end module Rackspace class << self if Fog.credentials[:rackspace_api_key] && Fog.credentials[:rackspace_username] def [](service) @@connections ||= Hash.new do |hash, key| credential = (ARGV.first && :"#{ARGV.first}") || :default credentials = Fog.credentials.reject do |k,v| ![:rackspace_api_key, :rackspace_username].include?(k) end hash[key] = case key when :files Fog::Rackspace::Files.new(credentials) when :servers Fog::Rackspace::Servers.new(credentials) end end @@connections[service] end def flavors self[:servers].flavors end def images self[:servers].images end def servers self[:servers].servers end end end end ARGV.clear # Avoid passing args to IRB IRB.setup(nil) @irb = IRB::Irb.new(nil) IRB.conf[:MAIN_CONTEXT] = @irb.context @irb.context.workspace = IRB::WorkSpace.new(binding) catch(:IRB_EXIT) { @irb.eval_input }