» digitalocean_sizes

Retrieves information about droplet sizes that DigitalOcean supports. This data source provides all of droplet size properties, with the ability to filter and sort the results.

» Example Usage

Most common usage will probably be to supply a size to droplet:

data "digitalocean_sizes" "main" {
  filter {
    key    = "slug"
    values = ["s-1vcpu-1gb"]
  }
}

resource "digitalocean_droplet" "web" {
  image  = "ubuntu-18-04-x64"
  name   = "web-1"
  region = "sgp1"
  size   = element(data.digitalocean_sizes.main.sizes, 0).slug
}

The data source also supports multiple filters and sorts. For example, to fetch sizes with 1 or 2 virtual CPU that are available "sgp1" region, then pick the cheapest one:

data "digitalocean_sizes" "main" {
  filter {
    key    = "vcpus"
    values = [1, 2]
  }

  filter {
    key    = "regions"
    values = ["sgp1"]
  }

  sort {
    key       = "price_monthly"
    direction = "asc"
  }
}

resource "digitalocean_droplet" "web" {
  image  = "ubuntu-18-04-x64"
  name   = "web-1"
  region = "sgp1"
  size   = element(data.digitalocean_sizes.main.sizes, 0).slug
}

The data source can also handle multiple sorts. In which case, the sort will be applied in the order it is defined. For example, to sort by memory in ascending order, then sort by disk in descending order between sizes with same memory:

data "digitalocean_sizes" "main" {
  sort {
    // Sort by memory ascendingly
    key       = "memory"
    direction = "asc"
  }

  sort {
    // Then sort by disk descendingly for sizes with same memory
    key       = "disk"
    direction = "desc"
  }
}

» Argument Reference

The following arguments are supported:

  • filter - (Optional) Filter the results. The filter block is documented below.
  • sort - (Optional) Sort the results. The sort block is documented below.

filter supports the following:

  • key - (Required) Filter the sizes by this key. This may be one of slug, regions, memory, vcpus, disk, transfer, price_monthly, price_hourly, or available.
  • values - (Required) Only retrieves images which keys has value that matches one of the values provided here.

sort supports the following:

  • key - (Required) Sort the sizes by this key. This may be one of slug, memory, vcpus, disk, transfer, price_monthly, or price_hourly.
  • direction - (Required) The sort direction. This may be either asc or desc.

» Attributes Reference

The following attributes are exported:

  • slug - A human-readable string that is used to uniquely identify each size.
  • available - This represents whether new Droplets can be created with this size.
  • transfer - The amount of transfer bandwidth that is available for Droplets created in this size. This only counts traffic on the public interface. The value is given in terabytes.
  • price_monthly - The monthly cost of Droplets created in this size if they are kept for an entire month. The value is measured in US dollars.
  • price_hourly - The hourly cost of Droplets created in this size as measured hourly. The value is measured in US dollars.
  • memory - The amount of RAM allocated to Droplets created of this size. The value is measured in megabytes.
  • vcpus - The number of CPUs allocated to Droplets of this size.
  • disk - The amount of disk space set aside for Droplets of this size. The value is measured in gigabytes.
  • regions - List of region slugs where Droplets can be created in this size.