mk_common.h 4.89 KB
Newer Older
1
/*
xiongziliang committed
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
 *
xiongziliang committed
6 7 8
 * Use of this source code is governed by MIT license that can be found in the
 * LICENSE file in the root of the source tree. All contributing project authors
 * may be found in the AUTHORS file in the root of the source tree.
9 10 11 12 13 14
 */

#ifndef MK_COMMON_H
#define MK_COMMON_H

#include <stdint.h>
15
#include <stddef.h>
16 17

#if defined(_WIN32)
18 19

#ifndef MediaKitApi_STATIC
20
#if defined(MediaKitApi_EXPORTS)
21 22 23 24
        #define API_EXPORT __declspec(dllexport)
    #else
        #define API_EXPORT __declspec(dllimport)
    #endif
25

26
    #define API_CALL __cdecl
27 28 29 30
#else
#define API_EXPORT
#define API_CALL
#endif
31 32 33 34 35 36 37 38 39 40

#else
#define API_EXPORT
#define API_CALL
#endif

#ifdef __cplusplus
extern "C" {
#endif

ziyue committed
41 42 43 44 45 46 47
//输出日志到shell
#define LOG_CONSOLE     (1 << 0)
//输出日志到文件
#define LOG_FILE        (1 << 1)
//输出日志到回调函数(mk_events::on_mk_log)
#define LOG_CALLBACK    (1 << 2)

48 49 50
typedef struct {
    // 线程数
    int thread_num;
xiongziliang committed
51

52 53
    // 日志级别,支持0~4
    int log_level;
ziyue committed
54 55
    //控制日志输出的掩模,请查看LOG_CONSOLE、LOG_FILE、LOG_CALLBACK等宏
    int log_mask;
xiongziliang committed
56 57 58 59
    //文件日志保存路径,路径可以不存在(内部可以创建文件夹),设置为NULL关闭日志输出至文件
    const char *log_file_path;
    //文件日志保存天数,设置为0关闭日志文件
    int log_file_days;
60 61 62

    // 配置文件是内容还是路径
    int ini_is_path;
63
    // 配置文件内容或路径,可以为NULL,如果该文件不存在,那么将导出默认配置至该文件
64 65 66 67 68 69 70 71
    const char *ini;

    // ssl证书是内容还是路径
    int ssl_is_path;
    // ssl证书内容或路径,可以为NULL
    const char *ssl;
    // 证书密码,可以为NULL
    const char *ssl_pwd;
xiongziliang committed
72
} mk_config;
73 74 75 76 77

/**
 * 初始化环境,调用该库前需要先调用此函数
 * @param cfg 库运行相关参数
 */
xiongziliang committed
78
API_EXPORT void API_CALL mk_env_init(const mk_config *cfg);
79 80

/**
81 82 83 84 85
 * 关闭所有服务器,请在main函数退出时调用
 */
API_EXPORT void API_CALL mk_stop_all_server();

/**
86
 * 基础类型参数版本的mk_env_init,为了方便其他语言调用
87 88
 * @param thread_num 线程数
 * @param log_level 日志级别,支持0~4
ziyue committed
89
 * @param log_mask 日志输出方式掩模,请查看LOG_CONSOLE、LOG_FILE、LOG_CALLBACK等宏
xiongziliang committed
90 91
 * @param log_file_path 文件日志保存路径,路径可以不存在(内部可以创建文件夹),设置为NULL关闭日志输出至文件
 * @param log_file_days 文件日志保存天数,设置为0关闭日志文件
92 93 94 95 96
 * @param ini_is_path 配置文件是内容还是路径
 * @param ini 配置文件内容或路径,可以为NULL,如果该文件不存在,那么将导出默认配置至该文件
 * @param ssl_is_path ssl证书是内容还是路径
 * @param ssl ssl证书内容或路径,可以为NULL
 * @param ssl_pwd 证书密码,可以为NULL
97
 */
xiongziliang committed
98 99
API_EXPORT void API_CALL mk_env_init1(int thread_num,
                                      int log_level,
ziyue committed
100
                                      int log_mask,
xiongziliang committed
101 102 103 104 105 106 107
                                      const char *log_file_path,
                                      int log_file_days,
                                      int ini_is_path,
                                      const char *ini,
                                      int ssl_is_path,
                                      const char *ssl,
                                      const char *ssl_pwd);
108 109

/**
110 111 112 113 114 115 116
 * 设置配置项
 * @param key 配置项名
 * @param val 配置项值
 */
API_EXPORT void API_CALL mk_set_option(const char *key, const char *val);

/**
117 118 119 120 121 122 123
 * 获取配置项的值
 * @param key 配置项名
 */
API_EXPORT const char * API_CALL mk_get_option(const char *key);


/**
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147
 * 创建http[s]服务器
 * @param port htt监听端口,推荐80,传入0则随机分配
 * @param ssl 是否为ssl类型服务器
 * @return 0:失败,非0:端口号
 */
API_EXPORT uint16_t API_CALL mk_http_server_start(uint16_t port, int ssl);

/**
 * 创建rtsp[s]服务器
 * @param port rtsp监听端口,推荐554,传入0则随机分配
 * @param ssl 是否为ssl类型服务器
 * @return 0:失败,非0:端口号
 */
API_EXPORT uint16_t API_CALL mk_rtsp_server_start(uint16_t port, int ssl);

/**
 * 创建rtmp[s]服务器
 * @param port rtmp监听端口,推荐1935,传入0则随机分配
 * @param ssl 是否为ssl类型服务器
 * @return 0:失败,非0:端口号
 */
API_EXPORT uint16_t API_CALL mk_rtmp_server_start(uint16_t port, int ssl);

/**
148 149 150 151 152
 * 创建rtp服务器
 * @param port rtp监听端口(包括udp/tcp)
 * @return 0:失败,非0:端口号
 */
API_EXPORT uint16_t API_CALL mk_rtp_server_start(uint16_t port);
xiongziliang committed
153 154 155 156 157 158 159

/**
 * 创建shell服务器
 * @param port shell监听端口
 * @return 0:失败,非0:端口号
 */
API_EXPORT uint16_t API_CALL mk_shell_server_start(uint16_t port);
160

161 162 163 164 165 166
#ifdef __cplusplus
}
#endif


#endif /* MK_COMMON_H */