You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

49 lines
1.6 KiB

  1. provider "exoscale" {}
  2. module "kubernetes" {
  3. source = "./modules/kubernetes-cluster"
  4. prefix = var.prefix
  5. machines = var.machines
  6. ssh_public_keys = var.ssh_public_keys
  7. ssh_whitelist = var.ssh_whitelist
  8. api_server_whitelist = var.api_server_whitelist
  9. nodeport_whitelist = var.nodeport_whitelist
  10. }
  11. #
  12. # Generate ansible inventory
  13. #
  14. data "template_file" "inventory" {
  15. template = file("${path.module}/templates/inventory.tpl")
  16. vars = {
  17. connection_strings_master = join("\n", formatlist("%s ansible_user=ubuntu ansible_host=%s ip=%s etcd_member_name=etcd%d",
  18. keys(module.kubernetes.master_ip_addresses),
  19. values(module.kubernetes.master_ip_addresses).*.public_ip,
  20. values(module.kubernetes.master_ip_addresses).*.private_ip,
  21. range(1, length(module.kubernetes.master_ip_addresses) + 1)))
  22. connection_strings_worker = join("\n", formatlist("%s ansible_user=ubuntu ansible_host=%s ip=%s",
  23. keys(module.kubernetes.worker_ip_addresses),
  24. values(module.kubernetes.worker_ip_addresses).*.public_ip,
  25. values(module.kubernetes.worker_ip_addresses).*.private_ip))
  26. list_master = join("\n", keys(module.kubernetes.master_ip_addresses))
  27. list_worker = join("\n", keys(module.kubernetes.worker_ip_addresses))
  28. api_lb_ip_address = module.kubernetes.control_plane_lb_ip_address
  29. }
  30. }
  31. resource "null_resource" "inventories" {
  32. provisioner "local-exec" {
  33. command = "echo '${data.template_file.inventory.rendered}' > ${var.inventory_file}"
  34. }
  35. triggers = {
  36. template = data.template_file.inventory.rendered
  37. }
  38. }