Compare commits

...

9 Commits

Author SHA1 Message Date
Steven Foerster 0f1c7fbcf6 Merge branch 'master' into 53-wifi 5 years ago
Steven Foerster ed6975e82d Merge branch 'master' into 53-wifi 5 years ago
Steven Foerster b7ee2e87bc local state 5 years ago
Steven Foerster c8c7663d08 Merge branch 'master' into 53-wifi 5 years ago
Steven Foerster 44e4a395fc Merge branch 'master' into 53-wifi 5 years ago
Steven Foerster 7a4498215b Merge branch 'master' into 53-wifi 5 years ago
Steven Foerster 255e1d5ecf env file 6 years ago
Steven Foerster 01cbf98b51 adding wificfg options 6 years ago
Steven Foerster 526cf49fb5 integrating wifi container 6 years ago
  1. 23
      extra/wifi.yml
  2. 18
      scripts/conf/wificfg.json
  3. 28
      scripts/services/Mistborn-wifi.service
  4. 75
      scripts/services/wifi/init.sh
  5. 0
      scripts/services/wifi/start.sh
  6. 0
      scripts/services/wifi/stop.sh
  7. 3
      scripts/subinstallers/wifi.sh

23
extra/wifi.yml

@ -0,0 +1,23 @@
version: '3'
services:
wifi:
#user: root
image: "cyber5k/wifi:${MISTBORN_TAG}"
container_name: mistborn_production_wifi
#labels:
# - "traefik.enable=true"
# - "traefik.port=80"
#env_file:
# - ../.envs/.production/.pihole
#command: /start
volumes:
- ../../mistborn_volumes/extra/wifi/hostapd.conf:/etc/hostapd/hostapd.conf
- ../../mistborn_volumes/extra/wifi/dnsmasq.conf:/etc/dnsmasq.conf
# - ../../mistborn_volumes/extra/wifi/wificfg.json:/cfg/wificfg.json
network_mode: bridge #host
cap_add:
- NET_ADMIN
- NET_RAW
#privileged: true

18
scripts/conf/wificfg.json

@ -0,0 +1,18 @@
{
"wifi_iface": "wlan0",
"dnsmasq_cfg": {
"address": "/#/192.168.27.1",
"dhcp_range": "192.168.27.100,192.168.27.150,1h",
"dhcp_option": "6,10.2.3.1",
"vendor_class": "set:device,IoT"
},
"host_apd_cfg": {
"ip": "192.168.27.1",
"ssid": "mistborn",
"wpa_passphrase":"iotwifipass",
"channel": "6"
},
"wpa_supplicant_cfg": {
"cfg_file": "/etc/wpa_supplicant/wpa_supplicant.conf"
}
}

28
scripts/services/Mistborn-wifi.service

@ -0,0 +1,28 @@
[Unit]
Description=Mistborn Wifi Service
Requires=Mistborn-base.service
After=Mistborn-base.service
[Service]
Restart=always
User=root
Group=docker
PermissionsStartOnly=true
# Shutdown container (if running) when unit is stopped
EnvironmentFile=/opt/mistborn/.env
ExecStartPre=/usr/local/bin/docker-compose -f /opt/mistborn/extra/wifi.yml down
ExecStartPre=/opt/mistborn/scripts/services/wifi/init.sh
ExecStartPre=/usr/local/bin/docker-compose -f /opt/mistborn/extra/wifi.yml build
# Start container when unit is started
ExecStart=/usr/local/bin/docker-compose -f /opt/mistborn/extra/wifi.yml up
ExecStartPost=/opt/mistborn/scripts/services/wifi/start.sh
# Stop container when unit is stopped
ExecStop=/usr/local/bin/docker-compose -f /opt/mistborn/extra/wifi.yml down
# Post stop
ExecStopPost=/opt/mistborn/scripts/services/wifi/stop.sh
[Install]
WantedBy=multi-user.target

75
scripts/services/wifi/init.sh

@ -0,0 +1,75 @@
#!/bin/bash
# Colors
MAGENTA='\e[0;35m'
RED='\e[0;31m'
GREEN='\e[0;32m'
BLUE='\e[0;34m'
NC='\e[0m'
# Check that the interface exists and its not in use. Returns iface phy
iface_check (){
IFACE="$1"
# Check that the requested iface is available
if ! [ -e /sys/class/net/"$IFACE" ]
then
echo -e "${RED}[ERROR]${NC} The interface provided does not exist. Exiting..."
exit 1
fi
# Check that the given interface is not used by the host as the default route
if [[ $(ip r | grep default | cut -d " " -f5) == "$IFACE" ]]
then
echo -e "${BLUE}[INFO]${NC} The selected interface is configured as the default route, if you use it you will lose internet connectivity"
exit 1;
fi
# Find the physical interface for the given wireless interface
PHY=$(cat /sys/class/net/"$IFACE"/phy80211/name)
echo $PHY
}
hostapd_setup() {
### Check if hostapd is running in the host
hostapd_pid=$(pgrep hostapd)
if [ ! "$hostapd_pid" == "" ]
then
echo -e "${BLUE}[INFO]${NC} hostapd service is already running in the system, make sure you use a different wireless interface..."
#kill -9 "$hostapd_pid"
fi
# Unblock wifi and bring the wireless interface up
echo -e "${BLUE}[INFO]${NC} Unblocking wifi and setting ${IFACE} up"
rfkill unblock wifi
ip link set "$IFACE" up
# Check if a wlan config file exists, else take wlan parameters by default
if [ -e "$PATHSCRIPT"/"$CONF_FILE" ]
then
echo -e "${BLUE}[INFO]${NC} Found WLAN config file"
# Parse the wlan config file
IFS="="
while read -r name value
do
case $name in
''|\#* ) continue;; # Skip blank lines and lines starting with #
"SSID" )
SSID=${value//\"/}
echo -e "${BLUE}"[INFO]"${NC}" SSID: "${MAGENTA}""$SSID""${NC}";;
"PASSPHRASE" )
PASSPHRASE=${value//\"/};;
"HW_MODE" )
HW_MODE=${value//\"/};;
"CHANNEL" )
CHANNEL=${value//\"/};;
* )
echo Parameter "$name" in "$PATHSCRIPT"/"$CONF_FILE" not recognized
esac
done < "$PATHSCRIPT"/"$CONF_FILE"
else
echo -e "${BLUE}[INFO]${NC} WLAN config file not found. Setting default WLAN parameters"
echo -e "${BLUE}"[INFO]"${NC}" SSID: "${MAGENTA}""$SSID""${NC}"
fi
}

0
scripts/services/wifi/start.sh

0
scripts/services/wifi/stop.sh

3
scripts/subinstallers/wifi.sh

@ -0,0 +1,3 @@
#!/bin/bash
sudo apt-get install -y bridge-utils iw rfkill
Loading…
Cancel
Save