my_ssl_server.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. /*
  2. * ssl_server.h
  3. *
  4. * Created on: 08.11.2017
  5. * Author: balbekova
  6. */
  7. #ifndef MY_SSL_SERVER_H_
  8. #define MY_SSL_SERVER_H_
  9. #include "common_config.h"
  10. #include "lwip/opt.h"
  11. #include "lwip/arch.h"
  12. #include "lwip/api.h"
  13. #include "mbedtls/ssl.h"
  14. #ifdef SSL_SERVER_ENABLE
  15. #define HTTP_AUTH_ENABLE
  16. #define SSL_TASK_PRIO ( configMAX_PRIORITIES - 3 )
  17. #define FRAME_SIZE (1000)
  18. #define SEND_BUF_MAX_LEN 4000
  19. #define RECIVE_BUF_MAX_LEN 2000
  20. typedef enum
  21. {
  22. SSL_ACCEPT = 0,
  23. SSL_ERROR,
  24. SSL_CRITICAL_ERROR,
  25. SSL_HANDSHAKE,
  26. SSL_READ,
  27. SSL_PROCESSING,
  28. SSL_CLOSE,
  29. SSL_WRITE,
  30. SSL_WRITE_OK,
  31. SSL_WRITE_ERROR,
  32. } SSL_SERVER_STATE;
  33. typedef enum
  34. {
  35. ALL_ACCESS = 0,
  36. TIME_ACCESS
  37. } ACCESS_TYPE_t;
  38. typedef enum
  39. {
  40. COMMON_ANSWER = 0,
  41. PARAMETER_ANSWER,
  42. HISTORY_ANSWER,
  43. UPS_HISTORY_ANSWER
  44. } REQ_TYPE_SEND_t;
  45. typedef enum
  46. {
  47. SEND_REQUIRED_YES = 0,
  48. SEND_REQUIRED_NO,
  49. SEND_REQUIRED_FILE
  50. } REQ_TYPE_t;
  51. struct http_state
  52. {
  53. char *file;
  54. u32_t left;
  55. u32_t reqnum;
  56. void *locked;
  57. };
  58. struct fs_file {
  59. char *data;
  60. int len;
  61. };
  62. void HTTP_Init();
  63. /**
  64. * @brief Выводим запросы в консоль
  65. */
  66. void vTaskPrintHttp(void *pvParameters);
  67. /**
  68. * @brief Установка даты производства
  69. */
  70. void HTTP_Prodate(char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  71. /**
  72. * @brief Парсинг строки настроек
  73. */
  74. void HTTP_SetSettings(char *buf, uint16_t lenBuf);
  75. /**
  76. * @brief
  77. * @retval None
  78. */
  79. char *HTTP_GetSert(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  80. /**
  81. * @brief
  82. * @retval None
  83. */
  84. char *HTTP_Upload_Sert(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  85. /**
  86. * @brief
  87. */
  88. void HTTP_SetInfo(char *buf, uint16_t lenBuf);
  89. /**
  90. * @brief
  91. */
  92. char* HTTP_SetSettingsPage(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  93. /**
  94. * @brief
  95. */
  96. char* HTTP_SetInfoPage(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  97. #ifdef HTTP_AUTH_ENABLE
  98. /**
  99. * @brief
  100. */
  101. char* HTTP_LoginPage(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  102. /**
  103. * @brief
  104. */
  105. char* HTTP_LogoutPage(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  106. /**
  107. * @brief Смена пароля пользователя
  108. * @retval None
  109. */
  110. char *HTTP_ChangeUserPwd(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  111. #endif
  112. /**
  113. * @brief
  114. */
  115. char* HTTP_UpsHistoryPage(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  116. /**
  117. * @brief
  118. */
  119. char* HTTP_HistoryPage(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  120. /**
  121. * @brief
  122. */
  123. char* HTTP_Reset(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  124. /**
  125. * @brief
  126. */
  127. char* HTTP_Reboot(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  128. /**
  129. * @brief
  130. */
  131. char* HTTP_Confirm(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  132. /**
  133. * @brief Запуск/останов теста UPS
  134. */
  135. char* HTTP_UPSTest(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  136. /**
  137. * @brief Выклюение UPS
  138. */
  139. char* HTTP_UPSshutdown(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  140. char *HTTP_UPS_Serial(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  141. /**
  142. * @brief Проверка пароля для перехода в режим bootloader
  143. */
  144. char* HTTP_ConfirmBootPwd(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  145. /**
  146. * @brief Проверка пароля для входа в Web
  147. */
  148. int HTTP_ConfirmWebPwd(char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  149. void HTTP_LOGIN(char *bufOut, uint16_t *lenBufOut);
  150. /**
  151. * @brief
  152. */
  153. char* HTTP_GetRequest(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  154. /**
  155. * @brief
  156. */
  157. char* HTTP_NoFound(uint32_t reqNum, char *bufIn, char *bufOut, uint16_t lenBufIn, uint16_t *lenBufOut);
  158. /**
  159. * @brief
  160. */
  161. uint8_t GetParamValue(char *inStr, char *paramName, char *paramValue, uint8_t *paramLen);
  162. uint8_t GetCookieValue(char *inStr, char *paramName, char *paramValue, uint8_t *paramLen);
  163. /**
  164. * @brief
  165. * @retval None
  166. */
  167. uint8_t GetParamValueInEnd(char *inStr, char *paramName, char *paramValue, uint8_t *paramLen);
  168. void ClearParamString(char *inBuf);
  169. /**
  170. * @brief Замена символа в строке
  171. * @param *str - входная строка
  172. * @param sim1 - символ который надо заменить
  173. * @param sim2 - символ на который надо заменить
  174. */
  175. void HTTP_ReplaceSimbol(char *str, char sim1, char sim2);
  176. // -----------------------------------------------------------------------------
  177. //
  178. //
  179. // SSL тесты
  180. //
  181. //
  182. // -----------------------------------------------------------------------------
  183. #ifdef __cplusplus
  184. extern "C" {
  185. #endif
  186. /* Exported types ------------------------------------------------------------*/
  187. typedef struct
  188. {
  189. uint32_t State;
  190. }rng_state;
  191. void ssl_server(void *pvParameters);
  192. int RandVal(void* arg);
  193. void HTTP_SendHistory(void);
  194. void HTTP_SendLog(void);
  195. void HTTP_Init();
  196. void HTTPS_Init();
  197. int SSL_ReadRoutine(mbedtls_ssl_context *ssl, unsigned char* recvBuf);
  198. char* SSL_ProcessingRoutine(uint16_t* sendLen);
  199. SSL_SERVER_STATE SSL_WriteRoutine(mbedtls_ssl_context *ssl, char *data, int datalen);
  200. SSL_SERVER_STATE SSL_SendFrames(mbedtls_ssl_context *ssl, char *data, int datalen);
  201. SSL_SERVER_STATE SSL_Write(mbedtls_ssl_context *ssl, char *data, int datalen);
  202. #ifdef __cplusplus
  203. }
  204. #endif
  205. #endif
  206. #endif /* SSL_SERVER_H_ */