// Copyright (c) 2024 Vuplex Inc. All rights reserved. // // Licensed under the Vuplex Commercial Software Library License, you may // not use this file except in compliance with the License. You may obtain // a copy of the License at // // https://vuplex.com/commercial-library-license // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. using System; using System.Threading.Tasks; using UnityEngine; using Vuplex.WebView.Internal; namespace Vuplex.WebView { /// /// The Web static class contains APIs that globally impact the behavior of all IWebView instances, such as configuration options /// and global actions. It also contains the CreateWebView() method for creating an IWebView directly. /// /// /// The Web class's APIs cannot be used before Awake() is first called for the app. Attempting to use a Web API prior to Awake() will /// result in an InvalidOperationException. /// /// /// /// public static class Web { /// /// Returns the ICookieManager for managing HTTP cookies, or `null` if ICookieManager /// isn't supported on the current platform. /// /// /// ICookieManager is supported by all of the 3D WebView packages except for: /// - 3D WebView for Android with Gecko Engine /// - 2D WebView for WebGL /// public static ICookieManager CookieManager { get => _pluginFactory.GetDefaultPlugin().CookieManager; } /// /// Gets the default 3D WebView plugin type among those /// installed for the current platform. /// public static WebPluginType DefaultPluginType { get => _pluginFactory.GetDefaultPlugin().Type; } /// /// Clears all data that persists between webview instances, /// including cookies, storage, and cached resources. /// /// /// /// void Awake() { /// Web.ClearAllData(); /// } /// /// /// /// Important notes: /// /// On Windows and macOS, this method cannot be executed while the Chromium browser process is running. So, you will likely need to call it from Awake() to ensure that it's executed before Chromium is started. Alternatively, you can manually terminate Chromium prior to calling this method using StandaloneWebView.TerminateBrowserProcess(). /// On Universal Windows Platform, this method is unable to clear cookies due to a UWP limitation. /// /// /// public static void ClearAllData() { _pluginFactory.GetAllPlugins().ForEach(p => p.ClearAllData()); } /// /// Creates a new webview in a platform-agnostic way. After a webview /// is created, it must be initialized by calling its Init() method. /// /// /// Note that WebViewPrefab takes care of creating and managing /// an IWebView instance for you, so you only need to call this method directly /// if you need to create an IWebView instance outside of a prefab /// (for example, to connect it to your own custom GameObject). /// /// /// /// var webView = Web.CreateWebView(); /// // Initialize the webview to 600px x 300px. /// await webView.Init(600, 300); /// webView.LoadUrl("https://vuplex.com"); /// // Set the Material attached to this GameObject to display the webview. /// GetComponent<Renderer>().material = webView.CreateMaterial(); /// /// public static IWebView CreateWebView() { return _pluginFactory.GetDefaultPlugin().CreateWebView(); } /// /// Like CreateWebView(), except an array of preferred plugin types can be /// provided to override which 3D WebView plugin is used in the case where /// multiple plugins are installed for the same build platform. /// /// /// Currently, Android is the only platform that supports multiple 3D WebView /// plugins: WebPluginType.Android and WebPluginType.AndroidGecko. If both /// plugins are installed in the same project, WebPluginType.AndroidGecko will be used by default. /// However, you can override this to force WebPluginType.Android to be used instead by passing /// `new WebPluginType[] { WebPluginType.Android }`. /// public static IWebView CreateWebView(WebPluginType[] preferredPlugins) { return _pluginFactory.GetDefaultPlugin(preferredPlugins).CreateWebView(); } /// /// Enables [remote debugging](https://support.vuplex.com/articles/how-to-debug-web-content). /// /// /// On Windows and macOS, this method cannot be executed while the Chromium browser process is running. So, you will likely need to call it from Awake() to ensure that it's executed before Chromium is started. Alternatively, you can manually terminate Chromium prior to calling this method using StandaloneWebView.TerminateBrowserProcess(). /// /// /// /// void Awake() { /// Web.EnableRemoteDebugging(); /// } /// /// public static void EnableRemoteDebugging() { _pluginFactory.GetAllPlugins().ForEach(p => p.EnableRemoteDebugging()); } /// /// By default, browsers block sites from autoplaying video with audio, /// but this method can be used to enable autoplay. /// /// /// /// void Awake() { /// Web.SetAutoplayEnabled(true); /// } /// /// /// /// Important notes: /// /// /// On Windows and macOS, this method cannot be executed while the Chromium browser process is running. So, you will likely need to call it from Awake() to ensure that it's executed before Chromium is started. Alternatively, you can manually terminate Chromium prior to calling this method using StandaloneWebView.TerminateBrowserProcess(). /// /// /// This method works for every package except for 3D WebView for UWP, /// because the underlying UWP WebView control doesn't allow autoplaying /// video with audio. /// /// /// public static void SetAutoplayEnabled(bool enabled) { _pluginFactory.GetAllPlugins().ForEach(p => p.SetAutoplayEnabled(enabled)); } /// /// By default, web pages cannot access the device's /// camera or microphone via JavaScript, but this method can /// be used to grant **all web pages** access to the camera and microphone. /// This is useful, for example, to enable WebRTC support. Note that on /// macOS, Android, iOS, and UWP, [additional project configuration is needed in order to enable /// permission for the camera and microphone](https://support.vuplex.com/articles/webrtc). /// Camera and microphone permissions are enabled together with a single method because on some platforms (Windows, macOS, UWP), /// these permissions can only be enabled together and cannot be enabled separately. /// /// /// Important notes: /// /// /// On Windows and macOS, this method cannot be executed while the Chromium browser process is running. So, you will likely need to call it from Awake() to ensure that it's executed before Chromium is started. Alternatively, you can manually terminate Chromium prior to calling this method using StandaloneWebView.TerminateBrowserProcess(). /// /// /// On iOS, enabling the camera and microphone is only supported in iOS 14.3 or newer /// and is only supported in Native 2D Mode. /// /// /// /// /// /// void Awake() { /// Web.SetCameraAndMicrophoneEnabled(true); /// } /// /// public static void SetCameraAndMicrophoneEnabled(bool enabled) { _pluginFactory.GetAllPlugins().ForEach(p => p.SetCameraAndMicrophoneEnabled(enabled)); } /// /// By default, browsers block https URLs with invalid SSL certificates /// from being loaded, but this method can be used to disable those /// certificate errors. /// /// /// /// void Awake() { /// Web.SetIgnoreCertificateErrors(true); /// } /// /// /// /// Important notes: /// /// /// On Windows and macOS, this method cannot be executed while the Chromium browser process is running. So, you will likely need to call it from Awake() to ensure that it's executed before Chromium is started. Alternatively, you can manually terminate Chromium prior to calling this method using StandaloneWebView.TerminateBrowserProcess(). /// /// /// This method works for every package except for 3D WebView for UWP. /// For UWP, certificates must be [whitelisted in the Package.appxmanifest file](https://www.suchan.cz/2015/10/displaying-https-page-with-invalid-certificate-in-uwp-webview/). /// /// /// public static void SetIgnoreCertificateErrors(bool ignore) { _pluginFactory.GetAllPlugins().ForEach(p => p.SetIgnoreCertificateErrors(ignore)); } /// /// Controls whether data like cookies, localStorage, and cached resources /// is persisted between webview instances. The default is `true`, but this /// can be set to `false` to achieve an "incognito mode". /// /// /// On Windows and macOS, this method cannot be executed while the Chromium browser process is running. So, you will likely need to call it from Awake() to ensure that it's executed before Chromium is started. Alternatively, you can manually terminate Chromium prior to calling this method using StandaloneWebView.TerminateBrowserProcess(). /// /// /// /// void Awake() { /// Web.SetStorageEnabled(false); /// } /// /// public static void SetStorageEnabled(bool enabled) { _pluginFactory.GetAllPlugins().ForEach(p => p.SetStorageEnabled(enabled)); } /// /// Globally configures all webviews to use a mobile or desktop /// [User-Agent](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/User-Agent). /// By default, webviews use the browser engine's default User-Agent, but you /// can force them to use a mobile User-Agent by calling `Web.SetUserAgent(true)` or a /// desktop User-Agent with `Web.SetUserAgent(false)`. /// /// /// /// void Awake() { /// // Use a desktop User-Agent. /// Web.SetUserAgent(false); /// } /// /// /// public static void SetUserAgent(bool mobile) { _pluginFactory.GetAllPlugins().ForEach(p => p.SetUserAgent(mobile)); } /// /// Globally configures all webviews to use a custom /// [User-Agent](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/User-Agent). /// /// /// /// void Awake() { /// // Use FireFox's User-Agent. /// Web.SetUserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:91.0) Gecko/20100101 Firefox/91.0"); /// } /// /// /// public static void SetUserAgent(string userAgent) { _pluginFactory.GetAllPlugins().ForEach(p => p.SetUserAgent(userAgent)); } static internal void SetPluginFactory(WebPluginFactory pluginFactory) => _pluginFactory = pluginFactory; static WebPluginFactory _pluginFactory = new WebPluginFactory(); #region Obsolete APIs const string CreateMaterialMessage = "Web.CreateMaterial() is now deprecated in v4. Please use IWebView.CreateMaterial() instead: https://developer.vuplex.com/webview/IWebView#CreateMaterial"; const string CreateTextureMessage = "Web.CreateTexture() has been removed in v4 because IWebView instances now automatically create their own textures. For more details, please see this article: https://support.vuplex.com/articles/v4-changes#init"; // Added in v1.0, deprecated in v3.16. [Obsolete(CreateMaterialMessage)] public static Task CreateMaterial() { var taskSource = new TaskCompletionSource(); _pluginFactory.GetDefaultPlugin().CreateMaterial(taskSource.SetResult); return taskSource.Task; } // Added in v3.8, deprecated in v4.0. [Obsolete(CreateMaterialMessage)] public static void CreateMaterial(Action callback) => _pluginFactory.GetDefaultPlugin().CreateMaterial(callback); // Added in v3.10, removed in v4.0. [Obsolete(CreateTextureMessage, true)] public static Task CreateTexture(int width, int height) { return null; } // Added in v1.0, deprecated in v3.16, removed in v4.0. [Obsolete(CreateTextureMessage, true)] public static void CreateTexture(float width, float height, Action callback) {} // Added in v1.0, removed in v4.0. [Obsolete("Web.CreateVideoMaterial() has been removed. Please use IWithFallbackVideo.CreateVideoMaterial() instead: https://developer.vuplex.com/webview/IWithFallbackVideo#CreateVideoMaterial", true)] public static void CreateVideoMaterial(Action callback) {} // Added in v3.10, deprecated in v3.14, removed in v4.0. [Obsolete("Web.SetTouchScreenKeyboardEnabled() has been removed. Please use the NativeOnScreenKeyboardEnabled property of WebViewPrefab / CanvasWebViewPrefab or the IWithNativeOnScreenKeyboard interface instead: https://developer.vuplex.com/webview/WebViewPrefab#NativeOnScreenKeyboardEnabled", true)] public static void SetTouchScreenKeyboardEnabled(bool enabled) {} #endregion } }