rtmp_sys.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. #ifndef __RTMP_SYS_H__
  2. #define __RTMP_SYS_H__
  3. /*
  4. * Copyright (C) 2010 Howard Chu
  5. *
  6. * This file is part of librtmp.
  7. *
  8. * librtmp is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU Lesser General Public License as
  10. * published by the Free Software Foundation; either version 2.1,
  11. * or (at your option) any later version.
  12. *
  13. * librtmp is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public License
  19. * along with librtmp see the file COPYING. If not, write to
  20. * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
  21. * Boston, MA 02110-1301, USA.
  22. * http://www.gnu.org/copyleft/lgpl.html
  23. */
  24. #include <stdio.h>
  25. #include <stdlib.h>
  26. #include <string.h>
  27. #include <assert.h>
  28. #include <ctype.h>
  29. #include <stddef.h>
  30. #include <errno.h>
  31. #include <stdarg.h>
  32. #include <limits.h>
  33. #include <time.h>
  34. #include <stdint.h>
  35. #ifdef _WIN32
  36. #include <winsock2.h>
  37. #include <ws2tcpip.h>
  38. #ifdef _MSC_VER /* MSVC */
  39. #define snprintf _snprintf
  40. #define strcasecmp stricmp
  41. #define strncasecmp strnicmp
  42. #define vsnprintf _vsnprintf
  43. #endif
  44. #define GetSockError() WSAGetLastError()
  45. #define SetSockError(e) WSASetLastError(e)
  46. #define setsockopt(a,b,c,d,e) (setsockopt)(a,b,c,(const char *)d,(int)e)
  47. #ifdef EWOULDBLOCK
  48. #undef EWOULDBLOCK
  49. #endif
  50. #define EWOULDBLOCK WSAETIMEDOUT /* we don't use nonblocking, but we do use timeouts */
  51. #define sleep(n) Sleep(n*1000)
  52. #define msleep(n) Sleep(n)
  53. #define SET_RCVTIMEO(tv,s) int tv = s*1000
  54. #else /* !_WIN32 */
  55. #include <sys/types.h>
  56. #include <sys/socket.h>
  57. #include <sys/times.h>
  58. #include <netdb.h>
  59. #include <unistd.h>
  60. #include <netinet/in.h>
  61. #include <netinet/tcp.h>
  62. #include <arpa/inet.h>
  63. #define GetSockError() errno
  64. #define SetSockError(e) errno = e
  65. #undef closesocket
  66. #define closesocket(s) close(s)
  67. #define msleep(n) usleep(n*1000)
  68. #define SET_RCVTIMEO(tv,s) struct timeval tv = {s,0}
  69. #endif
  70. #include "rtmp.h"
  71. #ifdef USE_POLARSSL
  72. #include <polarssl/version.h>
  73. #include <polarssl/net.h>
  74. #include <polarssl/ssl.h>
  75. #include <polarssl/havege.h>
  76. #if POLARSSL_VERSION_NUMBER < 0x01010000
  77. #define havege_random havege_rand
  78. #endif
  79. #if POLARSSL_VERSION_NUMBER >= 0x01020000
  80. #define SSL_SET_SESSION(S,resume,timeout,ctx) ssl_set_session(S,ctx)
  81. #else
  82. #define SSL_SET_SESSION(S,resume,timeout,ctx) ssl_set_session(S,resume,timeout,ctx)
  83. #endif
  84. typedef struct tls_ctx
  85. {
  86. havege_state hs;
  87. ssl_session ssn;
  88. } tls_ctx;
  89. typedef struct tls_server_ctx
  90. {
  91. havege_state *hs;
  92. x509_cert cert;
  93. rsa_context key;
  94. ssl_session ssn;
  95. const char *dhm_P, *dhm_G;
  96. } tls_server_ctx;
  97. #define TLS_CTX tls_ctx *
  98. #define TLS_client(ctx,s) s = malloc(sizeof(ssl_context)); ssl_init(s);\
  99. ssl_set_endpoint(s, SSL_IS_CLIENT); ssl_set_authmode(s, SSL_VERIFY_NONE);\
  100. ssl_set_rng(s, havege_random, &ctx->hs);\
  101. ssl_set_ciphersuites(s, ssl_default_ciphersuites);\
  102. SSL_SET_SESSION(s, 1, 600, &ctx->ssn)
  103. #define TLS_server(ctx,s) s = malloc(sizeof(ssl_context)); ssl_init(s);\
  104. ssl_set_endpoint(s, SSL_IS_SERVER); ssl_set_authmode(s, SSL_VERIFY_NONE);\
  105. ssl_set_rng(s, havege_random, ((tls_server_ctx*)ctx)->hs);\
  106. ssl_set_ciphersuites(s, ssl_default_ciphersuites);\
  107. SSL_SET_SESSION(s, 1, 600, &((tls_server_ctx*)ctx)->ssn);\
  108. ssl_set_own_cert(s, &((tls_server_ctx*)ctx)->cert, &((tls_server_ctx*)ctx)->key);\
  109. ssl_set_dh_param(s, ((tls_server_ctx*)ctx)->dhm_P, ((tls_server_ctx*)ctx)->dhm_G)
  110. #define TLS_setfd(s,fd) ssl_set_bio(s, net_recv, &fd, net_send, &fd)
  111. #define TLS_connect(s) ssl_handshake(s)
  112. #define TLS_accept(s) ssl_handshake(s)
  113. #define TLS_read(s,b,l) ssl_read(s,(unsigned char *)b,l)
  114. #define TLS_write(s,b,l) ssl_write(s,(unsigned char *)b,l)
  115. #define TLS_shutdown(s) ssl_close_notify(s)
  116. #define TLS_close(s) ssl_free(s); free(s)
  117. #elif defined(USE_GNUTLS)
  118. #include <gnutls/gnutls.h>
  119. typedef struct tls_ctx
  120. {
  121. gnutls_certificate_credentials_t cred;
  122. gnutls_priority_t prios;
  123. } tls_ctx;
  124. #define TLS_CTX tls_ctx *
  125. #define TLS_client(ctx,s) gnutls_init((gnutls_session_t *)(&s), GNUTLS_CLIENT); gnutls_priority_set(s, ctx->prios); gnutls_credentials_set(s, GNUTLS_CRD_CERTIFICATE, ctx->cred)
  126. #define TLS_server(ctx,s) gnutls_init((gnutls_session_t *)(&s), GNUTLS_SERVER); gnutls_priority_set_direct(s, "NORMAL", NULL); gnutls_credentials_set(s, GNUTLS_CRD_CERTIFICATE, ctx)
  127. #define TLS_setfd(s,fd) gnutls_transport_set_ptr(s, (gnutls_transport_ptr_t)(long)fd)
  128. #define TLS_connect(s) gnutls_handshake(s)
  129. #define TLS_accept(s) gnutls_handshake(s)
  130. #define TLS_read(s,b,l) gnutls_record_recv(s,b,l)
  131. #define TLS_write(s,b,l) gnutls_record_send(s,b,l)
  132. #define TLS_shutdown(s) gnutls_bye(s, GNUTLS_SHUT_RDWR)
  133. #define TLS_close(s) gnutls_deinit(s)
  134. #elif defined(USE_ONLY_MD5)
  135. #include "md5.h"
  136. #include "cencode.h"
  137. #define MD5_DIGEST_LENGTH 16
  138. #else /* USE_OPENSSL */
  139. #define TLS_CTX SSL_CTX *
  140. #define TLS_client(ctx,s) s = SSL_new(ctx)
  141. #define TLS_server(ctx,s) s = SSL_new(ctx)
  142. #define TLS_setfd(s,fd) SSL_set_fd(s,fd)
  143. #define TLS_connect(s) SSL_connect(s)
  144. #define TLS_accept(s) SSL_accept(s)
  145. #define TLS_read(s,b,l) SSL_read(s,b,l)
  146. #define TLS_write(s,b,l) SSL_write(s,b,l)
  147. #define TLS_shutdown(s) SSL_shutdown(s)
  148. #define TLS_close(s) SSL_free(s)
  149. #endif
  150. #endif