Kaidah Penamaan
Kaidah umum
- Gunakan - _(garis bawah) daripada- -(tanda hubung) dimana saja (nama sumber daya, nama sumber data, nama variabel, keluaran, dan lain-lain)
- Pilihlah penggunaan huruf kecil dan angka (walaupun ada dukungan UTF-8) 
Argumen sumber daya dan sumber data
- Hindari mengulang jenis sumber daya pada nama sumber daya (baik itu sebagian atau sepenuhnya): - resource "aws_route_table" "public" {}- resource "aws_route_table" "public_route_table" {}- resource "aws_route_table" "public_aws_route_table" {}
- Sumber daya sebaiknya dinamakan - thisjika tidak tersedia nama lain yang lebih deskriptif dan umum, atau jika modul sumber daya menciptakan sumber daya tunggal dari tipe tersebut. Sebagai contoh pada modul AWS VPC terdapat sebuah sumber daya dengan tipe- aws_nat_gatewaydan beberapa sumber daya dengan tipe- aws_route_table. Maka dari itu sumber daya- aws_nat_gatewaysebaiknya dinamakan- thisdan- aws_route_tablediberi nama yang lebih deskriptif seperti- privat,- publik,- database.
- Selalu gunakan kata benda tunggal sebagai nama. 
- Gunakan - -pada nilai argumen dan ditempat-tempat lain dimana nilai akan dipaparkan ke orang lain (Contoh di dalam nama DNS sebuah RDS).
- Letakan argumen - count/- for_eachpada baris pertama di dalam blok sumber daya atau sumber data dan tambahkan baris baru untuk memisahkan dengan argumen lainnya.
- Letakan argumen - tags(jika sumber daya mendukung hal tersebut) sebagai argumen terakhir, diikuti oleh- depends_ondan- lifecyclejika diperlukan. Semua argumen tersebut sebaiknya dipisahkan oleh satu baris kosong.
- Ketika menggunakan argumen - count/- for_eachsebagai pernyataan bersyarat, pilihlah nilai boolean dibandingkan- lengthatau ekspresi lainnya
Contoh kode resource
Penggunaan count / for_each
count / for_eachresource "aws_route_table" "public" {
  count = 2
  vpc_id = "vpc-12345678"
  # ... sisa argumen sengaja dihilangkan
}
resource "aws_route_table" "private" {
  for_each = toset(["one", "two"])
  vpc_id = "vpc-12345678"
  # ... sisa argumen sengaja dihilangkan
}resource "aws_route_table" "public" {
  vpc_id = "vpc-12345678"
  count  = 2
  # ... sisa argumen sengaja dihilangkan
}Penempatan tags
tagsresource "aws_nat_gateway" "this" {
  count = 2
  allocation_id = "..."
  subnet_id     = "..."
  tags = {
    Name = "..."
  }
  depends_on = [aws_internet_gateway.this]
  lifecycle {
    create_before_destroy = true
  }
}   resource "aws_nat_gateway" "this" {
  count = 2
  tags = "..."
  depends_on = [aws_internet_gateway.this]
  lifecycle {
    create_before_destroy = true
  }
  allocation_id = "..."
  subnet_id     = "..."
}Pernyataan bersyarat count
countresource "aws_nat_gateway" "that" {    # Best
  count = var.create_public_subnets ? 1 : 0
}
resource "aws_nat_gateway" "this" {    # Good
  count = length(var.public_subnets) > 0 ? 1 : 0
}Variabel
- Hindari membuat ulang secara mandiri (don't reinvent the wheel) pada modul sumber daya: gunakan - name,- description, dan nilai- defaultuntuk variabel seperti yang didefinisikan pada bagian "Referensi Argumen" untuk sumber daya yang Anda kerjakan.
- Dukungan untuk validasi variabel bersifat terbatas (Contoh tidak bisa mengakses variabel lain atau melakukan pencarian). Buat perencanaan validasi dengan baik karena fitur ini tidak bisa digunakan pada beberapa kasus tertentu. 
- Gunakan bentuk jamak pada nama variabel dengan tipe - list(...)atau- map(...).
- Urutkan nama atribut di dalam blok variabel seperti berikut: - description,- type,- default,- validation
- Selalu sertakan - descriptiondisemua variabel walaupun menurut Anda hal tersebut sudah jelas (Anda akan membutuhkannya dimasa yang akan datang).
- Pilihlah tipe-tipe sederhana ( - number,- string,- list(...),- map(...),- any) daripada tipe yang lebih spesifik seperti- object()kecuali Anda memerlukan batasan ketat pada setiap atributnya.
- Gunakan tipe spesifik seperti - map(map(string))jika seluruh elemen dari- mapmemiliki tipe yang sama (Contoh- string) atau bisa dikonversikan menjadi tipe tersebut (Contoh tipe- numberbisa dikonversi menjadi- string).
- Gunakan tipe - anyuntuk menonaktifkan validasi tipe mulai dari level tertentu atau ketika perlu mendukung berbagai tipe.
- Nilai - {}bisa bertipe- mapatau bisa juga bertipe- object. Gunakan- tomap(...)untuk konversi menjadi map karena tidak ada cara untuk mengubah menjadi- object.
Keluaran
Buat keluaran konsisten dan mudah dipahami diluar cakupan mereka (Tipe dan atribut dari nilai yang dikembalikan harus jelas bagi pengguna modul ketika menggunakan modul tersebut).
- Nama keluaran sebaiknya menjelaskan properti yang dimiliki dan tidak terlalu menggunakan bentuk bebas yang biasa kita inginkan. 
- Struktur yang baik untuk nama keluaran berbentuk - {name}_{type}_{attribute}, dimana:- {name}adalah nama sumber daya atau sumber data tanpa awalan penyedia. Sebagai contoh- {name}untuk- aws_subnetadalah- subnet,- {name}untuk- aws_vpcadalah- vpc.
- {type}adalah tipe dari sumber daya
- {attribute}adalah atribut dari nilai keluaran
- Lihat contoh 
 
- Jika keluaran mengembalikan nilai dengan fungsi interpolasi dan banyak sumber daya maka - {name}dan- {type}sebaiknya dibuat seumum mungkin (- thissebagai prefiks sebaiknya diabaikan saja). Lihat contoh.
- Jika nilai kembalian adalah sebuah daftar maka gunakan bentuk jamak sebagai nama. Lihat contoh. 
- Selalu sertakan - descriptionuntuk semua keluaran walaupun hal itu dirasa sudah jelas.
- Hindari argumen - sensitivekecuali Anda mengontrol penuh penggunaan keluaran tersebut diseluruh tempat pada seluruh modul.
Contoh kode output
outputKembalikan paling banyak satu ID dari security group::
output "security_group_id" {
  description = "The ID of the security group"
  value       = try(aws_security_group.this[0].id, aws_security_group.name_prefix[0].id, "")
}Ketika bekerja dengan banyak sumber daya berjenis sama, this sebaiknya diabaikan dari nama keluaran:
output "this_security_group_id" {
  description = "The ID of the security group"
  value       = element(concat(coalescelist(aws_security_group.this.*.id, aws_security_group.web.*.id), [""]), 0)
}Gunakan bentuk jamak jika mengembalikan nilai yang berupa daftar
output "rds_cluster_instance_endpoints" {
  description = "A list of all cluster instance endpoints"
  value       = aws_rds_cluster_instance.this.*.endpoint
}Last updated
