-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbind_rpz_generator.sh
executable file
·147 lines (128 loc) · 5.96 KB
/
bind_rpz_generator.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
#!/bin/bash
################################################################################################################
# NAMA SCRIPT : TRUSTPOSITIF-RPZ-DNS-ZONE-UPDATER.SH
# FUNGSI : MEMPERBARUI ZONA DNS DENGAN DATA TRUSTPOSITIF, WHITELIST DAN SAFESEARCH
# DESKRIPSI : SCRIPT INI MENGUNDUH DATA DARI BERBAGAI SUMBER DAN MENGONVERSINYA KE FORMAT RPZ UNTUK BIND.
# AUTHOR : HARRY DERTIN SUTISNA
# WAKTU & TANGGAL : JAKARTA, 25 MARET 2025
################################################################################################################
# Warna ANSI
MERAH="\033[1;31m"
HIJAU="\033[1;32m"
KUNING="\033[1;33m"
CYAN="\033[1;36m"
MAGENTA="\033[1;35m"
BIRU="\033[1;34m"
PUTIH="\033[1;37m"
HITAM="\033[1;30m"
ABUABU="\033[1;90m"
MERAH_TUA="\033[1;91m"
HIJAU_TUA="\033[1;92m"
KUNING_TUA="\033[1;93m"
CYAN_TUA="\033[1;96m"
MAGENTA_TUA="\033[1;95m"
BIRU_TUA="\033[1;94m"
PUTIH_TUA="\033[1;97m"
RESET="\033[0m"
# Variabel
URL_TRUSTPOSITIF="https://raw.githubusercontent.com/alsyundawy/TrustPositif-To-RPZ-Binary/refs/heads/main/alsyundawy-blocklist/alsyundawy_blacklist_v2.txt"
FILE_TRUSTPOSITIF="/etc/bind/zones/trustpositif.zones"
CNAME_TRUSTPOSITIF="lamanlabuh.resolver.id."
TMP_TRUSTPOSITIF="/tmp/trustpositif_domains.txt"
# Fungsi untuk menampilkan pesan berwarna
function cetak_pesan() {
echo -e "$1$2${RESET}"
}
cetak_pesan "$CYAN" "PEMBAHARUAN DATABASE INTERNET SEHAT TRUSTPOSITIF DIPROSES"
# Banner dengan warna
echo -e "${MAGENTA}
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/ \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \
( H | A | R | R | Y ) ( D | S ) ( A | L | S | Y | U | N | D | A | W | Y )
\_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/
${RESET}"
echo -e "${CYAN}############################################################################${RESET}"
echo -e "${CYAN}## ##${RESET}"
echo -e "${CYAN}##${MERAH} PEMBAHARUAN DATABASE INTERNET SEHAT TRUSTPOSITIF ${CYAN}##${RESET}"
echo -e "${CYAN}##${MAGENTA} UNTUK DNS FILTER ISP ${CYAN}##${RESET}"
echo -e "${CYAN}## ##${RESET}"
echo -e "${CYAN}##${HIJAU} SCRIPT INI DIBUAT & DIMODIFIKASI OLEH HARRY DS ALSYUNDAWY ${CYAN}##${RESET}"
echo -e "${CYAN}##${BIRU} [email protected] | 08568515212 | ALSYUNDAWY.COM ${CYAN}##${RESET}"
echo -e "${CYAN}##${KUNING} PADA TANGGAL 25 MARET 2025 ${CYAN}##${RESET}"
echo -e "${CYAN}## ##${RESET}"
echo -e "${CYAN}############################################################################${RESET}"
# Fungsi untuk membuat header RPZ
generate_rpz_header() {
cat << EOF
;
;############################################################################
; _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
; / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \ / \
;( H | A | R | R | Y ) ( D | S ) ( A | L | S | Y | U | N | D | A | W | Y )
; \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/ \_/
;
;############################################################################
; RPZ FILE GENERATED BY : TRUSTPOSITIF-RPZ-GENERATOR
; DIBUAT PADA : $(date '+%Y-%m-%d %H:%M:%S')
; VERSION : $(date '+%y%m%d%H%M')
; SYNTAX : RPZ
; AUTHOR : HARRY DERTIN SUTISNA ALSYUNDAWY
; EMAIL : [email protected]
; WHATSAPP/TELEGRAM/CALL : +628568515212 & +6281298986464
; HOMEPAGE : HTTPS://ALSYUNDAWY.COM
;############################################################################
;
\$TTL 300
@ IN SOA dns.alsyundawy.com. hostmaster.alsyundawy.com. (
$(date '+%y%m%d%H%M') ; Serial
10800 ; Refresh
120 ; Retry
604800 ; Expire
3600 ) ; Minimum TTL
@ IN NS lamanlabuh.resolver.id.
EOF
}
# Fungsi untuk mengunduh dan memproses TrustPositif
generate_trustpositif_rpz() {
cetak_pesan "$HIJAU" "Mengunduh data TrustPositif..."
if ! curl -k "$URL_TRUSTPOSITIF" | tr '[:upper:]' '[:lower:]' > "$TMP_TRUSTPOSITIF"; then
cetak_pesan "$MERAH" "[ERROR] Gagal mengunduh data TrustPositif."
exit 1
fi
cetak_pesan "$HIJAU" "Mengonversi data TrustPositif ke format RPZ..."
{
generate_rpz_header
awk '/^[^#]/ {print $1 " 3600 IN CNAME " CNAME_TRUSTPOSITIF; print "*." $1 " 3600 IN CNAME " CNAME_TRUSTPOSITIF}' CNAME_TRUSTPOSITIF="$CNAME_TRUSTPOSITIF" "$TMP_TRUSTPOSITIF"
} > "$FILE_TRUSTPOSITIF"
}
# Fungsi untuk memeriksa file zona
check_zone_files() {
cetak_pesan "$HIJAU" "Memeriksa file zona..."
for file in "$FILE_TRUSTPOSITIF" "$FILE_WHITELIST" "$FILE_SAFESEARCH"; do
if ! named-checkzone "$(basename "$file" .zones)" "$file" > /dev/null 2>&1; then
cetak_pesan "$MERAH" "[ERROR] Kesalahan dalam file zona $(basename "$file")."
exit 1
fi
done
}
# Fungsi utama
main() {
cetak_pesan "$CYAN" "MEMULAI PEMBARUAN DATABASE DNS..."
generate_trustpositif_rpz
check_zone_files
# Reload DNS and restart necessary services
cetak_pesan "$MAGENTA" "Reloading DNS and restarting necessary services..."
echo 3 > /proc/sys/vm/drop_caches
swapoff -a && swapon -a
# Clear logs and temporary files
truncate -s 0 /var/log/syslog /var/log/daemon.log /var/log/lastlog /var/log/auth.log /var/log/btmp
# truncate -s 0 /var/log/*
find /var/log -type f -regex ".*\.(log(\..*)?|gz|1|vmware-.*\.log)$" -delete
rm -rf /root/filter/*.tmp /etc/bind/zones/*.txt /etc/bind/*.txt /var/log/nginx/*
# Update root hints
wget -q -O /usr/share/dns/root.hints "https://www.internic.net/domain/named.root"
# Optimize journal logs
journalctl --vacuum-size=75M --vacuum-time=2d
cetak_pesan "$HIJAU" "[BERHASIL] Semua file zona berhasil diperbarui dan diverifikasi."
}
main