class Fog::Compute::DigitalOcean::Servers

Public Instance Methods

all(filters = {}) click to toggle source
# File lib/fog/digitalocean/models/compute/servers.rb, line 10
def all(filters = {})
  data = service.list_servers.body['droplets']
  load(data)
end
bootstrap(new_attributes = {}) click to toggle source
# File lib/fog/digitalocean/models/compute/servers.rb, line 15
def bootstrap(new_attributes = {})
  server = new(new_attributes)

  check_keys(new_attributes)

  credential = Fog.respond_to?(:credential) && Fog.credential || :default
  name       = "fog_#{credential}"
  ssh_key    = service.ssh_keys.find { |key| key.name == name }
  if ssh_key.nil?
    ssh_key = service.ssh_keys.create(
      :name        => name,
      :ssh_pub_key => (new_attributes[:public_key] || File.read(new_attributes[:public_key_path]))
    )
  end
  server.ssh_keys = [ssh_key]

  server.save
  server.wait_for { ready? }

  if new_attributes[:private_key]
    server.setup :key_data => [new_attributes[:private_key]]
  else
    server.setup :keys => [new_attributes[:private_key_path]]
  end

  server
end
get(id) click to toggle source
# File lib/fog/digitalocean/models/compute/servers.rb, line 43
def get(id)
  server = service.get_server_details(id).body['droplet']
  new(server) if server
rescue Fog::Errors::NotFound
  nil
end

Protected Instance Methods

check_key(name, data, path) click to toggle source
# File lib/fog/digitalocean/models/compute/servers.rb, line 57
def check_key(name, data, path)
  if [data, path].all?(&:nil?)
    raise ArgumentError, "either #{name}_key or #{name}_key_path is required to configure the server"
  end
end
check_keys(attributes) click to toggle source
# File lib/fog/digitalocean/models/compute/servers.rb, line 52
def check_keys(attributes)
  check_key :public, attributes[:public_key], attributes[:public_key_path]
  check_key :private, attributes[:private_key], attributes[:private_key_path]
end