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/vpcs.rb
2012-03-05 22:47:10 -05:00

93 lines
2 KiB
Ruby

require 'fog/core/collection'
require 'fog/aws/models/compute/vpc'
module Fog
module Compute
class AWS
class Vpcs < Fog::Collection
attribute :filters
model Fog::Compute::AWS::VPC
# Creates a new VPC
#
# AWS.vpcs.new
#
# ==== Returns
#
# Returns the details of the new VPC
#
#>> AWS.vpcs.new
# <Fog::AWS::VPC::VPC
# id=nil,
# state=nil,
# cidr_block=nil,
# dhcp_options_id=nil
# tags=nil
# tenancy=nil
# >
#
def initialize(attributes)
self.filters ||= {}
super
end
# Returns an array of all VPCs that have been created
#
# AWS.vpcs.all
#
# ==== Returns
#
# Returns an array of all VPCs
#
#>> AWS.vpcs.all
# <Fog::AWS::VPC::VPCs
# filters={}
# [
# <Fog::AWS::VPC::VPC
# id="vpc-12345678",
# TODO
# >
# ]
# >
#
def all(filters = filters)
unless filters.is_a?(Hash)
Fog::Logger.warning("all with #{filters.class} param is deprecated, use all('vpc-id' => []) instead [light_black](#{caller.first})[/]")
filters = {'vpc-id' => [*filters]}
end
self.filters = filters
data = connection.describe_vpcs(filters).body
load(data['vpcSet'])
end
# Used to retreive a VPC
# vpc_id is required to get the associated VPC information.
#
# You can run the following command to get the details:
# AWS.vpcs.get("vpc-12345678")
#
# ==== Returns
#
#>> AWS.vpcs.get("vpc-12345678")
# <Fog::AWS::Compute::VPC
# id="vpc-12345678",
# TODO
# >
#
def get(vpc_id)
if vpc_id
self.class.new(:connection => connection).all('vpc-id' => vpc_id).first
end
end
end
end
end
end