You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

пре 6 година
пре 4 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
пре 6 година
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. #!/bin/bash
  2. ### Run as a normal user
  3. if [ $EUID -eq 0 ]; then
  4. echo "This script shouldn't be run as root."
  5. exit 1
  6. fi
  7. ## import common lib
  8. . "$HOME/.noaa.conf"
  9. . "$NOAA_HOME/common.sh"
  10. # $1 = Satellite Name
  11. # $2 = Frequency
  12. # $3 = FileName base
  13. # $4 = TLE File
  14. # $5 = EPOC start time
  15. # $6 = Time to capture
  16. # $7 = Satellite max elevation
  17. PREDICTION_START=$(predict -t "${NOAA_HOME}"/predict/weather.tle -p "${1}" | head -1)
  18. PREDICTION_END=$(predict -t "${NOAA_HOME}"/predict/weather.tle -p "${1}" | tail -1)
  19. var2=$(echo "${PREDICTION_END}" | cut -d " " -f 1)
  20. MAXELEV=$(predict -t "${NOAA_HOME}"/predict/weather.tle -p "${1}" | awk -v max=0 '{if($5>max){max=$5}}END{print max}')
  21. log "Looking for passes of $1" INFO
  22. while [ "$(date --date="@${var2}" +%D)" = "$(date +%D)" ]; do
  23. START_TIME=$(echo "$PREDICTION_START" | cut -d " " -f 3-4)
  24. var1=$(echo "$PREDICTION_START" | cut -d " " -f 1)
  25. var3=$(echo "$START_TIME" | cut -d " " -f 2 | cut -d ":" -f 3)
  26. TIMER=$(expr "${var2}" - "${var1}" + "${var3}")
  27. OUTDATE=$(date --date="TZ=\"UTC\" ${START_TIME}" +%Y%m%d-%H%M%S)
  28. if [ "${MAXELEV}" -gt "${SAT_MIN_ELEV}" ]; then
  29. SATNAME=$(echo "$1" | sed "s/ //g")
  30. echo "${SATNAME}" "${OUTDATE}" "$MAXELEV"
  31. echo "${NOAA_HOME}/receive.sh \"${1}\" $2 ${SATNAME}-${OUTDATE} "${NOAA_HOME}"/predict/weather.tle \
  32. ${var1} ${TIMER} ${MAXELEV}" | at "$(date --date="TZ=\"UTC\" ${START_TIME}" +"%H:%M %D")"
  33. sqlite3 $HOME/raspberry-noaa/panel.db "insert or replace into predict_passes (sat_name,pass_start,pass_end,max_elev,is_active) values (\"$SATNAME\",$var1,$var2,$MAXELEV, 1);"
  34. else
  35. log "Max. elevation ${MAXELEV} too small for configured ${SAT_MIN_ELEV}" DEBUG
  36. fi
  37. NEXTPREDICT=$(expr "${var2}" + 60)
  38. PREDICTION_START=$(predict -t "${NOAA_HOME}"/predict/weather.tle -p "${1}" "${NEXTPREDICT}" | head -1)
  39. PREDICTION_END=$(predict -t "${NOAA_HOME}"/predict/weather.tle -p "${1}" "${NEXTPREDICT}" | tail -1)
  40. MAXELEV=$(predict -t "${NOAA_HOME}"/predict/weather.tle -p "${1}" "${NEXTPREDICT}" | awk -v max=0 '{if($5>max){max=$5}}END{print max}')
  41. var2=$(echo "${PREDICTION_END}" | cut -d " " -f 1)
  42. done