QuecManager 1.0.2 BETA

- Added signal graphs for RSRP, RSRQ, and SINR
- Added ethernet connection details
- Added memory usage details
- Added ping graph

Known bug:
Signal graphs may sometimes show inaccurate values. It seems to be a fetching error but Ill try to find the real root cause as soon as possible

Co-Authored-By: Russel Yasol <73575327+dr-dolomite@users.noreply.github.com>
This commit is contained in:
Cameron Thompson
2024-12-17 19:11:26 -05:00
parent f145802509
commit b981b4a519
63 changed files with 266 additions and 84 deletions

View File

@@ -0,0 +1,69 @@
#!/bin/sh
# Ensure the directory exists
LOGDIR="/tmp/signal_graphs"
mkdir -p "$LOGDIR"
# Maximum number of entries
MAX_ENTRIES=10
# Interval between logs (in seconds)
INTERVAL=25
# Function to clean and extract actual output from atinout
clean_atinout_output() {
# Remove first line (echoed command), last line (OK), and trim whitespace
sed -n '2,/^OK$/p' | sed '$d' | tr -d '\r' | xargs
}
# Function to log signal metrics
log_signal_metric() {
local COMMAND="$1"
local FILENAME="$2"
local LOGFILE="$LOGDIR/$FILENAME"
# Ensure log directory exists
mkdir -p "$(dirname "$LOGFILE")"
# Get current timestamp
TIMESTAMP=$(date "+%Y-%m-%d %H:%M:%S")
# Run the AT command and capture its output, then clean it
SIGNAL_OUTPUT=$(echo "$COMMAND" | atinout - /dev/smd11 - | clean_atinout_output)
# Ensure the file exists and is a valid JSON array
if [ ! -s "$LOGFILE" ]; then
echo "[]" > "$LOGFILE"
fi
# Prepare new JSON entry
ESCAPED_TIMESTAMP=$(printf '%s' "$TIMESTAMP" | sed 's/"/\\"/g')
ESCAPED_OUTPUT=$(printf '%s' "$SIGNAL_OUTPUT" | sed 's/"/\\"/g')
# Use jq with a more robust approach
jq --arg datetime "$ESCAPED_TIMESTAMP" \
--arg output "$ESCAPED_OUTPUT" \
'
# Ensure the input is always an array
if type == "array" then .
else []
end |
# Add new entry
. + [{"datetime": $datetime, "output": $output}] |
# Trim to max entries
.[-'"$MAX_ENTRIES"':]
' "$LOGFILE" > "${LOGFILE}.tmp" && mv "${LOGFILE}.tmp" "$LOGFILE"
}
# Trap to handle script termination gracefully
cleanup() {
echo "Stopping signal logging..."
exit 0
}
trap cleanup SIGINT SIGTERM
# Continuous logging loop
echo "Starting continuous signal metrics logging (Press Ctrl+C to stop)..."
while true; do
# Log RSRP
log_signal_metric "AT+QRSRP" "rsrp.json"
# Log RSRQ
log_signal_metric "AT+QRSRQ" "rsrq.json"
# Log SINR
log_signal_metric "AT+QSINR" "sinr.json"
# Wait for the specified interval
sleep "$INTERVAL"
done