g1-stats/explorer.sh

63 lines
1.8 KiB
Bash
Executable File

#!/bin/bash
# Récupération du chemin absolut du répertoir du script actuel
GPATH="$( cd "$(dirname "$0")" ; pwd -P )"
source $GPATH/.env
# Parse options
for i in $@; do
case "$i" in
-c|--cumulate) echo "On cumule !";;
-h|--help) echo "Demande d'aide";;
*) isOptions+="$i|";;
esac
done
jsonFile="$GPATH/db/daily.json"
cmd=$(cut -d'|' -f1 <<<"$isOptions")
dateRange=$(cut -d'|' -f2 <<<"$isOptions")
args="$(cut -d'|' -f2- <<<"$isOptions" | sed 's/.$//' | tr '|' ' ')"
[[ -z "$dateRange" ]] && dateRange=$(jq -r '.[].date' $jsonFile | tail -n1)
[[ ! $(grep "$dateRange" $jsonFile) && $cmd != "select" ]] && echo "La date $dateRange n'existe pas en cache G1Stats" && exit 1
cumulate() {
jsonCum="$(jq -f $GPATH/lib/cumulate.jq $jsonFile)"
jq '.[] | select(.date=="'$dateRange'")' <<<$jsonCum
}
day() {
jq '.[] | select(.date=="'$dateRange'")' $jsonFile
}
mass() {
jsonDated=$(jq '.[0: map(.date) | index("'$dateRange'")+1]' $jsonFile | jq -f $GPATH/lib/cumulate.jq)
jq '.[] | .UD*.nbrMembers' <<<"$jsonDated" | awk '{ SUM += $1} END { printf "%.2f", SUM }'; echo
}
solde() {
cumDay=$(day)
soldeWallets=$(jq '(.rWallets-.sWallets)*100.0+ 0.5|floor/100.0' <<<$cumDay)
soldeMembers=$(jq '(.rMembers-.sMembers)*100.0+ 0.5|floor/100.0' <<<$cumDay)
jo -p date=$dateRange soldeWallets=$soldeWallets soldeMembers=$soldeMembers | jq .
}
total() {
cumDay=$(day)
totalReceived=$(jq '(.rWallets+.rMembers)*100.0+ 0.5|floor/100.0' <<<$cumDay)
totalSent=$(jq '(.sWallets+.sMembers)*100.0+ 0.5|floor/100.0' <<<$cumDay)
jo -p date=$dateRange totalReceived=$totalReceived totalSent=$totalSent | jq .
}
selectFunc() {
jq '.[] | select('"$args"')' $jsonFile
}
case $cmd in
select) selectFunc;;
'') cumulate;;
*) $cmd;;
esac