LCOV - code coverage report
Current view: top level - media/public/include - IMediaKeysCapabilities.h (source / functions) Coverage Total Hit
Test: coverage.info Lines: 100.0 % 4 4
Test Date: 2025-03-21 11:02:39 Functions: 100.0 % 4 4

            Line data    Source code
       1              : /*
       2              :  * If not stated otherwise in this file or this component's LICENSE file the
       3              :  * following copyright and licenses apply:
       4              :  *
       5              :  * Copyright 2022 Sky UK
       6              :  *
       7              :  * Licensed under the Apache License, Version 2.0 (the "License");
       8              :  * you may not use this file except in compliance with the License.
       9              :  * You may obtain a copy of the License at
      10              :  *
      11              :  * http://www.apache.org/licenses/LICENSE-2.0
      12              :  *
      13              :  * Unless required by applicable law or agreed to in writing, software
      14              :  * distributed under the License is distributed on an "AS IS" BASIS,
      15              :  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
      16              :  * See the License for the specific language governing permissions and
      17              :  * limitations under the License.
      18              :  */
      19              : 
      20              : #ifndef FIREBOLT_RIALTO_I_MEDIA_KEYS_CAPABILITIES_H_
      21              : #define FIREBOLT_RIALTO_I_MEDIA_KEYS_CAPABILITIES_H_
      22              : 
      23              : /**
      24              :  * @file IMediaKeysCapabilities.h
      25              :  *
      26              :  * The definition of the IMediaKeysCapabilities interface.
      27              :  */
      28              : 
      29              : #include <memory>
      30              : #include <string>
      31              : #include <vector>
      32              : 
      33              : namespace firebolt::rialto
      34              : {
      35              : class IMediaKeysCapabilities;
      36              : 
      37              : /**
      38              :  * @brief IMediaKeysCapabilities factory class, for getting the IMediaKeysCapabilities singleton object.
      39              :  */
      40              : class IMediaKeysCapabilitiesFactory
      41              : {
      42              : public:
      43           92 :     IMediaKeysCapabilitiesFactory() = default;
      44           92 :     virtual ~IMediaKeysCapabilitiesFactory() = default;
      45              : 
      46              :     /**
      47              :      * @brief Gets the IMediaKeysCapabilitiesFactory instance.
      48              :      *
      49              :      * @retval the factory instance or null on error.
      50              :      */
      51              :     static std::shared_ptr<IMediaKeysCapabilitiesFactory> createFactory();
      52              : 
      53              :     /**
      54              :      * @brief Gets the IMediaKeysCapabilities singleton object.
      55              :      *
      56              :      * @retval the MediaKeysCapabilities instance or null on error.
      57              :      */
      58              :     virtual std::shared_ptr<IMediaKeysCapabilities> getMediaKeysCapabilities() const = 0;
      59              : };
      60              : 
      61              : /**
      62              :  * @brief The definition of the IMediaKeysCapabilities interface.
      63              :  *
      64              :  * This interface defines the public API of Rialto for querying EME decryption capabilities.
      65              :  * It should be implemented by both Rialto Client & Rialto Server.
      66              :  */
      67              : class IMediaKeysCapabilities
      68              : {
      69              : public:
      70          143 :     IMediaKeysCapabilities() = default;
      71          143 :     virtual ~IMediaKeysCapabilities() = default;
      72              : 
      73              :     IMediaKeysCapabilities(const IMediaKeysCapabilities &) = delete;
      74              :     IMediaKeysCapabilities &operator=(const IMediaKeysCapabilities &) = delete;
      75              :     IMediaKeysCapabilities(IMediaKeysCapabilities &&) = delete;
      76              :     IMediaKeysCapabilities &operator=(IMediaKeysCapabilities &&) = delete;
      77              : 
      78              :     /**
      79              :      * @brief Returns the EME key systems supported by Rialto
      80              :      *
      81              :      * @retval The supported key systems.
      82              :      */
      83              :     virtual std::vector<std::string> getSupportedKeySystems() = 0;
      84              : 
      85              :     /**
      86              :      * @brief Indicates if the specified key system is supported.
      87              :      *
      88              :      * This method should be called to ensure that the specified key
      89              :      * system is supported by Rialto.
      90              :      *
      91              :      * @param[in] keySystem : The key system.
      92              :      *
      93              :      * @retval true if supported.
      94              :      */
      95              :     virtual bool supportsKeySystem(const std::string &keySystem) = 0;
      96              : 
      97              :     /**
      98              :      * @brief Returns version of supported key system
      99              :      *
     100              :      * @param[in] keySystem    : The key system.
     101              :      * @param[out] version     : The supported version of the key system
     102              :      *
     103              :      * @retval true if operation was successful
     104              :      */
     105              :     virtual bool getSupportedKeySystemVersion(const std::string &keySystem, std::string &version) = 0;
     106              : 
     107              :     /**
     108              :      * @brief Gets support server certificate.
     109              :      *
     110              :      * Some DRMs (e.g. WideVine) use a system-wide server certificate. This method
     111              :      * gets if system has support for that certificate.
     112              :      *
     113              :      * @param[in] keySystem    : The key system.
     114              :      *
     115              :      * @retval true if server certificate is supported
     116              :      */
     117              :     virtual bool isServerCertificateSupported(const std::string &keySystem) = 0;
     118              : };
     119              : 
     120              : }; // namespace firebolt::rialto
     121              : 
     122              : #endif // FIREBOLT_RIALTO_I_MEDIA_KEYS_CAPABILITIES_H_
        

Generated by: LCOV version 2.0-1