Source code for bitmovin_api_sdk.encoding.encodings.muxings.mp4.drm.widevine.widevine_api

# coding: utf-8

from __future__ import absolute_import

from bitmovin_api_sdk.common import BaseApi, BitmovinApiLoggerBase
from bitmovin_api_sdk.common.poscheck import poscheck_except
from bitmovin_api_sdk.models.bitmovin_response import BitmovinResponse
from bitmovin_api_sdk.models.response_envelope import ResponseEnvelope
from bitmovin_api_sdk.models.response_error import ResponseError
from bitmovin_api_sdk.models.widevine_drm import WidevineDrm
from bitmovin_api_sdk.encoding.encodings.muxings.mp4.drm.widevine.customdata.customdata_api import CustomdataApi
from bitmovin_api_sdk.encoding.encodings.muxings.mp4.drm.widevine.widevine_drm_list_query_params import WidevineDrmListQueryParams


[docs]class WidevineApi(BaseApi): @poscheck_except(2) def __init__(self, api_key, tenant_org_id=None, base_url=None, logger=None): # type: (str, str, str, BitmovinApiLoggerBase) -> None super(WidevineApi, self).__init__( api_key=api_key, tenant_org_id=tenant_org_id, base_url=base_url, logger=logger ) self.customdata = CustomdataApi( api_key=api_key, tenant_org_id=tenant_org_id, base_url=base_url, logger=logger )
[docs] def create(self, encoding_id, muxing_id, widevine_drm, **kwargs): # type: (string_types, string_types, WidevineDrm, dict) -> WidevineDrm """Add Widevine DRM to an MP4 muxing :param encoding_id: Id of the encoding. :type encoding_id: string_types, required :param muxing_id: Id of the MP4 muxing. :type muxing_id: string_types, required :param widevine_drm: The Widevine DRM to be created :type widevine_drm: WidevineDrm, required :return: Widevine DRM :rtype: WidevineDrm """ return self.api_client.post( '/encoding/encodings/{encoding_id}/muxings/mp4/{muxing_id}/drm/widevine', widevine_drm, path_params={'encoding_id': encoding_id, 'muxing_id': muxing_id}, type=WidevineDrm, **kwargs )
[docs] def delete(self, encoding_id, muxing_id, drm_id, **kwargs): # type: (string_types, string_types, string_types, dict) -> BitmovinResponse """Delete Widevine DRM from an MP4 muxing :param encoding_id: Id of the encoding. :type encoding_id: string_types, required :param muxing_id: Id of the MP4 muxing :type muxing_id: string_types, required :param drm_id: Id of the widevine drm. :type drm_id: string_types, required :return: Id of the Widevine DRM :rtype: BitmovinResponse """ return self.api_client.delete( '/encoding/encodings/{encoding_id}/muxings/mp4/{muxing_id}/drm/widevine/{drm_id}', path_params={'encoding_id': encoding_id, 'muxing_id': muxing_id, 'drm_id': drm_id}, type=BitmovinResponse, **kwargs )
[docs] def get(self, encoding_id, muxing_id, drm_id, **kwargs): # type: (string_types, string_types, string_types, dict) -> WidevineDrm """Widevine DRM Details of an MP4 muxing :param encoding_id: Id of the encoding. :type encoding_id: string_types, required :param muxing_id: Id of the MP4 muxing. :type muxing_id: string_types, required :param drm_id: Id of the widevine drm. :type drm_id: string_types, required :return: Widevine DRM :rtype: WidevineDrm """ return self.api_client.get( '/encoding/encodings/{encoding_id}/muxings/mp4/{muxing_id}/drm/widevine/{drm_id}', path_params={'encoding_id': encoding_id, 'muxing_id': muxing_id, 'drm_id': drm_id}, type=WidevineDrm, **kwargs )
[docs] def list(self, encoding_id, muxing_id, query_params=None, **kwargs): # type: (string_types, string_types, WidevineDrmListQueryParams, dict) -> WidevineDrm """List Widevine DRMs of an MP4 muxing :param encoding_id: Id of the encoding. :type encoding_id: string_types, required :param muxing_id: Id of the mp4 fragment. :type muxing_id: string_types, required :param query_params: Query parameters :type query_params: WidevineDrmListQueryParams :return: List of Widevine DRMs :rtype: WidevineDrm """ return self.api_client.get( '/encoding/encodings/{encoding_id}/muxings/mp4/{muxing_id}/drm/widevine', path_params={'encoding_id': encoding_id, 'muxing_id': muxing_id}, query_params=query_params, pagination_response=True, type=WidevineDrm, **kwargs )