123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- // 1-channel LoRa Gateway for ESP8266
- // Copyright (c) 2016-2020 Maarten Westenberg version for ESP mcu's
- //
- // based on work done by Thomas Telkamp for Raspberry PI 1ch gateway
- // and many others.
- //
- // All rights reserved. This program and the accompanying materials
- // are made available under the terms of the MIT License
- // which accompanies this distribution, and is available at
- // https://opensource.org/licenses/mit-license.php
- //
- // NO WARRANTY OF ANY KIND IS PROVIDED
- //
- // Author: Maarten Westenberg (mw12554@hotmail.com)
- //
- // This file contains a number of compile-time settings that can be set on (=1) or off (=0)
- // The disadvantage of compile time is minor compared to the memory gain of not having
- // too much code compiled and loaded on your ESP8266.
- //
- // ----------------------------------------------------------------------------------------
- // This file describes the includes necessary for ESP Filesystem.
- // At this moment there is only one record written to the ESP8266
- // filesystem. We can add more info, which makes the gateway even more usable,
- // however for large data we should only append to the existing file used.
- // This also means we'll have to check for available space so we won't run out of
- // storage space to quickly.
- // One way would be to use let's say 10 files of each 10000 lines and when full
- // delete the first file and start writing on a new one (for example)
- //
- // Define Pattern debug settings, this allows debugging per
- // module rather than per level. See also pdebug.
- //
- // P_SCAN statemachine
- // P_CAD
- // P_RX received actions only
- // P_TX transmissions
- // P_MAIN for main program setup() and loop()
- // P_GUI for www server GUI related
- // P_PRE for statemachine
- // P_RADIO; For code in _loraModem and _sensor
- #define P_SCAN 0x01
- #define P_CAD 0x02
- #define P_RX 0x04
- #define P_TX 0x08
- #define P_PRE 0x10
- #define P_MAIN 0x20
- #define P_GUI 0x40
- #define P_RADIO 0x80
- // Definition of the configuration record that is read at startup and written
- // when settings are changed.
- struct espGwayConfig {
- int32_t txDelay; // Init 0 at setup
- uint32_t ntpErrTime; // Record the time of the last NTP error
- uint16_t fcnt; // =0 as init value XXX Could be 32 bit in size
- uint16_t boots; // Number of restarts made by the gateway after reset
- uint16_t resets; // Number of statistics resets
- uint16_t views; // Number of sendWebPage() calls
- uint16_t wifis; // Number of WiFi Setups
- uint16_t reents; // Number of re-entrant interrupt handler calls
- uint16_t ntpErr; // Number of UTP requests that failed
- uint16_t ntps;
- uint16_t logFileRec; // Logging File Record number
- uint16_t logFileNo; // Logging File Number
- uint16_t logFileNum; // Number of log files max
-
- uint8_t ch; // index to freqs array, freqs[gwayCofnig.ch]=868100000 default
- uint8_t sf; // range from SF7 to SF12
- uint8_t debug; // range 0 to 4
- uint8_t pdebug; // pattern debug,
- uint8_t trusted; // pattern debug,
-
- bool cad; // is CAD enabled?
- bool hop; // Is HOP enabled (Note: default be disabled)
- bool isNode; // Is gateway node enabled
- bool refresh; // Is WWW browser refresh enabled
- bool seen;
- bool expert;
- bool monitor;
-
- } gwayConfig;
- // Define a log record to be written to the log file
- // Keep logfiles SHORT in name! to save memory
- #if _STAT_LOG == 1
- // We do keep admin of logfiles by number
- //
- //uint32_t logFileNo = 0; // Included in struct espGwayConfig LogFile number
- //uint32_t logFileRec = 0; // Number of records in a single logfile
- //uint32_t logFileNum = 1; // Number of log files
- #define LOGFILEMAX 10
- #define LOGFILEREC 100
- #endif // _STAT_LOG
- // Define the node list structure
- //
- #define nSF6 0x01
- #define nSF7 0x02
- #define nSF8 0x04
- #define nSF9 0x08
- #define nSF10 0x10
- #define nSF11 0x20
- #define nSF12 0x40
- #define nFSK 0x80
- // define the Seen functon as when we have seen seen nodes last time
- struct nodeSeen {
- time_t timSeen;
- uint32_t idSeen;
- uint32_t cntSeen;
- uint8_t chnSeen;
- uint8_t sfSeen; // Encode the SF seen.This might differ per message!
- };
- struct nodeSeen listSeen[_MAXSEEN];
- // define the logging structure used for printout of error and warning messages
- // We use a string for these lines (only time) as it is convenient.
- struct moniLine {
- String txt;
- };
- struct moniLine monitor[_MAXMONITOR];
|