trap_api.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. /********************************* (C) ROTEK ***********************************
  2. * @module trap_api
  3. * @file trap_api.c
  4. * @version 1.0.0
  5. * @date XX.XX.XXXX
  6. * $brief trap_api
  7. *******************************************************************************
  8. * @history Version Author Comment
  9. * XX.XX.XXXX 1.0.0 Telenkov D.A. First release.
  10. *******************************************************************************
  11. */
  12. #include "stm32f4xx.h"
  13. #include "trap_api.h"
  14. #include "parameters.h"
  15. #include "settings_api.h"
  16. #include "lwip/snmp.h"
  17. #include "lwip/snmp_msg.h"
  18. #include "lwip/snmp_asn1.h"
  19. #include "lwip/snmp_structs.h"
  20. #ifdef PRINTF_STDLIB
  21. #include <stdio.h>
  22. #endif
  23. #ifdef PRINTF_CUSTOM
  24. #include "tinystdio.h"
  25. #endif
  26. #include <string.h>
  27. #include <stdbool.h>
  28. /**
  29. * @brief Общая структура настроек
  30. */
  31. extern SETTINGS_t sSettings;
  32. /**
  33. * @brief Пул всех возможных трапов устройства
  34. */
  35. TRAP_t traps[15];
  36. /**
  37. * @brief Инициализация базы трапов
  38. * @retval
  39. */
  40. void SNMP_InitTrapsBase(void)
  41. {
  42. /* 1. FWVersionUpdate */ // +
  43. traps[FW_VERSION_UPDATE].trapId = FW_VERSION_UPDATE;
  44. traps[FW_VERSION_UPDATE].varbindId = 1;
  45. traps[FW_VERSION_UPDATE].trapEnable = true;
  46. traps[FW_VERSION_UPDATE].handle = GetVersionStr; /* FWVersion */
  47. /* 2. FWVersionUpdated */ // +
  48. traps[FW_VERSION_UPDATED].trapId = FW_VERSION_UPDATED;
  49. traps[FW_VERSION_UPDATED].varbindId = 1;
  50. traps[FW_VERSION_UPDATED].trapEnable = true;
  51. traps[FW_VERSION_UPDATED].handle = GetVersionStr; /* FWVersion */
  52. /* 3. DeviceRestored */ // +
  53. traps[DEVICE_RESTORED].trapId = DEVICE_RESTORED;
  54. traps[DEVICE_RESTORED].varbindId = 2;
  55. traps[DEVICE_RESTORED].trapEnable = true;
  56. traps[DEVICE_RESTORED].handle = GetRestore; /* RestoreSignal */
  57. /* 4. DeviceRebooted */ // +
  58. traps[DEVICE_REBOOTED].trapId = DEVICE_REBOOTED;
  59. traps[DEVICE_REBOOTED].varbindId = 3;
  60. traps[DEVICE_REBOOTED].trapEnable = true;
  61. traps[DEVICE_REBOOTED].handle = GetReboot; /* RebootSignal */
  62. /* 5. BatteryTemperatureNorm */ // +
  63. traps[BATTERY_TEMPERATURE_NORM].trapId = BATTERY_TEMPERATURE_NORM;
  64. traps[BATTERY_TEMPERATURE_NORM].varbindId = 4;
  65. traps[BATTERY_TEMPERATURE_NORM].trapEnable = true;
  66. traps[BATTERY_TEMPERATURE_NORM].handle = GetInternalTempStr; /* BatteryTemperature */
  67. /* 6. BatteryTemperatureAlarm */ // +
  68. traps[BATTERY_TEMPERATURE_ALARM].trapId = BATTERY_TEMPERATURE_ALARM;
  69. traps[BATTERY_TEMPERATURE_ALARM].varbindId = 4;
  70. traps[BATTERY_TEMPERATURE_ALARM].trapEnable = true;
  71. traps[BATTERY_TEMPERATURE_ALARM].handle = GetInternalTempStr; /* BatteryTemperature */
  72. /* 7. LineAlarm */ // +
  73. traps[LINE_ALARM].trapId = LINE_ALARM;
  74. traps[LINE_ALARM].varbindId = 9;
  75. traps[LINE_ALARM].trapEnable = true;
  76. traps[LINE_ALARM].handle = GetInputVoltageStr; /* LineAlarm */
  77. /* 8. LineNorm */ // +
  78. traps[LINE_NORM].trapId = LINE_NORM;
  79. traps[LINE_NORM].varbindId = 9;
  80. traps[LINE_NORM].trapEnable = true;
  81. traps[LINE_NORM].handle = GetInputVoltageStr; /* LineNorm */
  82. /* 9. LowBatAlarm */ // +
  83. traps[LOW_BAT_ALARM].trapId = LOW_BAT_ALARM;
  84. traps[LOW_BAT_ALARM].varbindId = 12;
  85. traps[LOW_BAT_ALARM].trapEnable = true;
  86. traps[LOW_BAT_ALARM].handle = GetBatCapacityStr; /* LowBatAlarm */
  87. /* 10. LowBatNorm */ // +
  88. traps[LOW_BAT_NORM].trapId = LOW_BAT_NORM;
  89. traps[LOW_BAT_NORM].varbindId = 12;
  90. traps[LOW_BAT_NORM].trapEnable = true;
  91. traps[LOW_BAT_NORM].handle = GetBatCapacityStr; /* LowBatNorm */
  92. /* 11. PowerAlarm */ // +
  93. traps[POWER_ALARM].trapId = POWER_ALARM;
  94. traps[POWER_ALARM].varbindId = 11;
  95. traps[POWER_ALARM].trapEnable = true;
  96. traps[POWER_ALARM].handle = GetPowerStr; /* PowerAlarm */
  97. /* 12. PowerNorm */ // +
  98. traps[POWER_NORM].trapId = POWER_NORM;
  99. traps[POWER_NORM].varbindId = 11;
  100. traps[POWER_NORM].trapEnable = true;
  101. traps[POWER_NORM].handle = GetPowerStr; /* PowerNorm */
  102. /* 13. ConnectMonitorAlarm */ //
  103. traps[CONNECT_MONITOR_ALARM].trapId = CONNECT_MONITOR_ALARM;
  104. traps[CONNECT_MONITOR_ALARM].varbindId = 13;
  105. traps[CONNECT_MONITOR_ALARM].trapEnable = true;
  106. traps[CONNECT_MONITOR_ALARM].handle = GetConnectMonitorStr; /* ConnectMonitor */
  107. /* 14. ConnectMonitorNorm */ //
  108. traps[CONNECT_MONITOR_NORM].trapId = CONNECT_MONITOR_NORM;
  109. traps[CONNECT_MONITOR_NORM].varbindId = 13;
  110. traps[CONNECT_MONITOR_NORM].trapEnable = true;
  111. traps[CONNECT_MONITOR_NORM].handle = GetConnectMonitorStr; /* ConnectMonitor */
  112. }
  113. /**
  114. * @brief Отправка обычного трапа с сообщением, зарегистрированного в базе.
  115. * @retval
  116. */
  117. bool SNMP_SendMessageTrap(TRAP_t trap, char* str, uint8_t len)
  118. {
  119. const uint8_t maxMsgLen = 30;
  120. char msg[30];
  121. struct snmp_varbind *vb;
  122. struct snmp_obj_id trapObjId = {11, {1, 3, 6, 1, 4, 1, 41752, 911, 1, 2, 1}};
  123. if (len <= maxMsgLen)
  124. {
  125. trapObjId.id[trapObjId.len - 1] = trap.trapId;
  126. strcpy(msg, str);
  127. vb = snmp_varbind_alloc(&trapObjId, SNMP_ASN1_OPAQUE, strlen(msg));
  128. vb->value = msg;
  129. trap_msg.outvb.head = vb;
  130. trap_msg.outvb.tail = vb;
  131. trap_msg.outvb.count = 1;
  132. snmp_send_trap(SNMP_GENTRAP_ENTERPRISESPC, &trapObjId, 0);
  133. trap_msg.outvb.head = NULL;
  134. trap_msg.outvb.tail = NULL;
  135. trap_msg.outvb.count = 0;
  136. snmp_varbind_list_free(&trap_msg.outvb);
  137. snmp_varbind_free(vb);
  138. return true;
  139. }
  140. else
  141. return false;
  142. }
  143. /**
  144. * @brief Отправка трапа с переменной, зарегистрированного в базе.
  145. * @retval
  146. */
  147. bool SNMP_SendVarbindTrap(TRAP_t *trap)
  148. {
  149. char msg[255];
  150. uint8_t len = 0;
  151. struct snmp_varbind *vb;
  152. struct snmp_obj_id trapObjId = {11, {1, 3, 6, 1, 4, 1, 41752, 911, 1, 2, 1}};
  153. struct snmp_obj_id varObjId = {11, {1, 3, 6, 1, 4, 1, 41752, 911, 1, 1, 1}};
  154. trapObjId.id[trapObjId.len - 1] = trap->trapId;
  155. varObjId.id[varObjId.len - 1] = trap->varbindId;
  156. trap->handle(msg, &len);
  157. vb = snmp_varbind_alloc(&varObjId, SNMP_ASN1_OC_STR, len);
  158. if(vb != NULL ) {
  159. memcpy(vb->value, msg, len);
  160. snmp_varbind_tail_add(&trap_msg.outvb, vb);
  161. snmp_send_trap(SNMP_GENTRAP_ENTERPRISESPC, &trapObjId, 0);
  162. snmp_varbind_list_free(&trap_msg.outvb);
  163. return true;
  164. }
  165. else {
  166. return false;
  167. }
  168. }
  169. /********************************* (C) ROTEK **********************************/