You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

205 line
6.2KB

  1. /*
  2. * Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
  3. *
  4. * This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
  5. *
  6. * Use of this source code is governed by MIT license that can be found in the
  7. * LICENSE file in the root of the source tree. All contributing project authors
  8. * may be found in the AUTHORS file in the root of the source tree.
  9. */
  10. #ifndef MK_COMMON_H
  11. #define MK_COMMON_H
  12. #include <stdint.h>
  13. #include <stddef.h>
  14. #if defined(GENERATE_EXPORT)
  15. #include "mk_export.h"
  16. #endif
  17. #if defined(_WIN32) && defined(_MSC_VER)
  18. # define API_CALL __cdecl
  19. #else
  20. # define API_CALL
  21. #endif
  22. #if defined(_WIN32) && defined(_MSC_VER)
  23. # if !defined(GENERATE_EXPORT)
  24. # if defined(MediaKitApi_EXPORTS)
  25. # define API_EXPORT __declspec(dllexport)
  26. # else
  27. # define API_EXPORT __declspec(dllimport)
  28. # endif
  29. # endif
  30. #elif !defined(GENERATE_EXPORT)
  31. # define API_EXPORT
  32. #endif
  33. #ifdef __cplusplus
  34. extern "C" {
  35. #endif
  36. //输出日志到shell
  37. #define LOG_CONSOLE (1 << 0)
  38. //输出日志到文件
  39. #define LOG_FILE (1 << 1)
  40. //输出日志到回调函数(mk_events::on_mk_log)
  41. #define LOG_CALLBACK (1 << 2)
  42. typedef struct {
  43. // 线程数
  44. int thread_num;
  45. // 日志级别,支持0~4
  46. int log_level;
  47. //控制日志输出的掩模,请查看LOG_CONSOLE、LOG_FILE、LOG_CALLBACK等宏
  48. int log_mask;
  49. //文件日志保存路径,路径可以不存在(内部可以创建文件夹),设置为NULL关闭日志输出至文件
  50. const char *log_file_path;
  51. //文件日志保存天数,设置为0关闭日志文件
  52. int log_file_days;
  53. // 配置文件是内容还是路径
  54. int ini_is_path;
  55. // 配置文件内容或路径,可以为NULL,如果该文件不存在,那么将导出默认配置至该文件
  56. const char *ini;
  57. // ssl证书是内容还是路径
  58. int ssl_is_path;
  59. // ssl证书内容或路径,可以为NULL
  60. const char *ssl;
  61. // 证书密码,可以为NULL
  62. const char *ssl_pwd;
  63. } mk_config;
  64. /**
  65. * 初始化环境,调用该库前需要先调用此函数
  66. * @param cfg 库运行相关参数
  67. */
  68. API_EXPORT void API_CALL mk_env_init(const mk_config *cfg);
  69. /**
  70. * 关闭所有服务器,请在main函数退出时调用
  71. */
  72. API_EXPORT void API_CALL mk_stop_all_server();
  73. /**
  74. * 基础类型参数版本的mk_env_init,为了方便其他语言调用
  75. * @param thread_num 线程数
  76. * @param log_level 日志级别,支持0~4
  77. * @param log_mask 日志输出方式掩模,请查看LOG_CONSOLE、LOG_FILE、LOG_CALLBACK等宏
  78. * @param log_file_path 文件日志保存路径,路径可以不存在(内部可以创建文件夹),设置为NULL关闭日志输出至文件
  79. * @param log_file_days 文件日志保存天数,设置为0关闭日志文件
  80. * @param ini_is_path 配置文件是内容还是路径
  81. * @param ini 配置文件内容或路径,可以为NULL,如果该文件不存在,那么将导出默认配置至该文件
  82. * @param ssl_is_path ssl证书是内容还是路径
  83. * @param ssl ssl证书内容或路径,可以为NULL
  84. * @param ssl_pwd 证书密码,可以为NULL
  85. */
  86. API_EXPORT void API_CALL mk_env_init1(int thread_num,
  87. int log_level,
  88. int log_mask,
  89. const char *log_file_path,
  90. int log_file_days,
  91. int ini_is_path,
  92. const char *ini,
  93. int ssl_is_path,
  94. const char *ssl,
  95. const char *ssl_pwd);
  96. /**
  97. * 设置日志文件
  98. * @param file_max_size 单个切片文件大小(MB)
  99. * @param file_max_count 切片文件个数
  100. */
  101. API_EXPORT void API_CALL mk_set_log(int file_max_size, int file_max_count);
  102. /**
  103. * 设置配置项
  104. * @param key 配置项名
  105. * @param val 配置项值
  106. */
  107. API_EXPORT void API_CALL mk_set_option(const char *key, const char *val);
  108. /**
  109. * 获取配置项的值
  110. * @param key 配置项名
  111. */
  112. API_EXPORT const char * API_CALL mk_get_option(const char *key);
  113. /**
  114. * 创建http[s]服务器
  115. * @param port htt监听端口,推荐80,传入0则随机分配
  116. * @param ssl 是否为ssl类型服务器
  117. * @return 0:失败,非0:端口号
  118. */
  119. API_EXPORT uint16_t API_CALL mk_http_server_start(uint16_t port, int ssl);
  120. /**
  121. * 创建rtsp[s]服务器
  122. * @param port rtsp监听端口,推荐554,传入0则随机分配
  123. * @param ssl 是否为ssl类型服务器
  124. * @return 0:失败,非0:端口号
  125. */
  126. API_EXPORT uint16_t API_CALL mk_rtsp_server_start(uint16_t port, int ssl);
  127. /**
  128. * 创建rtmp[s]服务器
  129. * @param port rtmp监听端口,推荐1935,传入0则随机分配
  130. * @param ssl 是否为ssl类型服务器
  131. * @return 0:失败,非0:端口号
  132. */
  133. API_EXPORT uint16_t API_CALL mk_rtmp_server_start(uint16_t port, int ssl);
  134. /**
  135. * 创建rtp服务器
  136. * @param port rtp监听端口(包括udp/tcp)
  137. * @return 0:失败,非0:端口号
  138. */
  139. API_EXPORT uint16_t API_CALL mk_rtp_server_start(uint16_t port);
  140. /**
  141. * 创建rtc服务器
  142. * @param port rtc监听端口
  143. * @return 0:失败,非0:端口号
  144. */
  145. API_EXPORT uint16_t API_CALL mk_rtc_server_start(uint16_t port);
  146. //获取webrtc answer sdp回调函数
  147. typedef void(API_CALL *on_mk_webrtc_get_answer_sdp)(void *user_data, const char *answer, const char *err);
  148. /**
  149. * webrtc交换sdp,根据offer sdp生成answer sdp
  150. * @param user_data 回调用户指针
  151. * @param cb 回调函数
  152. * @param type webrtc插件类型,支持echo,play,push
  153. * @param offer webrtc offer sdp
  154. * @param url rtc url, 例如 rtc://__defaultVhost/app/stream?key1=val1&key2=val2
  155. */
  156. API_EXPORT void API_CALL mk_webrtc_get_answer_sdp(void *user_data, on_mk_webrtc_get_answer_sdp cb, const char *type,
  157. const char *offer, const char *url);
  158. /**
  159. * 创建srt服务器
  160. * @param port srt监听端口
  161. * @return 0:失败,非0:端口号
  162. */
  163. API_EXPORT uint16_t API_CALL mk_srt_server_start(uint16_t port);
  164. /**
  165. * 创建shell服务器
  166. * @param port shell监听端口
  167. * @return 0:失败,非0:端口号
  168. */
  169. API_EXPORT uint16_t API_CALL mk_shell_server_start(uint16_t port);
  170. #ifdef __cplusplus
  171. }
  172. #endif
  173. #endif /* MK_COMMON_H */