Class: Fog::Compute::Google::Disks

Inherits:
Fog::Collection
  • Object
show all
Defined in:
lib/fog/compute/google/models/disks.rb

Instance Method Summary collapse

Instance Method Details

#all(zone: nil, filter: nil, max_results: nil, order_by: nil, page_token: nil) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# File 'lib/fog/compute/google/models/disks.rb', line 7

def all(zone: nil, filter: nil, max_results: nil, order_by: nil,
        page_token: nil)
  opts = {
    :filter => filter,
    :max_results => max_results,
    :order_by => order_by,
    :page_token => page_token
  }
  if zone
    data = service.list_disks(zone, opts).items || []
  else
    data = []
    service.list_aggregated_disks(opts).items.each_value do |scoped_list|
      data.concat(scoped_list.disks) if scoped_list.disks
    end
  end
  load(data.map(&:to_h))
end

#attached_disk_obj(source, writable: true, boot: false, device_name: nil, encryption_key: nil, auto_delete: false) ⇒ Hash

Returns an attached disk configuration hash.

Compute API needs attached disks to be specified in a custom format. This provides a handy shortcut for generating a preformatted config.

Example output:

:boot=>true,
:mode=>"READ_WRITE",
:source=>"https://www.googleapis.com/compute/v1/projects/myproj/zones/us-central1-f/disks/mydisk",
:type=>"PERSISTENT"

See Instances.insert API docs for more info: cloud.google.com/compute/docs/reference/rest/v1/instances/insert

Parameters:

  • source (String)

    self_link of an existing disk resource

  • writable (Boolean) (defaults to: true)

    The mode in which to attach this disk. (defaults to READ_WRITE)

  • boot (Boolean) (defaults to: false)

    Indicates whether this is a boot disk. (defaults to false)

  • device_name (String) (defaults to: nil)

    Specifies a unique device name of your choice that is reflected into the /dev/disk/by-id/google-* tree of a Linux operating system running within the instance.

  • encryption_key (Object) (defaults to: nil)

    Encrypts or decrypts a disk using a customer-supplied encryption key.

  • auto_delete (Object) (defaults to: false)

    Specifies whether the disk will be auto-deleted when the instance is deleted. (defaults to false)

Returns:

  • (Hash)


69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# File 'lib/fog/compute/google/models/disks.rb', line 69

def attached_disk_obj(source,
                      writable: true,
                      boot: false,
                      device_name: nil,
                      encryption_key: nil,
                      auto_delete: false)
  {
    :auto_delete => auto_delete,
    :boot => boot,
    :device_name => device_name,
    :disk_encryption_key => encryption_key,
    :mode => writable ? "READ_WRITE" : "READ_ONLY",
    :source => source,
    :type => "PERSISTENT"
  }.reject { |_k, v| v.nil? }
end

#get(identity, zone = nil) ⇒ Object



26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/fog/compute/google/models/disks.rb', line 26

def get(identity, zone = nil)
  if zone
    disk = service.get_disk(identity, zone).to_h
    return new(disk)
  elsif identity
    response = all(:filter => "name eq #{identity}",
                   :max_results => 1)
    disk = response.first unless response.empty?
    return disk
  end
rescue ::Google::Apis::ClientError => e
  raise e unless e.status_code == 404
  nil
end