diff --git a/kubernetes/certmanager/README.md b/helm/certmanager/README.md similarity index 100% rename from kubernetes/certmanager/README.md rename to helm/certmanager/README.md diff --git a/kubernetes/certmanager/default-values.yml b/helm/certmanager/default-values.yml similarity index 100% rename from kubernetes/certmanager/default-values.yml rename to helm/certmanager/default-values.yml diff --git a/kubernetes/certmanager/templates/clusterissuer-acme.yml b/helm/certmanager/templates/clusterissuer-acme.yml similarity index 100% rename from kubernetes/certmanager/templates/clusterissuer-acme.yml rename to helm/certmanager/templates/clusterissuer-acme.yml diff --git a/kubernetes/certmanager/templates/clusterissuer-selfsigned.yml b/helm/certmanager/templates/clusterissuer-selfsigned.yml similarity index 100% rename from kubernetes/certmanager/templates/clusterissuer-selfsigned.yml rename to helm/certmanager/templates/clusterissuer-selfsigned.yml diff --git a/kubernetes/certmanager/templates/issuer-acme.yml b/helm/certmanager/templates/issuer-acme.yml similarity index 100% rename from kubernetes/certmanager/templates/issuer-acme.yml rename to helm/certmanager/templates/issuer-acme.yml diff --git a/kubernetes/certmanager/templates/issuer-selfsigned.yml b/helm/certmanager/templates/issuer-selfsigned.yml similarity index 100% rename from kubernetes/certmanager/templates/issuer-selfsigned.yml rename to helm/certmanager/templates/issuer-selfsigned.yml diff --git a/kubernetes/certmanager/templates/secret-cloudflare.yml b/helm/certmanager/templates/secret-cloudflare.yml similarity index 100% rename from kubernetes/certmanager/templates/secret-cloudflare.yml rename to helm/certmanager/templates/secret-cloudflare.yml diff --git a/kubernetes/portainer/README.md b/helm/portainer/README.md similarity index 100% rename from kubernetes/portainer/README.md rename to helm/portainer/README.md diff --git a/kubernetes/portainer/templates/portainer-ingress.yml b/helm/portainer/templates/portainer-ingress.yml similarity index 100% rename from kubernetes/portainer/templates/portainer-ingress.yml rename to helm/portainer/templates/portainer-ingress.yml diff --git a/kubernetes/portainer/values.yml b/helm/portainer/values.yml similarity index 100% rename from kubernetes/portainer/values.yml rename to helm/portainer/values.yml diff --git a/kubernetes/traefik/README.md b/helm/traefik/README.md similarity index 100% rename from kubernetes/traefik/README.md rename to helm/traefik/README.md diff --git a/kubernetes/traefik/templates/ingress.yml b/helm/traefik/templates/ingress.yml similarity index 100% rename from kubernetes/traefik/templates/ingress.yml rename to helm/traefik/templates/ingress.yml diff --git a/kubernetes/traefik/values.yml b/helm/traefik/values.yml similarity index 100% rename from kubernetes/traefik/values.yml rename to helm/traefik/values.yml diff --git a/kubernetes/templates/cm-and-secrets/nginx-http-cm.yml b/kubectl/nginx-http/nginx-http-cm.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-http-cm.yml rename to kubectl/nginx-http/nginx-http-cm.yml diff --git a/kubernetes/templates/cm-and-secrets/nginx-http-deploy.yml b/kubectl/nginx-http/nginx-http-deploy.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-http-deploy.yml rename to kubectl/nginx-http/nginx-http-deploy.yml diff --git a/kubernetes/templates/cm-and-secrets/nginx-http-svc.yml b/kubectl/nginx-http/nginx-http-svc.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-http-svc.yml rename to kubectl/nginx-http/nginx-http-svc.yml diff --git a/kubernetes/templates/certificate.yaml b/kubectl/templates/certificate.yaml similarity index 100% rename from kubernetes/templates/certificate.yaml rename to kubectl/templates/certificate.yaml diff --git a/kubernetes/templates/cm-and-secrets/mysql-deploy.yml b/kubectl/templates/cm-and-secrets/mysql-deploy.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/mysql-deploy.yml rename to kubectl/templates/cm-and-secrets/mysql-deploy.yml diff --git a/kubernetes/templates/cm-and-secrets/mysql-secret.yml b/kubectl/templates/cm-and-secrets/mysql-secret.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/mysql-secret.yml rename to kubectl/templates/cm-and-secrets/mysql-secret.yml diff --git a/kubectl/templates/cm-and-secrets/nginx-http-cm.yml b/kubectl/templates/cm-and-secrets/nginx-http-cm.yml new file mode 100644 index 0000000..672f5e6 --- /dev/null +++ b/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; + } + } + } \ No newline at end of file diff --git a/kubectl/templates/cm-and-secrets/nginx-http-deploy.yml b/kubectl/templates/cm-and-secrets/nginx-http-deploy.yml new file mode 100644 index 0000000..6f57de3 --- /dev/null +++ b/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 \ No newline at end of file diff --git a/kubectl/templates/cm-and-secrets/nginx-http-svc.yml b/kubectl/templates/cm-and-secrets/nginx-http-svc.yml new file mode 100644 index 0000000..8f5a663 --- /dev/null +++ b/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 \ No newline at end of file diff --git a/kubernetes/templates/cm-and-secrets/nginx-https-cm.yml b/kubectl/templates/cm-and-secrets/nginx-https-cm.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-https-cm.yml rename to kubectl/templates/cm-and-secrets/nginx-https-cm.yml diff --git a/kubernetes/templates/cm-and-secrets/nginx-https-deploy.yml b/kubectl/templates/cm-and-secrets/nginx-https-deploy.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-https-deploy.yml rename to kubectl/templates/cm-and-secrets/nginx-https-deploy.yml diff --git a/kubernetes/templates/cm-and-secrets/nginx-https-secret-blank.yml b/kubectl/templates/cm-and-secrets/nginx-https-secret-blank.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-https-secret-blank.yml rename to kubectl/templates/cm-and-secrets/nginx-https-secret-blank.yml diff --git a/kubernetes/templates/cm-and-secrets/nginx-https-svc.yml b/kubectl/templates/cm-and-secrets/nginx-https-svc.yml similarity index 100% rename from kubernetes/templates/cm-and-secrets/nginx-https-svc.yml rename to kubectl/templates/cm-and-secrets/nginx-https-svc.yml diff --git a/kubernetes/templates/deployment.yaml b/kubectl/templates/deployment.yaml similarity index 100% rename from kubernetes/templates/deployment.yaml rename to kubectl/templates/deployment.yaml diff --git a/kubernetes/templates/ingress.yaml b/kubectl/templates/ingress.yaml similarity index 100% rename from kubernetes/templates/ingress.yaml rename to kubectl/templates/ingress.yaml diff --git a/kubernetes/templates/ingressroute-http.yaml b/kubectl/templates/ingressroute-http.yaml similarity index 100% rename from kubernetes/templates/ingressroute-http.yaml rename to kubectl/templates/ingressroute-http.yaml diff --git a/kubernetes/templates/ingressroute-https.yaml b/kubectl/templates/ingressroute-https.yaml similarity index 100% rename from kubernetes/templates/ingressroute-https.yaml rename to kubectl/templates/ingressroute-https.yaml diff --git a/kubernetes/templates/ingressroute-redirectscheme.yaml b/kubectl/templates/ingressroute-redirectscheme.yaml similarity index 100% rename from kubernetes/templates/ingressroute-redirectscheme.yaml rename to kubectl/templates/ingressroute-redirectscheme.yaml diff --git a/kubernetes/templates/persistentvolumeclaim.yaml b/kubectl/templates/persistentvolumeclaim.yaml similarity index 100% rename from kubernetes/templates/persistentvolumeclaim.yaml rename to kubectl/templates/persistentvolumeclaim.yaml diff --git a/kubernetes/templates/pv-and-pvc/civo-pvc.yml b/kubectl/templates/pv-and-pvc/civo-pvc.yml similarity index 100% rename from kubernetes/templates/pv-and-pvc/civo-pvc.yml rename to kubectl/templates/pv-and-pvc/civo-pvc.yml diff --git a/kubernetes/templates/pv-and-pvc/civo-web.yml b/kubectl/templates/pv-and-pvc/civo-web.yml similarity index 100% rename from kubernetes/templates/pv-and-pvc/civo-web.yml rename to kubectl/templates/pv-and-pvc/civo-web.yml diff --git a/kubernetes/templates/pv-and-pvc/local-web.yml b/kubectl/templates/pv-and-pvc/local-web.yml similarity index 100% rename from kubernetes/templates/pv-and-pvc/local-web.yml rename to kubectl/templates/pv-and-pvc/local-web.yml diff --git a/kubernetes/templates/pv-and-pvc/nfs-pv.yml b/kubectl/templates/pv-and-pvc/nfs-pv.yml similarity index 100% rename from kubernetes/templates/pv-and-pvc/nfs-pv.yml rename to kubectl/templates/pv-and-pvc/nfs-pv.yml diff --git a/kubernetes/templates/pv-and-pvc/nfs-pvc.yml b/kubectl/templates/pv-and-pvc/nfs-pvc.yml similarity index 100% rename from kubernetes/templates/pv-and-pvc/nfs-pvc.yml rename to kubectl/templates/pv-and-pvc/nfs-pvc.yml diff --git a/kubernetes/templates/pv-and-pvc/nfs-web.yml b/kubectl/templates/pv-and-pvc/nfs-web.yml similarity index 100% rename from kubernetes/templates/pv-and-pvc/nfs-web.yml rename to kubectl/templates/pv-and-pvc/nfs-web.yml diff --git a/kubernetes/templates/service.yaml b/kubectl/templates/service.yaml similarity index 100% rename from kubernetes/templates/service.yaml rename to kubectl/templates/service.yaml diff --git a/packer/proxmox/README.md b/packer/proxmox/README.md new file mode 100644 index 0000000..e69de29 diff --git a/packer/proxmox/credentials.pkr.hcl b/packer/proxmox/credentials.pkr.hcl new file mode 100644 index 0000000..03bd182 --- /dev/null +++ b/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" diff --git a/packer/proxmox/ubuntu-server-focal-docker/files/99-pve.cfg b/packer/proxmox/ubuntu-server-focal-docker/files/99-pve.cfg new file mode 100644 index 0000000..a78672c --- /dev/null +++ b/packer/proxmox/ubuntu-server-focal-docker/files/99-pve.cfg @@ -0,0 +1 @@ +datasource_list: [ConfigDrive, NoCloud] \ No newline at end of file diff --git a/packer/proxmox/ubuntu-server-focal-docker/http/meta-data b/packer/proxmox/ubuntu-server-focal-docker/http/meta-data new file mode 100644 index 0000000..e69de29 diff --git a/packer/proxmox/ubuntu-server-focal-docker/http/user-data b/packer/proxmox/ubuntu-server-focal-docker/http/user-data new file mode 100644 index 0000000..de3248e --- /dev/null +++ b/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 diff --git a/packer/proxmox/ubuntu-server-focal-docker/ubuntu-server-focal-docker.pkr.hcl b/packer/proxmox/ubuntu-server-focal-docker/ubuntu-server-focal-docker.pkr.hcl new file mode 100644 index 0000000..b6d1cde --- /dev/null +++ b/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 = [ + "", + "", + "", + "autoinstall ds=nocloud-net;s=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ ", + "--- " + ] + 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" + ] + } +} diff --git a/packer/proxmox/ubuntu-server-focal/files/99-pve.cfg b/packer/proxmox/ubuntu-server-focal/files/99-pve.cfg new file mode 100644 index 0000000..a78672c --- /dev/null +++ b/packer/proxmox/ubuntu-server-focal/files/99-pve.cfg @@ -0,0 +1 @@ +datasource_list: [ConfigDrive, NoCloud] \ No newline at end of file diff --git a/packer/proxmox/ubuntu-server-focal/http/meta-data b/packer/proxmox/ubuntu-server-focal/http/meta-data new file mode 100644 index 0000000..e69de29 diff --git a/packer/proxmox/ubuntu-server-focal/http/user-data b/packer/proxmox/ubuntu-server-focal/http/user-data new file mode 100644 index 0000000..de3248e --- /dev/null +++ b/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 diff --git a/packer/proxmox/ubuntu-server-focal/ubuntu-server-focal.pkr.hcl b/packer/proxmox/ubuntu-server-focal/ubuntu-server-focal.pkr.hcl new file mode 100644 index 0000000..ff9ca2e --- /dev/null +++ b/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 = [ + "", + "", + "", + "autoinstall ds=nocloud-net;s=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ ", + "--- " + ] + 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 + # ... +} diff --git a/terraform/cloudflare/credentials.tf b/terraform/cloudflare/credentials.tf index 69646d4..e8a0d24 100644 --- a/terraform/cloudflare/credentials.tf +++ b/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 -} \ No newline at end of file +} diff --git a/terraform/kubernetes/provider.tf b/terraform/kubernetes/provider.tf index 8cd2e1e..68bd904 100644 --- a/terraform/kubernetes/provider.tf +++ b/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 -# } \ No newline at end of file +# 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 +# } diff --git a/terraform/proxmox/README.md b/terraform/proxmox/README.md new file mode 100644 index 0000000..e69de29 diff --git a/terraform/proxmox/credentails.tfvars b/terraform/proxmox/credentails.tfvars new file mode 100644 index 0000000..0282198 --- /dev/null +++ b/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" \ No newline at end of file diff --git a/terraform/proxmox/full-clone.tf b/terraform/proxmox/full-clone.tf new file mode 100644 index 0000000..57ef39a --- /dev/null +++ b/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 = <