Skip to content

Releases: Binsabbar/oracle-cloud-terraform

v2.12.0

22 Jan 09:54
a95fd9b
Compare
Choose a tag to compare

New

  • instances: Add option to enable/disable cloud agent plugins.
    • new agent_plugins setting
  • network: Configure VCN DNS Resolver with attaching Private custom list of object of views, earlier views in the list have higher priority in resolution.
    • new dns_private_views setting
  • dns-management: support to create custom dns views and edit existing protected views

Fix

None

Breaking Changes

  • dns-management Add support to create private custom view or edit existing protected views, also module input is changed completely it now requires two objects protected_views or custom_views under each map of object of views, under each you define map of object of zones and under each zone you define map of object of records.
  • WARNING: This change will destroy and recreate all the DNS resources and will cause connection issue untill new resources created.

from:

module "dns" {
  ...
  compartment_id = "ocid1.compartment.oc1..example1"
  view_id        = "ocid1.dnsview.oc1..example1"
  zones          = {
    // ZONE 1
    "test" = {
      name = "test.com"
    }
    // ZONE 2
    "test-2" = {
      name = "test-2.com"
    }
  }

  records       = {
    // RECORD 1
    "test" = {
      domain_name = "*.test.com"
      rtype       = "A"
      zone_name   = "test.com"
      rdata       = "xxx.xxx.xxx.xxx"
      ttl         = 300
    }
    // RECORD 2
    "test-2" = {
      domain_name = "something.test-2.com"
      rtype       = "A"
      zone_name   = "test-2.com"
      rdata       = "xxx.xxx.xxx.xxx"
      ttl         = 300
    }
  }
}

to:

module "dns" {
  ...
  private_dns = {
    protected_views = {
      "stage_protected_views" = {
        view_id        = "ocid1.dnsview.oc1..example1"
        compartment_id = "ocid1.compartment.oc1..example1"
        zones = {
          "test-com" = {
            zone_name = "test.com"
            records = {
              "test" = {
                domain_name = "*.test.com"
                rdata      = "xxx.xxx.xxx.xxx"
                # rtype and ttl will use defaults (A and 300)
              }
            }
          }
          "test-2-com" = {
            zone_name = "test-2.com"
            records = {
              "test-2" = {
                domain_name = "something.test-2.com"
                rdata      = "xxx.xxx.xxx.xxx"
              }
            }
          }
        }
      }
    }
    custom_views = {}
  }
}

New Contributors

Full Changelog: v2.11.0...v2.12.0

v2.11.0

13 Oct 21:33
eb02526
Compare
Choose a tag to compare

New

  • network-sg: add support for all rule types: ip cidrs, service cidrs and nsg ids.
    • see the example in the module for how to use the new variable.
    • the default value is CIDR_BLOCK to ensure backward compatibility.
    • add new variables:
      • var.network_security_groups.*.*.type
      • var.network_security_groups.*.*.ips
      • var.network_security_groups.*.*.nsg_ids
      • var.network_security_groups.*.*.service_cidrs
    • They are optional based on the type, if type is not set, then var.network_security_groups.*.*.ips becomes mandatory.
  • kubernetes: Ability to add user defined tags for OKE nodes by using the optional variable node_pools.*.defined_tags

Fix

  • instances: Ignore changes made to metadata.user_data in any instance, since changing the value will destroy and recreate the instance.
resource "oci_core_instance" "instances" {
  ...
  ...
  metadata = {
    ssh_authorized_keys = each.value.autherized_keys
    user_data           = lookup(each.value.optionals, "user_data", null)
  }
  lifecycle {
    ignore_changes = [
      metadata["user_data"]   <------------------------------ note this 
    ]
  }
}

Breaking Changes

None

Full Changelog: v2.10.0...v2.11.0

v2.10.0

15 Nov 11:37
04a0c04
Compare
Choose a tag to compare

New

  • network-sg: change input type to support ports range in var.network_security_groups.*.ports variable.

Fix

None

Breaking Changes

  • network-sg modules input for network_security_groups is updated. The subkey port is replaced with ports and it is now a map of two objects max and min.
network_security_groups = {
    "group_1" = {
      "rule_1" = {
        direction = "INGRESS"
        protocol  = "tcp"
        port      = { min : 9090, max : 9090 }
        ips       = ["192.168.100.12", "192.168.100.12"]
      }
    }
}
  • Currently there is no easy migration path for this change, since the terraform resource name is updated. However, destroying and recreating the rules is the best and fastest way to do it, however, it might impact your networks for few minutes. Alternatively, reference the new release in a new module definition, and migration your rules one by one.

Full Changelog: v2.9.0...v2.10.0

v2.9.0

05 Nov 13:33
718ae6f
Compare
Choose a tag to compare

New

  • identity: add new argument capabilities in var.service_accounts variable.

Fix

  • Correct path argument by source argument to specify the module path in identity module usage examples in README.md.

Breaking Changes

  • identity modules input for service_accounts is updated. A new key capabilities is now required under var.service_accounts.*.
    • Add capabilities and set its value to {}.

from:

module "identity" {
 ...
 service_accounts = toset(["terraform-cli"])
 ...
}

to:

module "identity" {
 ...
 service_accounts = {
   "terraform-cli" = { 
     name = "terraform-cli", 
     capabilities = {}
   }
 }
 ...
}

Full Changelog: v2.8.0...v2.9.0

v2.8.0

11 Oct 13:39
Compare
Choose a tag to compare

v2.8.0:

New

  • instances: add new argument availability_config. for VM migration during infrastructure maintenance events

Fix

None

Breaking Changes

  • instances modules input is updated. A new key availability_config is now required under var.instances.*.config.
    • Add is_live_migration_preferred and set its value to true. Example of partial instance object.
    • Add recovery_action and set its value to RESTORE_INSTANCE. Example of partial instance object.
 instances = {
   ...
   ...
   ...
      network_sgs_ids = [
          "ocixxxxxx.xxxxxx.xxxxx", "ocixxxxxx.xxxxxx.xxxxx",
        ]
        primary_vnic = {
          primary_ip = ""
          secondary_ips = {}
        }
        availability_config   = {   <--------------------------------------------------- note this block 
          recovery_action             = "RESTORE_INSTANCE"  
          is_live_migration_preferred = false
        }
      }
    ...
    ...

v2.7.1

14 Sep 11:36
Compare
Choose a tag to compare

v2.7.1:

New

None

Fix

Change VNIC's skip_source_dest_check to an optional variable input.

Breaking Changes

None

v2.7.0

06 Aug 11:55
Compare
Choose a tag to compare

v2.7.0:

New

  • instances: add boot_volume_backup_policies to the input as optional value.
  • instances: add instances[*].optional.reference_to_backup_policy_key_name to the instance variable input as optional value to enable scheduled backup of boot volume

Fix

None

Breaking Changes

None

v2.6.1

20 Mar 09:08
Compare
Choose a tag to compare

v2.6.1:

New

  • instances: add hostname_label to the output

Fix

None

Breaking Changes

None

v2.6.0

05 Mar 09:22
Compare
Choose a tag to compare

v2.6.0

New

  • dns: add ability to manage dns records in oci dns service

Fix

None

Breaking Changes

None

v2.5.0

07 Feb 08:55
Compare
Choose a tag to compare

v2.5.0:

New

Fix

None

Breaking Changes

  • network modules input is updated. A new key add_route_rule_in_public_subnet is now required under var.service_gateway.
    • Add add_route_rule_in_public_subnet and set its value to false. See module's readme for full example.
service_gateway = {
  enable = true
  service_id = "ocid1.service.oc1.xxxxxxx"
  route_rule_destination = "all-pox-services-in-oracle-services-network"
  add_route_rule_in_public_subnet = false <-------------------------------------- note this line
  optionals     = {
    route_table_id = "oci.xxxxxxxxx"
  }
}