Adding Debian support
This commit is contained in:
parent
6941655ab3
commit
2d5ae65847
36
install.sh
36
install.sh
@ -3,7 +3,7 @@
|
|||||||
CURRENT_USER="${SUDO_USER}"
|
CURRENT_USER="${SUDO_USER}"
|
||||||
SCRIPT_PATH="$( cd "$(dirname "$0")" ; pwd -P )"
|
SCRIPT_PATH="$( cd "$(dirname "$0")" ; pwd -P )"
|
||||||
HOST="$( hostname )"
|
HOST="$( hostname )"
|
||||||
IFACES="$( ifconfig -a | grep -Eo '[a-z0-9]{4,14}\: ' | grep -oE [a-z0-9]+ )"
|
IFACES="$( ip a s | grep -Eo '[a-z0-9]{4,15}\: ' | grep -oE [a-z0-9]+ )"
|
||||||
IFACE_OUT=""
|
IFACE_OUT=""
|
||||||
IFACE_IN=""
|
IFACE_IN=""
|
||||||
LOCALES=(en fr cat es ru pt de it)
|
LOCALES=(en fr cat es ru pt de it)
|
||||||
@ -29,7 +29,7 @@ check_operating_system() {
|
|||||||
error="\e[91m [✘] Need to be run on a Debian-like operating system, exiting.\e[39m"
|
error="\e[91m [✘] Need to be run on a Debian-like operating system, exiting.\e[39m"
|
||||||
|
|
||||||
if [[ -f "/etc/os-release" ]]; then
|
if [[ -f "/etc/os-release" ]]; then
|
||||||
if [[ $(cat /etc/os-release | grep "ID_LIKE=debian") ]]; then
|
if [[ $(cat /etc/os-release | grep -e "ID_LIKE=\"\?debian" -e "ID=debian") ]]; then
|
||||||
echo -e "\e[92m [✔] Debian-like operating system\e[39m"
|
echo -e "\e[92m [✔] Debian-like operating system\e[39m"
|
||||||
else
|
else
|
||||||
echo -e "$error"
|
echo -e "$error"
|
||||||
@ -264,7 +264,7 @@ change_hostname() {
|
|||||||
|
|
||||||
install_package() {
|
install_package() {
|
||||||
# Install associated packages by using aptitude.
|
# Install associated packages by using aptitude.
|
||||||
if [[ $1 == "dnsmasq" || $1 == "hostapd" || $1 == "tshark" || $1 == "sqlite3" || $1 == "suricata" || $1 == "unclutter" ]]; then
|
if [[ $1 == "dnsmasq" || $1 == "hostapd" || $1 == "tshark" || $1 == "sqlite3" || $1 == "suricata" || $1 == "unclutter" || $1 == "swig" || $1 == "curl" ]]; then
|
||||||
apt-get install $1 -y
|
apt-get install $1 -y
|
||||||
elif [[ $1 == "zeek" ]]; then
|
elif [[ $1 == "zeek" ]]; then
|
||||||
distrib=$(cat /etc/os-release | grep -E "^ID=" | cut -d"=" -f2)
|
distrib=$(cat /etc/os-release | grep -E "^ID=" | cut -d"=" -f2)
|
||||||
@ -283,12 +283,14 @@ install_package() {
|
|||||||
rm Release.key && sudo apt-get update
|
rm Release.key && sudo apt-get update
|
||||||
apt-get install zeek -y
|
apt-get install zeek -y
|
||||||
elif [[ $1 == "node" ]]; then
|
elif [[ $1 == "node" ]]; then
|
||||||
curl -sL https://deb.nodesource.com/setup_14.x | bash
|
curl -sL https://deb.nodesource.com/setup_14.x | bash -
|
||||||
apt-get install -y nodejs
|
apt-get install -y nodejs
|
||||||
elif [[ $1 == "dig" ]]; then
|
elif [[ $1 == "dig" ]]; then
|
||||||
apt-get install -y dnsutils
|
apt-get install -y dnsutils
|
||||||
elif [[ $1 == "pip" ]]; then
|
elif [[ $1 == "pip" ]]; then
|
||||||
apt-get install -y python3-pip
|
apt-get install -y python3-pip
|
||||||
|
elif [[ $1 == "dhcpcd" ]]; then
|
||||||
|
apt-get install -y dhcpcd5
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -303,7 +305,10 @@ check_dependencies() {
|
|||||||
"/usr/bin/suricata"
|
"/usr/bin/suricata"
|
||||||
"/usr/bin/unclutter"
|
"/usr/bin/unclutter"
|
||||||
"/usr/bin/sqlite3"
|
"/usr/bin/sqlite3"
|
||||||
"/usr/bin/pip")
|
"/usr/bin/pip"
|
||||||
|
"/usr/bin/swig"
|
||||||
|
"/usr/sbin/dhcpcd"
|
||||||
|
"/usr/bin/curl")
|
||||||
|
|
||||||
echo -e "\e[39m[+] Checking dependencies...\e[39m"
|
echo -e "\e[39m[+] Checking dependencies...\e[39m"
|
||||||
for bin in "${bins[@]}"
|
for bin in "${bins[@]}"
|
||||||
@ -316,6 +321,7 @@ check_dependencies() {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
install_package node
|
install_package node
|
||||||
|
install_package dnsmasq
|
||||||
echo -e "\e[39m[+] Install Python packages...\e[39m"
|
echo -e "\e[39m[+] Install Python packages...\e[39m"
|
||||||
python3 -m pip install -r "$SCRIPT_PATH/assets/requirements.txt"
|
python3 -m pip install -r "$SCRIPT_PATH/assets/requirements.txt"
|
||||||
}
|
}
|
||||||
@ -364,7 +370,7 @@ cleaning() {
|
|||||||
check_interfaces(){
|
check_interfaces(){
|
||||||
|
|
||||||
# Get the current connected interface name.
|
# Get the current connected interface name.
|
||||||
ciface="$(route | grep default | head -1 | grep -Eo '[a-z0-9]+$')"
|
ciface="$(ip r l default |grep -Po '(?<=(dev ))(\S+)')"
|
||||||
|
|
||||||
# Setup of iface_out which can be any interface,
|
# Setup of iface_out which can be any interface,
|
||||||
# but needs to be connected now or in the future.
|
# but needs to be connected now or in the future.
|
||||||
@ -379,7 +385,7 @@ check_interfaces(){
|
|||||||
IFACES=( "${IFACES[@]/$ciface}" )
|
IFACES=( "${IFACES[@]/$ciface}" )
|
||||||
for iface in $IFACES;
|
for iface in $IFACES;
|
||||||
do
|
do
|
||||||
config="$(ifconfig $iface)"
|
config="$(ip a s $iface)"
|
||||||
echo -n "[?] Do you want to use $iface as a bridge to Internet (network/out) ? [Y/n] "
|
echo -n "[?] Do you want to use $iface as a bridge to Internet (network/out) ? [Y/n] "
|
||||||
read answer
|
read answer
|
||||||
if [[ "$answer" =~ ^([yY][eE][sS]|[yY])$ ]]
|
if [[ "$answer" =~ ^([yY][eE][sS]|[yY])$ ]]
|
||||||
@ -396,8 +402,8 @@ check_interfaces(){
|
|||||||
# Wi-Fi interface with AP mode available.
|
# Wi-Fi interface with AP mode available.
|
||||||
for iface in $IFACES;
|
for iface in $IFACES;
|
||||||
do
|
do
|
||||||
if echo "$iface" | grep -Eq "(wlan[0-9]|wl[a-z0-9]{20})"; then
|
if echo "$iface" | grep -Eq "(wlan[0-9]|wl[a-z0-9]{,20})"; then
|
||||||
config="$(ifconfig $iface)" # Get the iface logic configuration
|
config="$(ip a s $iface)" # Get the iface logic configuration
|
||||||
if echo "$config" | grep -qv "inet "; then # Test if not currently connected
|
if echo "$config" | grep -qv "inet "; then # Test if not currently connected
|
||||||
hw="$(iw $iface info | grep wiphy | cut -d" " -f2)" # Get the iface hardware id.
|
hw="$(iw $iface info | grep wiphy | cut -d" " -f2)" # Get the iface hardware id.
|
||||||
info="$(iw phy$hw info)" # Get the iface hardware infos.
|
info="$(iw phy$hw info)" # Get the iface hardware infos.
|
||||||
@ -445,9 +451,15 @@ feeding_iocs() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
reboot_box() {
|
reboot_box() {
|
||||||
echo -e "\e[92m[+] The system is going to reboot\e[39m"
|
echo -e "\e[92m[+] The system is going to reboot, OK ?\e[39m"
|
||||||
sleep 5
|
read answer
|
||||||
reboot
|
if [[ "$answer" =~ ^([yY][eE][sS]|[yY])$ ]]
|
||||||
|
then
|
||||||
|
sleep 5
|
||||||
|
reboot
|
||||||
|
else
|
||||||
|
exit
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
if [[ $EUID -ne 0 ]]; then
|
if [[ $EUID -ne 0 ]]; then
|
||||||
|
@ -239,7 +239,7 @@ class Network(object):
|
|||||||
# Kill potential zombies of hostapd
|
# Kill potential zombies of hostapd
|
||||||
terminate_process("hostapd")
|
terminate_process("hostapd")
|
||||||
|
|
||||||
sp.Popen(["ifconfig", self.iface_in, "up"]).wait()
|
sp.Popen(["ip","link","set", self.iface_in, "up"]).wait()
|
||||||
sp.Popen(
|
sp.Popen(
|
||||||
"/usr/sbin/hostapd /tmp/hostapd.conf > /tmp/hostapd.log", shell=True)
|
"/usr/sbin/hostapd /tmp/hostapd.conf > /tmp/hostapd.log", shell=True)
|
||||||
|
|
||||||
@ -314,15 +314,15 @@ class Network(object):
|
|||||||
This enable interfaces, with a simple check.
|
This enable interfaces, with a simple check.
|
||||||
:return: bool if everything goes well
|
:return: bool if everything goes well
|
||||||
"""
|
"""
|
||||||
sh = sp.Popen(["ifconfig", iface],
|
sh = sp.Popen(["ip" ,"a","s", iface],
|
||||||
stdout=sp.PIPE, stderr=sp.PIPE)
|
stdout=sp.PIPE, stderr=sp.PIPE)
|
||||||
sh = sh.communicate()
|
sh = sh.communicate()
|
||||||
if b"<UP," in sh[0]:
|
if b",UP" in sh[0]:
|
||||||
return True # The interface is up.
|
return True # The interface is up.
|
||||||
elif sh[1]:
|
elif sh[1]:
|
||||||
return False # The interface doesn't exists (most of the cases).
|
return False # The interface doesn't exists (most of the cases).
|
||||||
else:
|
else:
|
||||||
sp.Popen(["ifconfig", iface, "up"]).wait()
|
sp.Popen(["ip","link","set", iface, "up"]).wait()
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def check_internet(self):
|
def check_internet(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user