69 lines
2.0 KiB
C++
69 lines
2.0 KiB
C++
// Copyright 2014 Google Inc. All rights reserved.
|
|
//
|
|
// 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
|
|
//
|
|
// Packager utility functions.
|
|
|
|
#ifndef PACKAGER_APP_PACKAGER_UTIL_H_
|
|
#define PACKAGER_APP_PACKAGER_UTIL_H_
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <memory>
|
|
|
|
#include "packager/media/base/fourccs.h"
|
|
|
|
DECLARE_bool(dump_stream_info);
|
|
|
|
namespace shaka {
|
|
|
|
struct MpdOptions;
|
|
|
|
namespace media {
|
|
|
|
class MediaHandler;
|
|
class KeySource;
|
|
class Status;
|
|
struct ChunkingOptions;
|
|
struct EncryptionOptions;
|
|
struct MuxerOptions;
|
|
|
|
/// Create KeySource based on provided command line options for content
|
|
/// encryption. Also fetches keys.
|
|
/// @param protection_scheme specifies the protection scheme to be used for
|
|
/// encryption.
|
|
/// @return A std::unique_ptr containing a new KeySource, or nullptr if
|
|
/// encryption is not required.
|
|
std::unique_ptr<KeySource> CreateEncryptionKeySource(FourCC protection_scheme);
|
|
|
|
/// Create KeySource based on provided command line options for content
|
|
/// decryption. Does not fetch keys.
|
|
/// @return A std::unique_ptr containing a new KeySource, or nullptr if
|
|
/// decryption is not required.
|
|
std::unique_ptr<KeySource> CreateDecryptionKeySource();
|
|
|
|
/// @return ChunkingOptions from provided command line options.
|
|
ChunkingOptions GetChunkingOptions();
|
|
|
|
/// @return EncryptionOptions from provided command line options.
|
|
EncryptionOptions GetEncryptionOptions();
|
|
|
|
/// @return MuxerOptions from provided command line options.
|
|
MuxerOptions GetMuxerOptions();
|
|
|
|
/// @return MpdOptions from provided command line options.
|
|
MpdOptions GetMpdOptions(bool on_demand_profile);
|
|
|
|
/// Connect handlers in the vector.
|
|
/// @param handlers A vector of media handlers to be conncected. the handlers
|
|
/// are chained from front() to back().
|
|
/// @return OK on success.
|
|
Status ConnectHandlers(std::vector<std::shared_ptr<MediaHandler>>& handlers);
|
|
|
|
} // namespace media
|
|
} // namespace shaka
|
|
|
|
#endif // PACKAGER_APP_PACKAGER_UTIL_H_
|