• Home
  • Berita
  • Waspada GitHub Dorking: Cara Mengatasi Secret Bocor di Repo Publik

Waspada GitHub Dorking: Cara Mengatasi Secret Bocor di Repo Publik

Oleh Fitri Aulia
GitHub Dorking

Pernahkah DomaiNesians mendengar tentang GitHub Dorking? Teknik ini memanfaatkan query khusus untuk mencari informasi yang tidak sengaja terbuka di repository publik GitHub. Ternyata, banyak sekali data sensitif seperti API key, password, dan konfigurasi server yang bisa terbongkar hanya karena kesalahan dalam pengaturan privasi repository. Tanpa sadar, kita bisa saja membocorkan rahasia penting. Jadi, sangat penting untuk memahami cara kerja GitHub Dorking dan langkah-langkah yang bisa diambil untuk melindungi repository agar tetap aman dari kebocoran data. Secara sederhana, GitHub Dorking adalah teknik pencarian yang memanfaatkan fitur search GitHub untuk menemukan file, konfigurasi, atau kredensial yang tidak sengaja terekspos di repository publik. Risiko terbesar dari teknik ini adalah terbukanya API key, token akses, password, dan informasi infrastruktur yang dapat disalahgunakan oleh pihak lain.

Apa Itu GitHub Dorking dan Bagaimana Teknik Ini Bekerja

GitHub

GitHub Dorking adalah teknik pencarian lanjutan yang memanfaatkan fitur pencarian GitHub untuk menemukan informasi tertentu di repository publik. Alih‑alih mencari proyek atau kode secara umum, pelaku menggunakan kombinasi kata kunci, nama file, dan operator pencarian untuk menyingkap potongan data yang tidak dimaksudkan untuk dipublikasikan. Secara garis besar, mekanismenya bekerja seperti ini:

  • Targeting melalui metadata dan teks
    GitHub menyimpan banyak metadata dan isi file yang dapat dicari (commit messages, nama file, path, README, dsb.). Dengan menargetkan kata kunci yang umum dipakai pada file konfigurasi atau secrets, hasil pencarian bisa memunculkan repo yang memuat data sensitif.
  • Memanfaatkan pola dan nama file
    Banyak project menggunakan nama file dan pola standar. Pencari yang jeli menyorot pola tersebut untuk mempersempit hasil.
  • Filter berdasarkan bahasa, path, dan repo
    Operator pencarian GitHub memungkinkan memfilter hasil menurut bahasa pemrograman, path file, atau pemilik repo, sehingga pencarian menjadi sangat terfokus.
  • Automasi dan skala
    Teknik ini bisa dijalankan manual oleh individu atau diotomasi dengan script/tool untuk memindai banyak repo sekaligus sehingga eksposur kecil bisa cepat berubah jadi kebocoran massal.
Baca Juga:  Mengenal Apa Itu Top Level Domain dan Kegunaannya

Cara Mendeteksi dan Mencegah Secret Bocor di Repo Publik

Melindungi repository dari kebocoran data sensitif bukan hanya soal menjaga kode tetap bersih, tetapi juga mengamankan informasi yang tidak boleh terlihat oleh publik. Dengan banyaknya teknik yang dapat dimanfaatkan untuk menemukan secrets, seperti GitHub Dorking, penting untuk mengetahui cara mencegah dan mendeteksi potensi kebocoran tersebut. Berikut adalah beberapa langkah yang dapat dilakukan:

1. Gunakan GitHub Secret Scanning

GitHub memiliki fitur Secret Scanning yang secara otomatis mendeteksi kredensial atau token yang tidak sengaja terkomit ke repository publik. Secret Scanning akan memeriksa repository dan memberi tahu pengguna jika ada data sensitif seperti API key atau password yang terdeteksi. Pastikan fitur ini diaktifkan, terutama untuk repository publik.

2. Gunakan Pre-Commit Hooks untuk Validasi

Salah satu cara terbaik untuk mencegah secret masuk ke repository adalah dengan menggunakan pre-commit hooks. Pre-commit hooks dapat diatur untuk memeriksa file yang akan dikomit sebelum benar-benar di-push ke GitHub. Tools seperti Git-Secrets atau Detect-secrets bisa diintegrasikan untuk memindai file dan menandai potensi secrets yang bocor sebelum melanjutkan commit.

3. Gunakan File .gitignore dengan Bijak

Pastikan untuk menambahkan file atau folder yang berisi informasi sensitif ke dalam .gitignore agar tidak masuk ke dalam version control. Misalnya, file konfigurasi seperti .env, config.json, atau lainnya yang berisi kredensial.

4. Enkripsi dan Gunakan Vault untuk Secrets

Jika perlu menyimpan informasi sensitif dalam repository, pastikan untuk mengenkripsi file tersebut terlebih dahulu. Gunakan HashiCorp Vault atau layanan enkripsi lain untuk menyimpan dan mengelola secrets. Jangan pernah menulis kredensial dalam teks biasa di repository.

5. Penyaringan dan Monitoring repository secara Rutin

Lakukan pengecekan rutin terhadap repository untuk memeriksa apakah ada secrets yang terlewat. Tools seperti truffleHog atau Gitleaks dapat membantu memindai seluruh history repository untuk menemukan potensi kebocoran.

6. Tetap Menggunakan Branches Privat untuk Pengembangan Sensitif

Untuk proyek sensitif, pastikan pengembangan dilakukan di branches privat terlebih dahulu, dan jangan langsung melakukan commit ke branch utama (master/main) tanpa pengecekan manual. Penggunaan branch privat juga membantu dalam memisahkan kerja yang bersifat pribadi atau sensitif dari repository publik.

Baca Juga:  Cara Membuat Website Desa (WordPress) + Contoh Struktur Menu & Fitur Wajib

7. Cegah Akses Tidak Sah dengan Kontrol Akses GitHub

Atur kontrol akses pada repository GitHub untuk membatasi siapa yang bisa melakukan push dan pull ke repository. Pastikan hanya anggota tim yang berwenang yang memiliki akses ke repository tertentu. Gunakan fitur seperti branch protection rules untuk memverifikasi review sebelum perubahan diterima.

Langkah-langkah Setelah Secret Bocor

github dorks

Meskipun sudah melakukan pencegahan, terkadang kebocoran informasi sensitif bisa tetap terjadi di repository publik. Dalam kasus ini, penting untuk mengambil tindakan cepat agar tidak terjadi eksposur lebih lanjut yang bisa membahayakan keamanan sistem. Berikut adalah langkah-langkah yang harus diambil segera setelah secret ditemukan bocor:

1. Segera Revoke dan Ganti Credentials yang Bocor

Langkah pertama yang harus dilakukan adalah mencabut dan mengganti semua kredensial atau token yang terdeteksi bocor. Misalnya, jika API key atau password ditemukan, segera revoke aksesnya di layanan terkait dan buat kredensial baru. Layanan seperti AWS, GitHub, dan API lainnya biasanya menyediakan cara cepat untuk mengganti kredensial yang telah bocor.

  • AWS: Ganti akses key dan secret key di IAM (Identity and Access Management)
  • GitHub: Jika token atau SSH key bocor, segera buat token baru dan hapus token lama di pengaturan GitHub.
  • API Keys: Hapus dan buat ulang API key yang bocor untuk aplikasi lain yang menggunakannya.

2. Hapus Secret dari History Git

Secret yang sudah terlanjur terkomit di repository Git tetap ada dalam riwayat commit, meskipun sudah dihapus dari file terbaru. Gunakan alat seperti BFG Repo-Cleaner atau git-filter-branch untuk membersihkan secret dari riwayat repository Git.

3. Monitor Aktivitas Akses Setelah Kebocoran

Lakukan monitoring yang lebih intensif terhadap log dan aktivitas di platform yang menggunakan kredensial yang bocor. Periksa apakah ada akses yang mencurigakan atau upaya eksploitasi yang dilakukan menggunakan data sensitif tersebut.
4. Periksa repository dengan Alat Deteksi

Setelah menghapus secret dan mengganti kredensial, lakukan pemindaian ulang terhadap repository dengan alat seperti Gitleaks atau truffleHog untuk memastikan tidak ada data sensitif lainnya yang terlewat.

Baca Juga:  Ghost CMS, Alternatif CMS Blogging Selain WordPress

5. Evaluasi Kebijakan Keamanan dan Akses

Setelah kebocoran terjadi, evaluasi kembali kebijakan akses dan protokol keamanan yang diterapkan. Tinjau siapa yang memiliki akses ke repository dan pertimbangkan untuk menambah pengamanan ekstra seperti menggunakan autentikasi multi-faktor (MFA), memperketat kontrol akses, serta memperkenalkan sistem review yang lebih ketat untuk perubahan kode sensitif.

6. Memberi Tahu Tim atau Pihak Terkait

Jika kebocoran terjadi di repository tim atau perusahaan, segera beritahu semua anggota tim yang relevan dan pihak-pihak terkait, seperti pihak keamanan atau manajer proyek. Pastikan mereka memahami langkah-langkah yang diambil dan mengubah akses atau kebijakan yang diperlukan untuk mencegah kebocoran serupa di masa depan.

7. Lakukan Evaluasi Terhadap Proses Development

Sebagai tindak lanjut, lakukan evaluasi terhadap proses pengembangan yang ada untuk mengidentifikasi potensi kelemahan lainnya. Menggunakan alat seperti pre-commit hooks dan CI/CD integration untuk memastikan secret tidak lagi terkomit secara tidak sengaja.

Lindungi Repo GitHub dari Dorking dan Kebocoran Data

Ringkasan:
  • GitHub Dorking memanfaatkan fitur pencarian GitHub untuk menemukan data sensitif yang terekspos.
  • Gunakan Secret Scanning, pre-commit hooks, dan .gitignore untuk mencegah kebocoran.
  • Lakukan pemindaian repository secara berkala menggunakan tools pendeteksi secret.
  • Jika secret bocor, segera revoke kredensial dan bersihkan riwayat Git.
  • Terapkan kontrol akses dan review keamanan secara berkelanjutan.

GitHub Dorking dapat menjadi ancaman serius bagi pengembang, karena memanfaatkan celah dalam repository publik untuk menemukan informasi sensitif yang tidak sengaja terkomit. Kebocoran seperti API key, password, dan token dapat menempatkan aplikasi dan data pengguna dalam bahaya besar. Namun, dengan langkah-langkah pencegahan yang tepat, repository dapat terlindungi dari kebocoran data dan potensi eksploitasi.

Amankan repository dan aplikasi Anda dengan infrastruktur yang stabil dan terpercaya. Gunakan Cloud VPS untuk mendukung performa deployment, menjaga keamanan data, serta memastikan aplikasi tetap berjalan optimal. Dengan resource yang fleksibel dan koneksi yang andal, Cloud VPS siap menjadi fondasi kuat untuk pengembangan hingga skala besar.

Fitri Aulia

Hi! I'm a tech enthusiast who loves digging into how things work, especially in web development, VPS setups, and anything open-source.


Berlangganan Artikel

Dapatkan artikel, free ebook dan video
terbaru dari DomaiNesia

{{ errors.name }} {{ errors.email }}
Migrasi ke DomaiNesia

Migrasi Hosting ke DomaiNesia Gratis 1 Bulan

Ingin memiliki hosting dengan performa terbaik? Migrasikan hosting Anda ke DomaiNesia. Gratis jasa migrasi dan gratis 1 bulan masa aktif!

Ya, Migrasikan Hosting Saya