1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/lib/fog/aws/models/compute/servers.rb

73 lines
2 KiB
Ruby
Raw Normal View History

2010-03-16 15:46:21 -07:00
require 'fog/collection'
2010-09-08 14:40:02 -07:00
require 'fog/aws/models/compute/server'
2010-03-16 15:46:21 -07:00
2009-09-15 23:11:06 -07:00
module Fog
module AWS
2010-09-08 14:40:02 -07:00
class Compute
2009-09-15 23:11:06 -07:00
2010-01-08 11:29:07 -08:00
class Servers < Fog::Collection
2009-09-15 23:11:06 -07:00
2010-01-08 11:29:07 -08:00
attribute :server_id
2010-09-08 14:40:02 -07:00
model Fog::AWS::Compute::Server
2009-10-08 23:01:09 -07:00
def initialize(attributes)
2010-01-08 11:29:07 -08:00
@server_id ||= []
2009-10-08 23:01:09 -07:00
super
end
2010-01-08 11:29:07 -08:00
def all(server_id = @server_id)
@server_id = server_id
data = connection.describe_instances(server_id).body
load(
data['reservationSet'].map do |reservation|
reservation['instancesSet'].map do |instance|
instance.merge(:groups => reservation['groupSet'])
end
end.flatten
)
2009-09-15 23:11:06 -07:00
end
def bootstrap(new_attributes = {})
2010-09-23 17:39:25 -07:00
server = connection.servers.new(new_attributes)
# first or create fog_#{credential} keypair
2010-09-23 17:39:25 -07:00
unless server.key_pair = connection.key_pairs.get("fog_#{Fog.credential}")
server.key_pair = connection.key_pairs.create(
:name => "fog_#{Fog.credential}",
:public_key => server.public_key
)
end
# make sure port 22 is open in the first security group
security_group = connection.security_groups.get(server.groups.first)
ip_permission = security_group.ip_permissions.detect do |ip_permission|
ip_permission['ipRanges'].first && ip_permission['ipRanges'].first['cidrIp'] == '0.0.0.0/0' &&
ip_permission['fromPort'] == 22 &&
ip_permission['ipProtocol'] == 'tcp' &&
ip_permission['toPort'] == 22
end
unless ip_permission
security_group.authorize_port_range(22..22)
end
2010-09-23 17:39:25 -07:00
server.save
server.wait_for { ready? }
2010-09-23 17:39:25 -07:00
server.setup(:key_data => [server.private_key])
server
end
2010-01-08 11:29:07 -08:00
def get(server_id)
if server_id
all(server_id).first
2009-10-22 20:46:15 -07:00
end
rescue Fog::Errors::NotFound
nil
end
2009-09-15 23:11:06 -07:00
end
end
end
end