loraFiles.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. // 1-channel LoRa Gateway for ESP8266
  2. // Copyright (c) 2016, 2017, 2018, 2019 Maarten Westenberg version for ESP8266
  3. // Version 6.1.3
  4. // Date: 2019-11-20
  5. //
  6. // based on work done by Thomas Telkamp for Raspberry PI 1ch gateway
  7. // and many others.
  8. //
  9. // All rights reserved. This program and the accompanying materials
  10. // are made available under the terms of the MIT License
  11. // which accompanies this distribution, and is available at
  12. // https://opensource.org/licenses/mit-license.php
  13. //
  14. // NO WARRANTY OF ANY KIND IS PROVIDED
  15. //
  16. // Author: Maarten Westenberg (mw12554@hotmail.com)
  17. //
  18. // This file contains a number of compile-time settings that can be set on (=1) or off (=0)
  19. // The disadvantage of compile time is minor compared to the memory gain of not having
  20. // too much code compiled and loaded on your ESP8266.
  21. //
  22. // ----------------------------------------------------------------------------------------
  23. // This file describes the includes necessary for ESP Filesystem.
  24. // At this moment there is only one record written to the ESP8266
  25. // filesystem. We can add more info, which makes the gateway even more usable,
  26. // however for large data we should only append to the existing file used.
  27. // This also means we'll have to check for available space so we won't run out of
  28. // storage space to quickly.
  29. // One way would be to use let's say 10 files of each 10000 lines and when full
  30. // delete the first file and start writing on a new one (for example)
  31. //
  32. // Define Pattern debug settings, this allows debugging per
  33. // module rather than per level. See also pdebug.
  34. //
  35. #define P_SCAN 0x01
  36. #define P_CAD 0x02
  37. #define P_RX 0x04
  38. #define P_TX 0x08
  39. #define P_PRE 0x10
  40. #define P_MAIN 0x20
  41. #define P_GUI 0x40
  42. #define P_RADIO 0x80
  43. // Definition of the configuration record that is read at startup and written
  44. // when settings are changed.
  45. struct espGwayConfig {
  46. int32_t txDelay; // Init 0 at setup
  47. uint32_t ntpErrTime; // Record the time of the last NTP error
  48. uint16_t fcnt; // =0 as init value XXX Could be 32 bit in size
  49. uint16_t boots; // Number of restarts made by the gateway after reset
  50. uint16_t resets; // Number of statistics resets
  51. uint16_t views; // Number of sendWebPage() calls
  52. uint16_t wifis; // Number of WiFi Setups
  53. uint16_t reents; // Number of re-entrant interrupt handler calls
  54. uint16_t ntpErr; // Number of UTP requests that failed
  55. uint16_t ntps;
  56. uint16_t logFileRec; // Logging File Record number
  57. uint16_t logFileNo; // Logging File Number
  58. uint16_t logFileNum; // Number of log files
  59. uint8_t ch; // index to freqs array, freqs[ifreq]=868100000 default
  60. uint8_t sf; // range from SF7 to SF12
  61. uint8_t debug; // range 0 to 4
  62. uint8_t pdebug; // pattern debug,
  63. uint8_t trusted; // pattern debug,
  64. bool cad; // is CAD enabled?
  65. bool hop; // Is HOP enabled (Note: default be disabled)
  66. bool isNode; // Is gateway node enabled
  67. bool refresh; // Is WWW browser refresh enabled
  68. bool expert;
  69. String ssid; // SSID of the last connected WiFi Network
  70. String pass; // Password of WiFi network
  71. } gwayConfig;
  72. // Define a log record to be written to the log file
  73. // Keep logfiles SHORT in name! to save memory
  74. #if STAT_LOG == 1
  75. // We do keep admin of logfiles by number
  76. //
  77. //uint32_t logFileNo = 1; // Included in struct espGwayConfig LogFile number
  78. //uint32_t logFileRec = 0; // Number of records in a single logfile
  79. //uint32_t logFileNum = 1; // Number of log files
  80. #define LOGFILEMAX 10
  81. #define LOGFILEREC 100
  82. #endif // STAT_LOG
  83. // Define the node list structure
  84. //
  85. #define nSF6 0x01
  86. #define nSF7 0x02
  87. #define nSF8 0x04
  88. #define nSF9 0x08
  89. #define nSF10 0x10
  90. #define nSF11 0x20
  91. #define nSF12 0x40
  92. #define nFSK 0x80
  93. struct nodeSeen {
  94. unsigned long timSeen;
  95. uint32_t idSeen;
  96. uint8_t sfSeen;
  97. };
  98. struct nodeSeen listSeen[_SEENMAX];