2013-01-24 12:09:09 -05:00
|
|
|
#!/usr/bin/env ruby
|
|
|
|
|
|
|
|
# This example demonstrates how to delete servers with Fog and the Rackspace Open Cloud
|
|
|
|
|
|
|
|
require 'rubygems' #required for Ruby 1.8.x
|
|
|
|
require 'fog'
|
|
|
|
|
|
|
|
def get_user_input(prompt)
|
|
|
|
print "#{prompt}: "
|
|
|
|
gets.chomp
|
|
|
|
end
|
|
|
|
|
|
|
|
def select_server(servers)
|
2013-03-28 15:38:46 -04:00
|
|
|
abort "\nThere are not any servers to delete in the Chicago region. Try running create_server.rb\n\n" if servers.empty?
|
2013-01-24 12:09:09 -05:00
|
|
|
|
|
|
|
puts "\nSelect Server To Delete:\n\n"
|
|
|
|
servers.each_with_index do |server, i|
|
|
|
|
puts "\t #{i}. #{server.name} [#{server.public_ip_address}]"
|
|
|
|
end
|
|
|
|
|
|
|
|
delete_str = get_user_input "\nEnter Server Number"
|
|
|
|
servers[delete_str.to_i]
|
|
|
|
end
|
|
|
|
|
|
|
|
# Use username defined in ~/.fog file, if absent prompt for username.
|
|
|
|
# For more details on ~/.fog refer to http://fog.io/about/getting_started.html
|
|
|
|
def rackspace_username
|
|
|
|
Fog.credentials[:rackspace_username] || get_user_input("Enter Rackspace Username")
|
|
|
|
end
|
|
|
|
|
|
|
|
# Use api key defined in ~/.fog file, if absent prompt for api key
|
|
|
|
# For more details on ~/.fog refer to http://fog.io/about/getting_started.html
|
|
|
|
def rackspace_api_key
|
|
|
|
Fog.credentials[:rackspace_api_key] || get_user_input("Enter Rackspace API key")
|
|
|
|
end
|
|
|
|
|
|
|
|
#create Next Generation Cloud Server service
|
|
|
|
service = Fog::Compute.new({
|
|
|
|
:provider => 'rackspace',
|
|
|
|
:rackspace_username => rackspace_username,
|
|
|
|
:rackspace_api_key => rackspace_api_key,
|
|
|
|
:version => :v2, # Use Next Gen Cloud Servers
|
2013-03-15 10:11:39 -04:00
|
|
|
:rackspace_region => :ord #Use Chicago Region
|
2013-01-24 12:09:09 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
#retrieve list of servers
|
|
|
|
servers = service.servers
|
|
|
|
|
|
|
|
#prompt user for server
|
|
|
|
server = select_server(servers)
|
|
|
|
|
|
|
|
#destroy server
|
|
|
|
server.destroy
|
|
|
|
|
|
|
|
puts "\nServer #{server.name} has been destroyed\n"
|
|
|
|
|