mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
9fd132e8a3
- Bug 1153248, re-enable a bunch of tests that now work with e10s, r=billm (c7d1a1d95) - Bug 1113086 - AudioChannel policy in Browser API - patch 1 - BrowserElementAudioChannel, r=ehsan (b25164d4f) - Bug 1158798 - Properly initialize the LookAndFeel cache in the child. r=mstange. (0f4232b5c) - Bug 1113086 - AudioChannel policy in Browser API - patch 2 - IPC communication between AudioChannelServices, r=ehsan (a2132f4d4) - Bug 1113086 - AudioChannel policy in Browser API - patch 3 - right management of audiochannel-activity events in child processes, r=ehsan (d1bd88e79) - Bug 1150727 - Enable software vsync refresh driver on Linux. r=kats (a991d3c25) - Bug 1113086 - AudioChannel policy in Browser API - patch 4 - Muted by default, e=alwu (a8978ef69) - Bug 1167064 - Patch3: Update mochitests for switching to Bluetooth APIv2. r=bz (f02729d0d) - Bug 1113086 - AudioChannel policy in Browser API - patch 5 - nsTObserverArray instead hashtables, r=ehsan, r=alwu (8f9aa5d4f) - Bug 1113086 - AudioChannel policy in Browser API - patch 6 - media-playback has to be dispatched async, r=alwu (da4da2207) - Bug 1113086 - AudioChannel policy in Browser API - patch 7 - Support non-app iframe, r=alwu (7078c3df5) - Bug 1174733 - Browser API: iframe.executeScript. r=kanru, r=bholley (5e19f9186) - Bug 1146355: Prepare build system to support Bluetooth APIs v1 and v2, r=shuang (ffe7bf5ef) - Bug 1156716: Build GATT backend as part of Bluetooth v1, r=joliu (033da499a) - Bug 1168343 - Remove the improper MOZ_ASSERT in |BluetoothServiceBluedroid::BondStateChangedNotification|. r=shuang (10d398b57) - Bug 1128386 - Handle |STATUS_FAIL| in |BondStateChangedNotification()|. r=tzimmermann (0bb76982f) - Bug 1164498: Remove |DispatchBluetoothReply| from |BluetoothServiceBluedroid|, r=btian (c027eb350) - Bug 1167064 - Patch1: Switch to bluetooth APIv2. r=shuang (37c775331) - Bug 1153717 - [Stingray] Update document reference link on InputPort API. r=baku, a=NPOTB (550bd985d) - Bug 1179718 - Rename CheckPermissions to CheckAnyPermissions. r=bz (b8e4bf1b7) - Bug 1152702 - Fix upper bounds of ContiguousEnumSerializer for BluetoothStatus and BluetoothSspVariant. r=tzimmermann (30ec5dc1a) - Bug 1162893 - Fix BluetoothGattWriteType serialization problem. f=elin, r=jocelyn (d36e089da) - Bug 1152631 - We no longer display category data for platform data in call tree, r=jsantell (6e2e877a0) - Bug 1164338 - Tests that the style markers have restyleHints. r=pbrosset (d6c357832) - Bug 1058898 - Enable e10s tests on the performance tool. r=vp (18c8324c3) - Bug 814497 - Fix nsScriptErrorWithStack constructor. r=ehsan (8096b8a8a) - Bug 814497 followup: Add missing 'override' keyword to nsScriptErrorWithStack method 'GetStack'. rs=ehsan (30889b974)
697 lines
19 KiB
C++
697 lines
19 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* 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 "nsBrowserElement.h"
|
|
|
|
#include "mozilla/Preferences.h"
|
|
#include "mozilla/Services.h"
|
|
#include "mozilla/dom/BrowserElementBinding.h"
|
|
#include "mozilla/dom/BrowserElementAudioChannel.h"
|
|
#include "mozilla/dom/DOMRequest.h"
|
|
#include "mozilla/dom/ScriptSettings.h"
|
|
#include "mozilla/dom/ToJSValue.h"
|
|
|
|
#include "AudioChannelService.h"
|
|
|
|
#include "mozIApplication.h"
|
|
#include "nsComponentManagerUtils.h"
|
|
#include "nsContentUtils.h"
|
|
#include "nsFrameLoader.h"
|
|
#include "nsIAppsService.h"
|
|
#include "nsIDOMDOMRequest.h"
|
|
#include "nsIDOMElement.h"
|
|
#include "nsIMozBrowserFrame.h"
|
|
#include "nsINode.h"
|
|
#include "nsIPrincipal.h"
|
|
|
|
using namespace mozilla::dom;
|
|
|
|
namespace mozilla {
|
|
|
|
bool
|
|
nsBrowserElement::IsBrowserElementOrThrow(ErrorResult& aRv)
|
|
{
|
|
if (mBrowserElementAPI) {
|
|
return true;
|
|
}
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_NODE_TYPE_ERR);
|
|
return false;
|
|
}
|
|
|
|
bool
|
|
nsBrowserElement::IsNotWidgetOrThrow(ErrorResult& aRv)
|
|
{
|
|
if (!mOwnerIsWidget) {
|
|
return true;
|
|
}
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_NODE_TYPE_ERR);
|
|
return false;
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::InitBrowserElementAPI()
|
|
{
|
|
bool isBrowserOrApp;
|
|
nsCOMPtr<nsIFrameLoader> frameLoader = GetFrameLoader();
|
|
NS_ENSURE_TRUE_VOID(frameLoader);
|
|
nsresult rv = frameLoader->GetOwnerIsBrowserOrAppFrame(&isBrowserOrApp);
|
|
NS_ENSURE_SUCCESS_VOID(rv);
|
|
rv = frameLoader->GetOwnerIsWidget(&mOwnerIsWidget);
|
|
NS_ENSURE_SUCCESS_VOID(rv);
|
|
|
|
if (!isBrowserOrApp) {
|
|
return;
|
|
}
|
|
|
|
mBrowserElementAPI = do_CreateInstance("@mozilla.org/dom/browser-element-api;1");
|
|
if (mBrowserElementAPI) {
|
|
mBrowserElementAPI->SetFrameLoader(frameLoader);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::SetVisible(bool aVisible, ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->SetVisible(aVisible);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::GetVisible(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->GetVisible(getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::SetActive(bool aVisible, ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->SetActive(aVisible);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
bool
|
|
nsBrowserElement::GetActive(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), false);
|
|
|
|
bool isActive;
|
|
nsresult rv = mBrowserElementAPI->GetActive(&isActive);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return false;
|
|
}
|
|
|
|
return isActive;
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::SendMouseEvent(const nsAString& aType,
|
|
uint32_t aX,
|
|
uint32_t aY,
|
|
uint32_t aButton,
|
|
uint32_t aClickCount,
|
|
uint32_t aModifiers,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->SendMouseEvent(aType,
|
|
aX,
|
|
aY,
|
|
aButton,
|
|
aClickCount,
|
|
aModifiers);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::SendTouchEvent(const nsAString& aType,
|
|
const Sequence<uint32_t>& aIdentifiers,
|
|
const Sequence<int32_t>& aXs,
|
|
const Sequence<int32_t>& aYs,
|
|
const Sequence<uint32_t>& aRxs,
|
|
const Sequence<uint32_t>& aRys,
|
|
const Sequence<float>& aRotationAngles,
|
|
const Sequence<float>& aForces,
|
|
uint32_t aCount,
|
|
uint32_t aModifiers,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
if (aIdentifiers.Length() != aCount ||
|
|
aXs.Length() != aCount ||
|
|
aYs.Length() != aCount ||
|
|
aRxs.Length() != aCount ||
|
|
aRys.Length() != aCount ||
|
|
aRotationAngles.Length() != aCount ||
|
|
aForces.Length() != aCount) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_ACCESS_ERR);
|
|
return;
|
|
}
|
|
|
|
nsresult rv = mBrowserElementAPI->SendTouchEvent(aType,
|
|
aIdentifiers.Elements(),
|
|
aXs.Elements(),
|
|
aYs.Elements(),
|
|
aRxs.Elements(),
|
|
aRys.Elements(),
|
|
aRotationAngles.Elements(),
|
|
aForces.Elements(),
|
|
aCount,
|
|
aModifiers);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::GoBack(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->GoBack();
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::GoForward(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->GoForward();
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::Reload(bool aHardReload, ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->Reload(aHardReload);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::Stop(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->Stop();
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::Download(const nsAString& aUrl,
|
|
const BrowserElementDownloadOptions& aOptions,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsCOMPtr<nsIXPConnectWrappedJS> wrappedObj = do_QueryInterface(mBrowserElementAPI);
|
|
MOZ_ASSERT(wrappedObj, "Failed to get wrapped JS from XPCOM component.");
|
|
AutoJSAPI jsapi;
|
|
jsapi.Init(wrappedObj->GetJSObject());
|
|
JSContext* cx = jsapi.cx();
|
|
JS::Rooted<JS::Value> options(cx);
|
|
if (!ToJSValue(cx, aOptions, &options)) {
|
|
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
|
|
return nullptr;
|
|
}
|
|
nsresult rv = mBrowserElementAPI->Download(aUrl, options, getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::PurgeHistory(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->PurgeHistory(getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::GetScreenshot(uint32_t aWidth,
|
|
uint32_t aHeight,
|
|
const nsAString& aMimeType,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->GetScreenshot(aWidth, aHeight, aMimeType,
|
|
getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
if (rv == NS_ERROR_INVALID_ARG) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_ACCESS_ERR);
|
|
} else {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::Zoom(float aZoom, ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->Zoom(aZoom);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::GetCanGoBack(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->GetCanGoBack(getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::GetCanGoForward(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->GetCanGoForward(getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::GetContentDimensions(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->GetContentDimensions(getter_AddRefs(req));
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::FindAll(const nsAString& aSearchString,
|
|
BrowserFindCaseSensitivity aCaseSensitivity,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
uint32_t caseSensitivity;
|
|
if (aCaseSensitivity == BrowserFindCaseSensitivity::Case_insensitive) {
|
|
caseSensitivity = nsIBrowserElementAPI::FIND_CASE_INSENSITIVE;
|
|
} else {
|
|
caseSensitivity = nsIBrowserElementAPI::FIND_CASE_SENSITIVE;
|
|
}
|
|
|
|
nsresult rv = mBrowserElementAPI->FindAll(aSearchString, caseSensitivity);
|
|
|
|
if (NS_FAILED(rv)) {
|
|
aRv.Throw(rv);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::FindNext(BrowserFindDirection aDirection,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
uint32_t direction;
|
|
if (aDirection == BrowserFindDirection::Backward) {
|
|
direction = nsIBrowserElementAPI::FIND_BACKWARD;
|
|
} else {
|
|
direction = nsIBrowserElementAPI::FIND_FORWARD;
|
|
}
|
|
|
|
nsresult rv = mBrowserElementAPI->FindNext(direction);
|
|
|
|
if (NS_FAILED(rv)) {
|
|
aRv.Throw(rv);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::ClearMatch(ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
NS_ENSURE_TRUE_VOID(IsNotWidgetOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->ClearMatch();
|
|
|
|
if (NS_FAILED(rv)) {
|
|
aRv.Throw(rv);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::AddNextPaintListener(BrowserElementNextPaintEventCallback& aListener,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
|
|
CallbackObjectHolder<BrowserElementNextPaintEventCallback,
|
|
nsIBrowserElementNextPaintListener> holder(&aListener);
|
|
nsCOMPtr<nsIBrowserElementNextPaintListener> listener = holder.ToXPCOMCallback();
|
|
|
|
nsresult rv = mBrowserElementAPI->AddNextPaintListener(listener);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::RemoveNextPaintListener(BrowserElementNextPaintEventCallback& aListener,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
|
|
CallbackObjectHolder<BrowserElementNextPaintEventCallback,
|
|
nsIBrowserElementNextPaintListener> holder(&aListener);
|
|
nsCOMPtr<nsIBrowserElementNextPaintListener> listener = holder.ToXPCOMCallback();
|
|
|
|
nsresult rv = mBrowserElementAPI->RemoveNextPaintListener(listener);
|
|
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::SetInputMethodActive(bool aIsActive,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsresult rv = mBrowserElementAPI->SetInputMethodActive(aIsActive,
|
|
getter_AddRefs(req));
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
if (rv == NS_ERROR_INVALID_ARG) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_ACCESS_ERR);
|
|
} else {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::GetAllowedAudioChannels(
|
|
nsTArray<nsRefPtr<BrowserElementAudioChannel>>& aAudioChannels,
|
|
ErrorResult& aRv)
|
|
{
|
|
aAudioChannels.Clear();
|
|
|
|
// If empty, it means that this is the first call of this method.
|
|
if (mBrowserElementAudioChannels.IsEmpty()) {
|
|
nsCOMPtr<nsIFrameLoader> frameLoader = GetFrameLoader();
|
|
if (!frameLoader) {
|
|
aRv.Throw(NS_ERROR_FAILURE);
|
|
return;
|
|
}
|
|
|
|
bool isBrowserOrApp;
|
|
aRv = frameLoader->GetOwnerIsBrowserOrAppFrame(&isBrowserOrApp);
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
if (!isBrowserOrApp) {
|
|
return;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMElement> frameElement;
|
|
aRv = frameLoader->GetOwnerElement(getter_AddRefs(frameElement));
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
MOZ_ASSERT(frameElement);
|
|
|
|
nsCOMPtr<nsIDOMDocument> doc;
|
|
aRv = frameElement->GetOwnerDocument(getter_AddRefs(doc));
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
MOZ_ASSERT(doc);
|
|
|
|
nsCOMPtr<nsIDOMWindow> win;
|
|
aRv = doc->GetDefaultView(getter_AddRefs(win));
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
MOZ_ASSERT(win);
|
|
|
|
nsCOMPtr<nsPIDOMWindow> window = do_QueryInterface(win);
|
|
|
|
if (!window->IsInnerWindow()) {
|
|
window = window->GetCurrentInnerWindow();
|
|
}
|
|
|
|
nsCOMPtr<nsIMozBrowserFrame> mozBrowserFrame =
|
|
do_QueryInterface(frameElement);
|
|
if (NS_WARN_IF(!mozBrowserFrame)) {
|
|
aRv.Throw(NS_ERROR_FAILURE);
|
|
return;
|
|
}
|
|
|
|
nsAutoString manifestURL;
|
|
aRv = mozBrowserFrame->GetAppManifestURL(manifestURL);
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
nsCOMPtr<nsIAppsService> appsService =
|
|
do_GetService("@mozilla.org/AppsService;1");
|
|
if (NS_WARN_IF(!appsService)) {
|
|
aRv.Throw(NS_ERROR_FAILURE);
|
|
return;
|
|
}
|
|
|
|
nsCOMPtr<mozIApplication> app;
|
|
aRv = appsService->GetAppByManifestURL(manifestURL, getter_AddRefs(app));
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
// Normal is always allowed.
|
|
nsTArray<nsRefPtr<BrowserElementAudioChannel>> channels;
|
|
|
|
nsRefPtr<BrowserElementAudioChannel> ac =
|
|
new BrowserElementAudioChannel(window, frameLoader, mBrowserElementAPI,
|
|
AudioChannel::Normal);
|
|
|
|
aRv = ac->Initialize();
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
channels.AppendElement(ac);
|
|
|
|
if (app) {
|
|
const nsAttrValue::EnumTable* audioChannelTable =
|
|
AudioChannelService::GetAudioChannelTable();
|
|
|
|
bool allowed;
|
|
nsAutoCString permissionName;
|
|
|
|
for (uint32_t i = 0; audioChannelTable && audioChannelTable[i].tag; ++i) {
|
|
permissionName.AssignASCII("audio-channel-");
|
|
permissionName.AppendASCII(audioChannelTable[i].tag);
|
|
|
|
aRv = app->HasPermission(permissionName.get(), &allowed);
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
if (allowed) {
|
|
nsRefPtr<BrowserElementAudioChannel> ac =
|
|
new BrowserElementAudioChannel(window, frameLoader,
|
|
mBrowserElementAPI,
|
|
(AudioChannel)audioChannelTable[i].value);
|
|
|
|
aRv = ac->Initialize();
|
|
if (NS_WARN_IF(aRv.Failed())) {
|
|
return;
|
|
}
|
|
|
|
channels.AppendElement(ac);
|
|
}
|
|
}
|
|
}
|
|
|
|
mBrowserElementAudioChannels.AppendElements(channels);
|
|
}
|
|
|
|
aAudioChannels.AppendElements(mBrowserElementAudioChannels);
|
|
}
|
|
|
|
void
|
|
nsBrowserElement::SetNFCFocus(bool aIsFocus,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE_VOID(IsBrowserElementOrThrow(aRv));
|
|
|
|
nsresult rv = mBrowserElementAPI->SetNFCFocus(aIsFocus);
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
}
|
|
|
|
already_AddRefed<DOMRequest>
|
|
nsBrowserElement::ExecuteScript(const nsAString& aScript,
|
|
const BrowserElementExecuteScriptOptions& aOptions,
|
|
ErrorResult& aRv)
|
|
{
|
|
NS_ENSURE_TRUE(IsBrowserElementOrThrow(aRv), nullptr);
|
|
NS_ENSURE_TRUE(IsNotWidgetOrThrow(aRv), nullptr);
|
|
|
|
nsRefPtr<nsFrameLoader> frameLoader = GetFrameLoader();
|
|
if (!frameLoader) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMElement> ownerElement;
|
|
nsresult rv = frameLoader->GetOwnerElement(getter_AddRefs(ownerElement));
|
|
if (NS_FAILED(rv)) {
|
|
aRv.Throw(rv);
|
|
return nullptr;
|
|
}
|
|
|
|
nsCOMPtr<nsINode> node = do_QueryInterface(ownerElement);
|
|
nsCOMPtr<nsIPrincipal> principal = node->NodePrincipal();
|
|
|
|
if (!nsContentUtils::IsExactSitePermAllow(principal, "browser:universalxss")) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_ACCESS_ERR);
|
|
return nullptr;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMDOMRequest> req;
|
|
nsCOMPtr<nsIXPConnectWrappedJS> wrappedObj = do_QueryInterface(mBrowserElementAPI);
|
|
MOZ_ASSERT(wrappedObj, "Failed to get wrapped JS from XPCOM component.");
|
|
AutoJSAPI jsapi;
|
|
jsapi.Init(wrappedObj->GetJSObject());
|
|
JSContext* cx = jsapi.cx();
|
|
JS::Rooted<JS::Value> options(cx);
|
|
if (!ToJSValue(cx, aOptions, &options)) {
|
|
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
|
|
return nullptr;
|
|
}
|
|
|
|
rv = mBrowserElementAPI->ExecuteScript(aScript, options, getter_AddRefs(req));
|
|
|
|
if (NS_FAILED(rv)) {
|
|
if (rv == NS_ERROR_INVALID_ARG) {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_ACCESS_ERR);
|
|
} else {
|
|
aRv.Throw(NS_ERROR_DOM_INVALID_STATE_ERR);
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
return req.forget().downcast<DOMRequest>();
|
|
}
|
|
|
|
} // namespace mozilla
|