private_mib_bt6709.c 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941
  1. /*
  2. * private_mib_bt6709.c
  3. *
  4. * Created on: 03.10.2018
  5. * Author: balbekova
  6. */
  7. #if defined HARDWARE_BT6709
  8. #include "stm32f4xx.h"
  9. #include "private_mib.h"
  10. #include "parameters.h"
  11. #include "settings_api.h"
  12. #include "log.h"
  13. #include "megatec.h"
  14. #include "control_symbol.h"
  15. #include "sntp_api.h"
  16. #include "FreeRTOS.h"
  17. #include "task.h"
  18. #include <ctype.h>
  19. #ifdef PRINTF_STDLIB
  20. #include <stdio.h>
  21. #endif
  22. #ifdef PRINTF_CUSTOM
  23. #include "tinystdio.h"
  24. #endif
  25. #include "lwip/apps/snmp_scalar.h"
  26. #include "lwip/apps/snmp.h"
  27. //#include "snmp_core.h"
  28. extern struct snmp_mib mib2;
  29. /**
  30. * @brief Общая структура настроек
  31. */
  32. extern SETTINGS_t sSettings;
  33. static s16_t signal_get_value(struct snmp_node_instance* instance, void* value);
  34. static snmp_err_t signal_set_value(struct snmp_node_instance* instance, u16_t len, void* value);
  35. static snmp_err_t signal_set_test(struct snmp_node_instance* instance, u16_t len, void* value);
  36. /* signal .1.3.6.1.4.1.41752.911.8.1.44 */
  37. static const struct snmp_scalar_node signal44 = SNMP_SCALAR_CREATE_NODE_READONLY(44, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  38. /* signal .1.3.6.1.4.1.41752.911.8.1.43 */
  39. static const struct snmp_scalar_node signal43 = SNMP_SCALAR_CREATE_NODE(43, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  40. /* signal .1.3.6.1.4.1.41752.911.8.1.42 */
  41. static const struct snmp_scalar_node signal42 = SNMP_SCALAR_CREATE_NODE(42, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  42. /* signal .1.3.6.1.4.1.41752.911.8.1.41 */
  43. static const struct snmp_scalar_node signal41 = SNMP_SCALAR_CREATE_NODE(41, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  44. /* signal .1.3.6.1.4.1.41752.911.8.1.40 */
  45. static const struct snmp_scalar_node signal40 = SNMP_SCALAR_CREATE_NODE(40, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  46. /* signal .1.3.6.1.4.1.41752.911.8.1.39 */
  47. static const struct snmp_scalar_node signal39 = SNMP_SCALAR_CREATE_NODE(39, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  48. /* signal .1.3.6.1.4.1.41752.911.8.1.38 */
  49. static const struct snmp_scalar_node signal38 = SNMP_SCALAR_CREATE_NODE(38, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  50. /* signal .1.3.6.1.4.1.41752.911.8.1.37 */
  51. static const struct snmp_scalar_node signal37 = SNMP_SCALAR_CREATE_NODE(37, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  52. /* signal .1.3.6.1.4.1.41752.911.8.1.36 */
  53. static const struct snmp_scalar_node signal36 = SNMP_SCALAR_CREATE_NODE(36, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  54. /* signal .1.3.6.1.4.1.41752.911.8.1.22 */
  55. static const struct snmp_scalar_node signal35 = SNMP_SCALAR_CREATE_NODE(35, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  56. /* signal .1.3.6.1.4.1.41752.911.8.1.34 */
  57. static const struct snmp_scalar_node signal34 = SNMP_SCALAR_CREATE_NODE(34, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  58. /* signal .1.3.6.1.4.1.41752.911.8.1.33 */
  59. static const struct snmp_scalar_node signal33 = SNMP_SCALAR_CREATE_NODE(33, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  60. /* signal .1.3.6.1.4.1.41752.911.8.1.32 */
  61. static const struct snmp_scalar_node signal32 = SNMP_SCALAR_CREATE_NODE(32, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  62. /* signal .1.3.6.1.4.1.41752.911.8.1.31 */
  63. static const struct snmp_scalar_node signal31 = SNMP_SCALAR_CREATE_NODE(31, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  64. /* signal .1.3.6.1.4.1.41752.911.8.1.22 */
  65. static const struct snmp_scalar_node signal30 = SNMP_SCALAR_CREATE_NODE(30, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  66. /* signal .1.3.6.1.4.1.41752.911.8.1.29 */
  67. static const struct snmp_scalar_node signal29 = SNMP_SCALAR_CREATE_NODE(29, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  68. /* signal .1.3.6.1.4.1.41752.911.8.1.28 */
  69. static const struct snmp_scalar_node signal28 = SNMP_SCALAR_CREATE_NODE(28, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  70. /* signal .1.3.6.1.4.1.41752.911.8.1.27 */
  71. static const struct snmp_scalar_node signal27 = SNMP_SCALAR_CREATE_NODE_READONLY(27, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  72. /* signal .1.3.6.1.4.1.41752.911.8.1.26 */
  73. static const struct snmp_scalar_node signal26 = SNMP_SCALAR_CREATE_NODE_READONLY(26, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  74. /* signal .1.3.6.1.4.1.41752.911.8.1.25 */
  75. static const struct snmp_scalar_node signal25 = SNMP_SCALAR_CREATE_NODE_READONLY(25, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  76. /* signal .1.3.6.1.4.1.41752.911.8.1.24 */
  77. static const struct snmp_scalar_node signal24 = SNMP_SCALAR_CREATE_NODE_READONLY(24, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  78. /* signal .1.3.6.1.4.1.41752.911.8.1.23 */
  79. static const struct snmp_scalar_node signal23 = SNMP_SCALAR_CREATE_NODE_READONLY(23, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  80. /* signal .1.3.6.1.4.1.41752.911.8.1.22 */
  81. static const struct snmp_scalar_node signal22 = SNMP_SCALAR_CREATE_NODE(22, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  82. /* signal .1.3.6.1.4.1.41752.911.8.1.21 */
  83. static const struct snmp_scalar_node signal21 = SNMP_SCALAR_CREATE_NODE(21, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  84. /* signal .1.3.6.1.4.1.41752.911.8.1.20 */
  85. static const struct snmp_scalar_node signal20 = SNMP_SCALAR_CREATE_NODE(20, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  86. /* signal .1.3.6.1.4.1.41752.911.8.1.19 */
  87. static const struct snmp_scalar_node signal19 = SNMP_SCALAR_CREATE_NODE(19, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  88. /* signal .1.3.6.1.4.1.41752.911.8.1.18 */
  89. static const struct snmp_scalar_node signal18 = SNMP_SCALAR_CREATE_NODE(18, SNMP_NODE_INSTANCE_READ_WRITE, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value, signal_set_test, signal_set_value);
  90. /* signal .1.3.6.1.4.1.41752.911.8.1.17 */
  91. static const struct snmp_scalar_node signal17 = SNMP_SCALAR_CREATE_NODE_READONLY(17, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  92. /* signal .1.3.6.1.4.1.41752.911.8.1.16 */
  93. static const struct snmp_scalar_node signal16 = SNMP_SCALAR_CREATE_NODE_READONLY(16, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  94. /* signal .1.3.6.1.4.1.41752.911.8.1.15 */
  95. static const struct snmp_scalar_node signal15 = SNMP_SCALAR_CREATE_NODE_READONLY(15, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  96. /* signal .1.3.6.1.4.1.41752.911.8.1.14 */
  97. static const struct snmp_scalar_node signal14 = SNMP_SCALAR_CREATE_NODE_READONLY(14, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  98. /* signal .1.3.6.1.4.1.41752.911.8.1.13 */
  99. static const struct snmp_scalar_node signal13 = SNMP_SCALAR_CREATE_NODE_READONLY(13, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  100. /* signal .1.3.6.1.4.1.41752.911.8.1.12 */
  101. static const struct snmp_scalar_node signal12 = SNMP_SCALAR_CREATE_NODE_READONLY(12, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  102. /* signal .1.3.6.1.4.1.41752.911.8.1.11 */
  103. static const struct snmp_scalar_node signal11 = SNMP_SCALAR_CREATE_NODE_READONLY(11, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  104. /* signal .1.3.6.1.4.1.41752.911.8.1.10 */
  105. static const struct snmp_scalar_node signal10 = SNMP_SCALAR_CREATE_NODE_READONLY(10, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  106. /* signal .1.3.6.1.4.1.41752.911.8.1.9 */
  107. static const struct snmp_scalar_node signal9 = SNMP_SCALAR_CREATE_NODE_READONLY(9, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  108. /* signal .1.3.6.1.4.1.41752.911.8.1.8 */
  109. static const struct snmp_scalar_node signal8 = SNMP_SCALAR_CREATE_NODE(8, SNMP_NODE_INSTANCE_WRITE_ONLY, SNMP_ASN1_TYPE_OCTET_STRING, NULL, signal_set_test, signal_set_value);
  110. /* signal .1.3.6.1.4.1.41752.911.8.1.7 */
  111. static const struct snmp_scalar_node signal7 = SNMP_SCALAR_CREATE_NODE(7, SNMP_NODE_INSTANCE_WRITE_ONLY, SNMP_ASN1_TYPE_INTEGER, NULL, signal_set_test, signal_set_value);
  112. /* signal .1.3.6.1.4.1.41752.911.8.1.6 */
  113. static const struct snmp_scalar_node signal6 = SNMP_SCALAR_CREATE_NODE_READONLY(6, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  114. /* signal .1.3.6.1.4.1.41752.911.8.1.5 */
  115. static const struct snmp_scalar_node signal5 = SNMP_SCALAR_CREATE_NODE_READONLY(5, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  116. /* signal .1.3.6.1.4.1.41752.911.8.1.4 */
  117. static const struct snmp_scalar_node signal4 = SNMP_SCALAR_CREATE_NODE_READONLY(4, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  118. /* signal .1.3.6.1.4.1.41752.911.8.1.3 */
  119. static const struct snmp_scalar_node signal3 = SNMP_SCALAR_CREATE_NODE(3, SNMP_NODE_INSTANCE_WRITE_ONLY, SNMP_ASN1_TYPE_INTEGER, NULL, signal_set_test, signal_set_value);
  120. /* signal .1.3.6.1.4.1.41752.911.8.1.2 */
  121. static const struct snmp_scalar_node signal2 = SNMP_SCALAR_CREATE_NODE(2, SNMP_NODE_INSTANCE_WRITE_ONLY, SNMP_ASN1_TYPE_INTEGER, NULL, signal_set_test, signal_set_value);
  122. /* signal .1.3.6.1.4.1.41752.911.8.1.1 */
  123. static const struct snmp_scalar_node signal1 = SNMP_SCALAR_CREATE_NODE_READONLY(1, SNMP_ASN1_TYPE_OCTET_STRING, signal_get_value);
  124. // signals .1.3.6.1.4.1.41752.911.8.1
  125. static const struct snmp_node* const signals_nodes[] = {
  126. &signal1.node.node,
  127. &signal2.node.node,
  128. &signal3.node.node,
  129. &signal4.node.node,
  130. &signal5.node.node,
  131. &signal6.node.node,
  132. &signal7.node.node,
  133. &signal8.node.node,
  134. &signal9.node.node,
  135. &signal10.node.node,
  136. &signal11.node.node,
  137. &signal12.node.node,
  138. &signal13.node.node,
  139. &signal14.node.node,
  140. &signal15.node.node,
  141. &signal16.node.node,
  142. &signal17.node.node,
  143. &signal18.node.node,
  144. &signal19.node.node,
  145. &signal20.node.node,
  146. &signal21.node.node,
  147. &signal22.node.node,
  148. &signal23.node.node,
  149. &signal24.node.node,
  150. &signal25.node.node,
  151. &signal26.node.node,
  152. &signal27.node.node,
  153. &signal28.node.node,
  154. &signal29.node.node,
  155. &signal30.node.node,
  156. &signal31.node.node,
  157. &signal32.node.node,
  158. &signal33.node.node,
  159. &signal34.node.node,
  160. &signal35.node.node,
  161. &signal36.node.node,
  162. &signal37.node.node,
  163. &signal38.node.node,
  164. &signal39.node.node,
  165. &signal40.node.node,
  166. &signal41.node.node,
  167. &signal42.node.node,
  168. &signal43.node.node,
  169. &signal44.node.node,
  170. };
  171. static const struct snmp_tree_node signals_node = SNMP_CREATE_TREE_NODE(1, signals_nodes);
  172. // bt_6703 .1.3.6.1.4.1.41752.911.8
  173. static const struct snmp_node* const bt6709_nodes[] = {
  174. &signals_node.node
  175. };
  176. static const struct snmp_tree_node bt6709_node = SNMP_CREATE_TREE_NODE(8, bt6709_nodes);
  177. // swt .1.3.6.1.4.1.41752.911
  178. static const struct snmp_node* const swt_nodes[] = {
  179. &bt6709_node.node
  180. };
  181. static const struct snmp_tree_node swt_node = SNMP_CREATE_TREE_NODE(911, swt_nodes);
  182. // rotek .1.3.6.1.4.1.41752
  183. static const struct snmp_node* const rotek_nodes[] = {
  184. &swt_node.node
  185. };
  186. static const struct snmp_tree_node rotek_node = SNMP_CREATE_TREE_NODE(41752, rotek_nodes);
  187. // enterprises .1.3.6.1.4.1
  188. static const struct snmp_node* const enterprises_nodes[] = {
  189. &rotek_node.node
  190. };
  191. static const struct snmp_tree_node enterprises_node = SNMP_CREATE_TREE_NODE(1, enterprises_nodes);
  192. // private .1.3.6.1.4
  193. static const struct snmp_node* const private_nodes[] = {
  194. &enterprises_node.node
  195. };
  196. static const struct snmp_tree_node private_root = SNMP_CREATE_TREE_NODE(0, private_nodes);
  197. static const u32_t prvmib_base_oid[] = { 1,3,6,1,4 };
  198. static const struct snmp_mib private_mib = SNMP_MIB_CREATE(prvmib_base_oid, &private_root.node);
  199. void lwip_privmib_init(void)
  200. {
  201. static const struct snmp_mib *my_snmp_mibs[] = {&mib2, &private_mib};
  202. snmp_set_mibs(my_snmp_mibs, LWIP_ARRAYSIZE(my_snmp_mibs));
  203. }
  204. uint32_t check_netsettings(char *addr, uint8_t len)
  205. {
  206. uint32_t val = 0;
  207. char c;
  208. uint8_t i, j;
  209. uint8_t cnt_dot = 0;
  210. uint8_t digit = 0;
  211. c = *addr;
  212. for(j = 0; j <= len; j ++){
  213. if (isdigit(c)) {
  214. val = (val * 10) + (int)(c - '0');
  215. }
  216. else if (c == '.' || c == 0) {
  217. if(val > 0xff){
  218. return 0;
  219. }
  220. cnt_dot ++;
  221. val = 0;
  222. }
  223. else{
  224. return 0;
  225. }
  226. c = *++addr;
  227. }
  228. if(cnt_dot != 4){
  229. return 0;
  230. }
  231. return 1;
  232. }
  233. static s16_t signal_get_value(struct snmp_node_instance* instance, void* value)
  234. {
  235. u8_t *paramStr = (u8_t*)value;
  236. u8_t paramLength = 0;
  237. u32_t oid = instance->node->oid; // id сигнала
  238. switch (oid){
  239. case 1: /* FWVersion */
  240. GetVersionStr((char*)paramStr, &paramLength);
  241. break;
  242. case 4: /* UPSModel*/
  243. GetUPSModelStr((char*)paramStr, &paramLength);
  244. break;
  245. case 5: /* UPSSerial*/
  246. GetUPSSerialStr((char*)paramStr, &paramLength);
  247. break;
  248. case 6: /* UPSVersion*/
  249. GetUPSVersionStr((char*)paramStr, &paramLength);
  250. break;
  251. case 9: /* IntTemp */
  252. GetInternalTempStr((char*)paramStr, &paramLength);
  253. break;
  254. case 10: /* InFreq */
  255. GetInputFreqStr((char*)paramStr, &paramLength);
  256. break;
  257. case 11: /* InVoltVAC */
  258. GetInputVoltageStr((char*)paramStr, &paramLength);
  259. break;
  260. case 12: /* OutVoltVAC */
  261. GetOutputVoltageStr((char*)paramStr, &paramLength);
  262. break;
  263. case 13: /* Power */
  264. GetPowerStr((char*)paramStr, &paramLength);
  265. break;
  266. case 14: /* BatCap */
  267. GetBatCapacityStr((char*)paramStr, &paramLength);
  268. break;
  269. case 15: /* BatTime */
  270. GetRuntimeStr((char*)paramStr, &paramLength);
  271. break;
  272. case 16: /* ConnectMonitor */
  273. GetConnectMonitorStr((char*)paramStr, &paramLength);
  274. break;
  275. case 17: /* Alarms */
  276. GetAlarmStr((char*)paramStr, &paramLength);
  277. break;
  278. case 18: /* IP server1 (traps) */
  279. GetManagerIp((char*)paramStr, &paramLength);
  280. break;
  281. case 19: /* IP server2 (traps) */
  282. GetManagerIp2((char*)paramStr, &paramLength);
  283. break;
  284. case 20: /* IP server3 (traps) */
  285. GetManagerIp3((char*)paramStr, &paramLength);
  286. break;
  287. case 21: /* IP server4 (traps) */
  288. GetManagerIp4((char*)paramStr, &paramLength);
  289. break;
  290. case 22: /* IP server5 (traps) */
  291. GetManagerIp5((char*)paramStr, &paramLength);
  292. break;
  293. case 23: /* WhiteList range 1 */
  294. GetWhiteListSTR((char*)paramStr, &paramLength, 0);
  295. break;
  296. case 24: /* WhiteList range 2 */
  297. GetWhiteListSTR((char*)paramStr, &paramLength, 1);
  298. break;
  299. case 25: /* WhiteList range 3 */
  300. GetWhiteListSTR((char*)paramStr, &paramLength, 2);
  301. break;
  302. case 26: /* WhiteList range 4 */
  303. GetWhiteListSTR((char*)paramStr, &paramLength, 3);
  304. break;
  305. case 27: /* WhiteList range 5 */
  306. GetWhiteListSTR((char*)paramStr, &paramLength, 4);
  307. break;
  308. case 28: /* UPSVoltCellMin */
  309. GetUPSVoltCellMinStr((char*)paramStr, &paramLength);
  310. break;
  311. case 29: /* UPSVoltCellMax */
  312. GetUPSVoltCellMaxStr((char*)paramStr, &paramLength);
  313. break;
  314. case 30: /* VACAlarmHighRange */
  315. GetVACAlarmHighRangeStr((char*)paramStr, &paramLength);
  316. break;
  317. case 31: /* VACAlarmLowRange */
  318. GetVACAlarmLowRangeStr((char*)paramStr, &paramLength);
  319. break;
  320. case 32: /* VACAlarmHistRange */
  321. GetVACAlarmHisteStr((char*)paramStr, &paramLength);
  322. break;
  323. case 33: /* TemperatureAlarmHighRange */
  324. GetTemperatureAlarmHighRangeStr((char*)paramStr, &paramLength);
  325. break;
  326. case 34: /* TemperatureAlarmLowRange */
  327. GetTemperatureAlarmLowRangeStr((char*)paramStr, &paramLength);
  328. break;
  329. case 35: /* TemperatureAlarmHistRange */
  330. GetTemperatureAlarmHisteStr((char*)paramStr, &paramLength);
  331. break;
  332. case 36: /* LoadAlarmHighRange */
  333. GetLoadAlarmHighRangeStr((char*)paramStr, &paramLength);
  334. break;
  335. case 37: /* LoadAlarmHistRange */
  336. GetLoadAlarmHisteStr((char*)paramStr, &paramLength);
  337. break;
  338. case 38: /* SntpTimeZone */
  339. GetSntpTimeZoneStr((char*)paramStr, &paramLength);
  340. break;
  341. case 39: /* SntpState */
  342. GetSntpStateStr((char*)paramStr, &paramLength);
  343. break;
  344. case 40: /* SntpServerIp */
  345. GetSntpServerIpStr((char*)paramStr, &paramLength);
  346. break;
  347. case 41: /* SntpLastData */
  348. GetSntpLastDataStr((char*)paramStr, &paramLength);
  349. break;
  350. case 42: /* Date */
  351. GetDateStr((char*)paramStr, &paramLength);
  352. break;
  353. case 43: /* Time */
  354. GetTimeStr((char*)paramStr, &paramLength);
  355. break;
  356. case 44: /* AKBTimeWork */
  357. GetAKBWorktimeStr((char*)paramStr, &paramLength);
  358. break;
  359. default:
  360. break;
  361. }
  362. return paramLength;
  363. }
  364. static snmp_err_t signal_set_value(struct snmp_node_instance* instance, u16_t len, void* value)
  365. {
  366. u32_t oid = instance->node->oid; // id сигнала
  367. char *val_string;
  368. char str[20];
  369. int8_t res = 0;
  370. s32_t val;
  371. bool enable_old_sntp;
  372. memset(str, 0, 20);
  373. switch (oid)
  374. {
  375. case 2: /* RestoreSignal */
  376. val = *(s32_t*)value;
  377. if (val == 1) {
  378. // SNMP_SendUserTrap(DEVICE_RESTORED);
  379. log_event_data(LOG_SYSTEM_DEFCONFIG, "Администратор");
  380. vTaskDelay(500);
  381. SETTINGS_SetPartDefault();
  382. SETTINGS_Save();
  383. }
  384. break;
  385. case 3: /* RebootSignal */
  386. val = *(s32_t*)value;
  387. if (val == 1){
  388. #ifndef BT6702_SERVICE
  389. // SNMP_SendUserTrap(DEVICE_REBOOTED);
  390. log_event_data(LOG_SYSTEM_BOOT, "Администратор");
  391. vTaskDelay(1010);
  392. LOG_Disable();
  393. #endif
  394. NVIC_SystemReset();
  395. }
  396. break;
  397. case 7: /* BatTest */
  398. val =*(s32_t*)value;
  399. if(val == 0){
  400. res = ups_metac_service_pdu(ups_cancel_test);
  401. if(res == 1){
  402. log_event_data(LOG_TEST_UPS, "Администратор (Останов)");
  403. }
  404. }
  405. else if(val > 0 && val < 100){
  406. TimeParam = val;
  407. res = ups_metac_service_pdu(ups_test_time);
  408. if(res == 1){
  409. log_event_data(LOG_TEST_UPS, "Администратор (Запущен)");
  410. }
  411. }
  412. else if(val == 100){
  413. res = ups_metac_service_pdu(ups_test_10sec);
  414. if(res == 1){
  415. log_event_data(LOG_TEST_UPS, "Администратор (Запущен)");
  416. }
  417. }
  418. else if(val == 999){
  419. res = ups_metac_service_pdu(ups_test_low_bat);
  420. if(res == 1){
  421. log_event_data(LOG_TEST_UPS, "Администратор (Запущен)");
  422. }
  423. }
  424. break;
  425. case 8: /* Shutdown UPS */
  426. val_string = (char*)value;
  427. float shtdn_val = atof(val_string);
  428. if(shtdn_val == 0){
  429. res = ups_metac_service_pdu(ups_cancel_shut_down);
  430. if(res == 1){
  431. log_event_data(LOG_SHUTDOWN_UPS, "Администратор (Останов)");
  432. }
  433. }
  434. else{
  435. TimeParamFloat = shtdn_val;
  436. res = ups_metac_service_pdu(ups_shutdown);
  437. if(res == 1)
  438. log_event_data(LOG_SHUTDOWN_UPS, "Администратор");
  439. }
  440. break;
  441. case 18:
  442. val_string = (char*)value;
  443. SetManagerIp(val_string);
  444. break;
  445. case 19:
  446. val_string = (char*)value;
  447. SetManagerIp2(val_string);
  448. break;
  449. case 20:
  450. val_string = (char*)value;
  451. SetManagerIp3(val_string);
  452. break;
  453. case 21:
  454. val_string = (char*)value;
  455. SetManagerIp4(val_string);
  456. break;
  457. case 22:
  458. val_string = (char*)value;
  459. SetManagerIp5(val_string);
  460. break;
  461. case 28:
  462. val_string = (char*)value;
  463. SetUPSVoltCellMinStr(val_string);
  464. break;
  465. case 29:
  466. val_string = (char*)value;
  467. SetUPSVoltCellMaxStr(val_string);
  468. break;
  469. case 30:
  470. val_string = (char*)value;
  471. SetVACAlarmHighRangeStr(val_string);
  472. break;
  473. case 31:
  474. val_string = (char*)value;
  475. SetVACAlarmLowRangeStr(val_string);
  476. break;
  477. case 32:
  478. val_string = (char*)value;
  479. SetVACAlarmHisteStr(val_string);
  480. break;
  481. case 33:
  482. val_string = (char*)value;
  483. SetTemperatureAlarmHighRangeStr(val_string);
  484. break;
  485. case 34:
  486. val_string = (char*)value;
  487. SetTemperatureAlarmLowRangeStr(val_string);
  488. break;
  489. case 35:
  490. val_string = (char*)value;
  491. SetTemperatureAlarmHisteStr(val_string);
  492. break;
  493. case 36:
  494. val_string = (char*)value;
  495. SetLoadAlarmHighRangeStr(val_string);
  496. break;
  497. case 37:
  498. val_string = (char*)value;
  499. SetLoadAlarmHistStr(val_string);
  500. break;
  501. case 38:
  502. val_string = (char*)value;
  503. SetSntpTimeZoneStr(val_string);
  504. break;
  505. case 39:
  506. enable_old_sntp = sSettings.sSNTP.sntpEnable;
  507. val_string = (char*)value;
  508. SetSntpStateStr(val_string);
  509. if(sSettings.sSNTP.sntpEnable != enable_old_sntp){
  510. SETTINGS_Save();
  511. log_event_data(LOG_SETTING_SAVE, "Администратор (SNMP)");
  512. SNTP_Init();
  513. //vTaskDelay(7000);
  514. SNTP_Poll();
  515. }
  516. break;
  517. case 40:
  518. val_string = (char*)value;
  519. if(strncmp(val_string, sSettings.sSNTP.ip, strlen(val_string)) != 0){
  520. SetSntpServerIpStr(val_string);
  521. SETTINGS_Save();
  522. log_event_data(LOG_SETTING_SAVE, "Администратор (SNMP)");
  523. SNTP_Init();
  524. //vTaskDelay(7000);
  525. SNTP_Poll();
  526. }
  527. break;
  528. case 41:
  529. break;
  530. case 42:
  531. val_string = (char*)value;
  532. SetDateStr(val_string);
  533. break;
  534. case 43:
  535. val_string = (char*)value;
  536. SetTimeStr(val_string);
  537. break;
  538. default :
  539. return SNMP_ERR_GENERROR;
  540. break;
  541. };
  542. if((oid >= 18 && oid <= 22)
  543. || (oid >= 28 && oid <= 38)){
  544. SETTINGS_Save();
  545. log_event_data(LOG_SETTING_SAVE, "Администратор (SNMP)");
  546. }
  547. return SNMP_ERR_NOERROR;
  548. }
  549. static snmp_err_t signal_set_test(struct snmp_node_instance* instance, u16_t len, void* value)
  550. {
  551. snmp_err_t ret = SNMP_ERR_WRONGVALUE;
  552. char *val_string;
  553. int32_t val;
  554. float tmp_value;
  555. uint8_t j;
  556. u32_t oid = instance->node->oid; // id сигнала
  557. bool fail = false;
  558. switch (oid)
  559. {
  560. case 2:
  561. if ( len == sizeof(s32_t) )
  562. {
  563. ret = SNMP_ERR_NOERROR;
  564. }
  565. break;
  566. case 3:
  567. if ( len == sizeof(s32_t) )
  568. {
  569. ret = SNMP_ERR_NOERROR;
  570. }
  571. break;
  572. case 7: /* BatTest */
  573. val = *((s32_t*)value);
  574. if((val >= 0 && val <= 100) || val == 999){
  575. ret = SNMP_ERR_NOERROR;
  576. }
  577. break;
  578. case 8: /* Shutdown UPS */
  579. if ( len <= 3 )
  580. {
  581. val_string = (char*)value;
  582. val_string[len] = 0;
  583. if(atof(val_string) <= 10){
  584. ret = SNMP_ERR_NOERROR;
  585. }
  586. }
  587. break;
  588. case 18:
  589. case 19:
  590. case 20:
  591. case 21:
  592. case 22:
  593. case 40:
  594. if ( len <= 15 )
  595. {
  596. val_string = (char*)value;
  597. val_string[len] = 0;
  598. if(check_netsettings(val_string, len))
  599. ret = SNMP_ERR_NOERROR;
  600. }
  601. break;
  602. case 28:
  603. val_string = (char*)value;
  604. val_string[len] = 0;
  605. for(j = 0; j < len; j ++){
  606. if(!isfloatdigit(val_string[j])){
  607. return ret;
  608. }
  609. }
  610. tmp_value = atof(val_string);
  611. if(tmp_value < sSettings.UPS_Setting.Ucellmax && tmp_value > MIN_VOLT_CELL_RANGE){
  612. ret = SNMP_ERR_NOERROR;
  613. }
  614. break;
  615. case 29:
  616. val_string = (char*)value;
  617. val_string[len] = 0;
  618. for(j = 0; j < len; j ++){
  619. if(!isfloatdigit(val_string[j])){
  620. return ret;
  621. }
  622. }
  623. tmp_value = atof(val_string);
  624. if(tmp_value > sSettings.UPS_Setting.Ucellmin && tmp_value <= MAX_VOLT_CELL_RANGE){
  625. ret = SNMP_ERR_NOERROR;
  626. }
  627. break;
  628. case 30:
  629. val_string = (char*)value;
  630. val_string[len] = 0;
  631. for(j = 0; j < len; j ++){
  632. if(!isdigit_int(val_string[j])){
  633. return ret;
  634. }
  635. }
  636. tmp_value = atof(val_string);
  637. if(tmp_value >= MAX_VAC_MIN_RANGE && tmp_value <= MAX_VAC_MAX_RANGE){
  638. ret = SNMP_ERR_NOERROR;
  639. }
  640. break;
  641. case 31:
  642. val_string = (char*)value;
  643. val_string[len] = 0;
  644. for(j = 0; j < len; j ++){
  645. if(!isdigit_int(val_string[j])){
  646. return ret;
  647. }
  648. }
  649. tmp_value = atof(val_string);
  650. if(tmp_value >= MIN_VAC_MIN_RANGE && tmp_value <= MIN_VAC_MAX_RANGE){
  651. ret = SNMP_ERR_NOERROR;
  652. }
  653. break;
  654. case 32:
  655. val_string = (char*)value;
  656. val_string[len] = 0;
  657. for(j = 0; j < len; j ++){
  658. if(!isdigit_int(val_string[j])){
  659. return ret;
  660. }
  661. }
  662. tmp_value = atof(val_string);
  663. if(tmp_value >= HIST_VAC_MIN_RANGE && tmp_value <= HIST_VAC_MAX_RANGE){
  664. ret = SNMP_ERR_NOERROR;
  665. }
  666. break;
  667. case 33:
  668. val_string = (char*)value;
  669. val_string[len] = 0;
  670. for(j = 0; j < len; j ++){
  671. if(!isdigit_int(val_string[j])){
  672. return ret;
  673. }
  674. }
  675. tmp_value = atof(val_string);
  676. if(tmp_value >= MAX_TEMP_MIN_RANGE && tmp_value <= MAX_TEMP_MAX_RANGE){
  677. ret = SNMP_ERR_NOERROR;
  678. }
  679. break;
  680. case 34:
  681. val_string = (char*)value;
  682. val_string[len] = 0;
  683. for(j = 0; j < len; j ++){
  684. if(!isdigit_int(val_string[j])){
  685. if(j == 0 && val_string[j] == '-'){
  686. continue;
  687. }
  688. else{
  689. return ret;
  690. }
  691. }
  692. }
  693. tmp_value = atof(val_string);
  694. if(tmp_value >= MIN_TEMP_MIN_RANGE && tmp_value <= MIN_TEMP_MAX_RANGE){
  695. ret = SNMP_ERR_NOERROR;
  696. }
  697. break;
  698. case 35:
  699. val_string = (char*)value;
  700. val_string[len] = 0;
  701. for(j = 0; j < len; j ++){
  702. if(!isfloatdigit(val_string[j])){
  703. return ret;
  704. }
  705. }
  706. tmp_value = atof(val_string);
  707. if(tmp_value >= HIST_TEMP_MIN_RANGE && tmp_value <= HIST_TEMP_MAX_RANGE){
  708. ret = SNMP_ERR_NOERROR;
  709. }
  710. break;
  711. case 36:
  712. val_string = (char*)value;
  713. val_string[len] = 0;
  714. for(j = 0; j < len; j ++){
  715. if(!isdigit_int(val_string[j])){
  716. return ret;
  717. }
  718. }
  719. tmp_value = atof(val_string);
  720. if(tmp_value >= MAX_LOAD_MIN_RANGE && tmp_value <= MAX_LOAD_MAX_RANGE){
  721. ret = SNMP_ERR_NOERROR;
  722. }
  723. break;
  724. case 37:
  725. val_string = (char*)value;
  726. val_string[len] = 0;
  727. for(j = 0; j < len; j ++){
  728. if(!isfloatdigit(val_string[j])){
  729. return ret;
  730. }
  731. }
  732. tmp_value = atof(val_string);
  733. if(tmp_value >= HIST_LOAD_MIN_RANGE && tmp_value <= HIST_LOAD_MAX_RANGE){
  734. ret = SNMP_ERR_NOERROR;
  735. }
  736. break;
  737. case 38:
  738. val_string = (char*)value;
  739. val_string[len] = 0;
  740. if(len > 1 && len < 5){
  741. bool fail = false;
  742. if(val_string[0] != '-' && val_string[0] != '+')
  743. fail = true;
  744. if(!isdigit_int(val_string[1]) && (!isdigit_int(val_string[2]) && val_string[2] != '.')
  745. && (!isdigit_int(val_string[3]) && val_string[3] != '.'))
  746. fail = true;
  747. if(len == 5){
  748. if(!isdigit_int(val_string[4]))
  749. fail = true;
  750. }
  751. if(!fail){
  752. tmp_value = atof(val_string);
  753. if(tmp_value >= -12.0 && tmp_value <= 12.0){
  754. ret = SNMP_ERR_NOERROR;
  755. }
  756. }
  757. }
  758. break;
  759. case 39:
  760. val_string = (char*)value;
  761. val_string[len] = 0;
  762. if(len == 1){
  763. if(val_string[0] == '0' || val_string[0] == '1')
  764. {
  765. ret = SNMP_ERR_NOERROR;
  766. }
  767. }
  768. break;
  769. case 42:
  770. val_string = (char*)value;
  771. val_string[len] = 0;
  772. if(len == 10){
  773. for(j = 0; j < len; j++)
  774. {
  775. if(j != 4 && j != 7)
  776. {
  777. if(val_string[j] > 0x39 || val_string[j] < 0x30){
  778. fail = true;
  779. break;
  780. }
  781. }
  782. else if(j == 4 || j == 7){
  783. if(val_string[j] != '-'){
  784. fail = true;
  785. break;
  786. }
  787. }
  788. }
  789. if(!fail)
  790. {
  791. uint16_t temp = 0;
  792. temp = 1000*(val_string[0] - 0x30) + 100*(val_string[1] - 0x30) + 10*(val_string[2] - 0x30) + val_string[3] - 0x30;
  793. if(temp > 2099 || temp < 2000)
  794. fail = true;
  795. temp = 0;
  796. temp = 10*(val_string[5] - 0x30) + (val_string[6] - 0x30);
  797. if(temp > 12)
  798. fail = true;
  799. temp = 0;
  800. temp = 10*(val_string[8] - 0x30) + (val_string[9] - 0x30);
  801. if(temp > 31)
  802. fail = true;
  803. }
  804. if(!fail){
  805. ret = SNMP_ERR_NOERROR;
  806. }
  807. }
  808. break;
  809. case 43:
  810. val_string = (char*)value;
  811. val_string[len] = 0;
  812. if(len == 5){
  813. for(j = 0; j < len; j++)
  814. {
  815. if(j != 2)
  816. {
  817. if(val_string[j] > 0x39 || val_string[j] < 0x30){
  818. fail = true;
  819. break;
  820. }
  821. }
  822. else if(j == 2){
  823. if(val_string[j] != ':'){
  824. fail = true;
  825. break;
  826. }
  827. }
  828. }
  829. if(!fail)
  830. {
  831. uint16_t temp = 0;
  832. temp = 10*(val_string[0] - 0x30) + (val_string[1] - 0x30);
  833. if(temp > 23)
  834. fail = true;
  835. temp = 0;
  836. temp = 10*(val_string[3] - 0x30) + (val_string[4] - 0x30);
  837. if(temp > 59)
  838. fail = true;
  839. }
  840. if(!fail){
  841. ret = SNMP_ERR_NOERROR;
  842. }
  843. }
  844. break;
  845. };
  846. return ret;
  847. }
  848. #endif