From ef90de6f3d9188dac81d19d1e5ceab33c9b80963 Mon Sep 17 00:00:00 2001 From: gitops_test Date: Fri, 23 Jan 2026 11:33:22 +0000 Subject: [PATCH] Add cloud_privisioner_template_terraform_20260123_113322.tf --- ...oner_template_terraform_20260123_113322.tf | 74 +++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 cloud_privisioner_template_terraform_20260123_113322.tf diff --git a/cloud_privisioner_template_terraform_20260123_113322.tf b/cloud_privisioner_template_terraform_20260123_113322.tf new file mode 100644 index 0000000..695a075 --- /dev/null +++ b/cloud_privisioner_template_terraform_20260123_113322.tf @@ -0,0 +1,74 @@ +terraform { + required_providers { + ovh = { + source = "ovh/ovh" + version = "2.3.0" + } + } +} + +provider "ovh" { + endpoint = "ovh-eu" +} + +variable "local_project_id" { + type = string + default = "var.simpl_project_id" +} + +variable "local_region" { + type = string + default = "var.simpl_region" +} + +# The flavor can be selected directly, name_filter in DS does strict equality +data "ovh_cloud_project_flavors" "flavors" { + service_name = var.local_project_id + name_filter = "var.simpl_flavor" + region = var.local_region +} + +# The image must be selected from its region based list using name filtering +data "ovh_cloud_project_images" "image" { + service_name = var.local_project_id + region = var.local_region +} + +locals { + selected_image = one([ + for m in data.ovh_cloud_project_images.image.images : m if m.name == "var.simpl_image" + ]) + selected_flavor = one(data.ovh_cloud_project_flavors.flavors.flavors) +} + +resource "ovh_cloud_project_instance" "simpl_vm" { + service_name = var.local_project_id + region = var.local_region + billing_period = "hourly" + + boot_from { + image_id = local.selected_image.id + } + + flavor { + flavor_id = local.selected_flavor.id + } + + name = "offering-enterprise-server-{UUID}-terraform" + + ssh_key_create { + name = "default-user-key" + public_key = "var.simpl_ssh_public_key" + } + + network { + public = true + } + + user_data = "var.simpl_cloud_init" +} + +output "vmIps" { + depends_on = [ovh_cloud_project_instance.simpl_vm] + value = tolist(ovh_cloud_project_instance.simpl_vm.addresses[*].ip) +}