bin/ 230 CLI tools (ask-*, br-*, agent-*, roadid, carpool) scripts/ 99 automation scripts fleet/ Node configs and deployment workers/ Cloudflare Worker sources (roadpay, road-search, squad webhooks) roadc/ RoadC programming language roadnet/ Mesh network (5 APs, WireGuard) operator/ Memory system scripts config/ System configs dotfiles/ Shell configs docs/ Documentation BlackRoad OS — Pave Tomorrow. RoadChain-SHA2048: d1a24f55318d338b RoadChain-Identity: alexa@sovereign RoadChain-Full: d1a24f55318d338b24b60bad7be39286379c76ae5470817482100cb0ddbbcb97e147d07ac7243da0a9f0363e4e5c833d612b9c0df3a3cd20802465420278ef74875a5b77f55af6fe42a931b8b635b3d0d0b6bde9abf33dc42eea52bc03c951406d8cbe49f1a3d29b26a94dade05e9477f34a7d4d4c6ec4005c3c2ac54e73a68440c512c8e83fd9b1fe234750b898ef8f4032c23db173961fe225e67a0432b5293a9714f76c5c57ed5fdf35b9fb40fd73c03ebf88b7253c6a0575f5afb6a6b49b3bda310602fb1ef676859962dad2aebbb2875814b30eee0a8ba195e482d4cbc91d8819e7f38f6db53e8063401649c77bb994371473cabfb917fb53e8cbe73d60
55 lines
2.2 KiB
Bash
Executable File
55 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
# BR-DNS - DNS lookup and management tool
|
|
PINK='\033[38;5;205m'
|
|
BLUE='\033[38;5;69m'
|
|
GREEN='\033[38;5;82m'
|
|
AMBER='\033[38;5;214m'
|
|
RESET='\033[0m'
|
|
|
|
while true; do
|
|
clear
|
|
printf "${PINK}╔════════════════════════════════════╗${RESET}\n"
|
|
printf "${PINK}║ 🌐 BR-DNS Manager ║${RESET}\n"
|
|
printf "${PINK}╚════════════════════════════════════╝${RESET}\n\n"
|
|
cat <<MENU
|
|
${BLUE}1${RESET}) Lookup domain (dig)
|
|
${BLUE}2${RESET}) Reverse DNS lookup
|
|
${BLUE}3${RESET}) Check blackroad.io records
|
|
${BLUE}4${RESET}) Check Pi-hole status (Alice)
|
|
${BLUE}5${RESET}) Flush local DNS cache
|
|
${BLUE}6${RESET}) Show /etc/resolv.conf
|
|
${BLUE}7${RESET}) Show blocked hosts (/etc/hosts)
|
|
${BLUE}0${RESET}) Quit
|
|
|
|
MENU
|
|
printf " ${PINK}> ${RESET}"
|
|
read -r c
|
|
case $c in
|
|
1) printf " Domain: "; read -r d
|
|
dig +short "$d" A "$d" AAAA "$d" MX "$d" CNAME 2>/dev/null || nslookup "$d"
|
|
read -rp " ↩ ";;
|
|
2) printf " IP: "; read -r ip
|
|
dig +short -x "$ip" 2>/dev/null || nslookup "$ip"
|
|
read -rp " ↩ ";;
|
|
3) printf "\n ${GREEN}blackroad.io DNS:${RESET}\n"
|
|
for t in A AAAA MX CNAME TXT NS; do
|
|
r=$(dig +short blackroad.io "$t" 2>/dev/null)
|
|
[[ -n "$r" ]] && printf " ${BLUE}%-6s${RESET} %s\n" "$t" "$r"
|
|
done
|
|
read -rp " ↩ ";;
|
|
4) printf "\n ${GREEN}Pi-hole (Alice):${RESET}\n"
|
|
curl -s "http://192.168.4.49/admin/api.php?summary" 2>/dev/null | python3 -m json.tool 2>/dev/null || echo " ⚠ Unreachable"
|
|
read -rp " ↩ ";;
|
|
5) sudo dscacheutil -flushcache 2>/dev/null && sudo killall -HUP mDNSResponder 2>/dev/null
|
|
printf " ${GREEN}DNS cache flushed${RESET}\n"
|
|
read -rp " ↩ ";;
|
|
6) cat /etc/resolv.conf; read -rp " ↩ ";;
|
|
7) blocked=$(grep -c '0.0.0.0\|127.0.0.1' /etc/hosts 2>/dev/null)
|
|
printf " ${AMBER}%d blocked domains in /etc/hosts${RESET}\n" "$blocked"
|
|
grep '0.0.0.0\|127.0.0.1' /etc/hosts | head -20
|
|
printf " ...\n"
|
|
read -rp " ↩ ";;
|
|
0|q) exit;;
|
|
esac
|
|
done
|