2019-08-08 19:01:45 +08:00
|
|
|
|
/*
|
2023-12-09 16:23:51 +08:00
|
|
|
|
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
|
2019-04-01 12:57:33 +08:00
|
|
|
|
*
|
2023-12-09 16:23:51 +08:00
|
|
|
|
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
|
2019-04-01 12:57:33 +08:00
|
|
|
|
*
|
2023-12-09 16:23:51 +08:00
|
|
|
|
* Use of this source code is governed by MIT-like license that can be found in the
|
2020-04-04 20:30:09 +08:00
|
|
|
|
* 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.
|
2019-04-01 12:57:33 +08:00
|
|
|
|
*/
|
|
|
|
|
|
2019-12-04 10:45:38 +08:00
|
|
|
|
#ifndef SRC_MEDIAFILE_RECORDER_H_
|
|
|
|
|
#define SRC_MEDIAFILE_RECORDER_H_
|
2022-11-12 23:54:35 +08:00
|
|
|
|
|
2019-12-04 10:45:38 +08:00
|
|
|
|
#include <memory>
|
|
|
|
|
#include <string>
|
2022-02-02 20:34:50 +08:00
|
|
|
|
|
2019-04-01 12:57:33 +08:00
|
|
|
|
namespace mediakit {
|
2019-12-04 10:45:38 +08:00
|
|
|
|
class MediaSinkInterface;
|
2022-11-12 23:54:35 +08:00
|
|
|
|
class ProtocolOption;
|
2019-12-04 10:45:38 +08:00
|
|
|
|
|
2023-05-25 16:23:24 +08:00
|
|
|
|
struct MediaTuple {
|
|
|
|
|
std::string vhost;
|
|
|
|
|
std::string app;
|
|
|
|
|
std::string stream;
|
|
|
|
|
std::string shortUrl() const {
|
|
|
|
|
return vhost + '/' + app + '/' + stream;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class RecordInfo: public MediaTuple {
|
2020-09-20 11:40:42 +08:00
|
|
|
|
public:
|
|
|
|
|
time_t start_time; // GMT 标准时间,单位秒
|
|
|
|
|
float time_len; // 录像长度,单位秒
|
|
|
|
|
off_t file_size; // 文件大小,单位 BYTE
|
2022-02-02 20:34:50 +08:00
|
|
|
|
std::string file_path; // 文件路径
|
|
|
|
|
std::string file_name; // 文件名称
|
|
|
|
|
std::string folder; // 文件夹路径
|
|
|
|
|
std::string url; // 播放路径
|
2020-09-20 11:40:42 +08:00
|
|
|
|
};
|
|
|
|
|
|
2019-12-04 10:45:38 +08:00
|
|
|
|
class Recorder{
|
2019-04-01 12:57:33 +08:00
|
|
|
|
public:
|
2020-03-20 11:51:24 +08:00
|
|
|
|
typedef enum {
|
|
|
|
|
// 录制hls
|
|
|
|
|
type_hls = 0,
|
|
|
|
|
// 录制MP4
|
2023-07-02 12:02:33 +08:00
|
|
|
|
type_mp4 = 1,
|
|
|
|
|
// 录制hls.fmp4
|
|
|
|
|
type_hls_fmp4 = 2,
|
|
|
|
|
// fmp4直播
|
|
|
|
|
type_fmp4 = 3,
|
|
|
|
|
// ts直播
|
|
|
|
|
type_ts = 4,
|
2020-03-20 11:51:24 +08:00
|
|
|
|
} type;
|
2019-12-04 18:36:30 +08:00
|
|
|
|
|
2020-03-20 11:51:24 +08:00
|
|
|
|
/**
|
|
|
|
|
* 获取录制文件绝对路径
|
|
|
|
|
* @param type hls还是MP4录制
|
2020-02-01 22:58:58 +08:00
|
|
|
|
* @param vhost 虚拟主机
|
|
|
|
|
* @param app 应用名
|
|
|
|
|
* @param stream_id 流id
|
2020-10-01 14:55:34 +08:00
|
|
|
|
* @param customized_path 录像文件保存自定义根目录,为空则采用配置文件设置
|
2020-03-20 11:51:24 +08:00
|
|
|
|
* @return 录制文件绝对路径
|
|
|
|
|
*/
|
2023-05-25 16:23:24 +08:00
|
|
|
|
static std::string getRecordPath(type type, const MediaTuple& tuple, const std::string &customized_path = "");
|
2020-02-01 22:58:58 +08:00
|
|
|
|
|
2020-03-20 11:51:24 +08:00
|
|
|
|
/**
|
|
|
|
|
* 创建录制器对象
|
|
|
|
|
* @param type hls还是MP4录制
|
2020-02-01 22:58:58 +08:00
|
|
|
|
* @param vhost 虚拟主机
|
|
|
|
|
* @param app 应用名
|
|
|
|
|
* @param stream_id 流id
|
2020-10-01 14:55:34 +08:00
|
|
|
|
* @param customized_path 录像文件保存自定义根目录,为空则采用配置文件设置
|
2021-03-07 10:41:57 +08:00
|
|
|
|
* @param max_second mp4录制最大切片时间,单位秒,置0则采用配置文件配置
|
2020-03-20 11:51:24 +08:00
|
|
|
|
* @return 对象指针,可能为nullptr
|
|
|
|
|
*/
|
2023-05-25 16:23:24 +08:00
|
|
|
|
static std::shared_ptr<MediaSinkInterface> createRecorder(type type, const MediaTuple& tuple, const ProtocolOption &option);
|
2020-04-05 09:26:29 +08:00
|
|
|
|
|
2019-12-04 10:45:38 +08:00
|
|
|
|
private:
|
2020-03-20 11:51:24 +08:00
|
|
|
|
Recorder() = delete;
|
|
|
|
|
~Recorder() = delete;
|
2019-04-01 12:57:33 +08:00
|
|
|
|
};
|
|
|
|
|
|
2019-12-04 10:45:38 +08:00
|
|
|
|
} /* namespace mediakit */
|
|
|
|
|
#endif /* SRC_MEDIAFILE_RECORDER_H_ */
|