/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* 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/. * * The origin of this IDL file is * http://www.whatwg.org/specs/web-apps/current-work/#the-navigator-object * http://www.w3.org/TR/tracking-dnt/ * http://www.w3.org/TR/geolocation-API/#geolocation_interface * http://www.w3.org/TR/battery-status/#navigatorbattery-interface * http://www.w3.org/TR/vibration/#vibration-interface * http://www.w3.org/2012/sysapps/runtime/#extension-to-the-navigator-interface-1 * https://dvcs.w3.org/hg/gamepad/raw-file/default/gamepad.html#navigator-interface-extension * http://www.w3.org/TR/beacon/#sec-beacon-method * https://html.spec.whatwg.org/#navigatorconcurrenthardware * http://wicg.github.io/netinfo/#extensions-to-the-navigator-interface * https://w3c.github.io/webappsec-credential-management/#framework-credential-management * https://w3c.github.io/webdriver/webdriver-spec.html#interface * https://wicg.github.io/media-capabilities/#idl-index * https://w3c.github.io/mediasession/#idl-index * * © Copyright 2004-2011 Apple Computer, Inc., Mozilla Foundation, and * Opera Software ASA. You are granted a license to use, reproduce * and create derivative works of this document. */ interface URI; // http://www.whatwg.org/specs/web-apps/current-work/#the-navigator-object [HeaderFile="Navigator.h", Exposed=Window] interface Navigator { // objects implementing this interface also implement the interfaces given below }; Navigator includes NavigatorID; Navigator includes NavigatorLanguage; Navigator includes NavigatorOnLine; Navigator includes NavigatorContentUtils; Navigator includes NavigatorStorageUtils; Navigator includes NavigatorConcurrentHardware; Navigator includes NavigatorStorage; Navigator includes NavigatorAutomationInformation; Navigator includes GPUProvider; interface mixin NavigatorID { // WebKit/Blink/Trident/Presto support this (hardcoded "Mozilla"). [Constant, Cached, Throws] readonly attribute DOMString appCodeName; // constant "Mozilla" [Constant, Cached, NeedsCallerType] readonly attribute DOMString appName; [Constant, Cached, Throws, NeedsCallerType] readonly attribute DOMString appVersion; [Pure, Cached, Throws, NeedsCallerType] readonly attribute DOMString platform; [Pure, Cached, Throws, NeedsCallerType] readonly attribute DOMString userAgent; [Constant, Cached] readonly attribute DOMString product; // constant "Gecko" // Everyone but WebKit/Blink supports this. See bug 679971. [Exposed=Window] boolean taintEnabled(); // constant false }; interface mixin NavigatorLanguage { // These two attributes are cached because this interface is also implemented // by Workernavigator and this way we don't have to go back to the // main-thread from the worker thread anytime we need to retrieve them. They // are updated when pref intl.accept_languages is changed. [Pure, Cached] readonly attribute DOMString? language; [Pure, Cached, Frozen] readonly attribute sequence languages; }; interface mixin NavigatorOnLine { readonly attribute boolean onLine; }; interface mixin NavigatorContentUtils { // content handler registration [Throws, ChromeOnly] void checkProtocolHandlerAllowed(DOMString scheme, URI handlerURI, URI documentURI); [Throws, SecureContext] void registerProtocolHandler(DOMString scheme, DOMString url); // NOT IMPLEMENTED //void unregisterProtocolHandler(DOMString scheme, DOMString url); }; [SecureContext] interface mixin NavigatorStorage { [Pref="dom.storageManager.enabled"] readonly attribute StorageManager storage; }; interface mixin NavigatorStorageUtils { // NOT IMPLEMENTED //void yieldForStorageUpdates(); }; partial interface Navigator { [Throws] readonly attribute Permissions permissions; }; // Things that definitely need to be in the spec and and are not for some // reason. See https://www.w3.org/Bugs/Public/show_bug.cgi?id=22406 partial interface Navigator { [Throws] readonly attribute MimeTypeArray mimeTypes; [Throws] readonly attribute PluginArray plugins; }; // http://www.w3.org/TR/tracking-dnt/ sort of partial interface Navigator { readonly attribute DOMString doNotTrack; }; // http://www.w3.org/TR/geolocation-API/#geolocation_interface interface mixin NavigatorGeolocation { [Throws, Pref="geo.enabled"] readonly attribute Geolocation geolocation; }; Navigator includes NavigatorGeolocation; // http://www.w3.org/TR/battery-status/#navigatorbattery-interface partial interface Navigator { // ChromeOnly to prevent web content from fingerprinting users' batteries. [Throws, ChromeOnly, Pref="dom.battery.enabled"] Promise getBattery(); }; // http://www.w3.org/TR/vibration/#vibration-interface partial interface Navigator { // We don't support sequences in unions yet //boolean vibrate ((unsigned long or sequence) pattern); boolean vibrate(unsigned long duration); boolean vibrate(sequence pattern); }; // http://www.w3.org/TR/pointerevents/#extensions-to-the-navigator-interface partial interface Navigator { [Pref="dom.w3c_pointer_events.enabled", NeedsCallerType] readonly attribute long maxTouchPoints; }; // https://wicg.github.io/media-capabilities/#idl-index [Exposed=Window] partial interface Navigator { [SameObject, Func="mozilla::dom::MediaCapabilities::Enabled"] readonly attribute MediaCapabilities mediaCapabilities; }; // Mozilla-specific extensions // Chrome-only interface for Vibration API permission handling. partial interface Navigator { /* Set permission state to device vibration. * @param permitted permission state (true for allowing vibration) * @param persistent make the permission session-persistent */ [ChromeOnly] void setVibrationPermission(boolean permitted, optional boolean persistent = true); }; partial interface Navigator { [Throws, Constant, Cached, NeedsCallerType] readonly attribute DOMString oscpu; // WebKit/Blink support this; Trident/Presto do not. readonly attribute DOMString vendor; // WebKit/Blink supports this (hardcoded ""); Trident/Presto do not. readonly attribute DOMString vendorSub; // WebKit/Blink supports this (hardcoded "20030107"); Trident/Presto don't readonly attribute DOMString productSub; // WebKit/Blink/Trident/Presto support this. readonly attribute boolean cookieEnabled; [Throws, Constant, Cached, NeedsCallerType] readonly attribute DOMString buildID; // WebKit/Blink/Trident/Presto support this. [Affects=Nothing, DependsOn=Nothing] boolean javaEnabled(); }; // Addon manager bits partial interface Navigator { [Throws, Func="mozilla::AddonManagerWebAPI::IsAPIEnabled"] readonly attribute AddonManager mozAddonManager; }; // NetworkInformation partial interface Navigator { [Throws, Pref="dom.netinfo.enabled"] readonly attribute NetworkInformation connection; }; // https://dvcs.w3.org/hg/gamepad/raw-file/default/gamepad.html#navigator-interface-extension partial interface Navigator { [Throws, Pref="dom.gamepad.enabled"] sequence getGamepads(); }; partial interface Navigator { [Pref="dom.gamepad.test.enabled"] GamepadServiceTest requestGamepadServiceTest(); }; // https://immersive-web.github.io/webvr/spec/1.1/#interface-navigator partial interface Navigator { [Throws, SecureContext, Pref="dom.vr.enabled"] Promise> getVRDisplays(); // TODO: Use FrozenArray once available. (Bug 1236777) [SecureContext, Frozen, Cached, Pure, Pref="dom.vr.enabled"] readonly attribute sequence activeVRDisplays; [ChromeOnly, Pref="dom.vr.enabled"] readonly attribute boolean isWebVRContentDetected; [ChromeOnly, Pref="dom.vr.enabled"] readonly attribute boolean isWebVRContentPresenting; [ChromeOnly, Pref="dom.vr.enabled"] void requestVRPresentation(VRDisplay display); }; partial interface Navigator { [Pref="dom.vr.puppet.enabled"] VRServiceTest requestVRServiceTest(); }; // https://immersive-web.github.io/webxr/#dom-navigator-xr partial interface Navigator { [SecureContext, SameObject, Throws, Pref="dom.vr.webxr.enabled"] readonly attribute XRSystem xr; }; // http://webaudio.github.io/web-midi-api/#requestmidiaccess partial interface Navigator { [Throws, Pref="dom.webmidi.enabled"] Promise requestMIDIAccess(optional MIDIOptions options = {}); }; callback NavigatorUserMediaSuccessCallback = void (MediaStream stream); callback NavigatorUserMediaErrorCallback = void (MediaStreamError error); partial interface Navigator { [Throws, Func="Navigator::HasUserMediaSupport"] readonly attribute MediaDevices mediaDevices; // Deprecated. Use mediaDevices.getUserMedia instead. [Deprecated="NavigatorGetUserMedia", Throws, Func="Navigator::HasUserMediaSupport", NeedsCallerType, UseCounter] void mozGetUserMedia(MediaStreamConstraints constraints, NavigatorUserMediaSuccessCallback successCallback, NavigatorUserMediaErrorCallback errorCallback); }; // nsINavigatorUserMedia callback MozGetUserMediaDevicesSuccessCallback = void (nsIVariant? devices); partial interface Navigator { [Throws, ChromeOnly] void mozGetUserMediaDevices(MediaStreamConstraints constraints, MozGetUserMediaDevicesSuccessCallback onsuccess, NavigatorUserMediaErrorCallback onerror, // The originating innerWindowID is needed to // avoid calling the callbacks if the window has // navigated away. It is optional only as legacy. optional unsigned long long innerWindowID = 0, // The callID is needed in case of multiple // concurrent requests to find the right one. // It is optional only as legacy. // TODO: Rewrite to not need this method anymore, // now that devices are enumerated earlier. optional DOMString callID = ""); }; // Service Workers/Navigation Controllers partial interface Navigator { [Func="ServiceWorkerContainer::IsEnabled", SameObject] readonly attribute ServiceWorkerContainer serviceWorker; }; partial interface Navigator { [Throws, Pref="beacon.enabled"] boolean sendBeacon(DOMString url, optional BodyInit? data = null); }; partial interface Navigator { [Throws, Pref="dom.presentation.enabled", SameObject] readonly attribute Presentation? presentation; }; partial interface Navigator { [NewObject, Func="mozilla::dom::TCPSocket::ShouldTCPSocketExist"] readonly attribute LegacyMozTCPSocket mozTCPSocket; }; partial interface Navigator { [NewObject] Promise requestMediaKeySystemAccess(DOMString keySystem, sequence supportedConfigurations); }; interface mixin NavigatorConcurrentHardware { readonly attribute unsigned long long hardwareConcurrency; }; // https://w3c.github.io/webappsec-credential-management/#framework-credential-management partial interface Navigator { [Pref="security.webauth.webauthn", SecureContext, SameObject] readonly attribute CredentialsContainer credentials; }; // https://w3c.github.io/webdriver/webdriver-spec.html#interface interface mixin NavigatorAutomationInformation { [Pref="dom.webdriver.enabled"] readonly attribute boolean webdriver; }; // https://www.w3.org/TR/clipboard-apis/#navigator-interface partial interface Navigator { [Pref="dom.events.asyncClipboard", SecureContext, SameObject] readonly attribute Clipboard clipboard; }; // https://wicg.github.io/web-share/#navigator-interface partial interface Navigator { [SecureContext, Throws, Func="Navigator::HasShareSupport"] Promise share(optional ShareData data = {}); }; // https://wicg.github.io/web-share/#sharedata-dictionary dictionary ShareData { USVString title; USVString text; USVString url; }; // https://w3c.github.io/mediasession/#idl-index [Exposed=Window] partial interface Navigator { [Pref="dom.media.mediasession.enabled", SameObject] readonly attribute MediaSession mediaSession; };