1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/bin/fog

115 lines
2.7 KiB
Text
Raw Normal View History

2009-10-02 02:22:47 -04:00
#!/usr/bin/env ruby
require File.join(File.dirname(__FILE__), '..', 'lib', 'fog')
require 'irb'
require 'yaml'
2009-10-15 01:03:31 -04:00
module AWS
class << self
key = (ARGV.first && :"#{ARGV.first}") || :default
unless Fog.credentials(key)
print("\n To run as '#{key}', add credentials like the following to ~/.fog\n")
yml = <<-YML
:#{key}:
:aws_access_key_id: INTENTIONALLY_LEFT_BLANK
:aws_secret_access_key: INTENTIONALLY_LEFT_BLANK
:rackspace_api_key: INTENTIONALLY_LEFT_BLANK
:rackspace_username: INTENTIONALLY_LEFT_BLANK
:slicehost_password: INTENTIONALLY_LEFT_BLANK
YML
print(yml)
raise ArgumentError.new("No credentials for :#{key}")
end
if Fog.credentials(key)[:aws_access_key_id] && Fog.credentials(key)[:aws_secret_access_key]
2009-10-08 02:45:33 -04:00
@@ec2 = Fog::AWS::EC2.new(
2009-11-22 17:53:29 -05:00
:aws_access_key_id => Fog.credentials[:aws_access_key_id],
:aws_secret_access_key => Fog.credentials[:aws_secret_access_key]
)
2009-10-02 02:22:47 -04:00
@@s3 = Fog::AWS::S3.new(
2009-11-22 17:53:29 -05:00
:aws_access_key_id => Fog.credentials[:aws_access_key_id],
:aws_secret_access_key => Fog.credentials[:aws_secret_access_key]
)
2009-10-08 02:45:33 -04:00
def addresses
@@ec2.addresses
end
2009-10-02 02:22:47 -04:00
def buckets
@@s3.buckets
end
2009-10-09 02:01:09 -04:00
2010-01-08 14:29:07 -05:00
def servers
@@ec2.servers
end
2009-10-08 02:45:33 -04:00
def key_pairs
@@ec2.key_pairs
end
2009-10-08 02:45:33 -04:00
def security_groups
@@ec2.security_groups
end
2009-10-15 01:03:31 -04:00
def snapshots
@@ec2.snapshots
end
2009-10-15 01:03:31 -04:00
def volumes
@@ec2.volumes
end
2009-10-15 01:03:31 -04:00
end
2009-10-15 01:03:31 -04:00
end
2009-10-08 02:45:33 -04:00
end
2009-10-15 01:03:31 -04:00
module Rackspace
class << self
key = (ARGV.first && :"#{ARGV.first}") || :default
unless Fog.credentials(key)
print("\n To run as '#{key}', add credentials like the following to ~/.fog\n")
yml = <<-YML
:#{key}:
:aws_access_key_id: INTENTIONALLY_LEFT_BLANK
:aws_secret_access_key: INTENTIONALLY_LEFT_BLANK
:rackspace_api_key: INTENTIONALLY_LEFT_BLANK
:rackspace_username: INTENTIONALLY_LEFT_BLANK
:slicehost_password: INTENTIONALLY_LEFT_BLANK
YML
print(yml)
raise ArgumentError.new("No credentials for :#{key}")
end
if Fog.credentials(key)[:rackspace_api_key] && Fog.credentials(key)[:rackspace_username]
2009-10-15 01:03:31 -04:00
@@servers = Fog::Rackspace::Servers.new(
2009-11-22 17:53:29 -05:00
:rackspace_api_key => Fog.credentials[:rackspace_api_key],
:rackspace_username => Fog.credentials[:rackspace_username]
)
2009-10-15 01:03:31 -04:00
def flavors
@@servers.flavors
end
def images
@@servers.images
end
def servers
@@servers.servers
end
2009-10-15 01:03:31 -04:00
end
end
2009-10-08 02:45:33 -04:00
end
2009-10-02 02:22:47 -04:00
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 }