summaryrefslogtreecommitdiff
path: root/main.tf
diff options
context:
space:
mode:
Diffstat (limited to 'main.tf')
-rw-r--r--main.tf61
1 files changed, 44 insertions, 17 deletions
diff --git a/main.tf b/main.tf
index b131d51..dcad586 100644
--- a/main.tf
+++ b/main.tf
@@ -1,8 +1,9 @@
terraform {
required_providers {
proxmox = {
- source = "telmate/proxmox"
- version = ">=2.0.0"
+ source = "telmate/proxmox"
+ #version = "3.0.1-rc6"
+ version = "2.9.14"
}
}
}
@@ -10,30 +11,56 @@ terraform {
provider "proxmox" {
# Configuration options
#pm_tls_insecure = true
- pm_api_url = "https://pve.example.com:8006/api2/json"
- #pm_user = "root@pam"
- #pm_password = "secret"
- pm_api_token_id = "root@pam!terraform"
- pm_api_token_secret = "350039e6-3f20-4fc2-856d-xxxxd7d"
+ pm_api_url = "https://pve.xlinfo.fr:8006/api2/json"
+ pm_user = "stagiaire@pve"
+ pm_password = "terraform"
+ #pm_api_token_id = "root@pam!terraform"
+ #pm_api_token_secret = "fd186c1f-ede9-4ff9-97bb-012410cb15f5"
}
-resource "proxmox_lxc" "basic" {
- target_node = "pve"
- hostname = "alpine"
- ostemplate = "local:vztmpl/alpine-3.17-default_20221129_amd64.tar.xz"
- password = "secret"
- unprivileged = true
- start = true
+resource "proxmox_lxc" "stagiaire" {
+ target_node = "pve"
+ count = var.nb
+ vmid = var.prem_id + count.index
+ hostname = element(var.prenom, count.index)
+ ostemplate = var.template
+ password = "secret"
+ unprivileged = true
+ start = true
+ ssh_public_keys = <<-EOT
+ ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCZJG/XcIIvW0JOJb6ftEpopS4szOo8dRehASGIOAswPRko6JFMT9QuAvl9YkmzgSorn0KpyQrqAxNTklADocMGPW2BJzKb/1fQyZYKY9bLXxyKaYZKbDZNaUJmW92ThDmUrIWPgjh5BhUxOTwRbDhTsRu/pvulnGw+8yOp7Tz8nUgAoJEZ/7fGkm7AaJPLmF/szQEhL/WSNqTtNdCHNYpQqgRIUZh5zqcb2jXa0pZ7GMnPmoSUMlz1OfAxMOIuziaP3i1J/KHVhXdxj4nrOtUjrUULfqk9vyfKkf7BLYKO3fO3BLR9H5HgeTlaB2aXNuDgRAQposNZ0FEK/VkWj+DQuqjuj9nYo57GbfMfhWr/dTKxTVj3xsbFdThDWtlp7sVI2jguqntwwlmhhexJp1fAYZn92KYkaxGHWLbR0bxLEWVjHXciVW2D12IUZfGWXh5wInoQN1gs1i6NUqgf1uDZhAax5H9G07YySR2fnM9TB5c5apyf7PFCg1kZAnqVHrE= jerome@parrot
+ EOT
- // Terraform will crash without rootfs defined
+ memory = 512
+ swap = 512
+ cores = 1
rootfs {
storage = "local-lvm"
size = "8G"
}
-
network {
name = "eth0"
bridge = "vmbr0"
- ip = "dhcp"
+ ip = "192.168.2.${var.prem_id + count.index}/24"
+ gw = "192.168.2.254"
+ }
+
+ provisioner "remote-exec" {
+ connection {
+ type = "ssh"
+ host = "192.168.2.${var.prem_id + count.index}"
+ user = "root"
+ private_key = file("~/.ssh/id_rsa")
+ timeout = "5m"
+ }
+ inline = [
+ "touch terraform_ok"
+ ]
}
+
+ provisioner "local-exec" {
+ command = "./local_script 192.168.2.${var.prem_id + count.index}"
+ }
+
}
+