#!/bin/bash ############################################################################### # # # IPFire.org - A linux based firewall # # Copyright (C) 2010 Michael Tremer & Christian Schmidt # # # # This program is free software: you can redistribute it and/or modify # # it under the terms of the GNU General Public License as published by # # the Free Software Foundation, either version 3 of the License, or # # (at your option) any later version. # # # # This program is distributed in the hope that it will be useful, # # but WITHOUT ANY WARRANTY; without even the implied warranty of # # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # # GNU General Public License for more details. # # # # You should have received a copy of the GNU General Public License # # along with this program. If not, see . # # # ############################################################################### . /usr/lib/network/header-port HOOK_SETTINGS="HOOK ADDRESS BROADCAST_SSID CHANNEL MODE PHY SSID" HOOK_SETTINGS="${HOOK_SETTINGS} ENCRYPTION KEY" ADDRESS=$(mac_generate) BROADCAST_SSID=on CHANNEL=1 ENCRYPTION="" KEY="" MODE="g" SSID= hook_check_settings() { assert isset ADDRESS assert ismac ADDRESS assert isset BROADCAST_SSID assert isbool BROADCAST_SSID assert isset CHANNEL assert isset MODE assert isoneof MODE a b g n assert isset PHY assert ismac PHY assert isset SSID if isset ENCRYPTION; then assert isoneof ENCRYPTION WPA WPA2 WPA/WPA2 assert isset KEY assert [ ${#KEY} -ge 8 ] assert [ ${#KEY} -le 63 ] fi } hook_new() { while [ $# -gt 0 ]; do case "${1}" in --broadcast-ssid=*) BROADCAST_SSID=$(cli_get_val ${1}) ;; --channel=*) CHANNEL=$(cli_get_val ${1}) ;; --encryption=*) ENCRYPTION=$(cli_get_val ${1}) ;; --key=*) KEY=$(cli_get_val ${1}) ;; --mac=*) ADDRESS=$(cli_get_val ${1}) ;; --mode=*) MODE=$(cli_get_val ${1}) ;; --phy=*) PHY=$(cli_get_val ${1}) ;; --ssid=*) SSID=$(cli_get_val ${1}) ;; *) warning "Ignoring unknown argument '${1}'" ;; esac shift done # Save address of phy do identify it again PHY=$(phy_get ${PHY}) PHY=$(phy_get_address ${PHY}) local port=$(port_find_free ${PORT_PATTERN_ACCESSPOINT}) assert isset port port_settings_write "${port}" ${HOOK_SETTINGS} exit ${EXIT_OK} } hook_edit() { local port=${1} shift assert isset port port_settings_read "${port}" ${HOOK_SETTINGS} while [ $# -gt 0 ]; do case "${1}" in --broadcast-ssid=*) BROADCAST_SSID=$(cli_get_val ${1}) ;; --channel=*) CHANNEL=$(cli_get_val ${1}) ;; --encryption=*) ENCRYPTION=$(cli_get_val ${1}) ;; --key=*) KEY=$(cli_get_val ${1}) ;; --ssid=*) SSID=$(cli_get_val ${1}) ;; --mode=*) MODE=$(cli_get_val ${1}) ;; *) warning "Unknown argument '${1}'" ;; esac shift done port_settings_write "${port}" ${HOOK_SETTINGS} exit ${EXIT_OK} } hook_create() { local port="${1}" assert isset port device_exists "${port}" && exit ${EXIT_OK} port_settings_read "${port}" ${HOOK_SETTINGS} # Check if the PHY is present. local phy=$(phy_get ${PHY}) if ! isset phy; then log DEBUG "phy '${PHY}' is not present" exit ${EXIT_ERROR} fi # Create the wireless device wireless_create "${port}" \ --phy="${phy}" \ --type="ap" \ --address="${ADDRESS}" exit ${EXIT_OK} } hook_remove() { local port="${1}" assert isset port # Remove the device if present if device_exists "${port}"; then wireless_remove "${port}" fi exit ${EXIT_OK} } hook_up() { local port="${1}" assert isset port # The port must already exist before # hostapd is started. Otherwise it will # fail horribly over and over again. assert device_exists "${port}" hostapd_start "${port}" } hook_down() { local port="${1}" assert isset port hostapd_stop "${port}" } hook_hotplug() { local port="${1}" assert isset port case "$(hotplug_action)" in add) # Create the port when the phy is plugged in if hotplug_event_port_uses_phy "${port}"; then hook_create "${port}" fi ;; remove) # Stop hostapd if hotplug_event_port_is_interface "${port}"; then hostapd_stop "${port}" exit ${EXIT_OK} fi ;; esac exit ${EXIT_NOT_HANDLED} }