luat_socket_rtt.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #include "luat_socket.h"
  2. #include "luat_msgbus.h"
  3. #include "rtthread.h"
  4. #ifdef SAL_USING_POSIX
  5. #include <sys/socket.h>
  6. #include <netdb.h>
  7. #define SAL_TLS_HOST "site0.cn"
  8. #define SAL_TLS_PORT 80
  9. #define SAL_TLS_BUFSZ 1024
  10. #define DBG_TAG "luat.socket"
  11. #define DBG_LVL DBG_INFO
  12. #include <rtdbg.h>
  13. #ifdef PKG_NETUTILS_NTP
  14. #include "ntp.h"
  15. static int socket_ntp_handler(lua_State *L, void* ptr) {
  16. lua_getglobal(L, "sys_pub");
  17. if (!lua_isnil(L, -1)) {
  18. /*
  19. @sys_pub ntp
  20. NTP更新
  21. NTP_UPDATE
  22. @usage
  23. sys.taskInit(function()
  24. sys.waitUntil("NTP_UPDATE")
  25. end)
  26. */
  27. lua_pushstring(L, "NTP_UPDATE");
  28. lua_call(L, 1, 0);
  29. }
  30. // 给rtos.recv方法返回个空数据
  31. lua_pushinteger(L, 0);
  32. return 1;
  33. }
  34. static void ntp_thread(void* params) {
  35. time_t cur_time = ntp_sync_to_rtc((const char*)params);
  36. rtos_msg_t msg;
  37. msg.handler = socket_ntp_handler;
  38. msg.ptr = NULL;
  39. luat_msgbus_put(&msg, 1);
  40. LOG_D("ntp sync complete");
  41. }
  42. int luat_socket_ntp_sync(const char* hostname) {
  43. LOG_D("ntp sync : %s", hostname);
  44. rt_thread_t t = rt_thread_create("ntpdate", ntp_thread, (void*)hostname, 1536, 26, 2);
  45. if (t) {
  46. if (rt_thread_startup(t)) {
  47. return 2;
  48. }
  49. else {
  50. return 0;
  51. }
  52. }
  53. else {
  54. return 1;
  55. }
  56. return 1;
  57. }
  58. #else
  59. int l_socket_ntp_sync(const char* hostname) {
  60. return -1;
  61. }
  62. #endif
  63. int luat_socket_tsend(const char* hostname, int port, void* buff, int len)
  64. {
  65. int ret, i;
  66. // char *recv_data;
  67. struct hostent *host;
  68. int sock = -1, bytes_received;
  69. struct sockaddr_in server_addr;
  70. // 强制GC一次先
  71. //lua_gc(L, LUA_GCCOLLECT, 0);
  72. /* 通过函数入口参数url获得host地址(如果是域名,会做域名解析) */
  73. host = gethostbyname(hostname);
  74. /* 创建一个socket,类型是SOCKET_STREAM,TCP 协议, TLS 类型 */
  75. if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0)
  76. {
  77. rt_kprintf("Socket error\n");
  78. goto __exit;
  79. }
  80. /* 初始化预连接的服务端地址 */
  81. server_addr.sin_family = AF_INET;
  82. server_addr.sin_port = htons(port);
  83. server_addr.sin_addr = *((struct in_addr *)host->h_addr);
  84. rt_memset(&(server_addr.sin_zero), 0, sizeof(server_addr.sin_zero));
  85. if (connect(sock, (struct sockaddr *)&server_addr, sizeof(struct sockaddr)) < 0)
  86. {
  87. rt_kprintf("Connect fail!\n");
  88. goto __exit;
  89. }
  90. /* 发送数据到 socket 连接 */
  91. ret = send(sock, buff, len, 0);
  92. if (ret <= 0)
  93. {
  94. rt_kprintf("send error,close the socket.\n");
  95. goto __exit;
  96. }
  97. __exit:
  98. // if (recv_data)
  99. // rt_free(recv_data);
  100. if (sock >= 0)
  101. closesocket(sock);
  102. return 0;
  103. }
  104. #include <arpa/inet.h> /* 包含 ip_addr_t 等地址相关的头文件 */
  105. #include <netdev.h> /* 包含全部的 netdev 相关操作接口函数 */
  106. int luat_socket_is_ready(void) {
  107. struct netdev *net = RT_NULL;
  108. net = netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);
  109. if (net == RT_NULL)
  110. return 0;
  111. return 1;
  112. }
  113. uint32_t luat_socket_selfip(void) {
  114. struct netdev *net = netdev_get_first_by_flags(NETDEV_FLAG_INTERNET_UP);
  115. if (net == RT_NULL)
  116. return 0;
  117. return net->ip_addr.addr;
  118. }
  119. #endif