Christian 4 лет назад
Родитель
Сommit
ebab652abf
55 измененных файлов с 538 добавлено и 13 удалено
  1. 0 0
      helm/certmanager/README.md
  2. 0 0
      helm/certmanager/default-values.yml
  3. 0 0
      helm/certmanager/templates/clusterissuer-acme.yml
  4. 0 0
      helm/certmanager/templates/clusterissuer-selfsigned.yml
  5. 0 0
      helm/certmanager/templates/issuer-acme.yml
  6. 0 0
      helm/certmanager/templates/issuer-selfsigned.yml
  7. 0 0
      helm/certmanager/templates/secret-cloudflare.yml
  8. 0 0
      helm/portainer/README.md
  9. 0 0
      helm/portainer/templates/portainer-ingress.yml
  10. 0 0
      helm/portainer/values.yml
  11. 0 0
      helm/traefik/README.md
  12. 0 0
      helm/traefik/templates/ingress.yml
  13. 0 0
      helm/traefik/values.yml
  14. 0 0
      kubectl/nginx-http/nginx-http-cm.yml
  15. 0 0
      kubectl/nginx-http/nginx-http-deploy.yml
  16. 0 0
      kubectl/nginx-http/nginx-http-svc.yml
  17. 0 0
      kubectl/templates/certificate.yaml
  18. 0 0
      kubectl/templates/cm-and-secrets/mysql-deploy.yml
  19. 0 0
      kubectl/templates/cm-and-secrets/mysql-secret.yml
  20. 28 0
      kubectl/templates/cm-and-secrets/nginx-http-cm.yml
  21. 32 0
      kubectl/templates/cm-and-secrets/nginx-http-deploy.yml
  22. 15 0
      kubectl/templates/cm-and-secrets/nginx-http-svc.yml
  23. 0 0
      kubectl/templates/cm-and-secrets/nginx-https-cm.yml
  24. 0 0
      kubectl/templates/cm-and-secrets/nginx-https-deploy.yml
  25. 0 0
      kubectl/templates/cm-and-secrets/nginx-https-secret-blank.yml
  26. 0 0
      kubectl/templates/cm-and-secrets/nginx-https-svc.yml
  27. 0 0
      kubectl/templates/deployment.yaml
  28. 0 0
      kubectl/templates/ingress.yaml
  29. 0 0
      kubectl/templates/ingressroute-http.yaml
  30. 0 0
      kubectl/templates/ingressroute-https.yaml
  31. 0 0
      kubectl/templates/ingressroute-redirectscheme.yaml
  32. 0 0
      kubectl/templates/persistentvolumeclaim.yaml
  33. 0 0
      kubectl/templates/pv-and-pvc/civo-pvc.yml
  34. 0 0
      kubectl/templates/pv-and-pvc/civo-web.yml
  35. 0 0
      kubectl/templates/pv-and-pvc/local-web.yml
  36. 0 0
      kubectl/templates/pv-and-pvc/nfs-pv.yml
  37. 0 0
      kubectl/templates/pv-and-pvc/nfs-pvc.yml
  38. 0 0
      kubectl/templates/pv-and-pvc/nfs-web.yml
  39. 0 0
      kubectl/templates/service.yaml
  40. 0 0
      packer/proxmox/README.md
  41. 3 0
      packer/proxmox/credentials.pkr.hcl
  42. 1 0
      packer/proxmox/ubuntu-server-focal-docker/files/99-pve.cfg
  43. 0 0
      packer/proxmox/ubuntu-server-focal-docker/http/meta-data
  44. 33 0
      packer/proxmox/ubuntu-server-focal-docker/http/user-data
  45. 148 0
      packer/proxmox/ubuntu-server-focal-docker/ubuntu-server-focal-docker.pkr.hcl
  46. 1 0
      packer/proxmox/ubuntu-server-focal/files/99-pve.cfg
  47. 0 0
      packer/proxmox/ubuntu-server-focal/http/meta-data
  48. 33 0
      packer/proxmox/ubuntu-server-focal/http/user-data
  49. 140 0
      packer/proxmox/ubuntu-server-focal/ubuntu-server-focal.pkr.hcl
  50. 1 1
      terraform/cloudflare/credentials.tf
  51. 13 12
      terraform/kubernetes/provider.tf
  52. 0 0
      terraform/proxmox/README.md
  53. 3 0
      terraform/proxmox/credentails.tfvars
  54. 49 0
      terraform/proxmox/full-clone.tf
  55. 38 0
      terraform/proxmox/provider.tf

+ 0 - 0
kubernetes/certmanager/README.md → helm/certmanager/README.md


+ 0 - 0
kubernetes/certmanager/default-values.yml → helm/certmanager/default-values.yml


+ 0 - 0
kubernetes/certmanager/templates/clusterissuer-acme.yml → helm/certmanager/templates/clusterissuer-acme.yml


+ 0 - 0
kubernetes/certmanager/templates/clusterissuer-selfsigned.yml → helm/certmanager/templates/clusterissuer-selfsigned.yml


+ 0 - 0
kubernetes/certmanager/templates/issuer-acme.yml → helm/certmanager/templates/issuer-acme.yml


+ 0 - 0
kubernetes/certmanager/templates/issuer-selfsigned.yml → helm/certmanager/templates/issuer-selfsigned.yml


+ 0 - 0
kubernetes/certmanager/templates/secret-cloudflare.yml → helm/certmanager/templates/secret-cloudflare.yml


+ 0 - 0
kubernetes/portainer/README.md → helm/portainer/README.md


+ 0 - 0
kubernetes/portainer/templates/portainer-ingress.yml → helm/portainer/templates/portainer-ingress.yml


+ 0 - 0
kubernetes/portainer/values.yml → helm/portainer/values.yml


+ 0 - 0
kubernetes/traefik/README.md → helm/traefik/README.md


+ 0 - 0
kubernetes/traefik/templates/ingress.yml → helm/traefik/templates/ingress.yml


+ 0 - 0
kubernetes/traefik/values.yml → helm/traefik/values.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-http-cm.yml → kubectl/nginx-http/nginx-http-cm.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-http-deploy.yml → kubectl/nginx-http/nginx-http-deploy.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-http-svc.yml → kubectl/nginx-http/nginx-http-svc.yml


+ 0 - 0
kubernetes/templates/certificate.yaml → kubectl/templates/certificate.yaml


+ 0 - 0
kubernetes/templates/cm-and-secrets/mysql-deploy.yml → kubectl/templates/cm-and-secrets/mysql-deploy.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/mysql-secret.yml → kubectl/templates/cm-and-secrets/mysql-secret.yml


+ 28 - 0
kubectl/templates/cm-and-secrets/nginx-http-cm.yml

@@ -0,0 +1,28 @@
+apiVersion: v1
+kind: ConfigMap
+metadata:
+  name: nginx-http-cm
+data:
+  # key: value
+  # file: |
+  #   content
+  # ---
+  nginx.conf: |
+    user nginx;
+    worker_processes 1;
+    events {
+      worker_connections  10240;
+    }
+    http {
+      server {
+        listen       80;
+        server_name  _;
+        location / {
+          root   /usr/share/nginx/html;
+          index  index.html index.htm;
+        }
+        location /test {
+          return 401;
+        }
+      }
+    }

+ 32 - 0
kubectl/templates/cm-and-secrets/nginx-http-deploy.yml

@@ -0,0 +1,32 @@
+apiVersion: apps/v1
+kind: Deployment
+metadata:
+  name: nginx-http
+spec:
+  replicas: 1
+  selector:
+    matchLabels: 
+      app: nginx-http
+  template:
+    metadata:
+      labels:
+        app: nginx-http
+    spec:
+      containers:
+      - name: nginx-http
+        image: nginx
+        ports:
+        - name: web
+          containerPort: 80
+        volumeMounts:
+        - name: nginx-http-cm
+          mountPath: /etc/nginx
+        - name: nginx-http-vol
+          mountPath: /usr/share/nginx/html
+      volumes:
+      - name: nginx-http-cm
+        configMap:
+          name: nginx-http-cm
+      - name: nginx-http-vol
+        hostPath:
+          path: /var/nginxserver

+ 15 - 0
kubectl/templates/cm-and-secrets/nginx-http-svc.yml

@@ -0,0 +1,15 @@
+apiVersion: v1
+kind: Service
+metadata:
+  name: nginx-http-svc
+  labels:
+    app: nginx-http
+spec:
+  type: LoadBalancer
+  ports:
+  - port: 30080
+    targetPort: 80
+    protocol: TCP
+    name: http
+  selector:
+    app: nginx-http

+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-https-cm.yml → kubectl/templates/cm-and-secrets/nginx-https-cm.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-https-deploy.yml → kubectl/templates/cm-and-secrets/nginx-https-deploy.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-https-secret-blank.yml → kubectl/templates/cm-and-secrets/nginx-https-secret-blank.yml


+ 0 - 0
kubernetes/templates/cm-and-secrets/nginx-https-svc.yml → kubectl/templates/cm-and-secrets/nginx-https-svc.yml


+ 0 - 0
kubernetes/templates/deployment.yaml → kubectl/templates/deployment.yaml


+ 0 - 0
kubernetes/templates/ingress.yaml → kubectl/templates/ingress.yaml


+ 0 - 0
kubernetes/templates/ingressroute-http.yaml → kubectl/templates/ingressroute-http.yaml


+ 0 - 0
kubernetes/templates/ingressroute-https.yaml → kubectl/templates/ingressroute-https.yaml


+ 0 - 0
kubernetes/templates/ingressroute-redirectscheme.yaml → kubectl/templates/ingressroute-redirectscheme.yaml


+ 0 - 0
kubernetes/templates/persistentvolumeclaim.yaml → kubectl/templates/persistentvolumeclaim.yaml


+ 0 - 0
kubernetes/templates/pv-and-pvc/civo-pvc.yml → kubectl/templates/pv-and-pvc/civo-pvc.yml


+ 0 - 0
kubernetes/templates/pv-and-pvc/civo-web.yml → kubectl/templates/pv-and-pvc/civo-web.yml


+ 0 - 0
kubernetes/templates/pv-and-pvc/local-web.yml → kubectl/templates/pv-and-pvc/local-web.yml


+ 0 - 0
kubernetes/templates/pv-and-pvc/nfs-pv.yml → kubectl/templates/pv-and-pvc/nfs-pv.yml


+ 0 - 0
kubernetes/templates/pv-and-pvc/nfs-pvc.yml → kubectl/templates/pv-and-pvc/nfs-pvc.yml


+ 0 - 0
kubernetes/templates/pv-and-pvc/nfs-web.yml → kubectl/templates/pv-and-pvc/nfs-web.yml


+ 0 - 0
kubernetes/templates/service.yaml → kubectl/templates/service.yaml


+ 0 - 0
packer/proxmox/README.md


+ 3 - 0
packer/proxmox/credentials.pkr.hcl

@@ -0,0 +1,3 @@
+proxmox_api_url = "https://0.0.0.0:8006/api2/json"  # Your Proxmox IP Address
+proxmox_api_token_id = "terraform@pam!terraform"  # API Token ID
+proxmox_api_token_secret = "your-api-token-secret"

+ 1 - 0
packer/proxmox/ubuntu-server-focal-docker/files/99-pve.cfg

@@ -0,0 +1 @@
+datasource_list: [ConfigDrive, NoCloud]

+ 0 - 0
packer/proxmox/ubuntu-server-focal-docker/http/meta-data


+ 33 - 0
packer/proxmox/ubuntu-server-focal-docker/http/user-data

@@ -0,0 +1,33 @@
+#cloud-config
+autoinstall:
+  version: 1
+  locale: en_US
+  keyboard:
+    layout: de
+  ssh:
+    install-server: true
+    allow-pw: true
+    disable_root: true
+    ssh_quiet_keygen: true
+    allow_public_ssh_keys: true
+  packages:
+    - qemu-guest-agent
+    - sudo
+  storage:
+    layout:
+      name: direct
+    swap:
+      size: 0
+  user-data:
+    package_upgrade: false
+    timezone: Europe/Berlin
+    users:
+      - name: your-user-name
+        groups: [adm, sudo]
+        lock-passwd: false
+        sudo: ALL=(ALL) NOPASSWD:ALL
+        shell: /bin/bash
+        # passwd: your-password
+        # - or -
+        # ssh_authorized_keys:
+        #   - your-ssh-key

+ 148 - 0
packer/proxmox/ubuntu-server-focal-docker/ubuntu-server-focal-docker.pkr.hcl

@@ -0,0 +1,148 @@
+# Ubuntu Server Focal Docker
+# ---
+# Packer Template to create an Ubuntu Server (Focal) with Docker on Proxmox
+
+# Variable Definitions
+variable "proxmox_api_url" {
+    type = string
+}
+
+variable "proxmox_api_token_id" {
+    type = string
+}
+
+variable "proxmox_api_token_secret" {
+    type = string
+    sensitive = true
+}
+
+# Resource Definiation for the VM Template
+source "proxmox" "ubuntu-server-focal-docker" {
+ 
+    # Proxmox Connection Settings
+    proxmox_url = "${var.proxmox_api_url}"
+    username = "${var.proxmox_api_token_id}"
+    token = "${var.proxmox_api_token_secret}"
+    # (Optional) Skip TLS Verification
+    # insecure_skip_tls_verify = true
+    
+    # VM General Settings
+    node = "your-proxmox-node"
+    vm_id = "100"
+    vm_name = "ubuntu-server-focal-docker"
+    template_description = "Ubuntu Server Focal Image with Docker pre-installed"
+
+    # VM OS Settings
+    # (Option 1) Local ISO File
+    # iso_file = "local:iso/ubuntu-20.04.2-live-server-amd64.iso"
+    # - or -
+    # (Option 2) Download ISO
+    # iso_url = "https://releases.ubuntu.com/20.04/ubuntu-20.04.3-live-server-amd64.iso"
+    # iso_checksum = "f8e3086f3cea0fb3fefb29937ab5ed9d19e767079633960ccb50e76153effc98"
+    iso_storage_pool = "local"
+    unmount_iso = true
+
+    # VM System Settings
+    qemu_agent = true
+
+    # VM Hard Disk Settings
+    scsi_controller = "virtio-scsi-pci"
+
+    disks {
+        disk_size = "20G"
+        format = "qcow2"
+        storage_pool = "local-lvm"
+        storage_pool_type = "lvm"
+        type = "sata"
+    }
+
+    # VM CPU Settings
+    cores = "1"
+    
+    # VM Memory Settings
+    memory = "2048" 
+
+    # VM Network Settings
+    network_adapters {
+        model = "virtio"
+        bridge = "vmbr0"
+        firewall = "false"
+    } 
+
+    # VM Cloud-Init Settings
+    cloud_init = true
+    cloud_init_storage_pool = "local-lvm"
+
+    # PACKER Boot Commands
+    boot_command = [
+        "<esc><wait><esc><wait>",
+        "<f6><wait><esc><wait>",
+        "<bs><bs><bs><bs><bs>",
+        "autoinstall ds=nocloud-net;s=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ ",
+        "--- <enter>"
+    ]
+    boot = "c"
+    boot_wait = "5s"
+
+    # PACKER Autoinstall Settings
+    http_directory = "http" 
+    # (Optional) Bind IP Address and Port
+    # http_bind_address = "0.0.0.0"
+    # http_port_min = 8802
+    # http_port_max = 8802
+
+    ssh_username = "your-user-name"
+
+    # (Option 1) Add your Password here
+    # ssh_password = "your-password"
+    # - or -
+    # (Option 2) Add your Private SSH KEY file here
+    # ssh_private_key_file = "~/.ssh/id_rsa"
+
+    # Raise the timeout, when installation takes longer
+    ssh_timeout = "20m"
+}
+
+# Build Definition to create the VM Template
+build {
+
+    name = "ubuntu-server-focal-docker"
+    sources = ["source.proxmox.ubuntu-server-focal-docker"]
+
+    # Provisioning the VM Template for Cloud-Init Integration in Proxmox #1
+    provisioner "shell" {
+        inline = [
+            "while [ ! -f /var/lib/cloud/instance/boot-finished ]; do echo 'Waiting for cloud-init...'; sleep 1; done",
+            "sudo rm /etc/ssh/ssh_host_*",
+            "sudo truncate -s 0 /etc/machine-id",
+            "sudo apt -y autoremove --purge",
+            "sudo apt -y clean",
+            "sudo apt -y autoclean",
+            "sudo cloud-init clean",
+            "sudo rm -f /etc/cloud/cloud.cfg.d/subiquity-disable-cloudinit-networking.cfg",
+            "sudo sync"
+        ]
+    }
+
+    # Provisioning the VM Template for Cloud-Init Integration in Proxmox #2
+    provisioner "file" {
+        source = "files/99-pve.cfg"
+        destination = "/tmp/99-pve.cfg"
+    }
+
+    # Provisioning the VM Template for Cloud-Init Integration in Proxmox #3
+    provisioner "shell" {
+        inline = [ "sudo cp /tmp/99-pve.cfg /etc/cloud/cloud.cfg.d/99-pve.cfg" ]
+    }
+
+    # Provisioning the VM Template with Docker Installation #4
+    provisioner "shell" {
+        inline = [
+            "sudo apt-get install -y ca-certificates curl gnupg lsb-release",
+            "curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg",
+            "echo \"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable\" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null",
+            "sudo apt-get -y update",
+            "sudo apt-get install -y docker-ce docker-ce-cli containerd.io"
+        ]
+    }
+}

+ 1 - 0
packer/proxmox/ubuntu-server-focal/files/99-pve.cfg

@@ -0,0 +1 @@
+datasource_list: [ConfigDrive, NoCloud]

+ 0 - 0
packer/proxmox/ubuntu-server-focal/http/meta-data


+ 33 - 0
packer/proxmox/ubuntu-server-focal/http/user-data

@@ -0,0 +1,33 @@
+#cloud-config
+autoinstall:
+  version: 1
+  locale: en_US
+  keyboard:
+    layout: de
+  ssh:
+    install-server: true
+    allow-pw: true
+    disable_root: true
+    ssh_quiet_keygen: true
+    allow_public_ssh_keys: true
+  packages:
+    - qemu-guest-agent
+    - sudo
+  storage:
+    layout:
+      name: direct
+    swap:
+      size: 0
+  user-data:
+    package_upgrade: false
+    timezone: Europe/Berlin
+    users:
+      - name: your-user-name
+        groups: [adm, sudo]
+        lock-passwd: false
+        sudo: ALL=(ALL) NOPASSWD:ALL
+        shell: /bin/bash
+        # passwd: your-password
+        # - or -
+        # ssh_authorized_keys:
+        #   - your-ssh-key

+ 140 - 0
packer/proxmox/ubuntu-server-focal/ubuntu-server-focal.pkr.hcl

@@ -0,0 +1,140 @@
+# Ubuntu Server Focal
+# ---
+# Packer Template to create an Ubuntu Server (Focal) on Proxmox
+
+# Variable Definitions
+variable "proxmox_api_url" {
+    type = string
+}
+
+variable "proxmox_api_token_id" {
+    type = string
+}
+
+variable "proxmox_api_token_secret" {
+    type = string
+    sensitive = true
+}
+
+# Resource Definiation for the VM Template
+source "proxmox" "ubuntu-server-focal" {
+ 
+    # Proxmox Connection Settings
+    proxmox_url = "${var.proxmox_api_url}"
+    username = "${var.proxmox_api_token_id}"
+    token = "${var.proxmox_api_token_secret}"
+    # (Optional) Skip TLS Verification
+    # insecure_skip_tls_verify = true
+    
+    # VM General Settings
+    node = "your-proxmox-node"
+    vm_id = "100"
+    vm_name = "ubuntu-server-focal"
+    template_description = "Ubuntu Server Focal Image"
+
+    # VM OS Settings
+    # (Option 1) Local ISO File
+    # iso_file = "local:iso/ubuntu-20.04.2-live-server-amd64.iso"
+    # - or -
+    # (Option 2) Download ISO
+    # iso_url = "https://releases.ubuntu.com/20.04/ubuntu-20.04.3-live-server-amd64.iso"
+    # iso_checksum = "f8e3086f3cea0fb3fefb29937ab5ed9d19e767079633960ccb50e76153effc98"
+    iso_storage_pool = "local"
+    unmount_iso = true
+
+    # VM System Settings
+    qemu_agent = true
+
+    # VM Hard Disk Settings
+    scsi_controller = "virtio-scsi-pci"
+
+    disks {
+        disk_size = "20G"
+        format = "qcow2"
+        storage_pool = "local-lvm"
+        storage_pool_type = "lvm"
+        type = "sata"
+    }
+
+    # VM CPU Settings
+    cores = "1"
+    
+    # VM Memory Settings
+    memory = "2048" 
+
+    # VM Network Settings
+    network_adapters {
+        model = "virtio"
+        bridge = "vmbr0"
+        firewall = "false"
+    } 
+
+    # VM Cloud-Init Settings
+    cloud_init = true
+    cloud_init_storage_pool = "local-lvm"
+
+    # PACKER Boot Commands
+    boot_command = [
+        "<esc><wait><esc><wait>",
+        "<f6><wait><esc><wait>",
+        "<bs><bs><bs><bs><bs>",
+        "autoinstall ds=nocloud-net;s=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ ",
+        "--- <enter>"
+    ]
+    boot = "c"
+    boot_wait = "5s"
+
+    # PACKER Autoinstall Settings
+    http_directory = "http" 
+    # (Optional) Bind IP Address and Port
+    # http_bind_address = "0.0.0.0"
+    # http_port_min = 8802
+    # http_port_max = 8802
+
+    ssh_username = "your-user-name"
+
+    # (Option 1) Add your Password here
+    # ssh_password = "your-password"
+    # - or -
+    # (Option 2) Add your Private SSH KEY file here
+    # ssh_private_key_file = "~/.ssh/id_rsa"
+
+    # Raise the timeout, when installation takes longer
+    ssh_timeout = "20m"
+}
+
+# Build Definition to create the VM Template
+build {
+
+    name = "ubuntu-server-focal"
+    sources = ["source.proxmox.ubuntu-server-focal"]
+
+    # Provisioning the VM Template for Cloud-Init Integration in Proxmox #1
+    provisioner "shell" {
+        inline = [
+            "while [ ! -f /var/lib/cloud/instance/boot-finished ]; do echo 'Waiting for cloud-init...'; sleep 1; done",
+            "sudo rm /etc/ssh/ssh_host_*",
+            "sudo truncate -s 0 /etc/machine-id",
+            "sudo apt -y autoremove --purge",
+            "sudo apt -y clean",
+            "sudo apt -y autoclean",
+            "sudo cloud-init clean",
+            "sudo rm -f /etc/cloud/cloud.cfg.d/subiquity-disable-cloudinit-networking.cfg",
+            "sudo sync"
+        ]
+    }
+
+    # Provisioning the VM Template for Cloud-Init Integration in Proxmox #2
+    provisioner "file" {
+        source = "files/99-pve.cfg"
+        destination = "/tmp/99-pve.cfg"
+    }
+
+    # Provisioning the VM Template for Cloud-Init Integration in Proxmox #3
+    provisioner "shell" {
+        inline = [ "sudo cp /tmp/99-pve.cfg /etc/cloud/cloud.cfg.d/99-pve.cfg" ]
+    }
+
+    # Add additional provisioning scripts here
+    # ...
+}

+ 1 - 1
terraform/cloudflare/credentials.tf

@@ -10,4 +10,4 @@ variable "cloudflare_email" {
 variable "cloudflare_api_key" {
     description = "The API key for your Cloudflare account"
     type = string
-}
+}

+ 13 - 12
terraform/kubernetes/provider.tf

@@ -3,21 +3,22 @@
 # Initial Provider Configuration for Kubectl
 
 terraform {
-  required_version = ">= 0.13.0"
 
-  required_providers {
-    kubectl = {
-      source = "gavinbunney/kubectl"
-      version = "1.13.1"
+    required_version = ">= 0.13.0"
+
+    required_providers {
+        kubectl = {
+          source = "gavinbunney/kubectl"
+          version = "1.13.1"
+        }
     }
-  }
 }
 
 # Dynamic Configuration from CIVO Kubernetes deployment
 # provider "kubectl" {
-#   host = "${yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).clusters.0.cluster.server}"
-#   client_certificate = "${base64decode(yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).users.0.user.client-certificate-data)}"
-#   client_key = "${base64decode(yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).users.0.user.client-key-data)}"
-#   cluster_ca_certificate = "${base64decode(yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).clusters.0.cluster.certificate-authority-data)}"
-#   load_config_file = false
-# }
+#     host = "${yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).clusters.0.cluster.server}"
+#     client_certificate = "${base64decode(yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).users.0.user.client-certificate-data)}"
+#     client_key = "${base64decode(yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).users.0.user.client-key-data)}"
+#     cluster_ca_certificate = "${base64decode(yamldecode(civo_kubernetes_cluster.your-kubernetes-cluster.kubeconfig).clusters.0.cluster.certificate-authority-data)}"
+#     load_config_file = false
+# }

+ 0 - 0
terraform/proxmox/README.md


+ 3 - 0
terraform/proxmox/credentails.tfvars

@@ -0,0 +1,3 @@
+proxmox_api_url = "https://0.0.0.0:8006/api2/json"  # Your Proxmox IP Address
+proxmox_api_token_id = "terraform@pam!terraform"  # API Token ID
+proxmox_api_token_secret = "your-api-token-secret"

+ 49 - 0
terraform/proxmox/full-clone.tf

@@ -0,0 +1,49 @@
+# Proxmox Full-Clone
+# ---
+# Create a new VM from a clone
+
+resource "proxmox_vm_qemu" "your-vm" {
+    
+    # VM General Settings
+    target_node = "your-proxmox-node"
+    vmid = "100"
+    name = "vm-name"
+    desc = "Description"
+
+    # VM Advanced General Settings
+    onboot = true 
+
+    # VM OS Settings
+    clone = "your-clone"
+
+    # VM System Settings
+    agent = 1
+    
+    # VM CPU Settings
+    cores = 1
+    sockets = 1
+    cpu = "host"    
+    
+    # VM Memory Settings
+    memory = 1024
+
+    # VM Network Settings
+    network {
+        bridge = "vmbr0"
+        model  = "virtio"
+    }
+
+    # VM Cloud-Init Settings
+    os_type = "cloud-init"
+
+    # (Optional) IP Address and Gateway
+    # ipconfig0 = "ip=0.0.0.0/0,gw=0.0.0.0"
+    
+    # (Optional) Default User
+    # ciuser = "your-username"
+    
+    # (Optional) Add your SSH KEY
+    # sshkeys = <<EOF
+    # #YOUR-PUBLIC-SSH-KEY
+    # EOF
+}

+ 38 - 0
terraform/proxmox/provider.tf

@@ -0,0 +1,38 @@
+# Proxmox Provider
+# ---
+# Initial Provider Configuration for Proxmox
+
+terraform {
+
+    required_version = ">= 0.13.0"
+
+    required_providers {
+        proxmox = {
+            source = "telmate/proxmox"
+            version = "2.9.3"
+        }
+    }
+}
+
+variable "proxmox_api_url" {
+    type = string
+}
+
+variable "proxmox_api_token_id" {
+    type = string
+}
+
+variable "proxmox_api_token_secret" {
+    type = string
+}
+
+provider "proxmox" {
+
+    pm_api_url = var.proxmox_api_url
+    pm_api_token_id = var.proxmox_api_token_id
+    pm_api_token_secret = var.proxmox_api_token_secret
+
+    # (Optional) Skip TLS Verification
+    # pm_tls_insecure = true
+
+}