index |
---|
nomor 1 |
nomor 2 |
nomor 3 |
nomor 4 |
nomor 5 |
Anda diminta tolong oleh teman anda untuk mengembalikan filenya yang telah dienkripsi oleh seseorang menggunakan bash script, file yang dimaksud adalah nature.zip. Karena terlalu mudah kalian memberikan syarat akan membuka seluruh file tersebut jika pukul 14:14 pada tanggal 14 Februari atau hari tersebut adalah hari jumat pada bulan Februari.
for f in ./nature/*; do
hexdump -C "$f"
base64 -d "$f" | xxd -r > ./nature/hasil/$(basename $f .jpg)_baru.jpg
done
penjelasan
asumsi kita telah mendownload nature.zip
.
file tersebut berisi gambar-gambar yang telah terenkripsi dengan base64
selanjutnya membuat folder baru bernama nature
dan di dalam folder tersebut kita buatkan folder dengan nama hasil
.
barulah membuat file script bash dengan nama prak1soal1.sh
for f in ./nature/*; do
...
done
syntax di atas digunakan untuk fungsi for each pada semua file foto yang ada di dalam folder nature.
hexdump -C "$f"
done
syntax di atas digunakan untuk menjaadikan hexadeximal .
base64 -d "$f" | xxd -r > ./nature/hasil/$(basename $f .jpg)_baru.jpg
done
syntax di atas digunakan untuk mendecode file gambar yang telah dihexdump lalu direverse ke bentuk format gambar kembali ke binary .
barulah kita masukkan ke dalam crontab untuk pukul 14:14 pada tanggal 14 Februari atau hari tersebut adalah harijumat pada bulan Februari
14 14 14 2 5 /bin/bash /home/vagrant/prak1soal1.sh
Anda merupakan pegawai magang pada sebuah perusahaan retail, dan anda diminta untuk memberikan laporan berdasarkan file WA_Sales_Products_2012-14.csv. Laporan yang diminta berupa:
- a. Tentukan negara dengan penjualan(quantity) terbanyak pada tahun 2012.
- b. Tentukan tiga product line yang memberikan penjualan(quantity)terbanyak pada soal poin a.
- c. Tentukan tiga product yang memberikan penjualan(quantity)terbanyak berdasarkan tiga product line yang didapatkan pada soalpoin b.
file="assets/WA_Sales_Products_2012-14.csv"
IFS=
temp=$(awk 'BEGIN { FS = "," ; OFS = ";" } ; $7 ~ /2012/ { print $1,$4,$6,$10,$7}' < $file | sort -t ';' -k 4 -V -r)
country=$(echo $temp | awk 'BEGIN { FS = ";" } ; {print $1} NR>0{exit}')
echo ""
echo "Nomor 2A"
echo "$country"
produk=$(echo $temp | awk -v negara="$country" 'BEGIN { FS= ";" } ; $1 ~ negara && !seen[$2]++ {print $2}' | awk '{print $0} NR>2{exit}')
echo ""
echo "Nomor 2B"
echo "$produk"
echo ""
echo "Nomor 2C"
echo $temp | awk -v negara="$country" 'BEGIN { FS= ";" } ; $1 ~ negara && ($2 ~ /Personal Accessories/ || $2 ~ /Camping Equipment/ || $2 ~ /Outdoor Protection/) && !seen[$3]++ {print $3}' | awk '{print} NR>2{exit}'
penjelasan
asumsi kita telah mendownload assets/WA_Sales_Products_2012-14.csv
.
File tersebut berisi sekumpulan data Produk, kuantitas, negara , dan lain-lain.
Pertama tama kita perlu mendapatkan data yang dibutuhkan.
file="assets/WA_Sales_Products_2012-14.csv"
IFS=
temp=$(awk 'BEGIN { FS = "," ; OFS = ";" } ; $7 ~ /2012/ { print $1,$4,$6,$10,$7}' < $file | sort -t ';' -k 4 -V -r)
syntax di atas digunakan untuk mengambil file yang dimaksud lalu diambil data-data yang diperlukan yaitu negara, produk, produk line, dan kuantitas. Semua data tersebut kemudian diurutkan dari kuantitas terbersar hingga terkecil dan disimpan dalam variabel temp untuk digunakan di pertanyaan berikutnya.
# 2.a
echo "Nomor 2A"
country=$(echo $temp | awk 'BEGIN { FS = ";" } ; {print $1} NR>0{exit}')
echo "$country"
Pada nomor 2a cukup dengan menampilkan nama negara pada urutan teratas yang ada dalam variabel temp .
# 2.b
echo ""
echo "Nomor 2B"
produk=$(echo $temp | awk -v negara="$country" 'BEGIN { FS= ";" } ; $1 ~ negara && !seen[$2]++ {print $2}' | awk '{print $0} NR>2{exit}')
echo "$produk"
Pada nomor 2b kita perlu mengolah data yang ada dalam variabel temp . data yang dimaksud diambil pada field product line
yaitu pada field ke 2
.
jangan lupa tambahkan kondisi !seen[$2]++
agar muncul secara identik.
Barulah kita tampilkan hasil sebanyak tiga teratas saja. Hasil tersebut kita masukkan ke dalam variabel produk agar bisa digunakan pada soal berikutnya.
# 2.c
echo ""
echo "Nomor 2C"
echo $temp | awk -v negara="$country" 'BEGIN { FS= ";" } ; $1 ~ negara && ($2 ~ /Personal Accessories/ || $2 ~ /Camping Equipment/ || $2 ~ /Outdoor Protection/) && !seen[$3]++ {print $3}' | awk '{print} NR>2{exit}'
Berikutnya kita tampilkan produk teratas yang termasuk ke dalam ketiga produk line.
Buatlah sebuah script bash yang dapat menghasilkan password secara acak sebanyak 12 karakter yang terdapat huruf besar, huruf kecil, dan angka. Password acak tersebut disimpan pada file berekstensi .txt dengan ketentuan pemberian nama sebagai berikut:
- a. Jika tidak ditemukan file password1.txt maka password acak tersebut disimpan pada file bernama password1.txt
- b. Jika file password1.txt sudah ada maka password acak baru akan disimpan pada file bernama password2.txt dan begitu seterusnya.
- c. Urutan nama file tidak boleh ada yang terlewatkan meski filenya dihapus.
- d. Password yang dihasilkan tidak boleh sama.
#!/bin/bash
file=/home/vagrant/genpass/password
while true
do
ok=1
password="$(dd if=/dev/urandom|tr -dc A-Za-z0-9|head -c 12)"
#cek huruf besar dan kecil
#echo "$password"
kcl=0
bsr=0
angka=0
for (( i=0; i<${#password}; i++)); do
kata="${password:i:1}"
#echo "$kata"
if [[ $kata =~ ^[A-Z]+$ ]];
then
let "bsr += 1"
fi
if [[ $kata =~ ^[a-z]+$ ]];
then
let "kcl += 1"
fi
if [[ $kata =~ ^[0-9]+$ ]];
then
let "angka += 1"
fi
done
#echo "$kcl $bsr $angka"
#cek apakah password sudah ada
for f in $file*; do
read -r line < $f
#echo $line
if [[ $kata = $line ]]
then
let "ok = 0"
fi
done
if [[ $ok -eq 1 ]]
then
break
fi
done
#untuk save file
i=1
#file=/home/vagrant/genpass/password
while [ -f "$file$i.txt" ]
do
let i++
done
echo "$password" >$file$i.txt
#echo "$password"
penjelasan
password="$(dd if=/dev/urandom|tr -dc A-Za-z0-9|head -c 12)"
syntax diatas digunakan untuk membuat password acak
for (( i=0; i<${#password}; i++)); do
kata="${password:i:1}"
#echo "$kata"
if [[ $kata =~ ^[A-Z]+$ ]];
then
let "bsr += 1"
fi
if [[ $kata =~ ^[a-z]+$ ]];
then
let "kcl += 1"
fi
if [[ $kata =~ ^[0-9]+$ ]];
then
let "angka += 1"
fi
done
Fungsi iterasi di atas untuk mengecek apakah password sudah mengandung angka, huruf besar, dan huruf kecil
for f in $file*; do
read -r line < $f
#echo $line
if [[ $kata = $line ]]
then
let "ok = 0"
fi
done
barulah kita cek apakah password sudah ada sebelumnya atau tidak, jika ya maka generate password lagi
i=1
while [ -f "$file$i.txt" ]
do
let i++
done
echo "$password" >$file$i.txt
selanjutnya kita simpan password tersebut
Lakukan backup file syslog setiap jam dengan format nama file “jam:menit tanggal- bulan-tahun”. Isi dari file backup terenkripsi dengan konversi huruf (string manipulation) yang disesuaikan dengan jam dilakukannya backup misalkan sebagai berikut:
- a. Huruf b adalah alfabet kedua, sedangkan saat ini waktu menunjukkanpukul 12, sehingga huruf b diganti dengan huruf alfabet yang memiliki urutan ke 12+2 = 14.
- b. Hasilnya huruf b menjadi huruf n karena huruf n adalah huruf ke empat belas, dan seterusnya.
- c. setelah huruf z akan kembali ke huruf a
- d. Backup file syslog setiap jam.
- e. dan buatkan juga bash script untuk dekripsinya.
lw=( {a..z} )
hi=( {A..Z} )
waktu=$(date +"%H")
fname=$(date +"%H:%M %d-%m-%Y")
a=$((waktu%26))
b=$((a-1))
while read -r line ; do
if [ $a -ne 0 ]; then
echo "$line" | tr [a-zA-Z] ["${lw[a]}"-za-"${lw[b]}""${hi[a]}"-ZA-"${hi[b]}"] >> encryptedsyslog/"$fname"
else
echo "$line" >> encryptedsyslog/"$fname"
fi
done < '/var/log/syslog'
--Penjelasan--
echo "$line" | tr [a-zA-Z] ["${lw[a]}"-za-"${lw[b]}""${hi[a]}"-ZA-"${hi[b]}"] >> encryptedsyslog/"$fname"
fungsi utama yang bekerja pada script ini adalah syntax di atas. ia akan menkonversi alphabet menjadi huruf ke-jam setelah huruf tersebut.
Buatlah sebuah script bash untuk menyimpan record dalam syslog yang memenuhi kriteria berikut:
- a. Tidak mengandung string “sudo”, tetapi mengandung string “cron”, serta buatlah pencarian stringnya tidak bersifat case sensitive, sehingga huruf kapital atau tidak, tidak menjadi masalah.
- b. Jumlah field (number of field) pada baris tersebut berjumlah kurang dari 13.
- c. Masukkan record tadi ke dalam file logs yang berada pada direktori
/home/[user]/modul1.
- d. Jalankan script tadi setiap 6 menit dari menit ke 2 hingga 30, contoh 13:02, 13:08, 13:14, dst.
awk 'BEGIN {IGNORECASE = 1} /cron/ && !/sudo/ ' /var/log/syslog | awk 'NF < 13' >> /home/vagrant/modul1/syslogno5.log
penjelasan
awk 'BEGIN {IGNORECASE = 1} /cron/ && !/sudo/ ' /var/log/syslog
Perintah awk di atas untuk mencari data pada syslog
dengan kata kunci cron dan bukan sudo dan harus case insensitive .
barulah kita tampilkan line syslog degan jumlah field kurang dari 13 dan dimasukkan ke dalam file /home/vagrant/modul1/syslogno5.log
untuk mensetting crontab: Every 6th minutes, from 2 through 30.
2-30/6 * * * * /bin/bash /home/vagrant/prak1soal5.sh