diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/media/ipc/MFCDMChild.h | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/media/ipc/MFCDMChild.h')
-rw-r--r-- | dom/media/ipc/MFCDMChild.h | 146 |
1 files changed, 146 insertions, 0 deletions
diff --git a/dom/media/ipc/MFCDMChild.h b/dom/media/ipc/MFCDMChild.h new file mode 100644 index 0000000000..e022e67862 --- /dev/null +++ b/dom/media/ipc/MFCDMChild.h @@ -0,0 +1,146 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef DOM_MEDIA_IPC_MFCDMCHILD_H_ +#define DOM_MEDIA_IPC_MFCDMCHILD_H_ + +#include <unordered_map> +#include "mozilla/Atomics.h" +#include "mozilla/MozPromise.h" +#include "mozilla/PMFCDMChild.h" + +namespace mozilla { + +class WMFCDMProxyCallback; + +/** + * MFCDMChild is a content process proxy to MFCDMParent and the actual CDM + * running in utility process. + */ +class MFCDMChild final : public PMFCDMChild { + public: + NS_INLINE_DECL_THREADSAFE_REFCOUNTING(MFCDMChild); + + explicit MFCDMChild(const nsAString& aKeySystem); + + using CapabilitiesPromise = MozPromise<MFCDMCapabilitiesIPDL, nsresult, true>; + RefPtr<CapabilitiesPromise> GetCapabilities(); + + template <typename PromiseType> + already_AddRefed<PromiseType> InvokeAsync( + std::function<void()>&& aCall, const char* aCallerName, + MozPromiseHolder<PromiseType>& aPromise); + + using InitPromise = MozPromise<MFCDMInitIPDL, nsresult, true>; + RefPtr<InitPromise> Init(const nsAString& aOrigin, + const CopyableTArray<nsString>& aInitDataTypes, + const KeySystemConfig::Requirement aPersistentState, + const KeySystemConfig::Requirement aDistinctiveID, + const bool aHWSecure, + WMFCDMProxyCallback* aProxyCallback); + + using SessionPromise = MozPromise<nsString, nsresult, true>; + RefPtr<SessionPromise> CreateSessionAndGenerateRequest( + uint32_t aPromiseId, const KeySystemConfig::SessionType aSessionType, + const nsAString& aInitDataType, const nsTArray<uint8_t>& aInitData); + + RefPtr<GenericPromise> LoadSession( + uint32_t aPromiseId, const KeySystemConfig::SessionType aSessionType, + const nsAString& aSessionId); + + RefPtr<GenericPromise> UpdateSession(uint32_t aPromiseId, + const nsAString& aSessionId, + nsTArray<uint8_t>& aResponse); + + RefPtr<GenericPromise> CloseSession(uint32_t aPromiseId, + const nsAString& aSessionId); + + RefPtr<GenericPromise> RemoveSession(uint32_t aPromiseId, + const nsAString& aSessionId); + + mozilla::ipc::IPCResult RecvOnSessionKeyMessage( + const MFCDMKeyMessage& aMessage); + mozilla::ipc::IPCResult RecvOnSessionKeyStatusesChanged( + const MFCDMKeyStatusChange& aKeyStatuses); + mozilla::ipc::IPCResult RecvOnSessionKeyExpiration( + const MFCDMKeyExpiration& aExpiration); + + uint64_t Id() const { return mId; } + + void IPDLActorDestroyed() { + AssertOnManagerThread(); + mIPDLSelfRef = nullptr; + if (!mShutdown) { + // Remote crashed! + mState = NS_ERROR_NOT_AVAILABLE; + } + } + void Shutdown(); + + nsISerialEventTarget* ManagerThread() { return mManagerThread; } + void AssertOnManagerThread() const { + MOZ_ASSERT(mManagerThread->IsOnCurrentThread()); + } + + private: + ~MFCDMChild(); + + using RemotePromise = GenericNonExclusivePromise; + RefPtr<RemotePromise> EnsureRemote(); + + void AssertSendable(); + + const nsString mKeySystem; + + const RefPtr<nsISerialEventTarget> mManagerThread; + RefPtr<MFCDMChild> mIPDLSelfRef; + + RefPtr<RemotePromise> mRemotePromise; + MozPromiseHolder<RemotePromise> mRemotePromiseHolder; + MozPromiseRequestHolder<RemotePromise> mRemoteRequest; + // Before EnsureRemote(): NS_ERROR_NOT_INITIALIZED; After EnsureRemote(): + // NS_OK or some error code. + Atomic<nsresult> mState; + + MozPromiseHolder<CapabilitiesPromise> mCapabilitiesPromiseHolder; + + Atomic<bool> mShutdown; + + // This represents an unique Id to indentify the CDM in the remote process. + // 0(zero) means the CDM is not yet initialized. + // Modified on the manager thread, and read on other threads. + Atomic<uint64_t> mId; + MozPromiseHolder<InitPromise> mInitPromiseHolder; + using InitIPDLPromise = MozPromise<mozilla::MFCDMInitResult, + mozilla::ipc::ResponseRejectReason, true>; + MozPromiseRequestHolder<InitIPDLPromise> mInitRequest; + + MozPromiseHolder<SessionPromise> mCreateSessionPromiseHolder; + MozPromiseRequestHolder<CreateSessionAndGenerateRequestPromise> + mCreateSessionRequest; + + MozPromiseHolder<GenericPromise> mLoadSessionPromiseHolder; + MozPromiseRequestHolder<LoadSessionPromise> mLoadSessionRequest; + + MozPromiseHolder<GenericPromise> mUpdateSessionPromiseHolder; + MozPromiseRequestHolder<UpdateSessionPromise> mUpdateSessionRequest; + + MozPromiseHolder<GenericPromise> mCloseSessionPromiseHolder; + MozPromiseRequestHolder<CloseSessionPromise> mCloseSessionRequest; + + MozPromiseHolder<GenericPromise> mRemoveSessionPromiseHolder; + MozPromiseRequestHolder<RemoveSessionPromise> mRemoveSessionRequest; + + std::unordered_map<uint32_t, MozPromiseHolder<SessionPromise>> + mPendingSessionPromises; + + std::unordered_map<uint32_t, MozPromiseHolder<GenericPromise>> + mPendingGenericPromises; + + RefPtr<WMFCDMProxyCallback> mProxyCallback; +}; + +} // namespace mozilla + +#endif // DOM_MEDIA_IPC_MFCDMCHILD_H_ |