You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
195 lines
6.1 KiB
Bash
195 lines
6.1 KiB
Bash
4 years ago
|
#!/bin/sh
|
||
|
|
||
|
. /lib/functions.sh
|
||
|
. /usr/lib/configsync_lib.sh
|
||
|
|
||
|
my_logger() {
|
||
|
logger -t configsync_handler "${@}"
|
||
|
}
|
||
|
|
||
|
create_local_configuration_file() {
|
||
|
#if it it not feasable that the uuid changes every time the service is started make the uuid persistent
|
||
|
UUID=$(cat /proc/sys/kernel/random/uuid)
|
||
|
if [ "$(uci_get ${MY_SERVICE_NAME} global configured)" = 1 ]; then
|
||
|
CONFIGURED="yes"
|
||
|
else
|
||
|
CONFIGURED="no"
|
||
|
fi
|
||
|
|
||
|
cat > ${CONFIGSYNC_CONFIGURATION_FILE}<<EOF
|
||
|
[interfaces]
|
||
|
i0=br-lan,B
|
||
|
[network]
|
||
|
interface=br-lan
|
||
|
almac=${ETH_MAC_ADDR}
|
||
|
unicasttobridge=on
|
||
|
[wsc]
|
||
|
authenticationtypes=Open,WPAPersonal,WPA2Personal
|
||
|
encryptiontypes=None,AES
|
||
|
connectiontypes=ESS
|
||
|
configurationmethods=VirtualPB
|
||
|
primarydevicetype=NetworkInfrastructure,Bridge
|
||
|
osversion=1
|
||
|
devicepasswordid=UserSpecified
|
||
|
manufacturer=$(eval "$(grep DEVICE_MANUFACTURER= /etc/device_info)"; echo $DEVICE_MANUFACTURER)
|
||
|
modelname=$(uci_get delos delos device_type)
|
||
|
devicename=$(eval "$(grep DEVICE_PRODUCT= /etc/device_info)"; echo $DEVICE_PRODUCT)
|
||
|
modelnumber=9999
|
||
|
serialnumber=$(uci_get_state delos baptization SerialNumber)
|
||
|
uuide=${UUID}
|
||
|
[wscregistrar]
|
||
|
freqband=CS
|
||
|
ssid=devolo-WiFi-Passwd
|
||
|
networkkey=devolo-WiFi
|
||
|
authenticationtype=WPA2Personal
|
||
|
encryptiontype=AES
|
||
|
[configuration]
|
||
|
registrar=off
|
||
|
renewonstart=on
|
||
|
autoconfigsearchtimer=30
|
||
|
[configsync]
|
||
|
enabled=yes
|
||
|
version=1
|
||
|
configured=${CONFIGURED}
|
||
|
useplcbutton=off
|
||
|
priority=0
|
||
|
domain=$(uci_get ${MY_SERVICE_NAME} global domain 0)
|
||
|
logging=$(uci_get ${MY_SERVICE_NAME} global logging 0)
|
||
|
[orange]
|
||
|
orangetlv=off
|
||
|
orangetlvm2=off
|
||
|
orangeexpbackoff=off
|
||
|
orangeconstbackoff=0
|
||
|
[debug]
|
||
|
encryption=on
|
||
|
messageidcheck=on
|
||
|
EOF
|
||
|
}
|
||
|
|
||
|
handle_event()
|
||
|
{
|
||
|
MESSAGE_TYPE=${1}
|
||
|
MESSAGE=${2}
|
||
|
EVENT=${3}
|
||
|
|
||
|
my_logger "handle_event: ${MESSAGE_TYPE} '${MESSAGE}', event ${EVENT}"
|
||
|
|
||
|
# copy configuration to temp configuration
|
||
|
wait_stable_config 0 5
|
||
|
[ "$event" = configsync_to_system ] &&
|
||
|
rm -rf $CS_TEMP_CONFIG_PATH/* $CS_TEMP_CHANGE_PATH/*
|
||
|
for CONFIGFILE in ${CS_SERVICES_TO_SYNC}; do
|
||
|
# ATT! this export will also export uncommitted changes!
|
||
|
uci -q export $CONFIGFILE | uci_tmp import $CS_PREFIX$CONFIGFILE
|
||
|
done
|
||
|
|
||
|
RETVAL=1
|
||
|
for CHANGE in ${MESSAGE}; do
|
||
|
EXECUTOR=${CHANGE}
|
||
|
my_logger "Got event ${EVENT} for change ${CHANGE}, calling ${EXECUTOR}"
|
||
|
if [ -f ${PATH_TO_CONFIGSYNC_EXECUTOR}/${EXECUTOR} ]; then
|
||
|
if ${PATH_TO_CONFIGSYNC_EXECUTOR}/${EXECUTOR} ${EVENT} ${CHANGE}; then
|
||
|
RETVAL=0
|
||
|
fi
|
||
|
else
|
||
|
if [ "${CHANGE}" != "${MESSAGE_TYPE}" ]; then
|
||
|
my_logger "Can not handle change ${CHANGE}!"
|
||
|
fi
|
||
|
fi
|
||
|
done
|
||
|
|
||
|
# check for changed configfiles and import to system configuration
|
||
|
if [ -s $CS_IMPORTSERVICELIST ]; then
|
||
|
# wait until configfiles are not in use
|
||
|
wait_stable_config 0 5
|
||
|
IMPORTSERVICELIST=$(cat $CS_IMPORTSERVICELIST)
|
||
|
for CONFIGFILE in ${IMPORTSERVICELIST}; do
|
||
|
uci revert ${CONFIGFILE}
|
||
|
uci_tmp export ${CS_PREFIX}${CONFIGFILE} | uci import ${CONFIGFILE}
|
||
|
update_md5sum ${CONFIGFILE}
|
||
|
done
|
||
|
>$CS_IMPORTSERVICELIST
|
||
|
fi
|
||
|
return $RETVAL
|
||
|
}
|
||
|
|
||
|
start_p1905()
|
||
|
{
|
||
|
my_logger ">>> start_p1905()"
|
||
|
|
||
|
# wait on first start after device boot
|
||
|
STARTDELAY=$(uci_get ${MY_SERVICE_NAME} global startdelay 0)
|
||
|
EXTENSIONDELAY=$(uci_get ${MY_SERVICE_NAME} global extensiondelay 20)
|
||
|
wait_stable_config ${STARTDELAY} ${EXTENSIONDELAY}
|
||
|
|
||
|
for SERVICE in ${CS_SERVICES_TO_SYNC}; do
|
||
|
update_md5sum ${SERVICE}
|
||
|
done
|
||
|
|
||
|
rm -f /tmp/cs_omit_wireless
|
||
|
killall p1905
|
||
|
# call init() for all files (not directories!) in PATH_TO_CONFIGSYNC_EXECUTOR
|
||
|
find ${PATH_TO_CONFIGSYNC_EXECUTOR} -type f -maxdepth 1 -exec sh -c "echo \"Call initialization of {} ...\"; {} init" \;
|
||
|
|
||
|
create_local_configuration_file
|
||
|
/usr/sbin/p1905 -f ${CONFIGSYNC_CONFIGURATION_FILE} | while read MESSAGE_TYPE MESSAGE
|
||
|
do
|
||
|
case ${MESSAGE_TYPE} in
|
||
|
AUTOCONFIG-FAILED)
|
||
|
my_logger "Message ${MESSAGE_TYPE} ${MESSAGE} ignored"
|
||
|
;;
|
||
|
NEW-AP-SETTINGS)
|
||
|
my_logger "Message ${MESSAGE_TYPE} ${MESSAGE} ignored"
|
||
|
;;
|
||
|
CONFIGSYNC-SET-CONFIGURED)
|
||
|
my_logger "Message ${MESSAGE_TYPE} ${MESSAGE} setting configsync state to configured"
|
||
|
uci_set configsync global configured '1'
|
||
|
uci_commit configsync
|
||
|
create_local_configuration_file
|
||
|
;;
|
||
|
NEW-CONFIGSYNC-SETTINGS)
|
||
|
# kill pending events from own website
|
||
|
killall configsync_event_delay.sh
|
||
|
>$CS_SERVICELIST
|
||
|
handle_event ${MESSAGE_TYPE} "${MESSAGE}" configsync_to_system
|
||
|
reload_config
|
||
|
;;
|
||
|
CONFIGSYNC-DYNAMIC-UPDATE)
|
||
|
handle_event ${MESSAGE_TYPE} "${MESSAGE}" dynamic_update
|
||
|
;;
|
||
|
CONFIGSYNC-RESET)
|
||
|
my_logger "Message ${MESSAGE_TYPE} ${MESSAGE} received"
|
||
|
rm $CS_CONFIGURATION_PATH/*
|
||
|
find ${PATH_TO_CONFIGSYNC_EXECUTOR} -type f -maxdepth 1 -exec sh -c "echo \"Call initialization of {} ...\"; {} init" \;
|
||
|
;;
|
||
|
VENDOR-MESSAGE)
|
||
|
my_logger "Vendor message received"
|
||
|
# cut off the VENDOR-MESSAGE prefix, decode base64 data and call service handler
|
||
|
/usr/bin/configsync_vs_handler.sh $(echo "$MESSAGE" | cut -d' ' -f2 | openssl enc -base64 -d)
|
||
|
;;
|
||
|
*)
|
||
|
my_logger "Unknown message ${MESSAGE_TYPE} ${MESSAGE}"
|
||
|
;;
|
||
|
esac
|
||
|
done
|
||
|
}
|
||
|
|
||
|
case ${1} in
|
||
|
SYSTEM-TO-CONFIGSYNC)
|
||
|
handle_event NEW-SYSTEM-CONFIG-SETTINGS "${2}" system_to_configsync
|
||
|
;;
|
||
|
APPLY)
|
||
|
my_logger "APPLY) Apply configsync changes"
|
||
|
killall -USR1 p1905
|
||
|
;;
|
||
|
STOP)
|
||
|
my_logger "STOP) Stop p1905"
|
||
|
killall p1905 2>/dev/null
|
||
|
;;
|
||
|
START)
|
||
|
ETH_MAC_ADDR=${2}
|
||
|
my_logger "START) Start p1905 with ${ETH_MAC_ADDR}"
|
||
|
start_p1905
|
||
|
;;
|
||
|
esac
|