2022-08-26 15:44:59 +00:00
|
|
|
// Copyright 2017 Google LLC. All rights reserved.
|
2017-08-02 20:37:47 +00:00
|
|
|
//
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file or at
|
|
|
|
// https://developers.google.com/open-source/licenses/bsd
|
|
|
|
|
2023-10-14 16:36:01 +00:00
|
|
|
#ifndef PACKAGER_PUBLIC_HLS_PARAMS_H_
|
|
|
|
#define PACKAGER_PUBLIC_HLS_PARAMS_H_
|
2017-08-02 20:37:47 +00:00
|
|
|
|
2023-10-14 16:36:01 +00:00
|
|
|
#include <cstdint>
|
2017-08-02 20:37:47 +00:00
|
|
|
#include <string>
|
|
|
|
|
|
|
|
namespace shaka {
|
|
|
|
|
|
|
|
/// Defines the EXT-X-PLAYLIST-TYPE in the HLS specification. For
|
|
|
|
/// HlsPlaylistType of kLive, EXT-X-PLAYLIST-TYPE tag is omitted.
|
|
|
|
enum class HlsPlaylistType {
|
|
|
|
kVod,
|
|
|
|
kEvent,
|
|
|
|
kLive,
|
|
|
|
};
|
|
|
|
|
|
|
|
/// HLS related parameters.
|
|
|
|
struct HlsParams {
|
|
|
|
/// HLS playlist type. See HLS specification for details.
|
|
|
|
HlsPlaylistType playlist_type = HlsPlaylistType::kVod;
|
|
|
|
/// HLS master playlist output path.
|
|
|
|
std::string master_playlist_output;
|
|
|
|
/// The base URL for the Media Playlists and media files listed in the
|
|
|
|
/// playlists. This is the prefix for the files.
|
|
|
|
std::string base_url;
|
|
|
|
/// Defines the live window, or the guaranteed duration of the time shifting
|
|
|
|
/// buffer for 'live' playlists.
|
|
|
|
double time_shift_buffer_depth = 0;
|
2018-05-01 17:47:06 +00:00
|
|
|
/// Segments outside the live window (defined by 'time_shift_buffer_depth'
|
|
|
|
/// above) are automatically removed except for the most recent X segments
|
|
|
|
/// defined by this parameter. This is needed to accommodate latencies in
|
|
|
|
/// various stages of content serving pipeline, so that the segments stay
|
|
|
|
/// accessible as they may still be accessed by the player. The segments are
|
|
|
|
/// not removed if the value is zero.
|
2018-04-17 22:03:02 +00:00
|
|
|
size_t preserved_segments_outside_live_window = 0;
|
2017-11-12 22:56:25 +00:00
|
|
|
/// Defines the key uri for "identity" and "com.apple.streamingkeydelivery"
|
|
|
|
/// key formats. Ignored if the playlist is not encrypted or not using the
|
|
|
|
/// above key formats.
|
|
|
|
std::string key_uri;
|
2018-01-17 23:43:41 +00:00
|
|
|
/// The renditions tagged with this language will have 'DEFAULT' set to 'YES'
|
|
|
|
/// in 'EXT-X-MEDIA' tag. This allows the player to choose the correct default
|
|
|
|
/// language for the content.
|
2018-11-20 00:09:24 +00:00
|
|
|
/// This applies to both audio and text tracks. The default language for text
|
|
|
|
/// tracks can be overriden by 'default_text_language'.
|
2018-01-17 23:43:41 +00:00
|
|
|
std::string default_language;
|
2018-11-20 00:09:24 +00:00
|
|
|
/// Same as above, but this overrides the default language for text tracks,
|
|
|
|
/// i.e. subtitles or close-captions.
|
|
|
|
std::string default_text_language;
|
2020-08-19 18:17:21 +00:00
|
|
|
// Indicates that all media samples in the media segments can be decoded
|
|
|
|
// without information from other segments.
|
|
|
|
bool is_independent_segments;
|
2018-11-14 20:47:48 +00:00
|
|
|
/// This is the target segment duration requested by the user. The actual
|
2019-07-11 21:32:10 +00:00
|
|
|
/// segment duration may be different to the target segment duration. It will
|
2018-11-14 20:47:48 +00:00
|
|
|
/// be populated from segment duration specified in ChunkingParams if not
|
|
|
|
/// specified.
|
|
|
|
double target_segment_duration = 0;
|
2020-01-31 18:25:19 +00:00
|
|
|
/// Custom EXT-X-MEDIA-SEQUENCE value to allow continuous media playback
|
|
|
|
/// across packager restarts. See #691 for details.
|
|
|
|
uint32_t media_sequence_number = 0;
|
2017-08-02 20:37:47 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace shaka
|
|
|
|
|
2023-10-14 16:36:01 +00:00
|
|
|
#endif // PACKAGER_PUBLIC_HLS_PARAMS_H_
|