mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
b564bd67d3
- Use CompositorWidgetProxy for dispatching vsync to the compositor. (bug 1269037 part 1, r=mchang) (c8b7a4240c) - Remove unused null widget checks. (bug 1269037 part 2, r=mchang) (4f4cc9952b) - Bug 1269422: Wrap Gonk widget in |CompositorWidgetProxyWrapper|. r=dvander (4513035cbf) - Remove nsBaseWidget::NewCompositorBridgeParent. (bug 1272472 part 1, r=kats) (ca813c1f2b) - Use IPDL to schedule composites on GTK. (bug 1272472 part 2, r=nical) (7402cf834e) - Use IPC to schedule composites on Windows. (bug 1272472 part 3, r=jimm) (e5d7281dd7) - Don't use nsIWidget to check APZ in LayerManagerComposite. (bug 1269653 part 1, r=kats) (79a1644111) - Restrict SetDispAcquireFence's nsIWidget access to Gonk. (bug 1269653 part 2, r=kats) (72110b7bc7) - Bug 1264764 - Move PTexture under PCompositorBridge r=nical,dvander (17e6ec7fc1) - Move CompositorThreadHolder into its own file. (bug 1273017 part 1, r=mattwoodrow) (464ede8be1) - Move CompositorBridgeParent::CompositorLoop to CompositorThreadHolder. (bug 1273017 part 2, r=mattwoodrow) (85708f3cde) - Bug 1268313: Part 1 - Be explicit about which NewRunnableMethod callers want to be able to cancel. r=froydnj (faa07aa139) - Bug 1268313: Part 2 - Replace some NewRunnableMethods with NS_NewNonOwningRunnableMethod. r=froydnj (010c43d000) - Bug 1268313: Part 3 - Replace some NewCancelableRunnableMethod with NS_NewNonOwningCancelableRunnableMethod. r=froydnj (55018ef234) - Bug 1268313: Part 4 - Replace NewCancelableRunnableMethod with NS_NewCancelableRunnableMethod. r=froydnj (c22711b35d) - Bug 1268313: Part 5 - Make NS_NewRunnableMethod able to call const functions. r=froydnj (b0f60963a3) - Bug 1268313: Part 6 - Replace NewRunnableMethod with NS_NewRunnableMethod. r=froydnj (18d40def2c) - Bug 1260950 - Set mInitialSizeFound to true when the initial size id found. r=jesup, r=pehrsons a=kwierso (5d6abe57e0) - Bug 1237176 - Notify synth start if we get a finished event without a blocking-changed event. r=roc (c1aebe903a) - Bug 911546, use a runnable so that popups don't rollup during a grab, r=karlt (a06bd44e6c) - Bug 1237617 - Call nsWindow::ForcePresent during going active r=bas.schouten (066cad8f89) - Bug 1268313: Part 7 - Move NS_NewRunnableMethod and friends to mozilla::NewRunnableMethod. r=froydnj (8b4bf34961) - Bug 1266595: Followup to fix IPDL tests. r=billm (216f2dcff5) - Bug 1268313: Fix up IPDL tests. r=billm (228348d642) - Add WinCompositorWidgetProxy. (bug 1265975 part 1, r=jimm) (bfafe7a8e2) - Implement WinCompositorWidgetProxy::GetClientSize. (bug 1265975 part 2, r=jimm) (a8710a3259) - Move the WM_SETTEXT present lock to CompositorWidgetProxy. (bug 1265975 part 3, r=jimm) (297ce28c8a) - Move transparency handling to WinCompositorWigetProxy. (bug 1265975 part 4, r=jimm) (46ba0c6d01) - Remove Windows-specific compositor calls to nsIWidget. (bug 1265975 part 5, r=jimm) (3ef157c160) - Remove plugin-related CompositorBridgeParent use of nsIWidget. (bug 1265975 part 6, r=jimm) (6d80cdd6fd) - Hide top-level CompositorBridgeParents behind a new API. (bug 1272472 part 4, r=mattwoodrow,kats,gwagner) (228c0efdb7) - Bug 1253424 - part 1 - add a already_AddRefed nsTransactionStack::Push overload; r=erahm (7059e20914) - Bug 1253424 - part 2 - add nsTransactionStack::IsEmpty; r=erahm (7e9764a146) - Bug 1254618 - modify nsTransactionStack to use nsDeque rather than std::deque; r=ehsan (5e47ea431e) - Bug 1136857 - Make DOMStorageCache::mLoaded flag atomic to prevent potential races, r=nfroyd (39aaea1de3) - Bug 1265408 - Add webidl for IIRFilterNode; r=smaug (040ce9aa43) - Bug 1265408 - Implement IIRFilterNode; r=padenot (6bf569a412) - Bug 1265408 - Import IIRFilter from blink; r=padenot (71b28c0ad2) - Bug 1265408 - Use IIRFilter from blink; r=padenot (5d058d8568) - Bug 1265408 - Add buffersAreZero to IIRFilter; r=karlt (45edba3e13) - Bug 1265408 - Avoid subnormals in IIRFilter; r=karlt (0e1ae93f0b) - Bug 1265408 - Add LogToDeveloperConsole to WebAudioUtils; r=padenot (88d5f0222a) - Bug 1268984 - Store GMPStorage on GMPServiceParent so that it persists inside the same PB session. r=gerald (17d4d0abaf) - Bug 1267905 - Replace uses of ScopedCERTCertList with UniqueCERTCertList. r=keeler (783bf11b2a) - Bug 1270005 - Replace uses of ScopedPK11SlotInfo with UniquePK11SlotInfo in PSM. r=keeler (ea9a4011aa) - Bug 1271501 - Remove unnecessary uses of reinterpret_cast in PSM. r=keeler (6be40f0a85) - Bug 1271501 - Downgrade unnecessarily strong reinterpret_casts in PSM. r=keeler (95245f00ce) - Bug 1082346 - 01. Convert PKCS12 password endian using copyAndSwapToBigEndian. r=keeler (9cc58fc550) - Bug 1082346 - 02. Test case. r=keeler r=Cykesiopka (7fb0e8abc4) - Bug 160122 - Stop using PR_smprintf in PSM. r=keeler (1e5b68819c) - Bug 1271501 - Use mozilla::BitwiseCast instead of reinterpret_cast in PSM. r=keeler (894966a2ef) - Bug 1273855: TraceLogger - Include PID in the log names in order to support browser with e10s, r=bbouvier (8cf2233db3) - Bug 1274189. Part 1 - rename some functions to be consistent with other MediaDataDecoder sub-classes. r=jya. (4511b3d3f7) - Bug 1274189. Part 2 - remove use of FlushableTaskQueue::Flush(). r=jya. (77e745fdd1) - Bug 1274189. Part 3 - remove use of FlushableTaskQueue. r=jya (aac61dcd02) - Bug 1269963. Part 1 - Add a SyncRunnable::DispatchToThread() overload for AbstractThread. r=bobbyholley. (839752aff4) - Bug 1269672 - part1 : revert sampling rate changing of the bug1235612. (9015782e13) - Bug 1270698 - check if we need to enter buffering periodically to ensure we start buffering when running out of decoded audio/video data. r=cpearce. (16734549b7) - Bug 1271581 - use newCurrentTime, instead of GetMediaTime() to decide the nextState; r=jwwang (9c5075eada) - Bug 1224973 - Part 1: Remove MediaDecoderOwner->IsHidden(). r=cpearce,jwwang (4fde3ede5a) - Bug 1224973 - Part 2: Set MediaDecoder visibility via NotifyOwnerActivityChanged. r=cpearce,jwwang (be917202eb) - Bug 1224973 - Part 3: Plumb element visibility into MDSM. r=jya,jwwang (9ec83fa243) - Bug 1224973 - Part 4: Pref media.suspend-bkgnd-video.enabled. r=cpearce,jwwang (43413a025f) - Bug 1269408: P1. Retry InternalSeek if previous attempt failed once more data is available. r=gerald (05db58dc7c) - crude fix (0097068989) - Bug 1269408: P2. Update mochitest. r=gerald (464b4c0724) - Bug 1269408: P3. Ensure a new seek request will cancel the previous internal seek. r=gerald (6ed4b8dc95) - Bug 1269408: P4. Ensure the decoders are flushed prior performing an internal seek. r=gerald (074234067b) - Bug 1269408: P5. Only drop the seek target if it's exactly the seek target. r=gerald (88701eb05a) - Bug 1269408: P6. Add debugging information, useful when a mochitest timeout. r=gerald (ef0270ab0d) - Bug 1269408: P7. Start skip to next keyframe logic when resume point is behind current time. r=gerald (bd40ebf3bc) - Bug 1269408: P8. Add debugging log. r=gerald (e6dbd1f0a6) - Bug 1269408: P9. Move handling logic of skip to next keyframe to its own function. r=gerald (3c8039e417) - Bug 1269408: P10. Reject promise early if in error state. r=me (8af54c574e) - Bug 1224973 - Part 5: Implement suspend decoding for background video. r=cpearce,jwwang,jya (22081521e3) - Bug 1242874 - part1 : create suspened types. r=baku (d3ac9548e5) - Bug 1242874 - part2 : window's suspend attribute. r=baku, r=ehsan (1fd9dc2647) - remove allowscirpted (39ab523036) - Bug 1242874 - part3 : implement different suspended methods. r=baku, r=jwwang (25d1f27a03) - Bug 1242874 - part4 : wrap the volume/mute/suspend for notifyStartedPlaying. r=baku (b8ba3238c2) - bug 1242874 - part5 : add test. r=baku, r=ehsan (f840139b5a) - Bug 1235612 - Part 1: Implement notify media-playback. r=baku (b5ec29da20) - Bug 1235612 - Part 2: Notify audible state in NotifyStartedPlaying. r=baku (dc38583a62) - Bug 1235612 - Part 3: Implement the logic of audible state notification for agent owners. r=baku (f65b3952fa) - Bug 1235612 - Part 4: Modify check audible method. r=jwwang (73457e39eb) - Bug 1269672 - part2 : move audible data checking from MDSM to DecodedAudioDataSink. (d2c3b6874c) - Bug 1269936 - Introduce and call a runtime-wide servo initialization hook. r=heycam (d4d505d4c2) - Bug 1263778 - Rename a bunch of low-level [[Prototype]] access methods to make their interactions with statically-known and dynamically-computed [[Prototype]]s clearer. r=efaust (66bbe8e7db) - Bug 888969 - Permit a cyclic [[Prototype]] chain to be created through a Location object. r=bz, r=efaust (3e3b9cbb16) - re-apply Bug 1054906 - Implement ES6 Symbol.hasInstance 2/2; r=jandem (8d5c7573ff) - Bug 1054906 - Implement ES6 Symbol.hasInstance 1/2; r=evilpie,bz (a836904e5d) - fix misspatch (54a5f2d708) - Bug 1270349 part 1. Add IDL parser support for [LegacyUnenumerableNamedProperties]. r=peterv (8c836bc74a) - Bug 1270349 part 2. Add [LegacyUnenumerableNamedProperties] to the interfaces that specify it in DOM and HTML. r=peterv (25d3cc1377) - Bug 1270349 part 3. Add a way to ask an interface descriptor for a proxy whether its named props should be enumerable. r=peterv (0a9f804867) - Bug 1270349 part 4. Use LegacyUnenumerableNamedProperties instead of NameIsEnumerable() calls to determine whether named props on DOM proxies should be enumerable. r=peterv (82f5158963) - Bug 1270349 part 5. Use LegacyUnenumerableNamedProperties instead of passing flags to GetSupportedNames to determine whether named props on DOM proxies should be reflected in ownPropertyKeys. r=peterv (3984176834) - Bug 1270349 followup to address a review comment. r=peterv (b49f4c5335)
453 lines
13 KiB
C++
453 lines
13 KiB
C++
/* 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 "DOMCameraManager.h"
|
|
#include "nsDebug.h"
|
|
#include "jsapi.h"
|
|
#include "Navigator.h"
|
|
#include "nsPIDOMWindow.h"
|
|
#include "mozilla/Services.h"
|
|
#include "nsContentPermissionHelper.h"
|
|
#include "nsIContentPermissionPrompt.h"
|
|
#include "nsIObserverService.h"
|
|
#include "nsIPermissionManager.h"
|
|
#include "nsIScriptObjectPrincipal.h"
|
|
#include "DOMCameraControl.h"
|
|
#include "nsDOMClassInfo.h"
|
|
#include "CameraCommon.h"
|
|
#include "CameraPreferences.h"
|
|
#include "mozilla/dom/BindingUtils.h"
|
|
#include "mozilla/dom/PermissionMessageUtils.h"
|
|
#include "nsQueryObject.h"
|
|
|
|
using namespace mozilla;
|
|
using namespace mozilla::dom;
|
|
|
|
NS_IMPL_CYCLE_COLLECTION_WRAPPERCACHE(nsDOMCameraManager, mWindow)
|
|
|
|
NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION(nsDOMCameraManager)
|
|
NS_WRAPPERCACHE_INTERFACE_MAP_ENTRY
|
|
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIObserver)
|
|
NS_INTERFACE_MAP_ENTRY(nsISupportsWeakReference)
|
|
NS_INTERFACE_MAP_ENTRY(nsIObserver)
|
|
NS_INTERFACE_MAP_END
|
|
|
|
NS_IMPL_CYCLE_COLLECTING_ADDREF(nsDOMCameraManager)
|
|
NS_IMPL_CYCLE_COLLECTING_RELEASE(nsDOMCameraManager)
|
|
|
|
/**
|
|
* Global camera logging object
|
|
*
|
|
* Set the NSPR_LOG_MODULES environment variable to enable logging
|
|
* in a debug build, e.g. NSPR_LOG_MODULES=Camera:5
|
|
*/
|
|
LogModule*
|
|
GetCameraLog()
|
|
{
|
|
static LazyLogModule sLog("Camera");
|
|
return sLog;
|
|
}
|
|
|
|
::WindowTable* nsDOMCameraManager::sActiveWindows = nullptr;
|
|
|
|
nsDOMCameraManager::nsDOMCameraManager(nsPIDOMWindow* aWindow)
|
|
: mWindowId(aWindow->WindowID())
|
|
, mPermission(nsIPermissionManager::DENY_ACTION)
|
|
, mWindow(aWindow)
|
|
{
|
|
/* member initializers and constructor code */
|
|
DOM_CAMERA_LOGT("%s:%d : this=%p, windowId=%" PRIx64 "\n", __func__, __LINE__, this, mWindowId);
|
|
MOZ_COUNT_CTOR(nsDOMCameraManager);
|
|
}
|
|
|
|
nsDOMCameraManager::~nsDOMCameraManager()
|
|
{
|
|
/* destructor code */
|
|
MOZ_COUNT_DTOR(nsDOMCameraManager);
|
|
DOM_CAMERA_LOGT("%s:%d : this=%p\n", __func__, __LINE__, this);
|
|
}
|
|
|
|
/* static */
|
|
void
|
|
nsDOMCameraManager::GetListOfCameras(nsTArray<nsString>& aList, ErrorResult& aRv)
|
|
{
|
|
aRv = ICameraControl::GetListOfCameras(aList);
|
|
}
|
|
|
|
/* static */
|
|
bool
|
|
nsDOMCameraManager::HasSupport(JSContext* aCx, JSObject* aGlobal)
|
|
{
|
|
return Navigator::HasCameraSupport(aCx, aGlobal);
|
|
}
|
|
|
|
/* static */
|
|
bool
|
|
nsDOMCameraManager::CheckPermission(nsPIDOMWindow* aWindow)
|
|
{
|
|
nsCOMPtr<nsIPermissionManager> permMgr =
|
|
services::GetPermissionManager();
|
|
NS_ENSURE_TRUE(permMgr, false);
|
|
|
|
uint32_t permission = nsIPermissionManager::DENY_ACTION;
|
|
permMgr->TestPermissionFromWindow(aWindow, "camera", &permission);
|
|
if (permission != nsIPermissionManager::ALLOW_ACTION &&
|
|
permission != nsIPermissionManager::PROMPT_ACTION) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/* static */
|
|
already_AddRefed<nsDOMCameraManager>
|
|
nsDOMCameraManager::CreateInstance(nsPIDOMWindow* aWindow)
|
|
{
|
|
// Initialize the shared active window tracker
|
|
if (!sActiveWindows) {
|
|
sActiveWindows = new ::WindowTable();
|
|
}
|
|
|
|
RefPtr<nsDOMCameraManager> cameraManager =
|
|
new nsDOMCameraManager(aWindow);
|
|
|
|
nsCOMPtr<nsIObserverService> obs = services::GetObserverService();
|
|
if (!obs) {
|
|
DOM_CAMERA_LOGE("Camera manager failed to get observer service\n");
|
|
return nullptr;
|
|
}
|
|
|
|
nsresult rv = obs->AddObserver(cameraManager, "xpcom-shutdown", true);
|
|
if (NS_FAILED(rv)) {
|
|
DOM_CAMERA_LOGE("Camera manager failed to add 'xpcom-shutdown' observer (0x%x)\n", rv);
|
|
return nullptr;
|
|
}
|
|
|
|
return cameraManager.forget();
|
|
}
|
|
|
|
class CameraPermissionRequest : public nsIContentPermissionRequest
|
|
, public nsIRunnable
|
|
{
|
|
public:
|
|
NS_DECL_CYCLE_COLLECTING_ISUPPORTS
|
|
NS_DECL_NSICONTENTPERMISSIONREQUEST
|
|
NS_DECL_NSIRUNNABLE
|
|
NS_DECL_CYCLE_COLLECTION_CLASS_AMBIGUOUS(CameraPermissionRequest,
|
|
nsIContentPermissionRequest)
|
|
|
|
CameraPermissionRequest(nsIPrincipal* aPrincipal,
|
|
nsPIDOMWindow* aWindow,
|
|
RefPtr<nsDOMCameraManager> aManager,
|
|
uint32_t aCameraId,
|
|
const CameraConfiguration& aInitialConfig,
|
|
RefPtr<Promise> aPromise)
|
|
: mPrincipal(aPrincipal)
|
|
, mWindow(aWindow)
|
|
, mCameraManager(aManager)
|
|
, mCameraId(aCameraId)
|
|
, mInitialConfig(aInitialConfig)
|
|
, mPromise(aPromise)
|
|
, mRequester(new nsContentPermissionRequester(mWindow))
|
|
{ }
|
|
|
|
protected:
|
|
virtual ~CameraPermissionRequest() { }
|
|
|
|
nsresult DispatchCallback(uint32_t aPermission);
|
|
void CallAllow();
|
|
void CallCancel();
|
|
nsCOMPtr<nsIPrincipal> mPrincipal;
|
|
nsCOMPtr<nsPIDOMWindow> mWindow;
|
|
RefPtr<nsDOMCameraManager> mCameraManager;
|
|
uint32_t mCameraId;
|
|
CameraConfiguration mInitialConfig;
|
|
RefPtr<Promise> mPromise;
|
|
nsCOMPtr<nsIContentPermissionRequester> mRequester;
|
|
};
|
|
|
|
NS_IMPL_CYCLE_COLLECTION(CameraPermissionRequest, mWindow, mPromise)
|
|
|
|
NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION(CameraPermissionRequest)
|
|
NS_INTERFACE_MAP_ENTRY(nsIContentPermissionRequest)
|
|
NS_INTERFACE_MAP_ENTRY(nsIRunnable)
|
|
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIContentPermissionRequest)
|
|
NS_INTERFACE_MAP_END
|
|
|
|
NS_IMPL_CYCLE_COLLECTING_ADDREF(CameraPermissionRequest)
|
|
NS_IMPL_CYCLE_COLLECTING_RELEASE(CameraPermissionRequest)
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::Run()
|
|
{
|
|
return nsContentPermissionUtils::AskPermission(this, mWindow);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::GetPrincipal(nsIPrincipal** aRequestingPrincipal)
|
|
{
|
|
NS_ADDREF(*aRequestingPrincipal = mPrincipal);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::GetWindow(nsIDOMWindow** aRequestingWindow)
|
|
{
|
|
NS_ADDREF(*aRequestingWindow = mWindow);
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::GetElement(nsIDOMElement** aElement)
|
|
{
|
|
*aElement = nullptr;
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::Cancel()
|
|
{
|
|
return DispatchCallback(nsIPermissionManager::DENY_ACTION);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::Allow(JS::HandleValue aChoices)
|
|
{
|
|
MOZ_ASSERT(aChoices.isUndefined());
|
|
return DispatchCallback(nsIPermissionManager::ALLOW_ACTION);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::GetRequester(nsIContentPermissionRequester** aRequester)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aRequester);
|
|
|
|
nsCOMPtr<nsIContentPermissionRequester> requester = mRequester;
|
|
requester.forget(aRequester);
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
CameraPermissionRequest::DispatchCallback(uint32_t aPermission)
|
|
{
|
|
nsCOMPtr<nsIRunnable> callbackRunnable;
|
|
if (aPermission == nsIPermissionManager::ALLOW_ACTION) {
|
|
callbackRunnable = NewRunnableMethod(this, &CameraPermissionRequest::CallAllow);
|
|
} else {
|
|
callbackRunnable = NewRunnableMethod(this, &CameraPermissionRequest::CallCancel);
|
|
}
|
|
return NS_DispatchToMainThread(callbackRunnable.forget());
|
|
}
|
|
|
|
void
|
|
CameraPermissionRequest::CallAllow()
|
|
{
|
|
mCameraManager->PermissionAllowed(mCameraId, mInitialConfig, mPromise);
|
|
}
|
|
|
|
void
|
|
CameraPermissionRequest::CallCancel()
|
|
{
|
|
mCameraManager->PermissionCancelled(mCameraId, mInitialConfig, mPromise);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
CameraPermissionRequest::GetTypes(nsIArray** aTypes)
|
|
{
|
|
nsTArray<nsString> emptyOptions;
|
|
return nsContentPermissionUtils::CreatePermissionArray(NS_LITERAL_CSTRING("camera"),
|
|
NS_LITERAL_CSTRING("unused"),
|
|
emptyOptions,
|
|
aTypes);
|
|
}
|
|
|
|
#ifdef MOZ_WIDGET_GONK
|
|
/* static */ void
|
|
nsDOMCameraManager::PreinitCameraHardware()
|
|
{
|
|
nsDOMCameraControl::PreinitCameraHardware();
|
|
}
|
|
#endif
|
|
|
|
already_AddRefed<Promise>
|
|
nsDOMCameraManager::GetCamera(const nsAString& aCamera,
|
|
const CameraConfiguration& aInitialConfig,
|
|
ErrorResult& aRv)
|
|
{
|
|
DOM_CAMERA_LOGT("%s:%d\n", __func__, __LINE__);
|
|
|
|
uint32_t cameraId = 0; // back (or forward-facing) camera by default
|
|
if (aCamera.EqualsLiteral("front")) {
|
|
cameraId = 1;
|
|
}
|
|
|
|
nsCOMPtr<nsIGlobalObject> global = do_QueryInterface(mWindow);
|
|
if (!global) {
|
|
aRv.Throw(NS_ERROR_FAILURE);
|
|
return nullptr;
|
|
}
|
|
|
|
RefPtr<Promise> promise = Promise::Create(global, aRv);
|
|
if (aRv.Failed()) {
|
|
return nullptr;
|
|
}
|
|
|
|
if (mPermission == nsIPermissionManager::ALLOW_ACTION) {
|
|
PermissionAllowed(cameraId, aInitialConfig, promise);
|
|
return promise.forget();
|
|
}
|
|
|
|
nsCOMPtr<nsIScriptObjectPrincipal> sop = do_QueryInterface(mWindow);
|
|
if (!sop) {
|
|
aRv.Throw(NS_ERROR_UNEXPECTED);
|
|
return nullptr;
|
|
}
|
|
|
|
nsCOMPtr<nsIPrincipal> principal = sop->GetPrincipal();
|
|
// If we are a CERTIFIED app, we can short-circuit the permission check,
|
|
// which gets us a performance win.
|
|
uint16_t status = nsIPrincipal::APP_STATUS_NOT_INSTALLED;
|
|
principal->GetAppStatus(&status);
|
|
// Unprivileged mochitests always fail the dispatched permission check,
|
|
// even if permission to the camera has been granted.
|
|
bool immediateCheck = false;
|
|
CameraPreferences::GetPref("camera.control.test.permission", immediateCheck);
|
|
if ((status == nsIPrincipal::APP_STATUS_CERTIFIED || immediateCheck) && CheckPermission(mWindow)) {
|
|
PermissionAllowed(cameraId, aInitialConfig, promise);
|
|
return promise.forget();
|
|
}
|
|
|
|
nsCOMPtr<nsIRunnable> permissionRequest =
|
|
new CameraPermissionRequest(principal, mWindow, this, cameraId,
|
|
aInitialConfig, promise);
|
|
|
|
NS_DispatchToMainThread(permissionRequest);
|
|
return promise.forget();
|
|
}
|
|
|
|
void
|
|
nsDOMCameraManager::PermissionAllowed(uint32_t aCameraId,
|
|
const CameraConfiguration& aInitialConfig,
|
|
Promise* aPromise)
|
|
{
|
|
mPermission = nsIPermissionManager::ALLOW_ACTION;
|
|
|
|
// Creating this object will trigger the aOnSuccess callback
|
|
// (or the aOnError one, if it fails).
|
|
RefPtr<nsDOMCameraControl> cameraControl =
|
|
new nsDOMCameraControl(aCameraId, aInitialConfig, aPromise, mWindow);
|
|
|
|
Register(cameraControl);
|
|
}
|
|
|
|
void
|
|
nsDOMCameraManager::PermissionCancelled(uint32_t aCameraId,
|
|
const CameraConfiguration& aInitialConfig,
|
|
Promise* aPromise)
|
|
{
|
|
mPermission = nsIPermissionManager::DENY_ACTION;
|
|
aPromise->MaybeReject(NS_ERROR_DOM_SECURITY_ERR);
|
|
}
|
|
|
|
void
|
|
nsDOMCameraManager::Register(nsDOMCameraControl* aDOMCameraControl)
|
|
{
|
|
DOM_CAMERA_LOGI(">>> Register( aDOMCameraControl = %p ) mWindowId = 0x%" PRIx64 "\n", aDOMCameraControl, mWindowId);
|
|
MOZ_ASSERT(NS_IsMainThread());
|
|
|
|
CameraControls* controls = sActiveWindows->Get(mWindowId);
|
|
if (!controls) {
|
|
controls = new CameraControls();
|
|
sActiveWindows->Put(mWindowId, controls);
|
|
}
|
|
|
|
// Remove any stale CameraControl objects to limit our memory usage
|
|
uint32_t i = controls->Length();
|
|
while (i > 0) {
|
|
--i;
|
|
RefPtr<nsDOMCameraControl> cameraControl =
|
|
do_QueryObject(controls->ElementAt(i));
|
|
if (!cameraControl) {
|
|
controls->RemoveElementAt(i);
|
|
}
|
|
}
|
|
|
|
// Put the camera control into the hash table
|
|
nsWeakPtr cameraControl =
|
|
do_GetWeakReference(static_cast<DOMMediaStream*>(aDOMCameraControl));
|
|
controls->AppendElement(cameraControl);
|
|
}
|
|
|
|
void
|
|
nsDOMCameraManager::Shutdown(uint64_t aWindowId)
|
|
{
|
|
DOM_CAMERA_LOGI(">>> Shutdown( aWindowId = 0x%" PRIx64 " )\n", aWindowId);
|
|
MOZ_ASSERT(NS_IsMainThread());
|
|
|
|
CameraControls* controls = sActiveWindows->Get(aWindowId);
|
|
if (!controls) {
|
|
return;
|
|
}
|
|
|
|
uint32_t i = controls->Length();
|
|
while (i > 0) {
|
|
--i;
|
|
RefPtr<nsDOMCameraControl> cameraControl =
|
|
do_QueryObject(controls->ElementAt(i));
|
|
if (cameraControl) {
|
|
cameraControl->Shutdown();
|
|
}
|
|
}
|
|
controls->Clear();
|
|
|
|
sActiveWindows->Remove(aWindowId);
|
|
}
|
|
|
|
void
|
|
nsDOMCameraManager::XpComShutdown()
|
|
{
|
|
DOM_CAMERA_LOGI(">>> XPCOM Shutdown\n");
|
|
MOZ_ASSERT(NS_IsMainThread());
|
|
|
|
nsCOMPtr<nsIObserverService> obs = services::GetObserverService();
|
|
obs->RemoveObserver(this, "xpcom-shutdown");
|
|
|
|
delete sActiveWindows;
|
|
sActiveWindows = nullptr;
|
|
}
|
|
|
|
nsresult
|
|
nsDOMCameraManager::Observe(nsISupports* aSubject, const char* aTopic, const char16_t* aData)
|
|
{
|
|
if (strcmp(aTopic, "xpcom-shutdown") == 0) {
|
|
XpComShutdown();
|
|
}
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
nsDOMCameraManager::OnNavigation(uint64_t aWindowId)
|
|
{
|
|
DOM_CAMERA_LOGI(">>> OnNavigation event\n");
|
|
Shutdown(aWindowId);
|
|
}
|
|
|
|
bool
|
|
nsDOMCameraManager::IsWindowStillActive(uint64_t aWindowId)
|
|
{
|
|
MOZ_ASSERT(NS_IsMainThread());
|
|
|
|
if (!sActiveWindows) {
|
|
return false;
|
|
}
|
|
|
|
return !!sActiveWindows->Get(aWindowId);
|
|
}
|
|
|
|
JSObject*
|
|
nsDOMCameraManager::WrapObject(JSContext* aCx, JS::Handle<JSObject*> aGivenProto)
|
|
{
|
|
return CameraManagerBinding::Wrap(aCx, this, aGivenProto);
|
|
}
|