private_mib_bt6708.c 28 KB

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