Class: Piculet::EC2Wrapper::SecurityGroupCollection::SecurityGroup

Inherits:
Object
  • Object
show all
Extended by:
Forwardable
Includes:
Logger::ClientHelper
Defined in:
lib/piculet/wrapper/permission.rb,
lib/piculet/wrapper/security-group.rb,
lib/piculet/wrapper/permission-collection.rb

Defined Under Namespace

Classes: PermissionCollection

Instance Method Summary collapse

Methods included from Logger::ClientHelper

#log

Constructor Details

#initialize(security_group, options) ⇒ SecurityGroup

Returns a new instance of SecurityGroup.



16
17
18
19
# File 'lib/piculet/wrapper/security-group.rb', line 16

def initialize(security_group, options)
  @security_group = security_group
  @options = options
end

Instance Method Details

#deleteObject



33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/piculet/wrapper/security-group.rb', line 33

def delete
  log(:info, 'Delete SecurityGroup', :red, "#{vpc_id || :classic} > #{name}")

  if name == 'default'
    log(:warn, 'SecurityGroup `default` is reserved', :yellow)
  else
    unless @options.dry_run
      @security_group.delete
      @options.updated = true
    end
  end
end

#egress_ip_permissionsObject



50
51
52
# File 'lib/piculet/wrapper/security-group.rb', line 50

def egress_ip_permissions
  PermissionCollection.new(@security_group, :egress, @options)
end

#eql?(dsl) ⇒ Boolean

Returns:

  • (Boolean)


21
22
23
# File 'lib/piculet/wrapper/security-group.rb', line 21

def eql?(dsl)
  @security_group.description == dsl.description
end

#ingress_ip_permissionsObject



46
47
48
# File 'lib/piculet/wrapper/security-group.rb', line 46

def ingress_ip_permissions
  PermissionCollection.new(@security_group, :ingress, @options)
end

#update(dsl) ⇒ Object



25
26
27
28
29
30
31
# File 'lib/piculet/wrapper/security-group.rb', line 25

def update(dsl)
  if @security_group.description != dsl.description
    log(:warn, '`description` cannot be updated', :yellow, "#{vpc_id || :classic} > #{name}")
  end

  # XXX:
end