Di sini saya akan berusaha menjelaskan logika di balik script autologin milik saya, siapa tahu anda ingin melihat cara kerjanya, atau berminat membuat alternatif lainnya sesuai kondisi jaringan di daerah.
Semua script bergantung kepada berkas ini, yang merupakan hasil ketika kita login hotspot yang direkam oleh browser (di sini saya pakai Google Chrome, supaya hasilnya seragam dan mudah dibaca).
Berkas ini mengandung perintah yang diperlukan untuk mengulangi login menggunakan curl
.
Berkas harus diberi izin eksekusi dengan perintah chmod +x <nama file>
(biasanya: chmod +x /etc/login_file.txt
) agar bisa dijalankan oleh sistem.
Terdiri dari beberapa varian dan tipe, script akan mengecek kondisi jaringan terlebih dahulu ke server-server yang telah ditentukan, jika tidak terdeteksi adanya koneksi internet, baru akan dicoba untuk login kembali. Jadi tidak membombardir server login pihak hotspot (dalam ini @wifi.id dan turunannya), yang bisa menyebabkan akun diblokir.
-
autologin.sh / autologin-v2.sh / autologin-wms.sh
Varian ini mengecek kondisi jaringan dengan cara mengunduh berkascek
di serverperiksakoneksi.kopijahe.my.id
, dan memastikan bahwa isinya adalahOK
. Jika isinya berbeda (misal terkena redirect ke halaman login), maka bisa disimpulkan bahwa perlu dilakukan login kembali. -
autologin-firefox.sh / autologin-firefox-v2.sh / autologin-wms-firefox.sh
Varian ini mengecek kondisi jaringan dengan cara mengunduh berkassuccess.txt
di serverdetectportal.firefox.com
, dan memastikan bahwa isinya adalahsuccess
. Jika isinya berbeda (misal terkena redirect ke halaman login), maka bisa disimpulkan bahwa perlu dilakukan login kembali. -
autologin-google.sh / autologin-google-v2.sh / autologin-wms-google.sh
Varian ini mengecek kondisi jaringan dengan cara mengunduh berkasgenerate_204
di serverconnectivitycheck.gstatic.com
(ini adalah server bawaan android untuk memeriksa koneksi internet), dan memastikan bahwa respon server adalahHTTP/1.1 204 No Content
. Jika respon server berbeda (misal terkena redirect ke halaman login), maka bisa disimpulkan bahwa perlu dilakukan login kembali.
Semua script akan dirubah namanya menjadi autologin.sh
ketika diunduh, supaya memudahkan pengguna ketika mengikuti langkah-langkah tutorial.
Sistem login Venue WMS berbeda dengan jaringan @wifi.id, dimana sistem akan menambahkan titik .
serta 4 karakter angka dan huruf di akhir username pengguna, misal: usernamesaya
akan dirubah menjadi usernamesaya.Br0W
.
Pertama kita buat 4 karakter huruf dan angka baru secara acak dari /dev/urandom
, lalu kita masukkan ke berkas login_file.txt, akan tetapi jika dilakukan seperti ini, setiap kali script melakukan login kembali, 4 karakter tadi akan berubah, yang menyebabkan script tidak akan berjalan...
Maka dari itu, saya atur supaya berkas asli dirubah saja 4 karakter tadi menjadi kopijahe
, supaya selalu konsisten. Lalu berkas ini dibawa ke tempat sementara untuk diproses oleh script sebelum dijalankan untuk keperluan login kembali.
Script yang berakhiran v2 memuat logika tambahan untuk berjaga-jaga jika terdapat gangguan yang menyebabkan dilakukannya login secara berulang-ulang (setidaknya 6 kali berturut-turut) dalam waktu singkat, yang menyebabkan perubahan status akun menjadi [Blocked IP]
. Jika terdeteksi perubahan status ini, maka script akan berusaha meminta alamat IP baru sebelum melakukan login kembali.
Karena cara yang digunakan, script v2 tidak cocok untuk dipakai ketika perangkat autologin bukanlah perangkat yang menangkap langsung sinyal @wifi.id (misal: Sinyal @wifi.id ditangkap menggunakan CPE 210, lalu dipancarkan lagi menggunakan router openwrt).