mirror of
https://dev.iopsys.eu/bbf/bbfdm.git
synced 2025-12-10 07:44:39 +01:00
70 lines
2.7 KiB
Bash
Executable file
70 lines
2.7 KiB
Bash
Executable file
#!/bin/sh
|
|
# Copyright (C) 2019 iopsys Software Solutions AB
|
|
# Author: AMIN Ben Ramdhane <amin.benramdhane@pivasoftware.com>
|
|
|
|
source /usr/share/bbfdm/bbf_uci_api
|
|
|
|
traceroute_launch() {
|
|
local i proto device res host ip time=0
|
|
local host=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.Host`
|
|
local cnt=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.NumberOfTries 3`
|
|
local dsize=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.DataBlockSize 38`
|
|
local timeout=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.Timeout 5000`
|
|
local maxhop=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.MaxHops 30`
|
|
local interface=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.interface`
|
|
local protocol=`uci_get_bbf_dmmap dmmap_diagnostics.traceroute.ProtocolVersion Any`
|
|
[ ! -z "$interface" ] && device=`ifstatus $interface | jsonfilter -e @.device` && device="-i $device" || device=""
|
|
if [ "$protocol" == "IPv4" ]; then proto="-4"; elif [ "$protocol" == "IPv6" ]; then proto="-6"; else proto=""; fi
|
|
[ "$host" = "" ] && return
|
|
timeout=$((timeout/1000))
|
|
[ "$timeout" = "0" ] && timeout = "1"
|
|
i=-2
|
|
delete_all_route_hops
|
|
rm -f /tmp/traceres
|
|
traceroute -m $maxhop -w $timeout -q $cnt $proto $device $host $dsize 2>&1 >/tmp/traceres
|
|
while read _ host ip time _; do
|
|
[ "$host" = "*" -a "$ip" = "*" ] && continue
|
|
let i++
|
|
[ "$i" = "-1" ] && continue;
|
|
ip=${ip#(}; ip=${ip%)}
|
|
time=${time%.*}
|
|
$UCI_ADD_BBF_DMMAP dmmap_diagnostics RouteHops
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.@RouteHops[$i].host=$host
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.@RouteHops[$i].ip=$ip
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.@RouteHops[$i].time=$time
|
|
done < /tmp/traceres
|
|
rm -f /tmp/traceres
|
|
let i++
|
|
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.traceroute.DiagnosticState=Complete
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.traceroute.NumberOfHops=$i
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.traceroute.ResponseTime=$($UCI_GET_BBF_DMMAP dmmap_diagnostics.@RouteHops[-1].time)
|
|
$UCI_COMMIT_BBF_DMMAP
|
|
}
|
|
|
|
delete_all_route_hops() {
|
|
local j
|
|
for j in $($UCI_SHOW_BBF_DMMAP dmmap_diagnostics | grep "dmmap_diagnostics.@RouteHops.*=RouteHops"); do
|
|
$UCI_DELETE_BBF_DMMAP dmmap_diagnostics.@RouteHops[-1]
|
|
$UCI_COMMIT_BBF_DMMAP
|
|
done
|
|
}
|
|
|
|
traceroute_stop() {
|
|
delete_all_route_hops
|
|
local pids=`ps aux | grep traceroute_launch | grep -v grep | grep -v stop | awk '{print $2}'`
|
|
[ -z "$pids" ] && pids=`ps | grep traceroute_launch | grep -v grep | grep -v stop | awk '{print $2}'`
|
|
if [ -n "$pids" ]; then
|
|
kill -9 $pids 2>/dev/null
|
|
$UCI_SET_BBF_DMMAP dmmap_diagnostics.traceroute.DiagnosticState=None
|
|
$UCI_COMMIT_BBF_DMMAP
|
|
fi
|
|
}
|
|
|
|
if [ "$1" == "run" ]; then
|
|
traceroute_launch 2>/dev/null
|
|
elif [ "$1" == "stop" ]; then
|
|
traceroute_stop 2>/dev/null
|
|
else
|
|
return
|
|
fi
|