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 tipeaws_nat_gatewaydan beberapa sumber daya dengan tipeaws_route_table. Maka dari itu sumber dayaaws_nat_gatewaysebaiknya dinamakanthisdanaws_route_tablediberi nama yang lebih deskriptif sepertiprivat,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 olehdepends_ondanlifecyclejika diperlukan. Semua argumen tersebut sebaiknya dipisahkan oleh satu baris kosong.Ketika menggunakan argumen
count/for_eachsebagai pernyataan bersyarat, pilihlah nilai boolean dibandingkanlengthatau 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 nilaidefaultuntuk 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(...)ataumap(...).Urutkan nama atribut di dalam blok variabel seperti berikut:
description,type,default,validationSelalu 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 sepertiobject()kecuali Anda memerlukan batasan ketat pada setiap atributnya.Gunakan tipe spesifik seperti
map(map(string))jika seluruh elemen darimapmemiliki tipe yang sama (Contohstring) atau bisa dikonversikan menjadi tipe tersebut (Contoh tipenumberbisa dikonversi menjadistring).Gunakan tipe
anyuntuk menonaktifkan validasi tipe mulai dari level tertentu atau ketika perlu mendukung berbagai tipe.Nilai
{}bisa bertipemapatau bisa juga bertipeobject. Gunakantomap(...)untuk konversi menjadi map karena tidak ada cara untuk mengubah menjadiobject.
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}untukaws_subnetadalahsubnet,{name}untukaws_vpcadalahvpc.{type}adalah tipe dari sumber daya{attribute}adalah atribut dari nilai keluaranLihat 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