parameters.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
  1. /********************************* (C) РОТЕК ***********************************
  2. * @module parameters
  3. * @file parameters.h
  4. * @version 1.0.0
  5. * @date XX.XX.XXXX
  6. * $brief parameters
  7. *******************************************************************************
  8. * @history Version Author Comment
  9. * XX.XX.XXXX 1.0.0 Telenkov D.A. First release.
  10. *******************************************************************************
  11. */
  12. /* Define to prevent recursive ----------------------------------------------*/
  13. #ifndef PARAMETERS_H
  14. #define PARAMETERS_H
  15. #include <stdbool.h>
  16. // ************************************************************************** //
  17. // Параметры UPS
  18. void GetInputFreqStr(char *str, uint8_t *len);
  19. void GetOutputFreqStr(char *str, uint8_t *len);
  20. void GetInputVoltageStr(char *str, uint8_t *len);
  21. void GetOutputVoltageStr(char *str, uint8_t *len);
  22. void GetPowerStr(char *str, uint8_t *len);
  23. void GetBatCapacityStr(char *str, uint8_t *len);
  24. void GetRuntimeStr(char *str, uint8_t *len);
  25. void GetInternalTempStr(char *str, uint8_t *len);
  26. /**
  27. * @brief
  28. */
  29. void GetAlarmMonitorStr(char *str, uint8_t *len);
  30. void GetConnectMonitorStr(char *str, uint8_t *len);
  31. /**
  32. * @brief Режим работы
  33. */
  34. void GetModeStr(char *str, uint8_t *len);
  35. /**
  36. * @brief Режим работы
  37. */
  38. void GetModeEn(char *str, uint8_t *len);
  39. /**
  40. * @brief Индикация аварийных ситуаций
  41. * TODO добавить реальный параметр
  42. */
  43. void GetAlarmStr(char *str, uint8_t *len);
  44. /**
  45. * @brief Индикация аварийных ситуаций
  46. */
  47. void GetUPSAlarmStr(char *str, uint8_t *len);
  48. /**
  49. * @brief Индикация аварийных ситуаций
  50. */
  51. void GetAKBAlarmStr(char *str, uint8_t *len);
  52. /**
  53. * @brief Индикация аварийных ситуаций
  54. */
  55. void GetConnectUPSAlarmStr(char *str, uint8_t *len);
  56. /**
  57. * @brief Индикация аварийных ситуаций
  58. */
  59. void GetUPSModeStr(char *str, uint8_t *len);
  60. /**
  61. * @brief Текущее время ч/м/с
  62. */
  63. void GetCurrentTimeStr(char *str, uint8_t *len);
  64. // ************************************************************************** //
  65. // Параметры даты и времени
  66. /**
  67. * @brief Дата (Ready for PRS!)
  68. */
  69. void GetDateStr(char *str, uint8_t *len);
  70. /**
  71. * @brief Время (Ready for PRS!)
  72. */
  73. void GetTimeStr(char *str, uint8_t *len);
  74. /**
  75. * @brief Время (Ready for PRS!)
  76. */
  77. void GetUnixTimeStr(char *str, uint8_t *len);
  78. // ************************************************************************** //
  79. // Параметры SNTP
  80. /**
  81. * @brief Состояние SNTP (Ready for PRS!)
  82. */
  83. void GetSntpStateStr(char *str, uint8_t *len);
  84. /**
  85. * @brief Состояние SNTP (Ready for PRS!)
  86. */
  87. void GetSntpStateStrRU(char *str, uint8_t *len);
  88. /**
  89. * @brief IP адрес SNTP сервера (Ready for PRS!)
  90. */
  91. void GetSntpServerIpStr(char *str, uint8_t *len);
  92. /**
  93. * @brief Часовой пояс контроллера (Ready for PRS!)
  94. */
  95. void GetSntpTimeZoneStr(char *str, uint8_t *len);
  96. /**
  97. * @brief Дата последней синхронизации SNTP (Ready for PRS!)
  98. */
  99. void GetSntpLastDataStr(char *str, uint8_t *len);
  100. // ************************************************************************** //
  101. // Информация
  102. // ************************************************************************** //
  103. // Настройки аутентификации
  104. void GetUserLogin(uint8_t user_id, char *str, uint8_t *len);
  105. void GetUserPassword(uint8_t user_id, char *str, uint8_t *len);
  106. void GetUserLevel(uint8_t user_id, char *str, uint8_t *len);
  107. void GetUserLevelInt(uint8_t user_id, uint8_t *value);
  108. /**
  109. * @brief Время работы устройства
  110. */
  111. void GetWorkTimeStr(char *str, uint8_t *len);
  112. /**
  113. * @brief Модель устройства
  114. */
  115. void GetModelStr(char *str, uint8_t *len);
  116. /**
  117. * @brief Дата производства
  118. */
  119. void GetProductionDataStr(char *str, uint8_t *len);
  120. /**
  121. * @brief Версия ПО
  122. */
  123. void GetVersionStr(char *str, uint8_t *len);
  124. /**
  125. * @brief MAC адрес устройства
  126. */
  127. void GetMacStr(char *str, uint8_t *len);
  128. /**
  129. * @brief Серийный номер устройства
  130. */
  131. void GetSerialNumberStr(char *str, uint8_t *len);
  132. /**
  133. * @brief Владелец устройства
  134. */
  135. void GetOwnerStr(char *str, uint8_t *len);
  136. /**
  137. * @brief Местоположение устройства
  138. */
  139. void GetLocationStr(char *str, uint8_t *len);
  140. /**
  141. * @brief Комментарии
  142. */
  143. void GetCommentsStr(char *str, uint8_t *len);
  144. /**
  145. * @brief Серийный номер UPS
  146. */
  147. void GetUPSSerialStr(char *str, uint8_t *len);
  148. /**
  149. * @brief Модель UPS
  150. */
  151. void GetUPSModelStr(char *str, uint8_t *len);
  152. /**
  153. * @brief Версия UPS ПО
  154. */
  155. void GetUPSVersionStr(char *str, uint8_t *len);
  156. // ************************************************************************** //
  157. // Параметры WEB
  158. /**
  159. * @brief Текущий IP адрес
  160. */
  161. void GetIpStr(char *str, uint8_t *len);
  162. /**
  163. * @brief Текущий шлюз
  164. */
  165. void GetGatewayStr(char *str, uint8_t *len);
  166. /**
  167. * @brief Текущая маска подсети
  168. */
  169. void GetMaskStr(char *str, uint8_t *len);
  170. /**
  171. * @brief Настройка DHCP
  172. */
  173. void GetDhcpStateStr(char *str, uint8_t *len);
  174. /**
  175. * @brief Настройка DHCP
  176. */
  177. void GetDhcpStateUDP(char *str, uint8_t *len);
  178. /**
  179. * @brief Настройка DHCP
  180. */
  181. void GetDhcpStateStrRu(char *str, uint8_t *len);
  182. #ifdef HARDWARE_BT6708
  183. // ************************************************************************** //
  184. // Параметры довверительных хостов
  185. /**
  186. * @brief диапазон доверительных хостов
  187. */
  188. void GetWhiteListSTR(char *str, uint8_t *len, uint8_t num);
  189. /**
  190. * @brief маска диапазона доверительных хостов
  191. */
  192. void GetWhiteListMask(uint32_t *value, uint8_t num);
  193. /**
  194. * @brief ip диапазона доверительных хостов
  195. */
  196. void GetWhiteListIP(uint32_t *value, uint8_t num);
  197. #endif
  198. // ************************************************************************** //
  199. // Параметры SNMP
  200. /**
  201. * @brief Текущее TRAP community
  202. */
  203. void GetTrapCommunity(char *str, uint8_t *len);
  204. /**
  205. * @brief Текущее community для чтения
  206. */
  207. void GetReadCommunity(char *str, uint8_t *len);
  208. /**
  209. * @brief Текущее community для записи
  210. */
  211. void GetWriteCommunity(char *str, uint8_t *len);
  212. /**
  213. * @brief IP SNMP менеджера
  214. */
  215. void GetManagerIp(char *str, uint8_t *len);
  216. void GetManagerIp2(char *str, uint8_t *len);
  217. void GetManagerIp3(char *str, uint8_t *len);
  218. void GetManagerIp4(char *str, uint8_t *len);
  219. void GetManagerIp5(char *str, uint8_t *len);
  220. #ifdef HARDWARE_BT6702
  221. // ************************************************************************** //
  222. // Параметры RADIUS
  223. /**
  224. * @brief Текущий IP адрес
  225. */
  226. void GetRDSIpStr(char *str, uint8_t *len);
  227. /**
  228. * @brief Текущий Порт
  229. */
  230. void GetRDSPortStr(char *str, uint8_t *len);
  231. /**
  232. * @brief Текущий Код access
  233. */
  234. void GetRDSKeyAccesstStr(char *str, uint8_t *len);
  235. /**
  236. * @brief Текущая пароль RADIUS
  237. */
  238. void GetRDSPasswordkStr(char *str, uint8_t *len);
  239. /**
  240. * @brief Настройка вкл/ выкл RADIUS сервера
  241. */
  242. void GetRDSEnableStateStr(char *str, uint8_t *len);
  243. /**
  244. * @brief Настройка вкл/ выкл авторизации
  245. */
  246. void GetAuthEnableStateStr(char *str, uint8_t *len);
  247. #endif
  248. #ifndef HARDWARE_BT6708
  249. // ************************************************************************** //
  250. // Параметры реле/сухих контактов
  251. /**
  252. * @brief Тип действий при срабатывание сухих контактов
  253. */
  254. void GetDINTypeActStr(char *str, uint8_t *len, uint8_t num);
  255. /**
  256. * @brief Состояние сухого контакта
  257. */
  258. void GetDINStatusStr(char *str, uint8_t *len, uint8_t num);
  259. /**
  260. * @brief Состояние сухого контакта
  261. */
  262. void GetDIN0StatusStr(char *str, uint8_t *len);
  263. /**
  264. * @brief Состояние сухого контакта
  265. */
  266. void GetDIN0StatusStrRU(char *str, uint8_t *len);
  267. /**
  268. * @brief Источник срабатывания реле
  269. */
  270. void GetROTypeActStr(char *str, uint8_t *len, uint8_t num);
  271. /**
  272. * @brief Состояние релейного выхода
  273. */
  274. void GetDOUTStatusStr(char *str, uint8_t *len, uint8_t num);
  275. /**
  276. * @brief Состояние релейного выхода
  277. */
  278. void GetDOUTStatusStrRU(char *str, uint8_t *len, uint8_t num);
  279. /**
  280. * @brief Состояние релейного выхода
  281. */
  282. void GetDOUT0StatusStr(char *str, uint8_t *len);
  283. /**
  284. * @brief Состояние релейного выхода
  285. */
  286. void GetDOUT1StatusStr(char *str, uint8_t *len);
  287. #if defined HARDWARE_BT6706 || HARDWARE_BT6708
  288. /**
  289. * @brief Состояние релейного выхода
  290. */
  291. void GetDOUT2StatusStr(char *str, uint8_t *len);
  292. #endif
  293. #endif
  294. #if defined HARDWARE_BT6706 || HARDWARE_BT6708
  295. // ************************************************************************** //
  296. // Параметры Telnet
  297. /**
  298. * @brief Текущий Порт
  299. */
  300. void GetTelnetPortStr(char *str, uint8_t *len);
  301. /**
  302. * @brief Настройка вкл/ выкл Telnet сервера
  303. */
  304. void GetTelnetEnableStateStr(char *str, uint8_t *len);
  305. #endif
  306. // ************************************************************************** //
  307. // Флаги
  308. /**
  309. * @brief Установить признак изменения сетевых параметров
  310. */
  311. void GetWebReinitFlag(char *str, uint8_t *len);
  312. // ************************************************************************** //
  313. // Параметры настройки ИБП
  314. /**
  315. * @brief Минимальное напряжение на ячейках АКБ
  316. */
  317. void GetUPSVoltCellMinStr(char *str, uint8_t *len);
  318. /**
  319. * @brief Максимальное напряжение на ячейках АКБ
  320. */
  321. void GetUPSVoltCellMaxStr(char *str, uint8_t *len);
  322. // ************************************************************************** //
  323. // Установка параметрв
  324. // ************************************************************************** //
  325. /**
  326. * @brief Установить признак обновления ПО.
  327. */
  328. void SetLoadMode(void);
  329. /**
  330. * @brief Установить признак изменения сетевых параметров
  331. */
  332. void SetWebReinitFlag(bool value);
  333. /**
  334. * @brief Установить флаг подтверждения сетевых настроек пользователем
  335. */
  336. void SetConfirmWebParamsFlag(void);
  337. // ************************************************************************** //
  338. // Сетевые параметры
  339. /**
  340. * @brief IP адрес
  341. */
  342. void SetIPStr(char *str);
  343. /**
  344. * @brief Шлюз
  345. */
  346. void SetGatewayStr(char *str);
  347. /**
  348. * @brief Текущая маска подсети
  349. */
  350. void SetMaskStr(char *str);
  351. /**
  352. * @brief Настройка DHCP
  353. */
  354. void SetDhcpStateStr(char *str);
  355. /**
  356. * @brief Настройка DHCP
  357. */
  358. void SetUDPDhcpStateStr(char *str);
  359. #ifdef HARDWARE_BT6708
  360. // ************************************************************************** //
  361. // Параметры довверительных хостов
  362. /**
  363. * @brief диапазон доверительных хостов
  364. */
  365. void SetWhiteListSTR(char *str, uint8_t num);
  366. #endif
  367. // ************************************************************************** //
  368. // Параметры SNMP
  369. /**
  370. * @brief TRAP community
  371. */
  372. void SetTrapCommunity(char *str);
  373. /**
  374. * @brief Community для чтения
  375. */
  376. void SetReadCommunity(char *str);
  377. /**
  378. * @brief Community для записи
  379. */
  380. void SetWriteCommunity(char *str);
  381. /**
  382. * @brief IP SNMP менеджера
  383. */
  384. void SetManagerIp(char *str);
  385. void SetManagerIp2(char *str);
  386. void SetManagerIp3(char *str);
  387. void SetManagerIp4(char *str);
  388. void SetManagerIp5(char *str);
  389. /**
  390. * @brief Установить владельца
  391. */
  392. void SetOwner(char *str);
  393. /**
  394. * @brief Установить местоположение
  395. */
  396. void SetLocation(char *str);
  397. /**
  398. * @brief Установить комментарий
  399. */
  400. void SetComment(char *str);
  401. #ifdef HARDWARE_BT6702
  402. // ************************************************************************** //
  403. // Сетевые параметры RADIUS сервера
  404. /**
  405. * @brief IP адрес
  406. */
  407. void SetRDSIpStr(char *str);
  408. /**
  409. * @brief Порт
  410. */
  411. void SetRDSPortStr(char *str);
  412. /**
  413. * @brief Код access
  414. */
  415. void SetRDSKeyAccesstStr(char *str);
  416. /**
  417. * @brief пароль RADIUS
  418. */
  419. void SetRDSPasswordkStr(char *str);
  420. /**
  421. * @brief Настройка вкл/ выкл RADIUS сервера
  422. */
  423. void SetRDSEnableStateStr(char *str);
  424. /**
  425. * @brief Настройка вкл/ выкл авторизации
  426. */
  427. void SetAuthEnableStateStr(char *str);
  428. #endif
  429. #if defined HARDWARE_BT6706 || HARDWARE_BT6708
  430. // ************************************************************************** //
  431. // Параметры Telnet
  432. /**
  433. * @brief Текущий Порт
  434. */
  435. void SetTelnetPortStr(char *str);
  436. /**
  437. * @brief Настройка вкл/ выкл Telnet сервера
  438. */
  439. void SetTelnetEnableStateStr(char *str);
  440. #endif
  441. // ************************************************************************** //
  442. // Параметры даты и времени
  443. /**
  444. * @brief Дата
  445. */
  446. void SetDateStr(char *str);
  447. /**
  448. * @brief Время
  449. */
  450. void SetTimeStr(char *str);
  451. // ************************************************************************** //
  452. // Параметры SNTP
  453. /**
  454. * @brief Состояние SNTP
  455. */
  456. void SetSntpStateStr(char *str);
  457. /**
  458. * @brief IP адрес SNTP сервера
  459. */
  460. void SetSntpServerIpStr(char *str);
  461. /**
  462. * @brief Часовой пояс контроллера
  463. */
  464. void SetSntpTimeZoneStr(char *str);
  465. #ifndef HARDWARE_BT6708
  466. // ************************************************************************** //
  467. // Параметры реле/сухих контактов
  468. /**
  469. * @brief Тип действий при срабатывание сухих контактов
  470. */
  471. void SetDINTypeActStr(char *str, uint8_t num);
  472. /**
  473. * @brief Источник срабатывания реле
  474. */
  475. void SetROTypeActStr(char *str, uint8_t num);
  476. /**
  477. * @brief
  478. */
  479. void SetROStr(char *str, uint8_t num);
  480. /**
  481. * @brief
  482. */
  483. void SetROInt(uint8_t val, uint8_t num);
  484. #endif
  485. // ************************************************************************** //
  486. // Параметры настройки ИБП
  487. /**
  488. * @brief Минимальное напряжение на ячейках АКБ
  489. */
  490. void SetUPSVoltCellMinStr(char *str);
  491. /**
  492. * @brief Максимальное напряжение на ячейках АКБ
  493. */
  494. void SetUPSVoltCellMaxStr(char *str);
  495. #endif /* #ifndef PARAMETERS_H */
  496. /********************************* (C) РОТЕК **********************************/