#!/bin/bash source /etc/nodemecu.conf source /opt/nodemecu/envs source $funciones conteo=$(cat $contador) uuid="$(uuidgen)" marca_de_tiempo="$(date +%s)" case $modo in test) funcion_datos_simulados ;; sensores) funcion_datos_sensores ;; esac # ARMADO DE FICHERO JSON for i in $lecturas;do case $i in id*) sensores="$sensores { $(echo \"id\":\"$(echo $i | cut -d ":" -f 2)\", \"sensores\": [ )" ;; tp*) sensores="$sensores { $(echo \"type\": \"$(echo $i | cut -d ":" -f 2)\",)" ;; vl*) sensores="$sensores $(echo \"value\": $(echo $i | cut -d ":" -f 2),)" ;; un*) sensores="$sensores $(echo \"unit\": \"$(echo $i | cut -d ":" -f 2)\",)" ;; er*) sensores="$sensores $(echo \"error\": $(echo $i | cut -d ":" -f 2) })" ;; AD_SENSOR) sensores="$sensores," ;; AD_ARDUINO) sensores="$sensores]}," ;; END) sensores="$sensores]}" ;; esac done json="{\"transaction_uuid\":\"$uuid\",\"serial_number\":\"$numero_serie\",\"public_key\":\"$(cat $public_key)\",\"controller_id\":\"$nombre\",\"timestamp\":\"$marca_de_tiempo\",\"error_code\":\"10\",\"coordinates\":{\"lat\":1,\"lng\":1},\"battery_status\":\"98\",\"sample\":\"0\",\"storage\":\"uso del almacenamiento\",\"arduinos\":[$sensores]}" touch $lock file=$(date +%Y%m%d%H%M%S -d @$marca_de_tiempo)-$uuid if echo $json | jsonlint-php 2> /dev/null;then echo $json > $registros/$file && rm $lock && echo $((conteo+1)) > $contador else echo "$(date +%Y-%m-%d-%H:%M:%S -d @$marca_de_tiempo) - No se pudo obtener informaciĆ³n." >> $log rm $lock fi exit # habia una razon para esto, ya va a saltar for ((i=1 ; i <=3 ; i++));do if echo $json | jsonlint-php 2> /dev/null;then echo $json > /opt/nodemecu/stack/$file && rm /opt/nodemecu/lock && echo $((counter+1)) > $contador && break else echo "$(date +%Y-%m-%d-%H:%M:%S) - No se pudo obtener informaciĆ³n." >> /opt/nodemecu/errors.log && sleep 1 fi done