def _get_sample_muxing(self): stream = self._get_sample_stream() create_stream_response = self.bitmovin.encodings.Stream.create(object_=stream, encoding_id=self.sampleEncoding.id) self.assertIsNotNone(create_stream_response) self.assertIsNotNone(create_stream_response.resource) self.assertIsNotNone(create_stream_response.resource.id) muxing_stream = MuxingStream(stream_id=create_stream_response.resource.id) muxing = TSMuxing(streams=[muxing_stream], segment_length=4, segment_naming='seg_%number%.ts', outputs=stream.outputs, name='Sample TSMuxing') return muxing
def make_ts_muxing(bitmovin, encoding, stream, output, muxing_output_path): """ Makes a TS muxing. """ acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) muxing_stream = MuxingStream(stream.id) muxing_output = EncodingOutput(output_id=output.id, output_path=muxing_output_path, acl=[acl_entry]) ts_muxing = TSMuxing(segment_length=4, segment_naming='segment_%number%.ts', streams=[muxing_stream], outputs=[muxing_output]) return bitmovin.encodings.Muxing.TS.create( object_=ts_muxing, encoding_id=encoding.id).resource
def main(): bitmovin = Bitmovin(api_key=API_KEY) # Create an S3 input. This resource is then used as base bucket for the input file. s3_input = S3Input(access_key=S3_INPUT_ACCESSKEY, secret_key=S3_INPUT_SECRETKEY, bucket_name=S3_INPUT_BUCKETNAME, name='S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource # Create an S3 Output. This will be used as target bucket for the muxings, sprites and manifests s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource # Create an Encoding. This will run in AWS_EU_WEST_1. This is the base entity used to configure the encoding. encoding = Encoding(name='Encoding with video/audio and stream condition', cloud_region=CloudRegion.AWS_EU_WEST_1) encoding = bitmovin.encodings.Encoding.create(encoding).resource encoding_configs = [] # Iterate over all encoding profiles and create the H264 configuration with the defined height and bitrate. for idx, _ in enumerate(encoding_profiles_h264): profile_h264 = encoding_profiles_h264[idx] encoding_config = dict(profile_h264=profile_h264) h264_codec_height = H264CodecConfiguration( name='H264 Codec {}p {}k Configuration'.format(profile_h264.get('height'), profile_h264.get('bitrate')), bitrate=profile_h264.get('bitrate') * 1000, height=profile_h264.get('height'), profile=profile_h264.get('profile'), rate=profile_h264.get("fps")) encoding_config['h264_codec_ar_gt_1'] = bitmovin.codecConfigurations.H264.create(h264_codec_height).resource h264_codec_height_landscape = H264CodecConfiguration( name='H264 Codec {}p {}k Configuration'.format(profile_h264.get('height'), profile_h264.get('bitrate')), bitrate=profile_h264.get('bitrate') * 1000, height=profile_h264.get('height_landscape'), profile=profile_h264.get('profile'), rate=profile_h264.get("fps")) encoding_config['h264_codec_ar_lt_1'] = bitmovin.codecConfigurations.H264.create(h264_codec_height_landscape).resource encoding_configs.append(encoding_config) # Also the AAC configuration has to be created, which will be later on used to create the streams. audio_codec_configuration = AACCodecConfiguration(name='AAC Codec Configuration', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create(audio_codec_configuration).resource video_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.VIDEO_RELATIVE, position=0) audio_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUDIO_RELATIVE, position=0) # With the configurations and the input file streams are now created and muxed later on. for encoding_config in encoding_configs: encoding_profile = encoding_config.get("profile_h264") video_stream_condition_ar_gt_1 = Condition(attribute="ASPECTRATIO", operator=">=", value="1") video_stream_h264 = Stream(codec_configuration_id=encoding_config.get("h264_codec_ar_gt_1").id, input_streams=[video_input_stream], conditions=video_stream_condition_ar_gt_1, name='Stream H264 {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_stream_ar_gt_1'] = bitmovin.encodings.Stream.create(object_=video_stream_h264, encoding_id=encoding.id).resource video_stream_condition_ar_lt_1 = Condition(attribute="ASPECTRATIO", operator="<", value="1") video_stream_h264 = Stream(codec_configuration_id=encoding_config.get("h264_codec_ar_lt_1").id, input_streams=[video_input_stream], conditions=video_stream_condition_ar_lt_1, name='Stream H264 {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_stream_ar_lt_1'] = bitmovin.encodings.Stream.create(object_=video_stream_h264, encoding_id=encoding.id).resource audio_stream_condition = Condition(attribute="INPUTSTREAM", operator="==", value="TRUE") audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], conditions=audio_stream_condition, name='Audio Stream') audio_stream = bitmovin.encodings.Stream.create(object_=audio_stream, encoding_id=encoding.id).resource acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) # Create FMP4 muxings which are later used for the DASH manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get("profile_h264") video_muxing_stream_h264_ar_gt_1 = MuxingStream(encoding_config.get("h264_stream_ar_gt_1").id) video_muxing_output_h264 = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/h264/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing_h264_ar_gt_1 = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream_h264_ar_gt_1], outputs=[video_muxing_output_h264], name='FMP4 H264 Muxing {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_muxing_ar_gt_1'] = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing_h264_ar_gt_1, encoding_id=encoding.id).resource video_ts_muxing_output_h264 = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/h264/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_ts_muxing_h264_ar_gt_1 = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_h264_ar_gt_1], outputs=[video_ts_muxing_output_h264], name='FMP4 H264 Muxing {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_ts_muxing_ar_gt_1'] = bitmovin.encodings.Muxing.TS.create( object_=video_ts_muxing_h264_ar_gt_1, encoding_id=encoding.id).resource video_muxing_stream_h264_ar_lt_1 = MuxingStream(encoding_config.get("h264_stream_ar_lt_1").id) video_muxing_output_h264 = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/h264/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing_h264_ar_lt_1 = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream_h264_ar_lt_1], outputs=[video_muxing_output_h264], name='FMP4 H264 Muxing {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_muxing_ar_lt_1'] = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing_h264_ar_lt_1, encoding_id=encoding.id).resource video_ts_muxing_output_h264 = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/h264/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_ts_muxing_h264_ar_lt_1 = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_h264_ar_lt_1], outputs=[video_ts_muxing_output_h264], name='FMP4 H264 Muxing {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_ts_muxing_ar_lt_1'] = bitmovin.encodings.Muxing.TS.create( object_=video_ts_muxing_h264_ar_lt_1, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) # mp4 audio muxing audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + "audio/dash/", acl=[acl_entry]) audio_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio Dash Muxing') audio_muxing = bitmovin.encodings.Muxing.FMP4.create(object_=audio_muxing, encoding_id=encoding.id).resource # TS audio muxing hls_audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + "audio/hls/", acl=[acl_entry]) hls_audio_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], outputs=[hls_audio_muxing_output], name='Audio TS Muxing') hls_audio_muxing = bitmovin.encodings.Muxing.TS.create(object_=hls_audio_muxing, encoding_id=encoding.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding.id) try: bitmovin.encodings.Encoding.wait_until_finished(encoding_id=encoding.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for encoding to finish:") pprint(bitmovin_error) exit(-1) # Specify the output for manifest which will be in the OUTPUT_BASE_PATH. manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) # Create a DASH H264 manifest and add one period with an adaptation set for audio and video dash_manifest_h264 = DashManifest(manifest_name='stream.mpd', outputs=[manifest_output], name='DASH H264 Manifest') dash_manifest_h264 = bitmovin.manifests.DASH.create(dash_manifest_h264).resource period_h264 = Period() period_h264 = bitmovin.manifests.DASH.add_period(object_=period_h264, manifest_id=dash_manifest_h264.id).resource video_adaptation_set_h264 = VideoAdaptationSet() video_adaptation_set_h264 = bitmovin.manifests.DASH.add_video_adaptation_set(object_=video_adaptation_set_h264, manifest_id=dash_manifest_h264.id, period_id=period_h264.id).resource audio_adaptation_set_h264 = AudioAdaptationSet(lang='en') audio_adaptation_set_h264 = bitmovin.manifests.DASH.add_audio_adaptation_set(object_=audio_adaptation_set_h264, manifest_id=dash_manifest_h264.id, period_id=period_h264.id).resource fmp4_representation_audio = FMP4Representation(FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_muxing.id, segment_path="audio/dash/") bitmovin.manifests.DASH.add_fmp4_representation(object_=fmp4_representation_audio, manifest_id=dash_manifest_h264.id, period_id=period_h264.id, adaptationset_id=audio_adaptation_set_h264.id) # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get("profile_h264") h264_muxing_ar_gt_1 = encoding_config.get('h264_muxing_ar_gt_1') fmp4_representation = FMP4Representation(FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=h264_muxing_ar_gt_1.id, segment_path='video/h264/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_dash'] = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation, manifest_id=dash_manifest_h264.id, period_id=period_h264.id, adaptationset_id=video_adaptation_set_h264.id ).resource h264_muxing_ar_lt_1 = encoding_config.get('h264_muxing_ar_lt_1') fmp4_representation = FMP4Representation(FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=h264_muxing_ar_lt_1.id, segment_path='video/h264/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_dash'] = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation, manifest_id=dash_manifest_h264.id, period_id=period_h264.id, adaptationset_id=video_adaptation_set_h264.id ).resource bitmovin.manifests.DASH.start(manifest_id=dash_manifest_h264.id) # Create a HLS H264 manifest and add one period with an adaptation set for audio and video hls_manifest = HlsManifest(manifest_name='stream.m3u8', outputs=[manifest_output], name='HLS H264 Manifest') hls_manifest = bitmovin.manifests.HLS.create(object_=hls_manifest).resource hls_audio_media = AudioMedia(name='en', group_id='audio_group', segment_path="audio/hls/", encoding_id=encoding.id, stream_id=audio_stream.id, muxing_id=hls_audio_muxing.id, language='en', uri="audio.m3u8") bitmovin.manifests.HLS.AudioMedia.create(manifest_id=hls_manifest.id, object_=hls_audio_media) # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get("profile_h264") video_muxing_stream_h264_ar_gt_1 = encoding_config.get("h264_stream_ar_gt_1") ts_muxing_ar_gt_1 = encoding_config.get('h264_ts_muxing_ar_gt_1') # append another variant stream for this video quality to our hls renditions. hls_variant_stream = VariantStream(audio="audio_group", segment_path='video/h264/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), uri='video_{}p_{}.m3u8'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), encoding_id=encoding.id, stream_id=video_muxing_stream_h264_ar_gt_1.id, muxing_id=ts_muxing_ar_gt_1.id) bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=hls_variant_stream) video_muxing_stream_h264_ar_lt_1 = encoding_config.get("h264_stream_ar_lt_1") ts_muxing_ar_lt_1 = encoding_config.get('h264_ts_muxing_ar_lt_1') # append another variant stream for this video quality to our hls renditions. hls_variant_stream = VariantStream(audio="audio_group", segment_path='video/h264/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), uri='video_{}p_{}.m3u8'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), encoding_id=encoding.id, stream_id=video_muxing_stream_h264_ar_lt_1.id, muxing_id=ts_muxing_ar_lt_1.id) bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=hls_variant_stream) bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) try: bitmovin.manifests.DASH.wait_until_finished(manifest_id=dash_manifest_h264.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for manifest creation to finish: {}".format(bitmovin_error)) exit(-1) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for manifest creation to finish: {}".format(bitmovin_error)) exit(-1)
def main(): bitmovin = Bitmovin(api_key=API_KEY) s3_input = S3Input(access_key=S3_INPUT_ACCESSKEY, secret_key=S3_INPUT_SECRETKEY, bucket_name=S3_INPUT_BUCKETNAME, name='Sample S3 Output') s3_input = bitmovin.inputs.S3.create(s3_input).resource s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='Sample S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource encoding = Encoding(name='hls fairplay example encoding - {}'.format(date_component)) encoding = bitmovin.encodings.Encoding.create(encoding).resource video_codec_configuration_480p = H264CodecConfiguration(name='example_video_codec_configuration_480p', bitrate=1200000, rate=None, height=480, profile=H264Profile.HIGH) video_codec_configuration_480p = bitmovin.codecConfigurations.H264.create(video_codec_configuration_480p).resource video_codec_configuration_360p = H264CodecConfiguration(name='example_video_codec_configuration_360p', bitrate=800000, rate=None, height=360, profile=H264Profile.HIGH) video_codec_configuration_360p = bitmovin.codecConfigurations.H264.create(video_codec_configuration_360p).resource video_codec_configuration_240p = H264CodecConfiguration(name='example_video_codec_configuration_240p', bitrate=400000, rate=None, height=240, profile=H264Profile.HIGH) video_codec_configuration_240p = bitmovin.codecConfigurations.H264.create(video_codec_configuration_240p).resource audio_codec_configuration_stereo = AACCodecConfiguration(name='example_audio_codec_configuration_stereo', bitrate=128000, rate=48000) audio_codec_configuration_stereo = bitmovin.codecConfigurations.AAC.create( audio_codec_configuration_stereo).resource video_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUTO) audio_input_stream_en_stereo = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUTO) video_stream_480p = Stream(codec_configuration_id=video_codec_configuration_480p.id, input_streams=[video_input_stream], name='Sample Stream 480p') video_stream_480p = bitmovin.encodings.Stream.create(object_=video_stream_480p, encoding_id=encoding.id).resource video_stream_360p = Stream(codec_configuration_id=video_codec_configuration_360p.id, input_streams=[video_input_stream], name='Sample Stream 360p') video_stream_360p = bitmovin.encodings.Stream.create(object_=video_stream_360p, encoding_id=encoding.id).resource video_stream_240p = Stream(codec_configuration_id=video_codec_configuration_240p.id, input_streams=[video_input_stream], name='Sample Stream 240p') video_stream_240p = bitmovin.encodings.Stream.create(object_=video_stream_240p, encoding_id=encoding.id).resource audio_stream_en_stereo = Stream(codec_configuration_id=audio_codec_configuration_stereo.id, input_streams=[audio_input_stream_en_stereo], name='Sample Audio Stream EN Stereo') audio_stream_en_stereo = bitmovin.encodings.Stream.create(object_=audio_stream_en_stereo, encoding_id=encoding.id).resource acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) video_muxing_stream_480p = MuxingStream(video_stream_480p.id) video_muxing_stream_360p = MuxingStream(video_stream_360p.id) video_muxing_stream_240p = MuxingStream(video_stream_240p.id) audio_muxing_stream_en_stereo = MuxingStream(audio_stream_en_stereo.id) video_muxing_480p_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/480p', acl=[acl_entry]) video_muxing_480p = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_480p], name='Sample Muxing 480p') video_muxing_480p = bitmovin.encodings.Muxing.TS.create(object_=video_muxing_480p, encoding_id=encoding.id).resource fair_play_480p = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_480p_output], name='FairPlay 480p') fair_play_480p = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_480p, encoding_id=encoding.id, muxing_id=video_muxing_480p.id).resource video_muxing_360p_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/360p', acl=[acl_entry]) video_muxing_360p = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_360p], name='Sample Muxing 360p') video_muxing_360p = bitmovin.encodings.Muxing.TS.create(object_=video_muxing_360p, encoding_id=encoding.id).resource fair_play_360p = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_360p_output], name='FairPlay 360p') fair_play_360p = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_360p, encoding_id=encoding.id, muxing_id=video_muxing_360p.id).resource video_muxing_240p_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/240p', acl=[acl_entry]) video_muxing_240p = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_240p], name='Sample Muxing 240p') video_muxing_240p = bitmovin.encodings.Muxing.TS.create(object_=video_muxing_240p, encoding_id=encoding.id).resource fair_play_240p = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_240p_output], name='FairPlay 240p') fair_play_240p = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_240p, encoding_id=encoding.id, muxing_id=video_muxing_240p.id).resource audio_muxing_output_en_stereo = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/hls/en_2_0', acl=[acl_entry]) audio_muxing_en_stereo = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream_en_stereo], name='Sample Audio Muxing EN Stereo') audio_muxing_en_stereo = bitmovin.encodings.Muxing.TS.create(object_=audio_muxing_en_stereo, encoding_id=encoding.id).resource fair_play_audio = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[audio_muxing_output_en_stereo], name='FairPlay Audio') fair_play_audio = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_audio, encoding_id=encoding.id, muxing_id=audio_muxing_en_stereo.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding.id) try: bitmovin.encodings.Encoding.wait_until_finished(encoding_id=encoding.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for encoding to finish: {}".format(bitmovin_error)) # Manifest ## manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) hls_manifest = HlsManifest(manifest_name='example_manifest_hls.m3u8', outputs=[manifest_output], name='Sample HLS FairPlay Manifest') hls_manifest = bitmovin.manifests.HLS.create(hls_manifest).resource audio_media = AudioMedia(name='Sample Audio Media', group_id='audio_group', segment_path=audio_muxing_output_en_stereo.outputPath, encoding_id=encoding.id, stream_id=audio_stream_en_stereo.id, muxing_id=audio_muxing_en_stereo.id, drm_id=fair_play_audio.id, language='en', uri='audiomedia.m3u8') audio_media = bitmovin.manifests.HLS.AudioMedia.create(manifest_id=hls_manifest.id, object_=audio_media).resource variant_stream_480p = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path=video_muxing_480p_output.outputPath, uri='video_480p.m3u8', encoding_id=encoding.id, stream_id=video_stream_480p.id, muxing_id=video_muxing_480p.id, drm_id=fair_play_480p.id) bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream_480p) variant_stream_360p = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path=video_muxing_360p_output.outputPath, uri='video_360p.m3u8', encoding_id=encoding.id, stream_id=video_stream_360p.id, muxing_id=video_muxing_360p.id, drm_id=fair_play_360p.id) bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream_360p) variant_stream_240p = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path=video_muxing_240p_output.outputPath, uri='video_240p.m3u8', encoding_id=encoding.id, stream_id=video_stream_240p.id, muxing_id=video_muxing_240p.id, drm_id=fair_play_240p.id) bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream_240p) bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for HLS manifest creation to finish: {}".format(bitmovin_error))
def createAACRendition(encoding, dash_manifest, period, adaptation_set, hls_manifest, audio_group_id, audio_input_stream, output, output_path, bitrate, rate): dash_output_path = output_path + '/dash' hls_output_path = output_path + '/hls' stream_identifier = str(bitrate) codec_configuration = AACCodecConfiguration(name='aac_config_' + str(bitrate), bitrate=bitrate, rate=rate) codec_configuration = bitmovin.codecConfigurations.AAC.create( codec_configuration).resource audio_stream = Stream( name='stream_' + stream_identifier, codec_configuration_id=codec_configuration.id, input_streams=[audio_input_stream], ) audio_stream = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) audio_muxing_fmp4_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + dash_output_path, acl=[acl_entry]) audio_muxing_fmp4 = FMP4Muxing(name='fmp4_muxing_' + stream_identifier, segment_length=SEGMENT_LENGTH, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream], outputs=[audio_muxing_fmp4_output]) audio_muxing_fmp4 = bitmovin.encodings.Muxing.FMP4.create( object_=audio_muxing_fmp4, encoding_id=encoding.id).resource audio_muxing_ts_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + hls_output_path, acl=[acl_entry]) audio_muxing_ts = TSMuxing( name='ts_muxing_' + stream_identifier, segment_length=SEGMENT_LENGTH, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], outputs=[audio_muxing_ts_output], ) audio_muxing_ts = bitmovin.encodings.Muxing.TS.create( object_=audio_muxing_ts, encoding_id=encoding.id).resource fmp4_representation = FMP4Representation(FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_muxing_fmp4.id, segment_path=dash_output_path) fmp4_representation = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=adaptation_set.id).resource audio_media = AudioMedia(name='Sample Audio Media', group_id=audio_group_id, segment_path=hls_output_path, encoding_id=encoding.id, stream_id=audio_stream.id, muxing_id=audio_muxing_ts.id, autoselect=False, language='en', uri='audio_' + stream_identifier + '.m3u8') audio_media = bitmovin.manifests.HLS.AudioMedia.create( object_=audio_media, manifest_id=hls_manifest.id).resource
def createH264Rendition(encoding, dash_manifest, period, adaptation_set, hls_manifest, audio_group_id, video_input_stream, output, output_path, bitrate, rate, width, height, profile): dash_output_path = output_path + '/dash' hls_output_path = output_path + '/hls' stream_identifier = str(bitrate) + '_' + str(width) + 'x' + str(height) codec_configuration = H264CodecConfiguration(name='h264_config_' + stream_identifier, bitrate=bitrate, rate=rate, width=width, height=height, profile=profile) codec_configuration = bitmovin.codecConfigurations.H264.create( codec_configuration).resource video_stream = Stream(name='stream_' + stream_identifier, codec_configuration_id=codec_configuration.id, input_streams=[video_input_stream]) video_stream = bitmovin.encodings.Stream.create( object_=video_stream, encoding_id=encoding.id).resource video_muxing_stream = MuxingStream(video_stream.id) acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) video_muxing_fmp4_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + dash_output_path, acl=[acl_entry]) video_muxing_fmp4 = FMP4Muxing(name='fmp4_muxing_' + stream_identifier, segment_length=SEGMENT_LENGTH, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream], outputs=[video_muxing_fmp4_output]) video_muxing_fmp4 = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing_fmp4, encoding_id=encoding.id).resource video_muxing_ts_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + hls_output_path, acl=[acl_entry]) video_muxing_ts = TSMuxing(name='ts_muxing_' + stream_identifier, segment_length=SEGMENT_LENGTH, segment_naming='seg_%number%.ts', streams=[video_muxing_stream], outputs=[video_muxing_ts_output]) video_muxing_ts = bitmovin.encodings.Muxing.TS.create( object_=video_muxing_ts, encoding_id=encoding.id).resource fmp4_representation = FMP4Representation(FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=video_muxing_fmp4.id, segment_path=dash_output_path) fmp4_representation = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=adaptation_set.id).resource variant_stream = VariantStream(audio=audio_group_id, uri='video_' + stream_identifier + '.m3u8', segment_path=hls_output_path, encoding_id=encoding.id, stream_id=video_stream.id, muxing_id=video_muxing_ts.id, closed_captions='NONE') variant_stream = bitmovin.manifests.HLS.VariantStream.create( object_=variant_stream, manifest_id=hls_manifest.id)
def main(): bitmovin = Bitmovin(api_key=API_KEY) # Create an S3 input. This resource is then used as base bucket for the input file. s3_input = S3Input(access_key=S3_INPUT_ACCESSKEY, secret_key=S3_INPUT_SECRETKEY, bucket_name=S3_INPUT_BUCKETNAME, name='S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource # Create an S3 Output. This will be used as target bucket for the muxings, sprites and manifests s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource video_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUTO) audio_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUTO) acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) encoding_analysis = Encoding(name='Per title encoding analysis', cloud_region=CloudRegion.AWS_EU_WEST_1) encoding_analysis = bitmovin.encodings.Encoding.create( encoding_analysis).resource # Do analysis encoding to get the complexity factor encoding_analysis = bitmovin.encodings.Encoding.create( encoding_analysis).resource encoding_analysis_config = H264CodecConfiguration( name='H264 Per Title Analysis Configuration', bitrate=None, crf=23.0, height=360, rate=None, profile=H264Profile.MAIN) encoding_analysis_config = bitmovin.codecConfigurations.H264.create( encoding_analysis_config).resource encoding_analysis_stream = Stream( codec_configuration_id=encoding_analysis_config.id, input_streams=[video_input_stream], name='Per Title Analysis Stream') encoding_analysis_stream = bitmovin.encodings.Stream.create( object_=encoding_analysis_stream, encoding_id=encoding_analysis.id).resource encoding_analysis_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/quality_analysis/', acl=[acl_entry]) encoding_analysis_muxing_stream = MuxingStream(encoding_analysis_stream.id) encoding_analysis_muxing = FMP4Muxing( segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[encoding_analysis_muxing_stream], outputs=[encoding_analysis_output], name='Per Title Analysis Muxing') encoding_analysis_muxing = bitmovin.encodings.Muxing.FMP4.create( object_=encoding_analysis_muxing, encoding_id=encoding_analysis.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding_analysis.id) try: bitmovin.encodings.Encoding.wait_until_finished( encoding_id=encoding_analysis.id, check_interval=5) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for encoding to finish: {}'. format(bitmovin_error)) exit(-1) encoding_analysis_muxing = bitmovin.encodings.Muxing.FMP4.retrieve( encoding_id=encoding_analysis.id, muxing_id=encoding_analysis_muxing.id).resource # Calculate and saturate the complexity factor complexity_factor = encoding_analysis_muxing.avgBitrate / MEDIAN_BITRATE if complexity_factor > MAX_COMPLEXITY_FACTOR: complexity_factor = MAX_COMPLEXITY_FACTOR elif complexity_factor < MIN_COMPLEXITY_FACTOR: complexity_factor = MIN_COMPLEXITY_FACTOR print('Got complexity factor of: {:0.2f}'.format(complexity_factor)) print('Updating encoding profile from:') pprint(encoding_profiles) print('To') # Multiply every bitrate with the complexity factor for profile in encoding_profiles: profile['bitrate'] = int(profile['bitrate'] * complexity_factor) pprint(encoding_profiles) # Create an Encoding. This will run in AWS_AP_SOUTHEAST_1. This is the base entity used to configure the encoding. encoding = Encoding(name='Per title encoding', cloud_region=CloudRegion.AWS_EU_WEST_1) encoding = bitmovin.encodings.Encoding.create(encoding).resource encoding_configs = [] # Iterate over all encoding profiles and create the H264 configuration with the defined height and bitrate. for encoding_profile in encoding_profiles: encoding_config = dict(profile=encoding_profile) codec = H264CodecConfiguration( name='H264 Codec {}p {}k Configuration'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), bitrate=encoding_profile.get('bitrate') * 1000, height=encoding_profile.get('height'), rate=encoding_profile.get('fps'), profile=H264Profile.HIGH) encoding_config['codec'] = bitmovin.codecConfigurations.H264.create( codec).resource encoding_configs.append(encoding_config) # Also the AAC configuration has to be created, which will be later on used to create the streams. audio_codec_configuration = AACCodecConfiguration( name='AAC Codec Configuration', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create( audio_codec_configuration).resource # With the configurations and the input file streams are now created and muxed later on. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') video_stream = Stream( codec_configuration_id=encoding_config.get('codec').id, input_streams=[video_input_stream], name='Stream {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['stream'] = bitmovin.encodings.Stream.create( object_=video_stream, encoding_id=encoding.id).resource audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], name='Audio Stream') audio_stream = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource # Create FMP4 muxings which are later used for the DASH manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') video_muxing_stream = MuxingStream(encoding_config.get('stream').id) video_muxing_output = EncodingOutput( output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/dash/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream], outputs=[video_muxing_output], name='FMP4 Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['fmp4_muxing'] = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio_dash/', acl=[acl_entry]) audio_fmp4_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio FMP4 Muxing') audio_fmp4_muxing = bitmovin.encodings.Muxing.FMP4.create( object_=audio_fmp4_muxing, encoding_id=encoding.id).resource # Create TS muxings which are later used for the DASH manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') video_muxing_stream = MuxingStream(encoding_config.get('stream').id) video_muxing_output = EncodingOutput( output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream], outputs=[video_muxing_output], name='TS Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['ts_muxing'] = bitmovin.encodings.Muxing.TS.create( object_=video_muxing, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio_hls/', acl=[acl_entry]) audio_ts_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio TS Muxing') audio_ts_muxing = bitmovin.encodings.Muxing.TS.create( object_=audio_ts_muxing, encoding_id=encoding.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding.id) try: bitmovin.encodings.Encoding.wait_until_finished( encoding_id=encoding.id, check_interval=5) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for encoding to finish: {}'. format(bitmovin_error)) exit(-1) # Specify the output for manifest which will be in the OUTPUT_BASE_PATH. manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) # Create a DASH manifest and add one period with an adapation set for audio and video dash_manifest = DashManifest(manifest_name='stream.mpd', outputs=[manifest_output], name='DASH Manifest') dash_manifest = bitmovin.manifests.DASH.create(dash_manifest).resource period = Period() period = bitmovin.manifests.DASH.add_period( object_=period, manifest_id=dash_manifest.id).resource video_adaptation_set = VideoAdaptationSet() video_adaptation_set = bitmovin.manifests.DASH.add_video_adaptation_set( object_=video_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource audio_adaptation_set = AudioAdaptationSet(lang='en') audio_adaptation_set = bitmovin.manifests.DASH.add_audio_adaptation_set( object_=audio_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') muxing = encoding_config.get('fmp4_muxing') fmp4_representation_1080p = FMP4Representation( FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=muxing.id, segment_path='video/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config[ 'dash'] = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation_1080p, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id).resource fmp4_representation_audio = FMP4Representation( FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_fmp4_muxing.id, segment_path='audio_dash/') bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation_audio, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=audio_adaptation_set.id) bitmovin.manifests.DASH.start(manifest_id=dash_manifest.id) # Create a HLS manifest and add one period with an adapation set for audio and video hls_manifest = HlsManifest(manifest_name='stream.m3u8', outputs=[manifest_output], name='HLS Manifest') hls_manifest = bitmovin.manifests.HLS.create(hls_manifest).resource audio_media = AudioMedia(name='HLS Audio Media', group_id='audio', segment_path='audio_hls/', encoding_id=encoding.id, stream_id=audio_stream.id, muxing_id=audio_ts_muxing.id, language='en', uri='audio.m3u8') audio_media = bitmovin.manifests.HLS.AudioMedia.create( manifest_id=hls_manifest.id, object_=audio_media).resource # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') stream = encoding_config.get('stream') muxing = encoding_config.get('ts_muxing') variant_stream = VariantStream( audio='audio', closed_captions='NONE', segment_path='video/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), uri='video_{}p_{}k.m3u8'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), encoding_id=encoding.id, stream_id=stream.id, muxing_id=muxing.id) variant_stream = bitmovin.manifests.HLS.VariantStream.create( manifest_id=hls_manifest.id, object_=variant_stream).resource bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) try: bitmovin.manifests.DASH.wait_until_finished( manifest_id=dash_manifest.id, check_interval=1) except BitmovinError as bitmovin_error: print( 'Exception occurred while waiting for manifest creation to finish: {}' .format(bitmovin_error)) exit(-1) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id, check_interval=1) except BitmovinError as bitmovin_error: print( 'Exception occurred while waiting for manifest creation to finish: {}' .format(bitmovin_error)) exit(-1)
def main(): bitmovin = Bitmovin(api_key=API_KEY) resource_response = bitmovin.inputs.RTMP.list() if not resource_response or \ not resource_response.resource or \ not isinstance(resource_response.resource, list) or \ len(resource_response.resource) < 1: print('Could not find any RTMP inputs. Please contact support.') sys.exit(3) rtmp_input_id = resource_response.resource[0].id print("Found RTMP input with ID '{}'".format(rtmp_input_id)) rtmp_input = bitmovin.inputs.RTMP.retrieve(id_=rtmp_input_id).resource output = GenericS3Output(access_key=GENERIC_S3_OUTPUT_ACCESSKEY, secret_key=GENERIC_S3_OUTPUT_SECRETKEY, bucket_name=GENERIC_S3_OUTPUT_BUCKETNAME, host=GENERIC_S3_OUTPUT_HOST, port=GENERIC_S3_OUTPUT_PORT, name='Sample Generic S3 Output') output = bitmovin.outputs.GenericS3.create(output).resource encoding = Encoding(name='example python hls live stream encoding', encoder_version=ENCODER_VERSION, cloud_region=CLOUD_REGION, infrastructure_id=INFRASTRUCTURE_ID) encoding = bitmovin.encodings.Encoding.create(encoding).resource video_codec_configuration_1080p = H264CodecConfiguration( name='example_video_codec_configuration_1080p', bitrate=4800000, rate=25.0, width=1920, height=1080, profile=H264Profile.HIGH) video_codec_configuration_1080p = bitmovin.codecConfigurations.H264.create( video_codec_configuration_1080p).resource video_codec_configuration_720p = H264CodecConfiguration( name='example_video_codec_configuration_720p', bitrate=2400000, rate=25.0, width=1280, height=720, profile=H264Profile.HIGH) video_codec_configuration_720p = bitmovin.codecConfigurations.H264.create( video_codec_configuration_720p).resource video_codec_configuration_360p = H264CodecConfiguration( name='example_video_codec_configuration_720p', bitrate=800000, rate=25.0, width=640, height=360, profile=H264Profile.HIGH) video_codec_configuration_360p = bitmovin.codecConfigurations.H264.create( video_codec_configuration_360p).resource audio_codec_configuration = AACCodecConfiguration( name='example_audio_codec_configuration_english', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create( audio_codec_configuration).resource video_input_stream = StreamInput(input_id=rtmp_input.id, input_path='live', position=0, selection_mode=SelectionMode.AUTO) audio_input_stream = StreamInput(input_id=rtmp_input.id, input_path='live', position=1, selection_mode=SelectionMode.AUTO) video_stream_1080p = Stream( codec_configuration_id=video_codec_configuration_1080p.id, input_streams=[video_input_stream], name='Sample Stream 1080p') video_stream_1080p = bitmovin.encodings.Stream.create( object_=video_stream_1080p, encoding_id=encoding.id).resource video_stream_720p = Stream( codec_configuration_id=video_codec_configuration_720p.id, input_streams=[video_input_stream], name='Sample Stream 720p') video_stream_720p = bitmovin.encodings.Stream.create( object_=video_stream_720p, encoding_id=encoding.id).resource video_stream_360p = Stream( codec_configuration_id=video_codec_configuration_360p.id, input_streams=[video_input_stream], name='Sample Stream 360p') video_stream_360p = bitmovin.encodings.Stream.create( object_=video_stream_360p, encoding_id=encoding.id).resource audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], name='Sample Stream AUDIO') audio_stream = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource video_muxing_stream_1080p = MuxingStream(video_stream_1080p.id) video_muxing_stream_720p = MuxingStream(video_stream_720p.id) video_muxing_stream_360p = MuxingStream(video_stream_360p.id) audio_muxing_stream = MuxingStream(audio_stream.id) acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) video_muxing_1080p_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + 'video/1080p', acl=[acl_entry]) video_muxing_1080p = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_1080p], outputs=[video_muxing_1080p_output], name='Sample Muxing 1080p') video_muxing_1080p = bitmovin.encodings.Muxing.TS.create( object_=video_muxing_1080p, encoding_id=encoding.id).resource video_muxing_720p_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + 'video/720p', acl=[acl_entry]) video_muxing_720p = TSMuxing(segment_length=4, segment_naming='seg_%number%.m4s', streams=[video_muxing_stream_720p], outputs=[video_muxing_720p_output], name='Sample Muxing 720p') video_muxing_720p = bitmovin.encodings.Muxing.TS.create( object_=video_muxing_720p, encoding_id=encoding.id).resource video_muxing_360p_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + 'video/360p', acl=[acl_entry]) video_muxing_360p = TSMuxing(segment_length=4, segment_naming='seg_%number%.m4s', streams=[video_muxing_stream_360p], outputs=[video_muxing_360p_output], name='Sample Muxing 360p') video_muxing_360p = bitmovin.encodings.Muxing.TS.create( object_=video_muxing_360p, encoding_id=encoding.id).resource audio_muxing_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH + 'audio/128k', acl=[acl_entry]) audio_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.m4s', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Sample Muxing AUDIO') audio_muxing = bitmovin.encodings.Muxing.TS.create( object_=audio_muxing, encoding_id=encoding.id).resource #### Manifest ##################################################################################################### manifest_output = EncodingOutput(output_id=output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) hls_manifest = HlsManifest( manifest_name='example_live_manifest.m3u8', outputs=[manifest_output], name='Sample HLS Manifest Live', description='Bitmovin Python Test Live HLS Manifest') hls_manifest = bitmovin.manifests.HLS.create(hls_manifest).resource audio_media = AudioMedia(name='Sample Audio Media', group_id='audio_group', segment_path="audio/128k/", encoding_id=encoding.id, stream_id=audio_stream.id, muxing_id=audio_muxing.id, language='en', uri='audiomedia.m3u8', autoselect=False) audio_media = bitmovin.manifests.HLS.AudioMedia.create( manifest_id=hls_manifest.id, object_=audio_media).resource variant_stream_1080p = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path="video/1080p/", uri='video_1080p.m3u8', encoding_id=encoding.id, stream_id=video_stream_1080p.id, muxing_id=video_muxing_1080p.id) variant_stream_1080p = bitmovin.manifests.HLS.VariantStream.create( manifest_id=hls_manifest.id, object_=variant_stream_1080p) variant_stream_720p = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path="video/720p/", uri='video_720p.m3u8', encoding_id=encoding.id, stream_id=video_stream_720p.id, muxing_id=video_muxing_720p.id) variant_stream_720p = bitmovin.manifests.HLS.VariantStream.create( manifest_id=hls_manifest.id, object_=variant_stream_720p) variant_stream_360p = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path="video/360p/", uri='video_360p.m3u8', encoding_id=encoding.id, stream_id=video_stream_360p.id, muxing_id=video_muxing_360p.id) variant_stream_360p = bitmovin.manifests.HLS.VariantStream.create( manifest_id=hls_manifest.id, object_=variant_stream_360p) bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) ################################################################################################################### live_hls_manifest = LiveHlsManifest(manifest_id=hls_manifest.id, time_shift=60) live_stream_configuration = LiveStreamConfiguration( stream_key=STREAM_KEY, live_hls_manifests=[live_hls_manifest], ) resource_response = bitmovin.encodings.Encoding.start_live( encoding_id=encoding.id, live_stream_configuration=live_stream_configuration) bitmovin.encodings.Encoding.wait_until_running( encoding_id=resource_response.resource.id) live_details = None retry = 0 while retry < LIVE_STREAM_INFORMATION_FETCH_MAX_RETRIES: try: live_details = bitmovin.encodings.Encoding.retrieve_live( encoding_id=resource_response.resource.id) break except BitmovinApiError as bitmovin_api_error: if bitmovin_api_error.response.data.code != ERROR_CODE_LIVE_STREAM_NOT_READY: sys.exit(2) print( "Live stream is not ready yet. Retrying to fetch live stream information in {} seconds..." .format(LIVE_STREAM_INFORMATION_FETCH_RETRY_INTERVAL)) retry += 1 time.sleep(LIVE_STREAM_INFORMATION_FETCH_RETRY_INTERVAL) if live_details is not None: print_live_stream_details(encoding_id=encoding.id, live_stream_details=live_details.resource) else: print("Unable to fetch live stream details!") sys.exit(1)
def main(): bitmovin = Bitmovin(api_key=API_KEY) # Create an S3 input. This resource is then used as base bucket for the input file. s3_input = S3Input(access_key=S3_INPUT_ACCESSKEY, secret_key=S3_INPUT_SECRETKEY, bucket_name=S3_INPUT_BUCKETNAME, name='S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource # Create an S3 Output. This will be used as target bucket for the muxings, sprites and manifests s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource # Create an Encoding. This will run in AWS_EU_WEST_1. This is the base entity used to configure the encoding. encoding = Encoding(name='Encoding with text filter', cloud_region=CloudRegion.AWS_EU_WEST_1) encoding = bitmovin.encodings.Encoding.create(encoding).resource encoding_configs = [] # Iterate over all encoding profiles and create the H264 configuration with the defined height and bitrate. for idx, _ in enumerate(encoding_profiles_h264): profile_h264 = encoding_profiles_h264[idx] encoding_config = dict(profile_h264=profile_h264) h264_codec = H264CodecConfiguration( name='H264 Codec {}p {}k Configuration'.format( profile_h264.get('height'), profile_h264.get('bitrate')), bitrate=profile_h264.get('bitrate') * 1000, height=profile_h264.get('height'), profile=profile_h264.get('profile'), rate=profile_h264.get('fps')) encoding_config[ 'h264_codec'] = bitmovin.codecConfigurations.H264.create( h264_codec).resource encoding_configs.append(encoding_config) # Also the AAC configuration has to be created, which will be later on used to create the streams. audio_codec_configuration = AACCodecConfiguration( name='AAC Codec Configuration', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create( audio_codec_configuration).resource video_input_stream = StreamInput( input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.VIDEO_RELATIVE, position=0) audio_input_stream = StreamInput( input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUDIO_RELATIVE, position=0) # Configure text filter here text_filter = TextFilter(name='Text Filter', text='Bitmovin is great!', x='main_w/2-text_w/2', y='10', font_color='#FFFFFF', font_size=48, box=True, box_color='#32A9E1', shadow_color='#218ECD', shadow_x=5, shadow_y=5, font=Font.DEJAVUSANS) text_filter = bitmovin.filters.Text.create(object_=text_filter).resource stream_filter = [StreamFilter(id=text_filter.id, position=0)] # With the configurations and the input file streams are now created and muxed later on. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile_h264') video_stream_h264 = Stream( codec_configuration_id=encoding_config.get('h264_codec').id, input_streams=[video_input_stream], name='Stream H264 {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_stream'] = bitmovin.encodings.Stream.create( object_=video_stream_h264, encoding_id=encoding.id).resource bitmovin.encodings.Stream.Filter.create( encoding_id=encoding.id, stream_id=encoding_config['h264_stream'].id, stream_filter=stream_filter) audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], name='Audio Stream') audio_stream = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) # Create TS and FMP4 muxings which are later used for the HLS and DASH manifest. The current settings will set a # segment length of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile_h264') video_muxing_stream_h264 = MuxingStream( encoding_config.get('h264_stream').id) video_muxing_output_h264 = EncodingOutput( output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/h264/dash/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing_h264 = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream_h264], outputs=[video_muxing_output_h264], name='FMP4 H264 Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['h264_muxing'] = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing_h264, encoding_id=encoding.id).resource video_ts_muxing_output_h264 = EncodingOutput( output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/h264/hls/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_ts_muxing_h264 = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_h264], outputs=[video_ts_muxing_output_h264], name='FMP4 H264 Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config[ 'h264_ts_muxing'] = bitmovin.encodings.Muxing.TS.create( object_=video_ts_muxing_h264, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) # mp4 audio muxing audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/dash/', acl=[acl_entry]) audio_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio Dash Muxing') audio_muxing = bitmovin.encodings.Muxing.FMP4.create( object_=audio_muxing, encoding_id=encoding.id).resource # TS audio muxing hls_audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/hls/', acl=[acl_entry]) hls_audio_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], outputs=[hls_audio_muxing_output], name='Audio TS Muxing') hls_audio_muxing = bitmovin.encodings.Muxing.TS.create( object_=hls_audio_muxing, encoding_id=encoding.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding.id) try: bitmovin.encodings.Encoding.wait_until_finished( encoding_id=encoding.id) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for encoding to finish:') pprint(bitmovin_error) exit(-1) # Specify the output for manifest which will be in the OUTPUT_BASE_PATH. manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) # Create a DASH H264 manifest and add one period with an adaptation set for audio and video dash_manifest_h264 = DashManifest(manifest_name='stream.mpd', outputs=[manifest_output], name='DASH H264 Manifest') dash_manifest_h264 = bitmovin.manifests.DASH.create( dash_manifest_h264).resource period_h264 = Period() period_h264 = bitmovin.manifests.DASH.add_period( object_=period_h264, manifest_id=dash_manifest_h264.id).resource video_adaptation_set_h264 = VideoAdaptationSet() video_adaptation_set_h264 = bitmovin.manifests.DASH.add_video_adaptation_set( object_=video_adaptation_set_h264, manifest_id=dash_manifest_h264.id, period_id=period_h264.id).resource audio_adaptation_set_h264 = AudioAdaptationSet(lang='en') audio_adaptation_set_h264 = bitmovin.manifests.DASH.add_audio_adaptation_set( object_=audio_adaptation_set_h264, manifest_id=dash_manifest_h264.id, period_id=period_h264.id).resource fmp4_representation_audio = FMP4Representation( FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_muxing.id, segment_path='audio/dash/') bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation_audio, manifest_id=dash_manifest_h264.id, period_id=period_h264.id, adaptationset_id=audio_adaptation_set_h264.id) # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile_h264') muxing = encoding_config.get('h264_muxing') fmp4_representation = FMP4Representation( FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=muxing.id, segment_path='video/h264/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config[ 'h264_dash'] = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation, manifest_id=dash_manifest_h264.id, period_id=period_h264.id, adaptationset_id=video_adaptation_set_h264.id).resource bitmovin.manifests.DASH.start(manifest_id=dash_manifest_h264.id) # Create a HLS H264 manifest and add one period with an adaptation set for audio and video hls_manifest = HlsManifest(manifest_name='stream.m3u8', outputs=[manifest_output], name='HLS H264 Manifest') hls_manifest = bitmovin.manifests.HLS.create(object_=hls_manifest).resource hls_audio_media = AudioMedia(name='en', group_id='audio_group', segment_path='audio/hls/', encoding_id=encoding.id, stream_id=audio_stream.id, muxing_id=hls_audio_muxing.id, language='en', uri='audio.m3u8') bitmovin.manifests.HLS.AudioMedia.create(manifest_id=hls_manifest.id, object_=hls_audio_media) # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile_h264') video_muxing_stream_h264 = encoding_config.get('h264_stream') ts_muxing = encoding_config.get('h264_ts_muxing') # append another variant stream for this video quality to our hls renditions. hls_variant_stream = VariantStream( audio='audio_group', segment_path='video/h264/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), uri='video_{}p_{}.m3u8'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), encoding_id=encoding.id, stream_id=video_muxing_stream_h264.id, muxing_id=ts_muxing.id) bitmovin.manifests.HLS.VariantStream.create( manifest_id=hls_manifest.id, object_=hls_variant_stream) bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) try: bitmovin.manifests.DASH.wait_until_finished( manifest_id=dash_manifest_h264.id) except BitmovinError as bitmovin_error: print( 'Exception occurred while waiting for manifest creation to finish: {}' .format(bitmovin_error)) exit(-1) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id) except BitmovinError as bitmovin_error: print( 'Exception occurred while waiting for manifest creation to finish: {}' .format(bitmovin_error)) exit(-1)
def main(): bitmovin = Bitmovin(api_key=API_KEY) s3_input = S3Input(access_key=S3_INPUT_ACCESSKEY, secret_key=S3_INPUT_SECRETKEY, bucket_name=S3_INPUT_BUCKETNAME, name='Sample S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='Sample S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource encoding = Encoding(name='Python Encoding with DASH CENC and Fairplay') encoding = bitmovin.encodings.Encoding.create(encoding).resource video_codec_configuration_480p = H264CodecConfiguration(name='example_video_codec_configuration_480p', bitrate=1200000, rate=None, height=480, profile=H264Profile.HIGH) video_codec_configuration_480p = bitmovin.codecConfigurations.H264.create(video_codec_configuration_480p).resource video_codec_configuration_360p = H264CodecConfiguration(name='example_video_codec_configuration_360p', bitrate=800000, rate=None, height=360, profile=H264Profile.HIGH) video_codec_configuration_360p = bitmovin.codecConfigurations.H264.create(video_codec_configuration_360p).resource video_codec_configuration_240p = H264CodecConfiguration(name='example_video_codec_configuration_240p', bitrate=400000, rate=None, height=240, profile=H264Profile.HIGH) video_codec_configuration_240p = bitmovin.codecConfigurations.H264.create(video_codec_configuration_240p).resource audio_codec_configuration_stereo = AACCodecConfiguration(name='example_audio_codec_configuration_stereo', bitrate=128000, rate=48000) audio_codec_configuration_stereo = \ bitmovin.codecConfigurations.AAC.create(audio_codec_configuration_stereo).resource video_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUTO) audio_input_stream_en_stereo = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_PATH, selection_mode=SelectionMode.AUTO) video_stream_480p = Stream(codec_configuration_id=video_codec_configuration_480p.id, input_streams=[video_input_stream], name='Sample Stream 480p') video_stream_480p = bitmovin.encodings.Stream.create(object_=video_stream_480p, encoding_id=encoding.id).resource video_stream_360p = Stream(codec_configuration_id=video_codec_configuration_360p.id, input_streams=[video_input_stream], name='Sample Stream 360p') video_stream_360p = bitmovin.encodings.Stream.create(object_=video_stream_360p, encoding_id=encoding.id).resource video_stream_240p = Stream(codec_configuration_id=video_codec_configuration_240p.id, input_streams=[video_input_stream], name='Sample Stream 240p') video_stream_240p = bitmovin.encodings.Stream.create(object_=video_stream_240p, encoding_id=encoding.id).resource audio_stream_en_stereo = Stream(codec_configuration_id=audio_codec_configuration_stereo.id, input_streams=[audio_input_stream_en_stereo], name='Sample Audio Stream EN Stereo') audio_stream_en_stereo = bitmovin.encodings.Stream.create(object_=audio_stream_en_stereo, encoding_id=encoding.id).resource acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) video_muxing_stream_480p = MuxingStream(video_stream_480p.id) video_muxing_stream_360p = MuxingStream(video_stream_360p.id) video_muxing_stream_240p = MuxingStream(video_stream_240p.id) audio_muxing_stream_en_stereo = MuxingStream(audio_stream_en_stereo.id) widevine_drm = CENCWidevineEntry(pssh=CENC_WIDEVINE_PSSH) play_ready_drm = CENCPlayReadyEntry(la_url=CENC_PLAYREADY_LA_URL) video_muxing_480p_dash_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/dash/480p/', acl=[acl_entry]) video_muxing_480p = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream_480p], name='FMP4 Muxing 480p') video_muxing_480p = bitmovin.encodings.Muxing.FMP4.create(object_=video_muxing_480p, encoding_id=encoding.id).resource cenc_480p = CENCDRMResource(key=CENC_KEY, kid=CENC_KID, widevine=widevine_drm, playReady=play_ready_drm, marlin=CENCMarlinEntry(), outputs=[video_muxing_480p_dash_output], name='Cenc') cenc_480p = bitmovin.encodings.Muxing.FMP4.DRM.CENC.create(object_=cenc_480p, encoding_id=encoding.id, muxing_id=video_muxing_480p.id).resource video_muxing_480p_ts = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_480p], name='TS Muxing 480p') video_muxing_480p_ts = bitmovin.encodings.Muxing.TS.create(object_=video_muxing_480p_ts, encoding_id=encoding.id).resource video_muxing_480p_hls_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/480p/', acl=[acl_entry]) fair_play_480p = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_480p_hls_output], name='FairPlay 480p') fair_play_480p = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_480p, encoding_id=encoding.id, muxing_id=video_muxing_480p_ts.id).resource video_muxing_360p_dash_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/dash/360p/', acl=[acl_entry]) video_muxing_360p = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream_360p], name='FMP4 Muxing 360p') video_muxing_360p = bitmovin.encodings.Muxing.FMP4.create(object_=video_muxing_360p, encoding_id=encoding.id).resource cenc_360p = CENCDRMResource(key=CENC_KEY, kid=CENC_KID, widevine=widevine_drm, playReady=play_ready_drm, marlin=CENCMarlinEntry(), outputs=[video_muxing_360p_dash_output], name='Cenc') cenc_360p = bitmovin.encodings.Muxing.FMP4.DRM.CENC.create(object_=cenc_360p, encoding_id=encoding.id, muxing_id=video_muxing_360p.id).resource video_muxing_360p_hls_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/360p/', acl=[acl_entry]) video_muxing_360p_ts = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_360p], name='TS Muxing 360p') video_muxing_360p_ts = bitmovin.encodings.Muxing.TS.create(object_=video_muxing_360p_ts, encoding_id=encoding.id).resource fair_play_360p = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_360p_hls_output], name='FairPlay 360p') fair_play_360p = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_360p, encoding_id=encoding.id, muxing_id=video_muxing_360p_ts.id).resource video_muxing_240p_dash_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/dash/240p/', acl=[acl_entry]) video_muxing_240p = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream_240p], name='FMP4 Muxing 240p') video_muxing_240p = bitmovin.encodings.Muxing.FMP4.create(object_=video_muxing_240p, encoding_id=encoding.id).resource cenc_240p = CENCDRMResource(key=CENC_KEY, kid=CENC_KID, widevine=widevine_drm, playReady=play_ready_drm, marlin=CENCMarlinEntry(), outputs=[video_muxing_240p_dash_output], name='Cenc') cenc_240p = bitmovin.encodings.Muxing.FMP4.DRM.CENC.create(object_=cenc_240p, encoding_id=encoding.id, muxing_id=video_muxing_240p.id).resource video_muxing_240p_hls_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/240p/', acl=[acl_entry]) video_muxing_240p_ts = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream_240p], name='TS Muxing 240p') video_muxing_240p_ts = bitmovin.encodings.Muxing.TS.create(object_=video_muxing_240p_ts, encoding_id=encoding.id).resource fair_play_240p = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_240p_hls_output], name='FairPlay 240p') fair_play_240p = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_240p, encoding_id=encoding.id, muxing_id=video_muxing_240p_ts.id).resource audio_muxing_dash_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/dash/en/', acl=[acl_entry]) audio_muxing_en_stereo = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream_en_stereo], name='Sample Audio Muxing EN Stereo') audio_muxing_en_stereo = bitmovin.encodings.Muxing.FMP4.create(object_=audio_muxing_en_stereo, encoding_id=encoding.id).resource cenc_audio = CENCDRMResource(key=CENC_KEY, kid=CENC_KID, widevine=widevine_drm, playReady=play_ready_drm, marlin=CENCMarlinEntry(), outputs=[audio_muxing_dash_output], name='Cenc') cenc_audio = bitmovin.encodings.Muxing.FMP4.DRM.CENC.create(object_=cenc_audio, encoding_id=encoding.id, muxing_id=audio_muxing_en_stereo.id).resource audio_muxing_hls_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/hls/en/', acl=[acl_entry]) audio_muxing_en_stereo_ts = TSMuxing(segment_length=4, segment_naming='seg_%number%.m4s', streams=[audio_muxing_stream_en_stereo], name='Sample TS Audio Muxing EN Stereo') audio_muxing_en_stereo_ts = bitmovin.encodings.Muxing.TS.create(object_=audio_muxing_en_stereo_ts, encoding_id=encoding.id).resource fair_play_audio = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[audio_muxing_hls_output], name='FairPlay Audio') fair_play_audio = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=fair_play_audio, encoding_id=encoding.id, muxing_id=audio_muxing_en_stereo_ts.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding.id) try: bitmovin.encodings.Encoding.wait_until_finished(encoding_id=encoding.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for encoding to finish: {}".format(bitmovin_error)) ################################################################################################################### manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) dash_manifest = DashManifest(manifest_name='stream.mpd', outputs=[manifest_output], name='Sample DASH Manifest') dash_manifest = bitmovin.manifests.DASH.create(dash_manifest).resource period = Period() period = bitmovin.manifests.DASH.add_period(object_=period, manifest_id=dash_manifest.id).resource video_adaptation_set = VideoAdaptationSet() video_adaptation_set = bitmovin.manifests.DASH.add_video_adaptation_set(object_=video_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource video_content_protection = ContentProtection(encoding_id=encoding.id, muxing_id=video_muxing_480p.id, drm_id=cenc_480p.id) bitmovin.manifests.DASH.add_content_protection_to_adaptionset(object_=video_content_protection, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id) fmp4_representation_480p = DRMFMP4Representation(type=FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=video_muxing_480p.id, drm_id=cenc_480p.id, segment_path='video/dash/480p/') fmp4_representation_480p = bitmovin.manifests.DASH.add_drm_fmp4_representation( object_=fmp4_representation_480p, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id ).resource fmp4_representation_360p = DRMFMP4Representation(type=FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=video_muxing_360p.id, drm_id=cenc_360p.id, segment_path='video/dash/360p/') fmp4_representation_360p = bitmovin.manifests.DASH.add_drm_fmp4_representation( object_=fmp4_representation_360p, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id ).resource fmp4_representation_240p = DRMFMP4Representation(type=FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=video_muxing_240p.id, drm_id=cenc_240p.id, segment_path='video/dash/240p/') fmp4_representation_240p = bitmovin.manifests.DASH.add_drm_fmp4_representation( object_=fmp4_representation_240p, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id ).resource audio_adaptation_set = AudioAdaptationSet(lang='EN') audio_adaptation_set = bitmovin.manifests.DASH.add_audio_adaptation_set(object_=audio_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource audio_content_protection = ContentProtection(encoding_id=encoding.id, muxing_id=audio_muxing_en_stereo.id, drm_id=cenc_audio.id) bitmovin.manifests.DASH.add_content_protection_to_adaptionset(object_=audio_content_protection, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=audio_adaptation_set.id) drm_cenc_fmp4_representation_audio = DRMFMP4Representation(type=FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_muxing_en_stereo.id, drm_id=cenc_audio.id, segment_path='audio/dash/en/') drm_cenc_fmp4_representation_audio = bitmovin.manifests.DASH.add_drm_fmp4_representation( object_=drm_cenc_fmp4_representation_audio, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=audio_adaptation_set.id ).resource bitmovin.manifests.DASH.start(manifest_id=dash_manifest.id) ################################################################################################################### hls_manifest = HlsManifest(manifest_name='stream.m3u8', outputs=[manifest_output], name='Sample HLS FairPlay Manifest') hls_manifest = bitmovin.manifests.HLS.create(hls_manifest).resource audio_media = AudioMedia(name='English', group_id='audio_group', segment_path='audio/hls/en/', encoding_id=encoding.id, stream_id=audio_stream_en_stereo.id, muxing_id=audio_muxing_en_stereo_ts.id, drm_id=fair_play_audio.id, language='en', uri='audio.m3u8') audio_media = bitmovin.manifests.HLS.AudioMedia.create(manifest_id=hls_manifest.id, object_=audio_media).resource variant_stream_480p = VariantStream(audio=audio_media.groupId, segment_path='video/hls/480p/', uri='video_480p.m3u8', encoding_id=encoding.id, stream_id=video_stream_480p.id, muxing_id=video_muxing_480p_ts.id, drm_id=fair_play_480p.id) variant_stream_480p = bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream_480p) variant_stream_360p = VariantStream(audio=audio_media.groupId, segment_path='video/hls/360p/', uri='video_360p.m3u8', encoding_id=encoding.id, stream_id=video_stream_360p.id, muxing_id=video_muxing_360p_ts.id, drm_id=fair_play_360p.id) variant_stream_360p = bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream_360p) variant_stream_240p = VariantStream(audio=audio_media.groupId, segment_path='video/hls/240p/', uri='video_240p.m3u8', encoding_id=encoding.id, stream_id=video_stream_240p.id, muxing_id=video_muxing_240p_ts.id, drm_id=fair_play_240p.id) variant_stream_240p = bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream_240p) bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) ################################################################################################################### try: bitmovin.manifests.DASH.wait_until_finished(manifest_id=dash_manifest.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for manifest creation to finish: {}".format(bitmovin_error)) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for HLS manifest creation to finish: {}".format(bitmovin_error))
def main(): bitmovin = Bitmovin(api_key=API_KEY) # Create an S3 input. This resource is then used as base bucket for the input file. s3_input = S3Input(access_key=S3_INPUT_ACCESSKEY, secret_key=S3_INPUT_SECRETKEY, bucket_name=S3_INPUT_BUCKETNAME, name='S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource # Create an S3 Output. This will be used as target bucket for the muxings, sprites and manifests s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource video_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_FILEPATH, selection_mode=SelectionMode.AUTO) audio_input_stream = StreamInput(input_id=s3_input.id, input_path=S3_INPUT_FILEPATH, selection_mode=SelectionMode.AUTO) acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) # Create an Encoding. encoding = Encoding( name='Encoding sample with HLS and DASH, and VTT subtitles', cloud_region=CloudRegion.AUTO) encoding = bitmovin.encodings.Encoding.create(encoding).resource encoding_configs = [] # Iterate over all encoding profiles and create the H264 configuration with the defined height and bitrate. for encoding_profile in encoding_profiles: encoding_config = dict(profile=encoding_profile) codec = H264CodecConfiguration( name='H264 Codec {}p {}k Configuration'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), bitrate=encoding_profile.get('bitrate'), height=encoding_profile.get('height'), rate=encoding_profile.get('fps'), profile=H264Profile.HIGH) encoding_config['codec'] = bitmovin.codecConfigurations.H264.create( codec).resource encoding_configs.append(encoding_config) # Also the AAC configuration has to be created, which will be later on used to create the streams. audio_codec_configuration = AACCodecConfiguration( name='AAC Codec Configuration', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create( audio_codec_configuration).resource # With the configurations and the input file streams are now created and muxed later on. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') video_stream = Stream( codec_configuration_id=encoding_config.get('codec').id, input_streams=[video_input_stream], name='Stream {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['stream'] = bitmovin.encodings.Stream.create( object_=video_stream, encoding_id=encoding.id).resource audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], name='Audio Stream') audio_stream = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource # Create FMP4 muxings which are later used for the DASH manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') video_muxing_stream = MuxingStream(encoding_config.get('stream').id) video_muxing_output = EncodingOutput( output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/dash/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream], outputs=[video_muxing_output], name='FMP4 Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['fmp4_muxing'] = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio_dash/', acl=[acl_entry]) audio_fmp4_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio FMP4 Muxing') audio_fmp4_muxing = bitmovin.encodings.Muxing.FMP4.create( object_=audio_fmp4_muxing, encoding_id=encoding.id).resource # Create TS muxings which are later used for the HLS manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') video_muxing_stream = MuxingStream(encoding_config.get('stream').id) video_muxing_output = EncodingOutput( output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream], outputs=[video_muxing_output], name='TS Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['ts_muxing'] = bitmovin.encodings.Muxing.TS.create( object_=video_muxing, encoding_id=encoding.id).resource audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio_hls/', acl=[acl_entry]) audio_ts_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio TS Muxing') audio_ts_muxing = bitmovin.encodings.Muxing.TS.create( object_=audio_ts_muxing, encoding_id=encoding.id).resource bitmovin.encodings.Encoding.start(encoding_id=encoding.id) try: bitmovin.encodings.Encoding.wait_until_finished( encoding_id=encoding.id, check_interval=5) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for encoding to finish: {}'. format(bitmovin_error)) exit(-1) # Specify the output for manifest which will be in the OUTPUT_BASE_PATH. manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) # Create a DASH manifest and add one period with an adapation set for audio and video dash_manifest = DashManifest(manifest_name='stream.mpd', outputs=[manifest_output], name='DASH Manifest') dash_manifest = bitmovin.manifests.DASH.create(dash_manifest).resource period = Period() period = bitmovin.manifests.DASH.add_period( object_=period, manifest_id=dash_manifest.id).resource video_adaptation_set = VideoAdaptationSet() video_adaptation_set = bitmovin.manifests.DASH.add_video_adaptation_set( object_=video_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource audio_adaptation_set = AudioAdaptationSet(lang='en') audio_adaptation_set = bitmovin.manifests.DASH.add_audio_adaptation_set( object_=audio_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource subtitle_adaptation_set = SubtitleAdaptationSet(lang='en') subtitle_adaptation_set = bitmovin.manifests.DASH.add_subtitle_adaptation_set( object_=subtitle_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') muxing = encoding_config.get('fmp4_muxing') fmp4_representation_1080p = FMP4Representation( FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=muxing.id, segment_path='video/dash/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config[ 'dash'] = bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation_1080p, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id).resource fmp4_representation_audio = FMP4Representation( FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_fmp4_muxing.id, segment_path='audio_dash/') bitmovin.manifests.DASH.add_fmp4_representation( object_=fmp4_representation_audio, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=audio_adaptation_set.id) vtt_representation = VttRepresentation(vtt_url=VTT_URL) bitmovin.manifests.DASH.add_vtt_representation( object_=vtt_representation, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=subtitle_adaptation_set.id) bitmovin.manifests.DASH.start(manifest_id=dash_manifest.id) # Create a HLS manifest and add one period with an adapation set for audio and video hls_manifest = HlsManifest(manifest_name='stream.m3u8', outputs=[manifest_output], name='HLS Manifest') hls_manifest = bitmovin.manifests.HLS.create(hls_manifest).resource audio_media = AudioMedia(name='HLS Audio Media', group_id='audio', segment_path='audio_hls/', encoding_id=encoding.id, stream_id=audio_stream.id, muxing_id=audio_ts_muxing.id, language='en', uri='audio.m3u8') audio_media = bitmovin.manifests.HLS.AudioMedia.create( manifest_id=hls_manifest.id, object_=audio_media).resource vtt_media = VttMedia(name='English subtitle', group_id='subs', vtt_url=VTT_URL, uri="subtitles_en.m3u8", language='en', is_default=True) vtt_media = bitmovin.manifests.HLS.VttMedia.create( manifest_id=hls_manifest.id, object_=vtt_media).resource # Add all representation to the video adaption set for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile') stream = encoding_config.get('stream') muxing = encoding_config.get('ts_muxing') variant_stream = VariantStream( audio='audio', closed_captions='NONE', subtitles='subs', segment_path='video/hls/{}p_{}k/'.format( encoding_profile.get('height'), encoding_profile.get('bitrate')), uri='video_{}p_{}k.m3u8'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), encoding_id=encoding.id, stream_id=stream.id, muxing_id=muxing.id) variant_stream = bitmovin.manifests.HLS.VariantStream.create( manifest_id=hls_manifest.id, object_=variant_stream).resource bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) try: bitmovin.manifests.DASH.wait_until_finished( manifest_id=dash_manifest.id, check_interval=1) except BitmovinError as bitmovin_error: print( 'Exception occurred while waiting for manifest creation to finish: {}' .format(bitmovin_error)) exit(-1) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id, check_interval=1) except BitmovinError as bitmovin_error: print( 'Exception occurred while waiting for manifest creation to finish: {}' .format(bitmovin_error)) exit(-1)
def encode_file_to_ts(encoding, input, input_path, output, output_path, encoding_configs): video_input_stream = StreamInput(input_id=input.id, input_path=input_path, selection_mode=SelectionMode.AUTO) audio_input_stream = StreamInput(input_id=input.id, input_path=input_path, selection_mode=SelectionMode.AUTO) new_encoding_configs = copy.deepcopy(encoding_configs) # With the configurations and the input file streams are now created and muxed later on. for encoding_config in new_encoding_configs: encoding_type = encoding_config.get("type") if encoding_type == 'video': encoding_profile = encoding_config.get("profile") video_stream = Stream( codec_configuration_id=encoding_config.get("codec").id, input_streams=[video_input_stream], name='Stream {}p_{}k'.format(encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['stream'] = bitmovin.encodings.Stream.create( object_=video_stream, encoding_id=encoding.id).resource if encoding_type == 'audio': audio_stream = Stream( codec_configuration_id=encoding_config.get("codec").id, input_streams=[audio_input_stream], name='Audio Stream') encoding_config['stream'] = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) # Create TS muxings which are later used for the HLS manifest. # The current settings will set a segment length of 4 seconds. for encoding_config in new_encoding_configs: encoding_type = encoding_config.get("type") if encoding_type == 'video': encoding_profile = encoding_config.get("profile") video_muxing_stream = MuxingStream( encoding_config.get("stream").id) video_muxing_output = EncodingOutput( output_id=output.id, output_path=output_path + 'video/{}p_{}k/'.format(encoding_profile.get('height'), encoding_profile.get('bitrate')), acl=[acl_entry]) video_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream], outputs=[video_muxing_output], name='TS Muxing {}p_{}k'.format( encoding_profile.get('height'), encoding_profile.get('bitrate'))) encoding_config['muxing'] = bitmovin.encodings.Muxing.TS.create( object_=video_muxing, encoding_id=encoding.id).resource if encoding_type == 'audio': audio_muxing_stream = MuxingStream( encoding_config.get("stream").id) audio_muxing_output = EncodingOutput(output_id=output.id, output_path=output_path + 'audio/', acl=[acl_entry]) audio_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], outputs=[audio_muxing_output], name='Audio TS Muxing') encoding_config['muxing'] = bitmovin.encodings.Muxing.TS.create( object_=audio_muxing, encoding_id=encoding.id).resource start_encoding_request = StartEncodingRequest( encoding_mode=EncodingMode.SINGLE_PASS) bitmovin.encodings.Encoding.start( encoding_id=encoding.id, start_encoding_request=start_encoding_request) try: bitmovin.encodings.Encoding.wait_until_finished( encoding_id=encoding.id, check_interval=5) return new_encoding_configs except BitmovinError as bitmovin_error: print("Exception occurred while waiting for encoding to finish: {}". format(bitmovin_error))
def main(): s3_input = S3Input(access_key=S3_INPUT_ACCESS_KEY, secret_key=S3_INPUT_SECRET_KEY, bucket_name=S3_INPUT_BUCKET_NAME, name='Sample S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='Sample S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource encoding = Encoding(name='Python Example - Per Title', cloud_region=CloudRegion.GOOGLE_EUROPE_WEST_1, encoder_version=EncoderVersion.BETA) encoding = bitmovin.encodings.Encoding.create(encoding).resource video_input_stream = StreamInput(input_id=s3_input.id, input_path=INPUT_PATH, selection_mode=SelectionMode.AUTO) audio_input_stream = StreamInput(input_id=s3_input.id, input_path=INPUT_PATH, selection_mode=SelectionMode.AUTO) audio_codec_configuration = AACCodecConfiguration( name='example_audio_codec_configuration_english', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create( object_=audio_codec_configuration).resource audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], name='Sample Stream Audio') audio_stream = bitmovin.encodings.Stream.create( object_=audio_stream, encoding_id=encoding.id).resource video_codec_configuration = H264CodecConfiguration( name='Sample video codec configuration', profile=H264Profile.HIGH) video_codec_configuration = bitmovin.codecConfigurations.H264.create( video_codec_configuration).resource video_stream = Stream(codec_configuration_id=video_codec_configuration.id, input_streams=[video_input_stream], name='Sample Stream Video', mode=StreamMode.PER_TITLE_TEMPLATE) video_stream = bitmovin.encodings.Stream.create( object_=video_stream, encoding_id=encoding.id).resource audio_output_fmp4 = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/fmp4') audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_fmp4 = FMP4Muxing(streams=[audio_muxing_stream], segment_length=4.0, outputs=[audio_output_fmp4]) audio_muxing_fmp4 = bitmovin.encodings.Muxing.FMP4.create( object_=audio_muxing_fmp4, encoding_id=encoding.id).resource audio_output_ts = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/ts') audio_muxing_ts = TSMuxing(streams=[audio_muxing_stream], segment_length=4.0, outputs=[audio_output_ts]) audio_muxing_ts = bitmovin.encodings.Muxing.TS.create( object_=audio_muxing_ts, encoding_id=encoding.id).resource audio_representation_info = dict( fmp4_muxing=audio_muxing_fmp4, ts_muxing=audio_muxing_ts, stream=audio_stream, ) video_output_fmp4 = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/fmp4/{uuid}') video_output_ts = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/ts/{uuid}') video_muxing_stream = MuxingStream(video_stream.id) video_muxing_fmp4 = FMP4Muxing(streams=[video_muxing_stream], segment_length=4.0, outputs=[video_output_fmp4]) video_muxing_fmp4 = bitmovin.encodings.Muxing.FMP4.create( object_=video_muxing_fmp4, encoding_id=encoding.id).resource video_muxing_ts = TSMuxing(streams=[video_muxing_stream], segment_length=4.0, outputs=[video_output_ts]) video_muxing_ts = bitmovin.encodings.Muxing.TS.create( object_=video_muxing_ts, encoding_id=encoding.id).resource auto_representations = AutoRepresentation() h264_per_title_configuration = H264PerTitleConfiguration( auto_representations=auto_representations) per_title = PerTitle(h264_configuration=h264_per_title_configuration) start_encoding_request = StartEncodingRequest( per_title=per_title, encoding_mode=EncodingMode.THREE_PASS) bitmovin.encodings.Encoding.start( encoding_id=encoding.id, start_encoding_request=start_encoding_request) try: bitmovin.encodings.Encoding.wait_until_finished( encoding_id=encoding.id) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for encoding to finish: {}'. format(bitmovin_error)) create_dash_manifest(output_id=s3_output.id, encoding_id=encoding.id, audio_representation_info=audio_representation_info) create_hls_manifest(output_id=s3_output.id, encoding_id=encoding.id, audio_representation_info=audio_representation_info)
def main(): # Create an S3 input. This resource is then used as base to acquire input files. s3_input = S3Input(access_key=S3_INPUT_ACCESS_KEY, secret_key=S3_INPUT_SECRET_KEY, bucket_name=S3_INPUT_BUCKET_NAME, name='Test S3 Input') s3_input = bitmovin.inputs.S3.create(s3_input).resource # Create an S3 Output. This will be used as target bucket for the muxings, sprites and manifests s3_output = S3Output(access_key=S3_OUTPUT_ACCESSKEY, secret_key=S3_OUTPUT_SECRETKEY, bucket_name=S3_OUTPUT_BUCKETNAME, name='Test S3 Output') s3_output = bitmovin.outputs.S3.create(s3_output).resource acl_entry = ACLEntry(permission=ACLPermission.PUBLIC_READ) # Create DRM resources widevine_drm = CENCWidevineEntry(pssh=CENC_WIDEVINE_PSSH) playready_drm = CENCPlayReadyEntry(la_url=CENC_PLAYREADY_LA_URL) # Create an Encoding. This is the base entity used to configure the encoding. encoding = Encoding(name='Constrained Per-title encoding test', cloud_region=CloudRegion.AUTO, encoder_version=EncoderVersion.BETA) encoding = bitmovin.encodings.Encoding.create(encoding).resource encoding_configs = [] # Iterate over all encoding profiles and create the H264 configuration. # As we are using per-title, we do not define bitrates, instead just providing the target height as indicator for idx, _ in enumerate(encoding_profiles_h264): profile_h264 = encoding_profiles_h264[idx] encoding_config = dict(profile_h264=profile_h264) h264_codec = H264CodecConfiguration( name='Sample video codec configuration', profile=H264Profile.HIGH, height=profile_h264.get("height") ) encoding_config['h264_codec'] = bitmovin.codecConfigurations.H264.create(h264_codec).resource encoding_configs.append(encoding_config) # Also the AAC configuration has to be created, which will be later on used to create the streams. audio_codec_configuration = AACCodecConfiguration(name='AAC Codec Configuration', bitrate=128000, rate=48000) audio_codec_configuration = bitmovin.codecConfigurations.AAC.create(audio_codec_configuration).resource # create the input stream resources video_input_stream = StreamInput(input_id=s3_input.id, input_path=INPUT_PATH, selection_mode=SelectionMode.AUTO) audio_input_stream = StreamInput(input_id=s3_input.id, input_path=INPUT_PATH, selection_mode=SelectionMode.AUTO) # With the configurations and the input file, streams are now created that will be muxed later on. # As we use per-title, the streams are used as templates for encoding_config in encoding_configs: encoding_profile = encoding_config.get("profile_h264") video_stream_condition = Condition(attribute="HEIGHT", operator=">=", value=str(encoding_profile.get('height'))) video_stream = Stream(codec_configuration_id=encoding_config.get("h264_codec").id, input_streams=[video_input_stream], conditions=video_stream_condition, name='Stream H264 {}p'.format(encoding_profile.get('height')), mode=StreamMode.PER_TITLE_TEMPLATE) encoding_config['h264_stream'] = bitmovin.encodings.Stream.create(object_=video_stream, encoding_id=encoding.id).resource # create the stream for the audio audio_stream = Stream(codec_configuration_id=audio_codec_configuration.id, input_streams=[audio_input_stream], name='Audio Stream') audio_stream = bitmovin.encodings.Stream.create(object_=audio_stream, encoding_id=encoding.id).resource # === FMP4 Muxings === # Create FMP4 muxings which are later used for the DASH manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get("profile_h264") video_muxing_stream = MuxingStream(encoding_config['h264_stream'].id) video_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + "video/dash/{height}p_{bitrate}_{uuid}/", acl=[acl_entry]) video_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[video_muxing_stream], name="Video FMP4 Muxing {}p".format(encoding_profile.get('height'))) encoding_config['fmp4_muxing'] = bitmovin.encodings.Muxing.FMP4.create(object_=video_muxing, encoding_id=encoding.id).resource video_cenc = CENCDRM(key=CENC_KEY, kid=CENC_KID, widevine=widevine_drm, playReady=playready_drm, outputs=[video_muxing_output], name="Video FMP4 CENC") encoding_config['fmp4_cenc'] = bitmovin.encodings.Muxing.FMP4.DRM.CENC.create( object_=video_cenc, encoding_id=encoding.id, muxing_id=encoding_config['fmp4_muxing'].id).resource audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/dash/', acl=[acl_entry]) audio_fmp4_muxing = FMP4Muxing(segment_length=4, segment_naming='seg_%number%.m4s', init_segment_name='init.mp4', streams=[audio_muxing_stream], name='Audio FMP4 Muxing') audio_fmp4_muxing = bitmovin.encodings.Muxing.FMP4.create(object_=audio_fmp4_muxing, encoding_id=encoding.id).resource audio_cenc = CENCDRM(key=CENC_KEY, kid=CENC_KID, widevine=widevine_drm, playReady=playready_drm, outputs=[audio_muxing_output], name='Audio FMP4 CENC') audio_cenc = bitmovin.encodings.Muxing.FMP4.DRM.CENC.create(object_=audio_cenc, encoding_id=encoding.id, muxing_id=audio_fmp4_muxing.id).resource # === TS Muxings === # Create TS muxings which are later used for the HLS manifest. The current settings will set a segment length # of 4 seconds. for encoding_config in encoding_configs: encoding_profile = encoding_config.get('profile_h264') video_muxing_stream = MuxingStream(encoding_config['h264_stream'].id) video_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'video/hls/{height}p_{bitrate}_{uuid}/', acl=[acl_entry]) video_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[video_muxing_stream], name='Video TS Muxing {}p'.format(encoding_profile.get('height'))) encoding_config['ts_muxing'] = bitmovin.encodings.Muxing.TS.create(object_=video_muxing, encoding_id=encoding.id).resource video_fairplay = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[video_muxing_output], name='Video TS FairPlay') encoding_config['ts_fairplay'] = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create( object_=video_fairplay, encoding_id=encoding.id, muxing_id=encoding_config['ts_muxing'].id).resource audio_muxing_stream = MuxingStream(audio_stream.id) audio_muxing_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH + 'audio/hls/', acl=[acl_entry]) audio_ts_muxing = TSMuxing(segment_length=4, segment_naming='seg_%number%.ts', streams=[audio_muxing_stream], name='Audio TS Muxing') audio_ts_muxing = bitmovin.encodings.Muxing.TS.create(object_=audio_ts_muxing, encoding_id=encoding.id).resource audio_fairplay = FairPlayDRM(key=FAIRPLAY_KEY, iv=FAIRPLAY_IV, uri=FAIRPLAY_URI, outputs=[audio_muxing_output], name='Audio FairPlay') audio_fairplay = bitmovin.encodings.Muxing.TS.DRM.FairPlay.create(object_=audio_fairplay, encoding_id=encoding.id, muxing_id=audio_ts_muxing.id).resource # Keep the audio info together audio_representation_info = dict( fmp4_muxing=audio_fmp4_muxing, ts_muxing=audio_ts_muxing, stream=audio_stream, ts_fairplay=audio_fairplay, fmp4_cenc=audio_cenc ) # Finally create the per-title configuration to pass to the encoding auto_representations = AutoRepresentation(adopt_configuration_threshold=0.5) h264_per_title_configuration = H264PerTitleConfiguration(auto_representations=auto_representations) per_title = PerTitle(h264_configuration=h264_per_title_configuration) # And start the encoding start_encoding_request = StartEncodingRequest(per_title=per_title, encoding_mode=EncodingMode.THREE_PASS) bitmovin.encodings.Encoding.start(encoding_id=encoding.id, start_encoding_request=start_encoding_request) try: bitmovin.encodings.Encoding.wait_until_finished(encoding_id=encoding.id) except BitmovinError as bitmovin_error: print("Exception occurred while waiting for encoding to finish: {}".format(bitmovin_error)) # Specify the output for manifest which will be in the OUTPUT_BASE_PATH. manifest_output = EncodingOutput(output_id=s3_output.id, output_path=OUTPUT_BASE_PATH, acl=[acl_entry]) # === DASH MANIFEST === muxing_for_contentprotection = None drm_for_contentprotection = None # Create a DASH manifest and add one period with an adapation set for audio and video dash_manifest = DashManifest(manifest_name='stream.mpd', outputs=[manifest_output], name='DASH Manifest') dash_manifest = bitmovin.manifests.DASH.create(dash_manifest).resource period = Period() period = bitmovin.manifests.DASH.add_period(object_=period, manifest_id=dash_manifest.id).resource video_adaptation_set = VideoAdaptationSet() video_adaptation_set = bitmovin.manifests.DASH.add_video_adaptation_set(object_=video_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource audio_adaptation_set = AudioAdaptationSet(lang='en') audio_adaptation_set = bitmovin.manifests.DASH.add_audio_adaptation_set(object_=audio_adaptation_set, manifest_id=dash_manifest.id, period_id=period.id).resource # Add the audio representation segment_path = audio_representation_info.get('fmp4_cenc').outputs[0].outputPath segment_path = remove_output_base_path(segment_path) fmp4_representation_audio = DRMFMP4Representation(FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=audio_representation_info.get('fmp4_muxing').id, drm_id=audio_representation_info.get('fmp4_cenc').id, segment_path=segment_path) bitmovin.manifests.DASH.add_drm_fmp4_representation(object_=fmp4_representation_audio, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=audio_adaptation_set.id) # Add all video representations to the video adaption set muxings = bitmovin.encodings.Muxing.FMP4.list(encoding_id=encoding.id).resource for muxing in muxings: drm = bitmovin.encodings.Muxing.FMP4.DRM.CENC.list(encoding.id, muxing.id).resource segment_path = drm[0].outputs[0].outputPath if 'audio' in segment_path: # we ignore the audio muxing continue if '{uuid}' in segment_path: # we ignore any muxing with placeholders in the path - they are the template muxings, not the result muxings continue segment_path = remove_output_base_path(segment_path) muxing_for_contentprotection = muxing drm_for_contentprotection = drm[0] fmp4_representation = DRMFMP4Representation( type=FMP4RepresentationType.TEMPLATE, encoding_id=encoding.id, muxing_id=muxing.id, segment_path=segment_path, drm_id=drm[0].id ) bitmovin.manifests.DASH.add_drm_fmp4_representation( object_=fmp4_representation, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id) # add content protection to the adaptation set video_content_protection = ContentProtection(encoding_id=encoding.id, muxing_id=muxing_for_contentprotection.id, drm_id=drm_for_contentprotection.id) bitmovin.manifests.DASH.add_content_protection_to_adaptionset(object_=video_content_protection, manifest_id=dash_manifest.id, period_id=period.id, adaptationset_id=video_adaptation_set.id) bitmovin.manifests.DASH.start(manifest_id=dash_manifest.id) # === HLS MANIFEST === # Create a HLS manifest and add one period with an adapation set for audio and video hls_manifest = HlsManifest(manifest_name='stream.m3u8', outputs=[manifest_output], name='HLS Manifest') hls_manifest = bitmovin.manifests.HLS.create(hls_manifest).resource segment_path = audio_representation_info.get('ts_fairplay').outputs[0].outputPath segment_path = remove_output_base_path(segment_path) audio_media = AudioMedia(name='HLS Audio Media', group_id='audio', segment_path=segment_path, encoding_id=encoding.id, stream_id=audio_representation_info.get('stream').id, muxing_id=audio_representation_info.get('ts_muxing').id, drm_id=audio_representation_info.get('ts_fairplay').id, language='en', uri='audio.m3u8') audio_media = bitmovin.manifests.HLS.AudioMedia.create(manifest_id=hls_manifest.id, object_=audio_media).resource # Add all video representations to the video adaption set muxings = bitmovin.encodings.Muxing.TS.list(encoding_id=encoding.id).resource for muxing in muxings: drm = bitmovin.encodings.Muxing.TS.DRM.FairPlay.list(encoding.id, muxing.id).resource segment_path = drm[0].outputs[0].outputPath if 'audio' in segment_path: # we ignore the audio muxing continue if '{uuid}' in segment_path: # we ignore any muxing with placeholders in the path - they are the template muxings, not the result muxings continue segment_path = remove_output_base_path(segment_path) variant_stream = VariantStream(audio=audio_media.groupId, closed_captions='NONE', segment_path=segment_path, uri='video_{}.m3u8'.format(muxing.avgBitrate), encoding_id=encoding.id, stream_id=muxing.streams[0].streamId, muxing_id=muxing.id, drm_id=drm[0].id) bitmovin.manifests.HLS.VariantStream.create(manifest_id=hls_manifest.id, object_=variant_stream) bitmovin.manifests.HLS.start(manifest_id=hls_manifest.id) try: bitmovin.manifests.DASH.wait_until_finished(manifest_id=dash_manifest.id, check_interval=1) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for manifest creation to finish: {}'.format(bitmovin_error)) try: bitmovin.manifests.HLS.wait_until_finished(manifest_id=hls_manifest.id, check_interval=1) except BitmovinError as bitmovin_error: print('Exception occurred while waiting for manifest creation to finish: {}'.format(bitmovin_error)) exit(-1)