halo sobat sekolahlinux, jadi kali ini aku akan coba memberikan guide bagaimana cara integrasi antara vault sebagai secret management dengan github action, yang mana kita tau github secret action value nya itu tidak bisa di reveal, jadi tentu ini menyulitkan kita ketika akan coba untuk melihat value yang sudah kita set
nah pada tutorial kali ini saya menggunakan self hosted runner, dan disini saya install vault-server didalam network private yang sama dengan github action self hosted runner, sehingga nanti nya jobs yang menggunakan self host runner bisa terhubung ke vault melalui private connection, oh dibawah ini detail koneksi yang digunakan
- vault-server: http://10.11.202.209:8200
oke langsung masuk saja ke parh github workflow action nya, dan dibawah ini adalah github workflow yang saya buat saya buat di .github/workflow/blank.yaml
name: CI on: push: branches: [ "main" ] workflow_dispatch: jobs: build: runs-on: [self-hosted-ec2] container: centos:centos7.9.2009 steps: - uses: actions/checkout@v3 - name: Vault uses: hashicorp/vault-action@v2.4.0 with: url: http://10.11.202.209:8200 token: ${{ secrets.VAULT_TOKEN }} secrets: | dev/data/fe_service url_test ; # for kv version_2 add /data/ between secrets name and path - name: Testing run: | echo "" echo "----------" curl -s $URL_TEST echo "----------"
dari script diatas kita coba bedah step per step
kita mulai dari step Vault
- name: Vault uses: hashicorp/vault-action@v2.4.0 with: url: http://10.11.202.209:8200 token: ${{ secrets.VAULT_TOKEN }} secrets: | dev/data/fe_service url_test ;
- pada paramater url: ganti endpoint sesuai dengan endpoint vault yang kalian setup, disini saya menggunakan selft host runner untuk github action runner nya, dan host runner saya setup masih sama dengan private network host vault, sehingga komunikasi antara vault dan runner bisa private
- pada paramater token: buat github secret action di dengan variable name VAULT_TOKEN dan berikan value dengan token yang sudah kalian buat, disini bisa meletakkan token root ataupun token yang kita buat dengan custom policy, untuk tutorial membuat custom token, kalian bisa lihat di tutorial saya
- pada paramater secrets: disini kita akan meregister secrets apa saja yang akan diload menjadi environment variable di github action, disini saya coba mereload variable url_test yang ada di dev/fe_service, pasti kalian bertanya2 kenapa di script diatas ditulisnya dev/data/fe_service, jadi pada kv version_2 di vault untuk meload sebuah secret diharuskan menambahkan /data/ diantara secret name dan path name, namun pada kv version_1 kita tidak perlu menambahkan /data/ cukup menulisnya dev/fe_service, sample:
- kv version_1:
- name: Vault uses: hashicorp/vault-action@v2.4.0 with: url: http://10.11.202.209:8200 token: ${{ secrets.VAULT_TOKEN }} secrets: | dev/fe_service url_test ;
-
- kv version_2:
- name: Vault uses: hashicorp/vault-action@v2.4.0 with: url: http://10.11.202.209:8200 token: ${{ secrets.VAULT_TOKEN }} secrets: | dev/data/fe_service url_test ;
untuk isi value dari variable url_test yang saya set kurang lebih seperti dibawah
lalu selanjutnya kita coba masuk ke step Testing
- name: Testing run: | echo "" echo "----------" curl -s $URL_TEST echo "----------"
- disini kita akan coba me run beberapa perintah sekaligus, diantaranya adalah perintah curl, disini kita akan curl url yang kita set di vault pada variable name $URL_TEST disini walau di vault kita set lower_case $url_test maka ketika di load di github action dia akan menjadi upper_case
maka result nya ketika jobs nya berjalan akan seperti capture dibawah
nah semoga tutorial singkat kali ini bermanfaat