Module: Capistrano::Configuration::GetServers

Included in:
Capistrano::Configuration
Defined in:
lib/capistrano-getservers/get_servers.rb

Instance Method Summary collapse

Instance Method Details

#get_servers(role = nil, region = nil, cli_tags, aws_access_key, aws_secret_key) ⇒ Object

def get_servers

Purpose: Retrieves a list of EC2 instances containing a tag

list which matches a supplied hash.

Matching instances are applied to the Cap server
list.

Usage: get_servers => ‘zumba’, ‘stack’ => ‘web’

Returns: Nothing



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/capistrano-getservers/get_servers.rb', line 24

def get_servers(role=nil, region=nil, cli_tags, aws_access_key, aws_secret_key)

  ec2 = Fog::Compute::AWS.new(
    aws_secret_access_key: aws_secret_key,
    aws_access_key_id: aws_access_key,
    region: region
  )

  ec2.servers.all.each do |instance|
    begin
      instance_tags = instance.tags.reject { |k,v| cli_tags[k] != instance.tags[k] }
      server instance.public_ip_address, role || :web if instance_tags.eql? cli_tags
    rescue => error
    end
  end

end

#parse(tags) ⇒ Object

def parse

Purpose: Parses a string object and returns a hash.

Usage: parse ‘k1:v1,k2:v2,k3:v3’

Returns: => ‘v1’, ‘k2’ => ‘v2’, ‘k3’ => ‘v3’



51
52
53
54
# File 'lib/capistrano-getservers/get_servers.rb', line 51

def parse tags
  return unless tags.class.eql? String
  tags.split(',').each.inject({}) { |hash, pair| hash.merge! Hash[*pair.split(':').flatten] }
end