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.

127 lines
6.5 KiB

  1. module "network" {
  2. source = "./modules/network"
  3. external_net = var.external_net
  4. network_name = var.network_name
  5. subnet_cidr = var.subnet_cidr
  6. cluster_name = var.cluster_name
  7. dns_nameservers = var.dns_nameservers
  8. network_dns_domain = var.network_dns_domain
  9. use_neutron = var.use_neutron
  10. port_security_enabled = var.port_security_enabled
  11. router_id = var.router_id
  12. }
  13. module "ips" {
  14. source = "./modules/ips"
  15. number_of_k8s_masters = var.number_of_k8s_masters
  16. number_of_k8s_masters_no_etcd = var.number_of_k8s_masters_no_etcd
  17. number_of_k8s_nodes = var.number_of_k8s_nodes
  18. floatingip_pool = var.floatingip_pool
  19. number_of_bastions = var.number_of_bastions
  20. external_net = var.external_net
  21. network_name = var.network_name
  22. router_id = module.network.router_id
  23. k8s_nodes = var.k8s_nodes
  24. k8s_masters = var.k8s_masters
  25. k8s_master_fips = var.k8s_master_fips
  26. bastion_fips = var.bastion_fips
  27. router_internal_port_id = module.network.router_internal_port_id
  28. }
  29. module "compute" {
  30. source = "./modules/compute"
  31. cluster_name = var.cluster_name
  32. az_list = var.az_list
  33. az_list_node = var.az_list_node
  34. number_of_k8s_masters = var.number_of_k8s_masters
  35. number_of_k8s_masters_no_etcd = var.number_of_k8s_masters_no_etcd
  36. number_of_etcd = var.number_of_etcd
  37. number_of_k8s_masters_no_floating_ip = var.number_of_k8s_masters_no_floating_ip
  38. number_of_k8s_masters_no_floating_ip_no_etcd = var.number_of_k8s_masters_no_floating_ip_no_etcd
  39. number_of_k8s_nodes = var.number_of_k8s_nodes
  40. number_of_bastions = var.number_of_bastions
  41. number_of_k8s_nodes_no_floating_ip = var.number_of_k8s_nodes_no_floating_ip
  42. number_of_gfs_nodes_no_floating_ip = var.number_of_gfs_nodes_no_floating_ip
  43. k8s_masters = var.k8s_masters
  44. k8s_nodes = var.k8s_nodes
  45. bastion_root_volume_size_in_gb = var.bastion_root_volume_size_in_gb
  46. etcd_root_volume_size_in_gb = var.etcd_root_volume_size_in_gb
  47. master_root_volume_size_in_gb = var.master_root_volume_size_in_gb
  48. node_root_volume_size_in_gb = var.node_root_volume_size_in_gb
  49. gfs_root_volume_size_in_gb = var.gfs_root_volume_size_in_gb
  50. gfs_volume_size_in_gb = var.gfs_volume_size_in_gb
  51. master_volume_type = var.master_volume_type
  52. node_volume_type = var.node_volume_type
  53. public_key_path = var.public_key_path
  54. image = var.image
  55. image_uuid = var.image_uuid
  56. image_gfs = var.image_gfs
  57. image_master = var.image_master
  58. image_master_uuid = var.image_master_uuid
  59. image_gfs_uuid = var.image_gfs_uuid
  60. ssh_user = var.ssh_user
  61. ssh_user_gfs = var.ssh_user_gfs
  62. flavor_k8s_master = var.flavor_k8s_master
  63. flavor_k8s_node = var.flavor_k8s_node
  64. flavor_etcd = var.flavor_etcd
  65. flavor_gfs_node = var.flavor_gfs_node
  66. network_name = var.network_name
  67. flavor_bastion = var.flavor_bastion
  68. k8s_master_fips = module.ips.k8s_master_fips
  69. k8s_master_no_etcd_fips = module.ips.k8s_master_no_etcd_fips
  70. k8s_masters_fips = module.ips.k8s_masters_fips
  71. k8s_node_fips = module.ips.k8s_node_fips
  72. k8s_nodes_fips = module.ips.k8s_nodes_fips
  73. bastion_fips = module.ips.bastion_fips
  74. bastion_allowed_remote_ips = var.bastion_allowed_remote_ips
  75. master_allowed_remote_ips = var.master_allowed_remote_ips
  76. k8s_allowed_remote_ips = var.k8s_allowed_remote_ips
  77. k8s_allowed_egress_ips = var.k8s_allowed_egress_ips
  78. supplementary_master_groups = var.supplementary_master_groups
  79. supplementary_node_groups = var.supplementary_node_groups
  80. master_allowed_ports = var.master_allowed_ports
  81. worker_allowed_ports = var.worker_allowed_ports
  82. use_access_ip = var.use_access_ip
  83. master_server_group_policy = var.master_server_group_policy
  84. node_server_group_policy = var.node_server_group_policy
  85. etcd_server_group_policy = var.etcd_server_group_policy
  86. extra_sec_groups = var.extra_sec_groups
  87. extra_sec_groups_name = var.extra_sec_groups_name
  88. group_vars_path = var.group_vars_path
  89. port_security_enabled = var.port_security_enabled
  90. force_null_port_security = var.force_null_port_security
  91. network_router_id = module.network.router_id
  92. network_id = module.network.network_id
  93. use_existing_network = var.use_existing_network
  94. depends_on = [
  95. module.network.subnet_id
  96. ]
  97. }
  98. output "private_subnet_id" {
  99. value = module.network.subnet_id
  100. }
  101. output "floating_network_id" {
  102. value = var.external_net
  103. }
  104. output "router_id" {
  105. value = module.network.router_id
  106. }
  107. output "k8s_master_fips" {
  108. value = var.number_of_k8s_masters + var.number_of_k8s_masters_no_etcd > 0 ? concat(module.ips.k8s_master_fips, module.ips.k8s_master_no_etcd_fips) : [for key, value in module.ips.k8s_masters_fips : value.address]
  109. }
  110. output "k8s_node_fips" {
  111. value = var.number_of_k8s_nodes > 0 ? module.ips.k8s_node_fips : [for key, value in module.ips.k8s_nodes_fips : value.address]
  112. }
  113. output "bastion_fips" {
  114. value = module.ips.bastion_fips
  115. }