mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
93 lines
2 KiB
Ruby
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
|