2014-04-18 18:49:49 +00:00
|
|
|
// 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
|
|
|
|
|
|
|
|
#ifndef MEDIA_FORMATS_MP4_KEY_ROTATION_FRAGMENTER_H_
|
|
|
|
#define MEDIA_FORMATS_MP4_KEY_ROTATION_FRAGMENTER_H_
|
|
|
|
|
2014-08-20 23:51:15 +00:00
|
|
|
#include "media/base/key_source.h"
|
2014-05-08 20:53:08 +00:00
|
|
|
#include "media/formats/mp4/encrypting_fragmenter.h"
|
2014-04-18 18:49:49 +00:00
|
|
|
|
|
|
|
namespace media {
|
|
|
|
namespace mp4 {
|
|
|
|
|
2014-05-08 20:53:08 +00:00
|
|
|
struct MovieFragment;
|
|
|
|
|
|
|
|
/// KeyRotationFragmenter generates MP4 fragments with sample encrypted by
|
|
|
|
/// rotation keys.
|
|
|
|
class KeyRotationFragmenter : public EncryptingFragmenter {
|
2014-04-18 18:49:49 +00:00
|
|
|
public:
|
|
|
|
/// @param moof points to a MovieFragment box.
|
|
|
|
/// @param traf points to a TrackFragment box.
|
|
|
|
/// @param encryption_key_source points to the source which generates
|
|
|
|
/// encryption keys.
|
|
|
|
/// @param track_type indicates whether SD key or HD key should be used to
|
|
|
|
/// encrypt the video content.
|
|
|
|
/// @param crypto_period_duration specifies crypto period duration in units
|
|
|
|
/// of the current track's timescale.
|
|
|
|
/// @param clear_time specifies clear lead duration in units of the current
|
|
|
|
/// track's timescale.
|
|
|
|
/// @param nalu_length_size NAL unit length size, in bytes, for subsample
|
|
|
|
/// encryption.
|
|
|
|
KeyRotationFragmenter(MovieFragment* moof,
|
|
|
|
TrackFragment* traf,
|
2014-08-20 23:51:15 +00:00
|
|
|
KeySource* encryption_key_source,
|
|
|
|
KeySource::TrackType track_type,
|
2014-04-18 18:49:49 +00:00
|
|
|
int64 crypto_period_duration,
|
|
|
|
int64 clear_time,
|
|
|
|
uint8 nalu_length_size);
|
|
|
|
virtual ~KeyRotationFragmenter();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/// @name Fragmenter implementation overrides.
|
|
|
|
/// @{
|
2014-05-08 21:50:38 +00:00
|
|
|
virtual Status PrepareFragmentForEncryption(bool enable_encryption) OVERRIDE;
|
2014-04-18 18:49:49 +00:00
|
|
|
virtual void FinalizeFragmentForEncryption() OVERRIDE;
|
|
|
|
/// @}
|
|
|
|
|
|
|
|
private:
|
|
|
|
MovieFragment* moof_;
|
|
|
|
|
2014-08-20 23:51:15 +00:00
|
|
|
KeySource* encryption_key_source_;
|
|
|
|
KeySource::TrackType track_type_;
|
2014-04-18 18:49:49 +00:00
|
|
|
const int64 crypto_period_duration_;
|
|
|
|
size_t prev_crypto_period_index_;
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(KeyRotationFragmenter);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace mp4
|
|
|
|
} // namespace media
|
|
|
|
|
|
|
|
#endif // MEDIA_FORMATS_MP4_KEY_ROTATION_FRAGMENTER_H_
|