summaryrefslogtreecommitdiffstats
path: root/dom/media/GetUserMediaRequest.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /dom/media/GetUserMediaRequest.cpp
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--dom/media/GetUserMediaRequest.cpp78
1 files changed, 78 insertions, 0 deletions
diff --git a/dom/media/GetUserMediaRequest.cpp b/dom/media/GetUserMediaRequest.cpp
new file mode 100644
index 0000000000..0bdf1cb277
--- /dev/null
+++ b/dom/media/GetUserMediaRequest.cpp
@@ -0,0 +1,78 @@
+/* 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/. */
+
+#include "GetUserMediaRequest.h"
+
+#include "base/basictypes.h"
+#include "mozilla/dom/MediaStreamBinding.h"
+#include "mozilla/dom/GetUserMediaRequestBinding.h"
+#include "nsIScriptGlobalObject.h"
+#include "nsPIDOMWindow.h"
+
+namespace mozilla::dom {
+
+GetUserMediaRequest::GetUserMediaRequest(
+ nsPIDOMWindowInner* aInnerWindow, const nsAString& aCallID,
+ const MediaStreamConstraints& aConstraints, bool aIsSecure,
+ bool aIsHandlingUserInput)
+ : mInnerWindowID(aInnerWindow->WindowID()),
+ mOuterWindowID(aInnerWindow->GetOuterWindow()->WindowID()),
+ mCallID(aCallID),
+ mConstraints(new MediaStreamConstraints(aConstraints)),
+ mIsSecure(aIsSecure),
+ mIsHandlingUserInput(aIsHandlingUserInput) {}
+
+GetUserMediaRequest::GetUserMediaRequest(nsPIDOMWindowInner* aInnerWindow,
+ const nsAString& aRawId,
+ const nsAString& aMediaSource,
+ bool aIsHandlingUserInput)
+ : mInnerWindowID(0),
+ mOuterWindowID(0),
+ mRawID(aRawId),
+ mMediaSource(aMediaSource),
+ mIsSecure(false),
+ mIsHandlingUserInput(aIsHandlingUserInput) {
+ if (aInnerWindow && aInnerWindow->GetOuterWindow()) {
+ mOuterWindowID = aInnerWindow->GetOuterWindow()->WindowID();
+ }
+}
+
+NS_IMPL_CYCLE_COLLECTION_WRAPPERCACHE_0(GetUserMediaRequest)
+NS_IMPL_CYCLE_COLLECTING_ADDREF(GetUserMediaRequest)
+NS_IMPL_CYCLE_COLLECTING_RELEASE(GetUserMediaRequest)
+NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION(GetUserMediaRequest)
+ NS_WRAPPERCACHE_INTERFACE_MAP_ENTRY
+ NS_INTERFACE_MAP_ENTRY(nsISupports)
+NS_INTERFACE_MAP_END
+
+JSObject* GetUserMediaRequest::WrapObject(JSContext* aCx,
+ JS::Handle<JSObject*> aGivenProto) {
+ return GetUserMediaRequest_Binding::Wrap(aCx, this, aGivenProto);
+}
+
+nsISupports* GetUserMediaRequest::GetParentObject() { return nullptr; }
+
+void GetUserMediaRequest::GetCallID(nsString& retval) { retval = mCallID; }
+
+void GetUserMediaRequest::GetRawID(nsString& retval) { retval = mRawID; }
+
+void GetUserMediaRequest::GetMediaSource(nsString& retval) {
+ retval = mMediaSource;
+}
+
+uint64_t GetUserMediaRequest::WindowID() { return mOuterWindowID; }
+
+uint64_t GetUserMediaRequest::InnerWindowID() { return mInnerWindowID; }
+
+bool GetUserMediaRequest::IsSecure() { return mIsSecure; }
+
+bool GetUserMediaRequest::IsHandlingUserInput() const {
+ return mIsHandlingUserInput;
+}
+
+void GetUserMediaRequest::GetConstraints(MediaStreamConstraints& result) {
+ result = *mConstraints;
+}
+
+} // namespace mozilla::dom