/* * Copyright (C) 2021 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef DRM_HAL_AIDL_H_ #define DRM_HAL_AIDL_H_ #include #include #include #include #include #include #include #include #include using IDrmPluginAidl = ::aidl::android::hardware::drm::IDrmPlugin; using IDrmFactoryAidl = ::aidl::android::hardware::drm::IDrmFactory; using EventTypeAidl = ::aidl::android::hardware::drm::EventType; using KeyStatusAidl = ::aidl::android::hardware::drm::KeyStatus; using ::aidl::android::hardware::drm::Uuid; namespace android { struct DrmHalAidl : public IDrm{ struct DrmSessionClient; DrmHalAidl(); virtual ~DrmHalAidl(); virtual status_t initCheck() const; virtual status_t isCryptoSchemeSupported(const uint8_t uuid[16], const String8& mimeType, DrmPlugin::SecurityLevel securityLevel, bool* result); virtual status_t createPlugin(const uint8_t uuid[16], const String8& appPackageName); virtual status_t destroyPlugin(); virtual status_t openSession(DrmPlugin::SecurityLevel securityLevel, Vector& sessionId); virtual status_t closeSession(Vector const& sessionId); virtual status_t getKeyRequest(Vector const& sessionId, Vector const& initData, String8 const& mimeType, DrmPlugin::KeyType keyType, KeyedVector const& optionalParameters, Vector& request, String8& defaultUrl, DrmPlugin::KeyRequestType* keyRequestType); virtual status_t provideKeyResponse(Vector const& sessionId, Vector const& response, Vector& keySetId); virtual status_t removeKeys(Vector const& keySetId); virtual status_t restoreKeys(Vector const& sessionId, Vector const& keySetId); virtual status_t queryKeyStatus(Vector const& sessionId, KeyedVector& infoMap) const; virtual status_t getProvisionRequest(String8 const& certType, String8 const& certAuthority, Vector& request, String8& defaultUrl); virtual status_t provideProvisionResponse(Vector const& response, Vector& certificate, Vector& wrappedKey); virtual status_t getSecureStops(List>& secureStops); virtual status_t getSecureStopIds(List>& secureStopIds); virtual status_t getSecureStop(Vector const& ssid, Vector& secureStop); virtual status_t releaseSecureStops(Vector const& ssRelease); virtual status_t removeSecureStop(Vector const& ssid); virtual status_t removeAllSecureStops(); virtual status_t getHdcpLevels(DrmPlugin::HdcpLevel* connectedLevel, DrmPlugin::HdcpLevel* maxLevel) const; virtual status_t getNumberOfSessions(uint32_t* currentSessions, uint32_t* maxSessions) const; virtual status_t getSecurityLevel(Vector const& sessionId, DrmPlugin::SecurityLevel* level) const; virtual status_t getOfflineLicenseKeySetIds(List>& keySetIds) const; virtual status_t removeOfflineLicense(Vector const& keySetId); virtual status_t getOfflineLicenseState(Vector const& keySetId, DrmPlugin::OfflineLicenseState* licenseState) const; virtual status_t getPropertyString(String8 const& name, String8& value) const; virtual status_t getPropertyByteArray(String8 const& name, Vector& value) const; virtual status_t setPropertyString(String8 const& name, String8 const& value) const; virtual status_t setPropertyByteArray(String8 const& name, Vector const& value) const; virtual status_t getMetrics(const sp& consumer); virtual status_t setCipherAlgorithm(Vector const& sessionId, String8 const& algorithm); virtual status_t setMacAlgorithm(Vector const& sessionId, String8 const& algorithm); virtual status_t encrypt(Vector const& sessionId, Vector const& keyId, Vector const& input, Vector const& iv, Vector& output); virtual status_t decrypt(Vector const& sessionId, Vector const& keyId, Vector const& input, Vector const& iv, Vector& output); virtual status_t sign(Vector const& sessionId, Vector const& keyId, Vector const& message, Vector& signature); virtual status_t verify(Vector const& sessionId, Vector const& keyId, Vector const& message, Vector const& signature, bool& match); virtual status_t signRSA(Vector const& sessionId, String8 const& algorithm, Vector const& message, Vector const& wrappedKey, Vector& signature); virtual status_t setListener(const sp& listener); virtual status_t requiresSecureDecoder(const char* mime, bool* required) const; virtual status_t requiresSecureDecoder(const char* mime, DrmPlugin::SecurityLevel securityLevel, bool* required) const; virtual status_t setPlaybackId(Vector const& sessionId, const char* playbackId); virtual status_t getLogMessages(Vector& logs) const; virtual status_t getSupportedSchemes(std::vector &schemes) const; ::ndk::ScopedAStatus onEvent(EventTypeAidl in_eventType, const std::vector& in_sessionId, const std::vector& in_data); ::ndk::ScopedAStatus onExpirationUpdate(const std::vector& in_sessionId, int64_t in_expiryTimeInMS); ::ndk::ScopedAStatus onKeysChange(const std::vector& in_sessionId, const std::vector& in_keyStatusList, bool in_hasNewUsableKey); ::ndk::ScopedAStatus onSessionLostState(const std::vector& in_sessionId); private: static Mutex mLock; mutable MediaDrmMetrics mMetrics; std::shared_ptr mListener; const std::vector> mFactories; std::shared_ptr mPlugin; status_t mInitCheck; std::vector> mOpenSessions; void cleanup(); void closeOpenSessions(); std::string reportPluginMetrics() const; std::string reportFrameworkMetrics(const std::string& pluginMetrics) const; status_t getPropertyStringInternal(String8 const& name, String8& value) const; status_t getPropertyByteArrayInternal(String8 const& name, Vector& value) const; DISALLOW_EVIL_CONSTRUCTORS(DrmHalAidl); }; } // namespace android #endif // DRM_HAL_AIDL_H_