/* * 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 #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 DrmStatus initCheck() const; virtual DrmStatus isCryptoSchemeSupported(const uint8_t uuid[16], const String8& mimeType, DrmPlugin::SecurityLevel securityLevel, bool* result); virtual DrmStatus createPlugin(const uint8_t uuid[16], const String8& appPackageName); virtual DrmStatus destroyPlugin(); virtual DrmStatus openSession(DrmPlugin::SecurityLevel securityLevel, Vector& sessionId); virtual DrmStatus closeSession(Vector const& sessionId); virtual DrmStatus getKeyRequest(Vector const& sessionId, Vector const& initData, String8 const& mimeType, DrmPlugin::KeyType keyType, KeyedVector const& optionalParameters, Vector& request, String8& defaultUrl, DrmPlugin::KeyRequestType* keyRequestType); virtual DrmStatus provideKeyResponse(Vector const& sessionId, Vector const& response, Vector& keySetId); virtual DrmStatus removeKeys(Vector const& keySetId); virtual DrmStatus restoreKeys(Vector const& sessionId, Vector const& keySetId); virtual DrmStatus queryKeyStatus(Vector const& sessionId, KeyedVector& infoMap) const; virtual DrmStatus getProvisionRequest(String8 const& certType, String8 const& certAuthority, Vector& request, String8& defaultUrl); virtual DrmStatus provideProvisionResponse(Vector const& response, Vector& certificate, Vector& wrappedKey); virtual DrmStatus getSecureStops(List>& secureStops); virtual DrmStatus getSecureStopIds(List>& secureStopIds); virtual DrmStatus getSecureStop(Vector const& ssid, Vector& secureStop); virtual DrmStatus releaseSecureStops(Vector const& ssRelease); virtual DrmStatus removeSecureStop(Vector const& ssid); virtual DrmStatus removeAllSecureStops(); virtual DrmStatus getHdcpLevels(DrmPlugin::HdcpLevel* connectedLevel, DrmPlugin::HdcpLevel* maxLevel) const; virtual DrmStatus getNumberOfSessions(uint32_t* currentSessions, uint32_t* maxSessions) const; virtual DrmStatus getSecurityLevel(Vector const& sessionId, DrmPlugin::SecurityLevel* level) const; virtual DrmStatus getOfflineLicenseKeySetIds(List>& keySetIds) const; virtual DrmStatus removeOfflineLicense(Vector const& keySetId); virtual DrmStatus getOfflineLicenseState(Vector const& keySetId, DrmPlugin::OfflineLicenseState* licenseState) const; virtual DrmStatus getPropertyString(String8 const& name, String8& value) const; virtual DrmStatus getPropertyByteArray(String8 const& name, Vector& value) const; virtual DrmStatus setPropertyString(String8 const& name, String8 const& value) const; virtual DrmStatus setPropertyByteArray(String8 const& name, Vector const& value) const; virtual DrmStatus getMetrics(const sp& consumer); virtual DrmStatus setCipherAlgorithm(Vector const& sessionId, String8 const& algorithm); virtual DrmStatus setMacAlgorithm(Vector const& sessionId, String8 const& algorithm); virtual DrmStatus encrypt(Vector const& sessionId, Vector const& keyId, Vector const& input, Vector const& iv, Vector& output); virtual DrmStatus decrypt(Vector const& sessionId, Vector const& keyId, Vector const& input, Vector const& iv, Vector& output); virtual DrmStatus sign(Vector const& sessionId, Vector const& keyId, Vector const& message, Vector& signature); virtual DrmStatus verify(Vector const& sessionId, Vector const& keyId, Vector const& message, Vector const& signature, bool& match); virtual DrmStatus signRSA(Vector const& sessionId, String8 const& algorithm, Vector const& message, Vector const& wrappedKey, Vector& signature); virtual DrmStatus setListener(const sp& listener); virtual DrmStatus requiresSecureDecoder(const char* mime, bool* required) const; virtual DrmStatus requiresSecureDecoder(const char* mime, DrmPlugin::SecurityLevel securityLevel, bool* required) const; virtual DrmStatus setPlaybackId(Vector const& sessionId, const char* playbackId); virtual DrmStatus getLogMessages(Vector& logs) const; virtual DrmStatus 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; std::shared_ptr 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; DrmStatus getPropertyStringInternal(String8 const& name, String8& value) const; DrmStatus getPropertyByteArrayInternal(String8 const& name, Vector& value) const; DISALLOW_EVIL_CONSTRUCTORS(DrmHalAidl); }; } // namespace android #endif // DRM_HAL_AIDL_H_