2018-06-30 16:20:54 +02:00
|
|
|
package runtime
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2018-07-15 20:00:18 +02:00
|
|
|
"strings"
|
2018-06-30 16:20:54 +02:00
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
|
|
|
|
"github.com/FreifunkBremen/freifunkmanager/ssh"
|
|
|
|
)
|
|
|
|
|
2018-07-26 14:14:23 +02:00
|
|
|
func (n *Node) SSHUpdate(sshmgmt *ssh.Manager, oldnode *Node) {
|
|
|
|
client, err := sshmgmt.ConnectTo(n.GetAddress())
|
2018-06-30 16:20:54 +02:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer client.Close()
|
|
|
|
|
|
|
|
if oldnode == nil || n.Hostname != oldnode.Hostname {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set system.@system[0].hostname='%s';
|
|
|
|
uci commit; echo $(uci get system.@system[0].hostname) > /proc/sys/kernel/hostname;`,
|
|
|
|
n.Hostname))
|
|
|
|
}
|
|
|
|
if oldnode == nil || n.Owner != oldnode.Owner {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set gluon-node-info.@owner[0].contact='%s';
|
|
|
|
uci commit gluon-node-info;`,
|
|
|
|
n.Owner))
|
|
|
|
}
|
|
|
|
if oldnode == nil || !locationEqual(n.Location, oldnode.Location) {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set gluon-node-info.@location[0].latitude='%f';
|
|
|
|
uci set gluon-node-info.@location[0].longitude='%f';
|
|
|
|
uci set gluon-node-info.@location[0].share_location=1;
|
|
|
|
uci commit gluon-node-info;`,
|
|
|
|
n.Location.Latitude, n.Location.Longitude))
|
|
|
|
|
|
|
|
}
|
|
|
|
runWifi := false
|
|
|
|
defer func() {
|
|
|
|
if runWifi {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, "wifi")
|
2018-06-30 16:20:54 +02:00
|
|
|
// send warning for running wifi, because it kicks clients from node
|
|
|
|
log.Warn("[cmd] wifi ", n.NodeID)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
2018-07-26 14:14:23 +02:00
|
|
|
result, err := ssh.Run(n.Address, client, `
|
2018-06-30 16:20:54 +02:00
|
|
|
if [ "$(uci get wireless.radio0.hwmode | grep -c g)" -ne 0 ]; then
|
|
|
|
echo "radio0";
|
|
|
|
elif [ "$(uci get wireless.radio1.hwmode | grep -c g)" -ne 0 ]; then
|
|
|
|
echo "radio1";
|
|
|
|
fi;`)
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
radio := ssh.SSHResultToString(result)
|
2018-07-15 20:00:18 +02:00
|
|
|
ch := GetChannel(n.Wireless.Channel24)
|
2018-07-26 14:14:23 +02:00
|
|
|
if radio != "" && ch != nil {
|
2018-06-30 16:20:54 +02:00
|
|
|
if oldnode == nil || n.Wireless.TxPower24 != oldnode.Wireless.TxPower24 {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set wireless.%s.txpower='%d';
|
|
|
|
uci commit wireless;`,
|
|
|
|
radio, n.Wireless.TxPower24))
|
|
|
|
runWifi = true
|
|
|
|
}
|
|
|
|
if oldnode == nil || n.Wireless.Channel24 != oldnode.Wireless.Channel24 {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-07-15 20:00:18 +02:00
|
|
|
ubus call hostapd.%s switch_chan '{"freq":%d}'
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set wireless.%s.channel='%d';
|
|
|
|
uci commit wireless;`,
|
2018-07-15 20:00:18 +02:00
|
|
|
strings.Replace(radio, "radio", "client", 1), ch.Frequenz,
|
2018-06-30 16:20:54 +02:00
|
|
|
radio, n.Wireless.Channel24))
|
2018-07-15 20:00:18 +02:00
|
|
|
|
2018-06-30 16:20:54 +02:00
|
|
|
}
|
|
|
|
}
|
2018-07-26 14:14:23 +02:00
|
|
|
result, err = ssh.Run(n.Address, client, `
|
2018-06-30 16:20:54 +02:00
|
|
|
if [ "$(uci get wireless.radio0.hwmode | grep -c a)" -ne 0 ]; then
|
|
|
|
echo "radio0";
|
|
|
|
elif [ "$(uci get wireless.radio1.hwmode | grep -c a)" -ne 0 ]; then
|
|
|
|
echo "radio1";
|
|
|
|
fi;`)
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
radio = ssh.SSHResultToString(result)
|
2018-07-15 20:00:18 +02:00
|
|
|
ch = GetChannel(n.Wireless.Channel5)
|
2018-07-26 14:14:23 +02:00
|
|
|
if radio != "" && ch != nil {
|
2018-06-30 16:20:54 +02:00
|
|
|
if oldnode == nil || n.Wireless.TxPower5 != oldnode.Wireless.TxPower5 {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set wireless.%s.txpower='%d';
|
|
|
|
uci commit wireless;`,
|
|
|
|
radio, n.Wireless.TxPower5))
|
|
|
|
runWifi = true
|
|
|
|
}
|
|
|
|
if oldnode == nil || n.Wireless.Channel5 != oldnode.Wireless.Channel5 {
|
2018-07-26 14:14:23 +02:00
|
|
|
ssh.Execute(n.Address, client, fmt.Sprintf(`
|
2018-07-15 20:00:18 +02:00
|
|
|
ubus call hostapd.%s switch_chan '{"freq":%d}'
|
2018-06-30 16:20:54 +02:00
|
|
|
uci set wireless.%s.channel='%d';
|
|
|
|
uci commit wireless;`,
|
2018-07-15 20:00:18 +02:00
|
|
|
strings.Replace(radio, "radio", "client", 1), ch.Frequenz,
|
2018-06-30 16:20:54 +02:00
|
|
|
radio, n.Wireless.Channel5))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
oldnode = n
|
|
|
|
}
|