diff --git a/UpgradeLog3.htm b/UpgradeLog3.htm new file mode 100644 index 0000000..e5374fe --- /dev/null +++ b/UpgradeLog3.htm @@ -0,0 +1,274 @@ + + + + Migration Report +

+ Migration Report -

Overview

ProjectPathErrorsWarningsMessages
Xero Browser SetupXero Browser Setup\Xero Browser Setup.vdproj100
Solution ItemsSolution Items000
SolutionXeroBrowser.sln001

Solution and projects

Xero Browser Setup

Message
Xero Browser Setup\Xero Browser Setup.vdproj: + The application which this project type is based on was not found. Please try this link for further information: 54435603-dbb4-11d2-8724-00a0c9a8b90c

Solution Items

Message
Solution Items logged no messages. +

Solution

Message
+ Show 1 additional messages +
XeroBrowser.sln: + The solution file does not require migration.
+ Hide 1 additional messages +
\ No newline at end of file diff --git a/WebBrowser/App.config b/WebBrowser/App.config index d423a16..f75a113 100644 --- a/WebBrowser/App.config +++ b/WebBrowser/App.config @@ -1,29 +1,37 @@ - + - + - - + + - - + + - - + + - - + + - - + + + + + + + + + + diff --git a/WebBrowser/DownloadHandler.cs b/WebBrowser/DownloadHandler.cs index 3eeb630..677d5ed 100644 --- a/WebBrowser/DownloadHandler.cs +++ b/WebBrowser/DownloadHandler.cs @@ -88,5 +88,10 @@ namespace XeroBrowser } catch (InvalidOperationException){} } + + public bool CanDownload(IWebBrowser chromiumWebBrowser, IBrowser browser, string url, string requestMethod) + { + throw new NotImplementedException(); + } } } \ No newline at end of file diff --git a/WebBrowser/Program.cs b/WebBrowser/Program.cs index 361fa11..6d1c18c 100644 --- a/WebBrowser/Program.cs +++ b/WebBrowser/Program.cs @@ -22,16 +22,9 @@ namespace XeroBrowser Application.SetCompatibleTextRenderingDefault(false); Container = new AppContainer(); CefSettings settings = new CefSettings(); - - if (settings.CefCommandLineArgs.ContainsKey("enable-system-flash")) - settings.CefCommandLineArgs.Remove("enable-system-flash"); - settings.CefCommandLineArgs.Add("enable-system-flash", "1"); - settings.CefCommandLineArgs.Add("ppapi-flash-path", Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "pepflashplayer64_32_0_0_465.dll")); - settings.CefCommandLineArgs.Add("ppapi-flash-version", "32.0.0.465"); settings.CefCommandLineArgs["plugin-policy"] = "allow"; settings.UserAgent = "cpprestsdk/2.9.0 Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/113.0.0.0 XeroBrowser/1.0.0"; settings.CefCommandLineArgs.Add("enable-media-stream", "1"); - Cef.EnableHighDPISupport(); settings.CachePath = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData) + @"\CEF"; Cef.Initialize(settings); diff --git a/WebBrowser/Xero Browser.csproj b/WebBrowser/Xero Browser.csproj index 04c76b6..7bf731f 100644 --- a/WebBrowser/Xero Browser.csproj +++ b/WebBrowser/Xero Browser.csproj @@ -1,8 +1,8 @@  - - - + + + 0128 @@ -183,18 +183,21 @@ ..\packages\Bunifu.Utils.1.0.6\lib\net\Bunifu.Utils.dll - - ..\packages\CefSharp.Common.87.1.132\lib\net452\CefSharp.dll + + ..\packages\CefSharp.Common.113.1.40\lib\net452\CefSharp.dll - - ..\packages\CefSharp.Common.87.1.132\lib\net452\CefSharp.Core.dll + + ..\packages\CefSharp.Common.113.1.40\lib\net452\CefSharp.Core.dll - - ..\packages\CefSharp.WinForms.87.1.132\lib\net452\CefSharp.WinForms.dll + + ..\packages\CefSharp.WinForms.113.1.40\lib\net462\CefSharp.WinForms.dll ..\packages\EasyTabs.2.0.0\lib\net40\EasyTabs.dll + + ..\packages\ExCSS.4.2.0\lib\net48\ExCSS.dll + ..\packages\Fizzler.1.3.0\lib\netstandard2.0\Fizzler.dll @@ -205,7 +208,7 @@ ..\packages\EasyTabs.2.0.0\lib\net40\Microsoft.WindowsAPICodePack.Shell.dll - ..\packages\Svg.3.4.1\lib\net461\Svg.dll + ..\packages\Svg.3.4.4\lib\net462\Svg.dll @@ -213,8 +216,8 @@ - - ..\packages\System.Memory.4.5.4\lib\net461\System.Memory.dll + + ..\packages\System.Memory.4.5.5\lib\net461\System.Memory.dll @@ -367,10 +370,10 @@ This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}. - - - - + + + + - + \ No newline at end of file diff --git a/WebBrowser/packages.config b/WebBrowser/packages.config index 1b5eec7..bee51ad 100644 --- a/WebBrowser/packages.config +++ b/WebBrowser/packages.config @@ -2,15 +2,16 @@ - - - - + + + + + - + - + diff --git a/packages/CefSharp.Common.113.1.40/.signature.p7s b/packages/CefSharp.Common.113.1.40/.signature.p7s new file mode 100644 index 0000000..171b721 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/.signature.p7s differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp.Common.113.1.40.nupkg b/packages/CefSharp.Common.113.1.40/CefSharp.Common.113.1.40.nupkg new file mode 100644 index 0000000..82530b7 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp.Common.113.1.40.nupkg differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.Core.dll b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.Core.dll new file mode 100644 index 0000000..ab51a5f Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.Core.dll differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.Core.pdb b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.Core.pdb new file mode 100644 index 0000000..ca642b2 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.Core.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.exe b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.exe new file mode 100644 index 0000000..4bd1959 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.exe differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.pdb b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.pdb new file mode 100644 index 0000000..dca31ea Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.BrowserSubprocess.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.dll b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.dll new file mode 100644 index 0000000..4dcf14b Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.dll differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.pdb b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.pdb new file mode 100644 index 0000000..7bbf78c Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.xml b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.xml new file mode 100644 index 0000000..693bd5a --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/CefSharp/x64/CefSharp.Core.Runtime.xml @@ -0,0 +1,12767 @@ + + + + "CefSharp.Core.Runtime" + + + + + + + +Creates a detailed expection string from a provided Cef V8 exception. + + The exception which will be used as base for the message + + + +Assigns the provided cef_string_t object from the given .NET string. + + The cef_string_t that should be updated. + The .NET string whose value should be used to update cefStr. + + + +Converts a .NET List of strings to native (unmanaged) format. + + The List of strings that should be converted. + An unmanaged representation of the provided List of strings, or an empty List if the input is a nullptr. + + + +Converts a .NET string to native (unmanaged) format. Note that this method does not allocate a new copy of the + + The string that should be converted. + An unmanaged representation of the provided string, or an empty string if the input string is a nullptr. + + + +Converts an unmanaged vector of strings to a (managed) .NET List of strings. + + The vector of strings that should be converted. + A .NET List of strings. + + + +Converts an unmanaged string to a (managed) .NET string. + + The string that should be converted. + A .NET string. + + + +Converts an unmanaged string to a (managed) .NET string. + + The string that should be converted. + A .NET string. + + + +Returns true if the function was called as a constructor via "new". + + + + +Returns true if the function was compiled using eval(). + + + + +Returns the 1-based column offset on the line for the function call or 0 +if unknown. + + + + +Returns the 1-based line number for the function call or 0 if unknown. + + + + +Returns the name of the function. + + + + +Returns the name of the resource script that contains the function or the +sourceURL value if the script name is undefined and its source ends with +a "//@ sourceURL=..." string. + + + + +Returns the name of the resource script that contains the function. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Class representing a V8 stack frame handle. V8 handles can only be accessed +from the thread on which they are created. Valid threads for creating a V8 +handle include the render process main thread (TID_RENDERER) and WebWorker +threads. A task runner for posting tasks on the associated thread can be +retrieved via the CefV8Context::GetTaskRunner() method. + + + + +Returns the stack frame at the specified 0-based index. + + + + +Returns the number of stack frames. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Returns the stack trace for the currently active context. |frame_limit| is +the maximum number of frames that will be captured. + + + + +Class representing a V8 stack trace handle. V8 handles can only be accessed +from the thread on which they are created. Valid threads for creating a V8 +handle include the render process main thread (TID_RENDERER) and WebWorker +threads. A task runner for posting tasks on the associated thread can be +retrieved via the CefV8Context::GetTaskRunner() method. + + + + +Reject the Promise using the current V8 context. This method should only +be called from within the scope of a CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. Returns true on success. Returns false if this +method is called incorrectly or an exception is thrown. + + + + +Resolve the Promise using the current V8 context. This method should only +be called from within the scope of a CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. |arg| is the argument passed to the resolved +promise. Returns true on success. Returns false if this method is called +incorrectly or an exception is thrown. + + + + +Execute the function using the specified V8 context. |object| is the +receiver ('this' object) of the function. If |object| is empty the +specified context's global object will be used. |arguments| is the list of +arguments that will be passed to the function. Returns the function return +value on success. Returns NULL if this method is called incorrectly or an +exception is thrown. + + + + +Execute the function using the current V8 context. This method should only +be called from within the scope of a CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. |object| is the receiver ('this' object) of the +function. If |object| is empty the current context's global object will be +used. |arguments| is the list of arguments that will be passed to the +function. Returns the function return value on success. Returns NULL if +this method is called incorrectly or an exception is thrown. + + + + +Returns the function handler or NULL if not a CEF-created function. + + + + +Returns the function name. + + + + +Prevent the ArrayBuffer from using it's memory block by setting the length +to zero. This operation cannot be undone. If the ArrayBuffer was created +with CreateArrayBuffer then CefV8ArrayBufferReleaseCallback::ReleaseBuffer +will be called to release the underlying buffer. + + + + +Returns the ReleaseCallback object associated with the ArrayBuffer or NULL +if the ArrayBuffer was not created with CreateArrayBuffer. + + + + +Returns the number of elements in the array. + + + + +Adjusts the amount of registered external memory for the object. Used to +give V8 an indication of the amount of externally allocated memory that is +kept alive by JavaScript objects. V8 uses this information to decide when +to perform global garbage collection. Each CefV8Value tracks the amount of +external memory associated with it and automatically decreases the global +total by the appropriate amount on its destruction. |change_in_bytes| +specifies the number of bytes to adjust by. This method returns the number +of bytes associated with the object after the adjustment. This method can +only be called on user created objects. + + + + +Returns the amount of externally allocated memory registered for the +object. + + + + +Returns the user data, if any, assigned to this object. + + + + +Sets the user data for this object and returns true on success. Returns +false if this method is called incorrectly. This method can only be called +on user created objects. + + + + +Read the keys for the object's values into the specified vector. Integer- +based keys will also be returned as strings. + + + + +Registers an identifier and returns true on success. Access to the +identifier will be forwarded to the CefV8Accessor instance passed to +CefV8Value::CreateObject(). Returns false if this method is called +incorrectly or an exception is thrown. For read-only values this method +will return true even though assignment failed. + + + + +Associates a value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly or an +exception is thrown. For read-only values this method will return true +even though assignment failed. + + + + +Associates a value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly or an +exception is thrown. For read-only values this method will return true +even though assignment failed. + + + + +Returns the value with the specified identifier on success. Returns NULL +if this method is called incorrectly or an exception is thrown. + + + + +Returns the value with the specified identifier on success. Returns NULL +if this method is called incorrectly or an exception is thrown. + + + + +Deletes the value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly, deletion +fails or an exception is thrown. For read-only and don't-delete values +this method will return true even though deletion failed. + + + + +Deletes the value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly or an +exception is thrown. For read-only and don't-delete values this method +will return true even though deletion failed. + + + + +Returns true if the object has a value with the specified identifier. + + + + +Returns true if the object has a value with the specified identifier. + + + + +Set whether this object will re-throw future exceptions. By default +exceptions are not re-thrown. If a exception is re-thrown the current +context should not be accessed again until after the exception has been +caught and not re-thrown. Returns true on success. This attribute exists +only in the scope of the current CEF value object. + + + + +Returns true if this object will re-throw future exceptions. This +attribute exists only in the scope of the current CEF value object. + + + + +Clears the last exception and returns true on success. + + + + +Returns the exception resulting from the last method call. This attribute +exists only in the scope of the current CEF value object. + + + + +Returns true if the last method call resulted in an exception. This +attribute exists only in the scope of the current CEF value object. + + + +OBJECT METHODS - These methods are only available on objects. Arrays and +functions are also objects. String- and integer-based keys can be used +interchangably with the framework converting between them as necessary. + +Returns true if this is a user created object. + + + + +Return a string value. + + + + +Return a Date value. + + + + +Return a double value. + + + + +Return an unsigned int value. + + + + +Return an int value. + + + + +Return a bool value. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +True if the value type is a Promise. + + + + +True if the value type is function. + + + + +True if the value type is an ArrayBuffer. + + + + +True if the value type is array. + + + + +True if the value type is object. + + + + +True if the value type is string. + + + + +True if the value type is Date. + + + + +True if the value type is double. + + + + +True if the value type is unsigned int. + + + + +True if the value type is int. + + + + +True if the value type is bool. + + + + +True if the value type is null. + + + + +True if the value type is undefined. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Create a new CefV8Value object of type Promise. This method should only be +called from within the scope of a CefRenderProcessHandler, CefV8Handler or +CefV8Accessor callback, or in combination with calling Enter() and Exit() +on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type function. This method should only +be called from within the scope of a CefRenderProcessHandler, CefV8Handler +or CefV8Accessor callback, or in combination with calling Enter() and +Exit() on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type ArrayBuffer which wraps the +provided |buffer| of size |length| bytes. The ArrayBuffer is externalized, +meaning that it does not own |buffer|. The caller is responsible for +freeing |buffer| when requested via a call to +CefV8ArrayBufferReleaseCallback::ReleaseBuffer. This method should only +be called from within the scope of a CefRenderProcessHandler, CefV8Handler +or CefV8Accessor callback, or in combination with calling Enter() and +Exit() on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type array with the specified |length|. +If |length| is negative the returned array will have length 0. This method +should only be called from within the scope of a CefRenderProcessHandler, +CefV8Handler or CefV8Accessor callback, or in combination with calling +Enter() and Exit() on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type object with optional accessor +and/or interceptor. This method should only be called from within the +scope of a CefRenderProcessHandler, CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. + + + + +Create a new CefV8Value object of type string. + + + + +Create a new CefV8Value object of type Date. This method should only be +called from within the scope of a CefRenderProcessHandler, CefV8Handler or +CefV8Accessor callback, or in combination with calling Enter() and Exit() +on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type double. + + + + +Create a new CefV8Value object of type unsigned int. + + + + +Create a new CefV8Value object of type int. + + + + +Create a new CefV8Value object of type bool. + + + + +Create a new CefV8Value object of type null. + + + + +Create a new CefV8Value object of type undefined. + + + + +Class representing a V8 value handle. V8 handles can only be accessed from +the thread on which they are created. Valid threads for creating a V8 handle +include the render process main thread (TID_RENDERER) and WebWorker threads. +A task runner for posting tasks on the associated thread can be retrieved +via the CefV8Context::GetTaskRunner() method. + + + + +Called to release |buffer| when the ArrayBuffer JS object is garbage +collected. |buffer| is the value that was passed to CreateArrayBuffer +along with this object. + + + + +Callback interface that is passed to CefV8Value::CreateArrayBuffer. + + + + +Returns the index within the line of the last character where the error +occurred. + + + + +Returns the index within the line of the first character where the error +occurred. + + + + +Returns the index within the script of the last character where the error +occurred. + + + + +Returns the index within the script of the first character where the error +occurred. + + + + +Returns the 1-based number of the line where the error occurred or 0 if +the line number is unknown. + + + + +Returns the resource name for the script from where the function causing +the error originates. + + + + +Returns the line of source code that the exception occurred within. + + + + +Returns the exception message. + + + + +Class representing a V8 exception. The methods of this class may be called +on any render process thread. + + + + +Handle assignment of the interceptor value identified by |index|. |object| +is the receiver ('this' object) of the interceptor. |value| is the new +value being assigned to the interceptor. If assignment fails, set +|exception| to the exception that will be thrown. +Return true if interceptor assignment was handled, false otherwise. + + + + +Handle assignment of the interceptor value identified by |name|. |object| +is the receiver ('this' object) of the interceptor. |value| is the new +value being assigned to the interceptor. If assignment fails, set +|exception| to the exception that will be thrown. This setter will always +be called, even when the property has an associated accessor. +Return true if interceptor assignment was handled, false otherwise. + + + + +Handle retrieval of the interceptor value identified by |index|. |object| +is the receiver ('this' object) of the interceptor. If retrieval succeeds, +set |retval| to the return value. If the requested value does not exist, +don't set either |retval| or |exception|. If retrieval fails, set +|exception| to the exception that will be thrown. +Return true if interceptor retrieval was handled, false otherwise. + + + + +Handle retrieval of the interceptor value identified by |name|. |object| +is the receiver ('this' object) of the interceptor. If retrieval succeeds, +set |retval| to the return value. If the requested value does not exist, +don't set either |retval| or |exception|. If retrieval fails, set +|exception| to the exception that will be thrown. If the property has an +associated accessor, it will be called only if you don't set |retval|. +Return true if interceptor retrieval was handled, false otherwise. + + + + +Interface that should be implemented to handle V8 interceptor calls. The +methods of this class will be called on the thread associated with the V8 +interceptor. Interceptor's named property handlers (with first argument of +type CefString) are called when object is indexed by string. Indexed +property handlers (with first argument of type int) are called when object +is indexed by integer. + + + + +Handle assignment of the accessor value identified by |name|. |object| is +the receiver ('this' object) of the accessor. |value| is the new value +being assigned to the accessor. If assignment fails set |exception| to the +exception that will be thrown. Return true if accessor assignment was +handled. + + + + +Handle retrieval the accessor value identified by |name|. |object| is the +receiver ('this' object) of the accessor. If retrieval succeeds set +|retval| to the return value. If retrieval fails set |exception| to the +exception that will be thrown. Return true if accessor retrieval was +handled. + + + + +Interface that should be implemented to handle V8 accessor calls. Accessor +identifiers are registered by calling CefV8Value::SetValue(). The methods +of this class will be called on the thread associated with the V8 accessor. + + + + +Handle execution of the function identified by |name|. |object| is the +receiver ('this' object) of the function. |arguments| is the list of +arguments passed to the function. If execution succeeds set |retval| to +the function return value. If execution fails set |exception| to the +exception that will be thrown. Return true if execution was handled. + + + + +Interface that should be implemented to handle V8 function calls. The +methods of this class will be called on the thread associated with the V8 +function. + + + + +Execute a string of JavaScript code in this V8 context. The |script_url| +parameter is the URL where the script in question can be found, if any. +The |start_line| parameter is the base line number to use for error +reporting. On success |retval| will be set to the return value, if any, +and the function will return true. On failure |exception| will be set to +the exception, if any, and the function will return false. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +Exit this context. Call this method only after calling Enter(). Returns +true if the scope was exited successfully. + + + + +Enter this context. A context must be explicitly entered before creating a +V8 Object, Array, Function or Date asynchronously. Exit() must be called +the same number of times as Enter() before releasing this context. V8 +objects belong to the context in which they are created. Returns true if +the scope was entered successfully. + + + + +Returns the global object for this context. The context must be entered +before calling this method. + + + + +Returns the frame for this context. This method will return an empty +reference for WebWorker contexts. + + + + +Returns the browser for this context. This method will return an empty +reference for WebWorker contexts. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Returns the task runner associated with this context. V8 handles can only +be accessed from the thread on which they are created. This method can be +called on any render process thread. + + + + +Returns true if V8 is currently inside a context. + + + + +Returns the entered (bottom) context object in the V8 context stack. + + + + +Returns the current (top) context object in the V8 context stack. + + + + +Class representing a V8 context handle. V8 handles can only be accessed from +the thread on which they are created. Valid threads for creating a V8 handle +include the render process main thread (TID_RENDERER) and WebWorker threads. +A task runner for posting tasks on the associated thread can be retrieved +via the CefV8Context::GetTaskRunner() method. + + + + +Register a new V8 extension with the specified JavaScript extension code and +handler. Functions implemented by the handler are prototyped using the +keyword 'native'. The calling of a native function is restricted to the +scope in which the prototype of the native function is defined. This +function may only be called on the render process main thread. + +Example JavaScript extension code: +
+  // create the 'example' global object if it doesn't already exist.
+  if (!example)
+    example = {};
+  // create the 'example.test' global object if it doesn't already exist.
+  if (!example.test)
+    example.test = {};
+  (function() {
+    // Define the function 'example.test.myfunction'.
+    example.test.myfunction = function() {
+      // Call CefV8Handler::Execute() with the function name 'MyFunction'
+      // and no arguments.
+      native function MyFunction();
+      return MyFunction();
+    };
+    // Define the getter function for parameter 'example.test.myparam'.
+    example.test.__defineGetter__('myparam', function() {
+      // Call CefV8Handler::Execute() with the function name 'GetMyParam'
+      // and no arguments.
+      native function GetMyParam();
+      return GetMyParam();
+    });
+    // Define the setter function for parameter 'example.test.myparam'.
+    example.test.__defineSetter__('myparam', function(b) {
+      // Call CefV8Handler::Execute() with the function name 'SetMyParam'
+      // and a single argument.
+      native function SetMyParam();
+      if(b) SetMyParam(b);
+    });
+
+    // Extension definitions can also contain normal JavaScript variables
+    // and functions.
+    var myint = 0;
+    example.test.increment = function() {
+      myint += 1;
+      return myint;
+    };
+  })();
+
+ +Example usage in the page: +
+  // Call the function.
+  example.test.myfunction();
+  // Set the parameter.
+  example.test.myparam = value;
+  // Get the parameter.
+  value = example.test.myparam;
+  // Call another function.
+  example.test.increment();
+
+ + +Post a task for delayed execution on the specified thread. Equivalent to +using CefTaskRunner::GetForThread(threadId)->PostDelayedTask(task, +delay_ms). + + + + +Post a task for execution on the specified thread. Equivalent to +using CefTaskRunner::GetForThread(threadId)->PostTask(task). + + + + +Returns true if called on the specified thread. Equivalent to using +CefTaskRunner::GetForThread(threadId)->BelongsToCurrentThread(). + + + + +Post a task for delayed execution on the thread associated with this task +runner. Execution will occur asynchronously. Delayed tasks are not +supported on V8 WebWorker threads and will be executed without the +specified delay. + + + + +Post a task for execution on the thread associated with this task runner. +Execution will occur asynchronously. + + + + +Returns true if this task runner is for the specified CEF thread. + + + + +Returns true if this task runner belongs to the current thread. + + + + +Returns true if this object is pointing to the same task runner as |that| +object. + + + + +Returns the task runner for the specified CEF thread. + + + + +Returns the task runner for the current thread. Only CEF threads will have +task runners. An empty reference will be returned if this method is called +on an invalid thread. + + + + +Class that asynchronously executes tasks on the associated thread. It is +safe to call the methods of this class on any thread. + +CEF maintains multiple internal threads that are used for handling different +types of tasks in different processes. The cef_thread_id_t definitions in +cef_types.h list the common CEF threads. Task runners are also available for +other CEF threads as appropriate (for example, V8 WebWorker threads). + + + + +Method that will be executed on the target thread. + + + + +Implement this interface for asynchronous task execution. If the task is +posted successfully and if the associated message loop is still running then +the Execute() method will be called on the target thread. If the task fails +to post then the task object may be destroyed on the source thread instead +of the target thread. For this reason be cautious when performing work in +the task object destructor. + + + + +Returns true if the browser's audio is muted. This method can only be +called on the UI thread. + + + + +Set whether the browser's audio is muted. + + + + +Returns true if this browser is hosting an extension background script. +Background hosts do not have a window and are not displayable. See +CefRequestContext::LoadExtension for details. + + + + +Returns the extension hosted in this browser or NULL if no extension is +hosted. See CefRequestContext::LoadExtension for details. + + + + +Enable notifications of auto resize via CefDisplayHandler::OnAutoResize. +Notifications are disabled by default. |min_size| and |max_size| define +the range of allowed sizes. + + + + +Set accessibility state for all frames. |accessibility_state| may be +default, enabled or disabled. If |accessibility_state| is STATE_DEFAULT +then accessibility will be disabled by default and the state may be +further controlled with the "force-renderer-accessibility" and +"disable-renderer-accessibility" command-line switches. If +|accessibility_state| is STATE_ENABLED then accessibility will be enabled. +If |accessibility_state| is STATE_DISABLED then accessibility will be +completely disabled. + +For windowed browsers accessibility will be enabled in Complete mode +(which corresponds to kAccessibilityModeComplete in Chromium). In this +mode all platform accessibility objects will be created and managed by +Chromium's internal implementation. The client needs only to detect the +screen reader and call this method appropriately. For example, on macOS +the client can handle the @"AXEnhancedUserInterface" accessibility +attribute to detect VoiceOver state changes and on Windows the client can +handle WM_GETOBJECT with OBJID_CLIENT to detect accessibility readers. + +For windowless browsers accessibility will be enabled in TreeOnly mode +(which corresponds to kAccessibilityModeWebContentsOnly in Chromium). In +this mode renderer accessibility is enabled, the full tree is computed, +and events are passed to CefAccessibiltyHandler, but platform +accessibility objects are not created. The client may implement platform +accessibility objects using CefAccessibiltyHandler callbacks if desired. + + + + +Returns the current visible navigation entry for this browser. This method +can only be called on the UI thread. + + + + +Call this method when the drag operation started by a +CefRenderHandler::StartDragging call has completed. This method may be +called immediately without first calling DragSourceEndedAt to cancel a +drag operation. If the web view is both the drag source and the drag +target then all DragTarget* methods should be called before DragSource* +mthods. +This method is only used when window rendering is disabled. + + + + +Call this method when the drag operation started by a +CefRenderHandler::StartDragging call has ended either in a drop or +by being cancelled. |x| and |y| are mouse coordinates relative to the +upper-left corner of the view. If the web view is both the drag source +and the drag target then all DragTarget* methods should be called before +DragSource* mthods. +This method is only used when window rendering is disabled. + + + + +Call this method when the user completes the drag operation by dropping +the object onto the web view (after calling DragTargetDragEnter). +The object being dropped is |drag_data|, given as an argument to +the previous DragTargetDragEnter call. +This method is only used when window rendering is disabled. + + + + +Call this method when the user drags the mouse out of the web view (after +calling DragTargetDragEnter). +This method is only used when window rendering is disabled. + + + + +Call this method each time the mouse is moved across the web view during +a drag operation (after calling DragTargetDragEnter and before calling +DragTargetDragLeave/DragTargetDrop). +This method is only used when window rendering is disabled. + + + + +Call this method when the user drags the mouse into the web view (before +calling DragTargetDragOver/DragTargetLeave/DragTargetDrop). +|drag_data| should not contain file contents as this type of data is not +allowed to be dragged into the web view. File contents can be removed +using CefDragData::ResetFileContents (for example, if |drag_data| comes +from CefRenderHandler::StartDragging). This method is only used when +window rendering is disabled. + + + + +Cancels the existing composition and discards the composition node +contents without applying them. See comments on ImeSetComposition for +usage. +This method is only used when window rendering is disabled. + + + + +Completes the existing composition by applying the current composition +node contents. If |keep_selection| is false the current selection, if any, +will be discarded. See comments on ImeSetComposition for usage. This +method is only used when window rendering is disabled. + + + + +Completes the existing composition by optionally inserting the specified +|text| into the composition node. |replacement_range| is an optional range +of the existing text that will be replaced. |relative_cursor_pos| is where +the cursor will be positioned relative to the current cursor position. See +comments on ImeSetComposition for usage. The |replacement_range| and +|relative_cursor_pos| values are only used on OS X. +This method is only used when window rendering is disabled. + + + + +Begins a new composition or updates the existing composition. Blink has a +special node (a composition node) that allows the input method to change +text without affecting other DOM nodes. |text| is the optional text that +will be inserted into the composition node. |underlines| is an optional +set of ranges that will be underlined in the resulting text. +|replacement_range| is an optional range of the existing text that will be +replaced. |selection_range| is an optional range of the resulting text +that will be selected after insertion or replacement. The +|replacement_range| value is only used on OS X. + +This method may be called multiple times as the composition changes. When +the client is done making changes the composition should either be +canceled or completed. To cancel the composition call +ImeCancelComposition. To complete the composition call either +ImeCommitText or ImeFinishComposingText. Completion is usually signaled +when: + +1. The client receives a WM_IME_COMPOSITION message with a GCS_RESULTSTR + flag (on Windows), or; +2. The client receives a "commit" signal of GtkIMContext (on Linux), or; +3. insertText of NSTextInput is called (on Mac). + +This method is only used when window rendering is disabled. + + + + +Set the maximum rate in frames per second (fps) that CefRenderHandler:: +OnPaint will be called for a windowless browser. The actual fps may be +lower if the browser cannot generate frames at the requested rate. The +minimum value is 1 and the maximum value is 60 (default 30). Can also be +set at browser creation via CefBrowserSettings.windowless_frame_rate. + + + + +Returns the maximum rate in frames per second (fps) that +CefRenderHandler::OnPaint will be called for a windowless browser. The +actual fps may be lower if the browser cannot generate frames at the +requested rate. The minimum value is 1 and the maximum value is 60 +(default 30). This method can only be called on the UI thread. + + + + +Notify the browser that the window hosting it is about to be moved or +resized. This method is only used on Windows and Linux. + + + + +Send a capture lost event to the browser. + + + + +Send a touch event to the browser for a windowless browser. + + + + +Send a mouse wheel event to the browser. The |x| and |y| coordinates are +relative to the upper-left corner of the view. The |deltaX| and |deltaY| +values represent the movement delta in the X and Y directions +respectively. In order to scroll inside select popups with window +rendering disabled CefRenderHandler::GetScreenPoint should be implemented +properly. + + + + +Send a mouse move event to the browser. The |x| and |y| coordinates are +relative to the upper-left corner of the view. + + + + +Send a mouse click event to the browser. The |x| and |y| coordinates are +relative to the upper-left corner of the view. + + + + +Send a key event to the browser. + + + + +Issue a BeginFrame request to Chromium. Only valid when +CefWindowInfo::external_begin_frame_enabled is set to true. + + + + +Invalidate the view. The browser will call CefRenderHandler::OnPaint +asynchronously. This method is only used when window rendering is +disabled. + + + + +Send a notification to the browser that the screen info has changed. The +browser will then call CefRenderHandler::GetScreenInfo to update the +screen information with the new values. This simulates moving the webview +window from one display to another, or changing the properties of the +current display. This method is only used when window rendering is +disabled. + + + + +Notify the browser that it has been hidden or shown. Layouting and +CefRenderHandler::OnPaint notification will stop when the browser is +hidden. This method is only used when window rendering is disabled. + + + + +Notify the browser that the widget has been resized. The browser will +first call CefRenderHandler::GetViewRect to get the new size and then call +CefRenderHandler::OnPaint asynchronously with the updated regions. This +method is only used when window rendering is disabled. + + + + +Returns true if window rendering is disabled. + + + + +Add the specified |word| to the spelling dictionary. + + + + +If a misspelled word is currently selected in an editable node calling +this method will replace it with the specified |word|. + + + + +Retrieve a snapshot of current navigation entries as values sent to the +specified visitor. If |current_only| is true only the current navigation +entry will be sent, otherwise all navigation entries will be sent. + + + + +Add an observer for DevTools protocol messages (method results and +events). The observer will remain registered until the returned +Registration object is destroyed. See the SendDevToolsMessage +documentation for additional usage information. + + + + +Execute a method call over the DevTools protocol. This is a more +structured version of SendDevToolsMessage. |message_id| is an incremental +number that uniquely identifies the message (pass 0 to have the next +number assigned automatically based on previous values). |method| is the +method name. |params| are the method parameters, which may be empty. See +the DevTools protocol documentation (linked above) for details of +supported methods and the expected |params| dictionary contents. This +method will return the assigned message ID if called on the UI thread and +the message was successfully submitted for validation, otherwise 0. See +the SendDevToolsMessage documentation for additional usage information. + + + + +Returns true if this browser currently has an associated DevTools browser. +Must be called on the browser process UI thread. + + + + +Explicitly close the associated DevTools browser, if any. + + + + +Open developer tools (DevTools) in its own browser. The DevTools browser +will remain associated with this browser. If the DevTools browser is +already open then it will be focused, in which case the |windowInfo|, +|client| and |settings| parameters will be ignored. If +|inspect_element_at| is non-empty then the element at the specified (x,y) +location will be inspected. The |windowInfo| parameter will be ignored if +this browser is wrapped in a CefBrowserView. + + + + +Cancel all searches that are currently going on. + + + + +Search for |searchText|. |forward| indicates whether to search forward or +backward within the page. |matchCase| indicates whether the search should +be case-sensitive. |findNext| indicates whether this is the first request +or a follow-up. The search will be restarted if |searchText| or +|matchCase| change. The search will be stopped if |searchText| is empty. +The CefFindHandler instance, if any, returned via +CefClient::GetFindHandler will be called to report find results. + + + + +Print the current browser contents to the PDF file specified by |path| and +execute |callback| on completion. The caller is responsible for deleting +|path| when done. For PDF printing to work on Linux you must implement the +CefPrintHandler::GetPdfPaperSize method. + + + + +Print the current browser contents. + + + + +Download the file at |url| using CefDownloadHandler. + + + + +Call to run a file chooser dialog. Only a single file chooser dialog may +be pending at any given time. |mode| represents the type of dialog to +display. |title| to the title to be used for the dialog and may be empty +to show the default title ("Open" or "Save" depending on the mode). +|default_file_path| is the path with optional directory and/or file name +component that will be initially selected in the dialog. |accept_filters| +are used to restrict the selectable file types and may any combination of +(a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), (b) +individual file extensions (e.g. +".txt" or ".png"), or (c) combined description and file extension +delimited using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg"). +|callback| will be executed after the dialog is dismissed or immediately +if another dialog is already pending. The dialog will be initiated +asynchronously on the UI thread. + + + + +Change the zoom level to the specified value. Specify 0.0 to reset the +zoom level. If called on the UI thread the change will be applied +immediately. Otherwise, the change will be applied asynchronously on the +UI thread. + + + + +Get the current zoom level. The default zoom level is 0.0. This method can +only be called on the UI thread. + + + + +Returns the request context for this browser. + + + + +Returns the client for this browser. + + + + +Returns true if this browser is wrapped in a CefBrowserView. + + + + +Retrieve the window handle (if any) of the browser that opened this +browser. Will return NULL for non-popup browsers or if this browser is +wrapped in a CefBrowserView. This method can be used in combination with +custom handling of modal windows. + + + + +Retrieve the window handle (if any) for this browser. If this browser is +wrapped in a CefBrowserView this method should be called on the browser +process UI thread and it will return the handle for the top-level native +window. + + + + +Set whether the browser is focused. + + + + +Helper for closing a browser. Call this method from the top-level window +close handler (if any). Internally this calls CloseBrowser(false) if the +close has not yet been initiated. This method returns false while the +close is pending and true after the close has completed. See +CloseBrowser() and CefLifeSpanHandler::DoClose() documentation for +additional usage information. This method must be called on the browser +process UI thread. + + + + +Request that the browser close. The JavaScript 'onbeforeunload' event will +be fired. If |force_close| is false the event handler, if any, will be +allowed to prompt the user and the user can optionally cancel the close. +If |force_close| is true the prompt will not be displayed and the close +will proceed. Results in a call to CefLifeSpanHandler::DoClose() if the +event handler allows the close or if |force_close| is true. See +CefLifeSpanHandler::DoClose() documentation for additional usage +information. + + + + +Returns the hosted browser object. + + + + +Create a new browser using the window parameters specified by +|windowInfo|. If |request_context| is empty the global request context +will be used. This method can only be called on the browser process UI +thread. The optional |extra_info| parameter provides an opportunity to +specify extra information specific to the created browser that will be +passed to CefRenderProcessHandler::OnBrowserCreated() in the render +process. + + + + +Create a new browser using the window parameters specified by +|windowInfo|. All values will be copied internally and the actual window +(if any) will be created on the UI thread. If |request_context| is empty +the global request context will be used. This method can be called on any +browser process thread and will not block. The optional |extra_info| +parameter provides an opportunity to specify extra information specific to +the created browser that will be passed to +CefRenderProcessHandler::OnBrowserCreated() in the render process. + + + + +Class used to represent the browser process aspects of a browser. The +methods of this class can only be called in the browser process. They may be +called on any thread in that process unless otherwise indicated in the +comments. + + + + +Method that will be executed when the image download has completed. +|image_url| is the URL that was downloaded and |http_status_code| is the +resulting HTTP status code. |image| is the resulting image, possibly at +multiple scale factors, or empty if the download failed. + + + + +Callback interface for CefBrowserHost::DownloadImage. The methods of this +class will be called on the browser process UI thread. + + + + +Method that will be executed when the PDF printing has completed. |path| +is the output path. |ok| will be true if the printing completed +successfully or false otherwise. + + + + +Callback interface for CefBrowserHost::PrintToPDF. The methods of this class +will be called on the browser process UI thread. + + + + +Method that will be executed. Do not keep a reference to |entry| outside +of this callback. Return true to continue visiting entries or false to +stop. |current| is true if this entry is the currently loaded navigation +entry. |index| is the 0-based index of this entry and |total| is the total +number of entries. + + + + +Callback interface for CefBrowserHost::GetNavigationEntries. The methods of +this class will be called on the browser process UI thread. + + + + +Called asynchronously after the file dialog is dismissed. +|file_paths| will be a single value or a list of values depending on the +dialog mode. If the selection was cancelled |file_paths| will be empty. + + + + +Callback interface for CefBrowserHost::RunFileDialog. The methods of this +class will be called on the browser process UI thread. + + + + +Returns the names of all existing frames. + + + + +Returns the identifiers of all existing frames. + + + + +Returns the number of frames that currently exist. + + + + +Returns the frame with the specified name, or NULL if not found. + + + + +Returns the frame with the specified identifier, or NULL if not found. + + + + +Returns the focused frame for the browser. + + + + +Returns the main (top-level) frame for the browser. In the browser process +this will return a valid object until after +CefLifeSpanHandler::OnBeforeClose is called. In the renderer process this +will return NULL if the main frame is hosted in a different renderer +process (e.g. for cross-origin sub-frames). The main frame object will +change during cross-origin navigation or re-navigation after renderer +process termination (due to crashes, etc). + + + + +Returns true if a document has been loaded in the browser. + + + + +Returns true if the browser is a popup. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +Returns the globally unique identifier for this browser. This value is +also used as the tabId for extension APIs. + + + + +Stop loading the page. + + + + +Reload the current page ignoring any cached data. + + + + +Reload the current page. + + + + +Returns true if the browser is currently loading. + + + + +Navigate forwards. + + + + +Returns true if the browser can navigate forwards. + + + + +Navigate backwards. + + + + +Returns true if the browser can navigate backwards. + + + + +Returns the browser host object. This method can only be called in the +browser process. + + + + +True if this object is currently valid. This will return false after +CefLifeSpanHandler::OnBeforeClose is called. + + + + +Class used to represent a browser. When used in the browser process the +methods of this class may be called on any thread unless otherwise indicated +in the comments. When used in the render process the methods of this class +may only be called on the main thread. + + + + +Returns the MediaRouter object associated with this context. If +|callback| is non-NULL it will be executed asnychronously on the UI thread +after the manager's context has been initialized. + + + + +Returns the extension matching |extension_id| or NULL if no matching +extension is accessible in this context (see HasExtension). This method +must be called on the browser process UI thread. + + + + +Retrieve the list of all extensions that this context has access to (see +HasExtension). |extension_ids| will be populated with the list of +extension ID values. Returns true on success. This method must be called +on the browser process UI thread. + + + + +Returns true if this context has access to the extension identified by +|extension_id|. This may not be the context that was used to load the +extension (see DidLoadExtension). This method must be called on the +browser process UI thread. + + + + +Returns true if this context was used to load the extension identified by +|extension_id|. Other contexts sharing the same storage will also have +access to the extension (see HasExtension). This method must be called on +the browser process UI thread. + + + + +Attempts to resolve |origin| to a list of associated IP addresses. +|callback| will be executed on the UI thread after completion. + + + + +Clears all active and idle connections that Chromium currently has. +This is only recommended if you have released all other CEF objects but +don't yet want to call CefShutdown(). If |callback| is non-NULL it will be +executed on the UI thread after completion. + + + + +Clears all HTTP authentication credentials that were added as part of +handling GetAuthCredentials. If |callback| is non-NULL it will be executed +on the UI thread after completion. + + + + +Clears all certificate exceptions that were added as part of handling +CefRequestHandler::OnCertificateError(). If you call this it is +recommended that you also call CloseAllConnections() or you risk not +being prompted again for server certificates if you reconnect quickly. +If |callback| is non-NULL it will be executed on the UI thread after +completion. + + + + +Clear all registered scheme handler factories. Returns false on error. +This function may be called on any thread in the browser process. + + + + +Register a scheme handler factory for the specified |scheme_name| and +optional |domain_name|. An empty |domain_name| value for a standard scheme +will cause the factory to match all domain names. The |domain_name| value +will be ignored for non-standard schemes. If |scheme_name| is a built-in +scheme and no handler is returned by |factory| then the built-in scheme +handler factory will be called. If |scheme_name| is a custom scheme then +you must also implement the CefApp::OnRegisterCustomSchemes() method in +all processes. This function may be called multiple times to change or +remove the factory that matches the specified |scheme_name| and optional +|domain_name|. Returns false if an error occurs. This function may be +called on any thread in the browser process. + + + + +Returns the cookie manager for this object. If |callback| is non-NULL it +will be executed asnychronously on the UI thread after the manager's +storage has been initialized. + + + + +Returns the cache path for this object. If empty an "incognito mode" +in-memory cache is being used. + + + + +Returns the handler for this context if any. + + + + +Returns true if this object is the global context. The global context is +used by default when creating a browser or URL request with a NULL context +argument. + + + + +Returns true if this object is sharing the same storage as |that| object. + + + + +Returns true if this object is pointing to the same context as |that| +object. + + + + +Creates a new context object that shares storage with |other| and uses an +optional |handler|. + + + + +Creates a new context object with the specified |settings| and optional +|handler|. + + + + +Returns the global context object. + + + + +A request context provides request handling for a set of related browser +or URL request objects. A request context can be specified when creating a +new browser via the CefBrowserHost static factory methods or when creating a +new URL request via the CefURLRequest static factory methods. Browser +objects with different request contexts will never be hosted in the same +render process. Browser objects with the same request context may or may not +be hosted in the same render process depending on the process model. Browser +objects created indirectly via the JavaScript window.open function or +targeted links will share the same render process and the same request +context as the source browser. When running in single-process mode there is +only a single render process (the main process) and so all browsers created +in single-process mode will share the same request context. This will be the +first request context passed into a CefBrowserHost static factory method and +all other request context objects will be ignored. + + + + +Called on the UI thread after the ResolveHost request has completed. +|result| will be the result code. |resolved_ips| will be the list of +resolved IP addresses or empty if the resolution failed. + + + + +Callback interface for CefRequestContext::ResolveHost. + + + + +Set the |value| associated with preference |name|. Returns true if the +value is set successfully and false otherwise. If |value| is NULL the +preference will be restored to its default value. If setting the +preference fails then |error| will be populated with a detailed +description of the problem. This method must be called on the browser +process UI thread. + + + + +Returns true if the preference with the specified |name| can be modified +using SetPreference. As one example preferences set via the command-line +usually cannot be modified. This method must be called on the browser +process UI thread. + + + + +Returns all preferences as a dictionary. If |include_defaults| is true +then preferences currently at their default value will be included. The +returned object contains a copy of the underlying preference values and +modifications to the returned object will not modify the underlying +preference values. This method must be called on the browser process UI +thread. + + + + +Returns the value for the preference with the specified |name|. Returns +NULL if the preference does not exist. The returned object contains a copy +of the underlying preference value and modifications to the returned +object will not modify the underlying preference value. This method must +be called on the browser process UI thread. + + + + +Returns true if a preference with the specified |name| exists. This method +must be called on the browser process UI thread. + + + + +Returns the global preference manager object. + + + + +Manage access to preferences. Many built-in preferences are registered by +Chromium. Custom preferences can be registered in +CefBrowserProcessHandler::OnRegisterCustomPreferences. + + + + +Register a preference with the specified |name| and |default_value|. To +avoid conflicts with built-in preferences the |name| value should contain +an application-specific prefix followed by a period (e.g. "myapp.value"). +The contents of |default_value| will be copied. The data type for the +preference will be inferred from |default_value|'s type and cannot be +changed after registration. Returns true on success. Returns false if +|name| is already registered or if |default_value| has an invalid type. +This method must be called from within the scope of the +CefBrowserProcessHandler::OnRegisterCustomPreferences callback. + + + + +Class that manages custom preference registrations. + + + + +Returns true if this source outputs its content via DIAL. + + + + +Returns true if this source outputs its content via Cast. + + + + +Returns the ID (media source URN or URL) for this source. + + + + +Represents a source from which media can be routed. Instances of this object +are retrieved via CefMediaRouter::GetSource. The methods of this class may +be called on any browser process thread unless otherwise indicated. + + + + +Method that will be executed asyncronously once device information has +been retrieved. + + + + +Callback interface for CefMediaSink::GetDeviceInfo. The methods of this +class will be called on the browser process UI thread. + + + + +Returns true if this sink is compatible with |source|. + + + + +Returns true if this sink accepts content via DIAL. + + + + +Returns true if this sink accepts content via Cast. + + + + +Asynchronously retrieves device info. + + + + +Returns the icon type for this sink. + + + + +Returns the name of this sink. + + + + +Returns the ID for this sink. + + + + +Represents a sink to which media can be routed. Instances of this object are +retrieved via CefMediaObserver::OnSinks. The methods of this class may +be called on any browser process thread unless otherwise indicated. + + + + +Method that will be executed when the route creation has finished. +|result| will be CEF_MRCR_OK if the route creation succeeded. |error| will +be a description of the error if the route creation failed. |route| is the +resulting route, or empty if the route creation failed. + + + + +Callback interface for CefMediaRouter::CreateRoute. The methods of this +class will be called on the browser process UI thread. + + + + +Terminate this route. Will result in an asynchronous call to +CefMediaObserver::OnRoutes on all registered observers. + + + + +Send a message over this route. |message| will be copied if necessary. + + + + +Returns the sink associated with this route. + + + + +Returns the source associated with this route. + + + + +Returns the ID for this route. + + + + +Represents the route between a media source and sink. Instances of this +object are created via CefMediaRouter::CreateRoute and retrieved via +CefMediaObserver::OnRoutes. Contains the status and metadata of a +routing operation. The methods of this class may be called on any browser +process thread unless otherwise indicated. + + + + +A message was recieved over |route|. |message| is only valid for +the scope of this callback and should be copied if necessary. + + + + +The connection state of |route| has changed. + + + + +The list of available media routes has changed or +CefMediaRouter::NotifyCurrentRoutes was called. + + + + +The list of available media sinks has changed or +CefMediaRouter::NotifyCurrentSinks was called. + + + + +Implemented by the client to observe MediaRouter events and registered via +CefMediaRouter::AddObserver. The methods of this class will be called on the +browser process UI thread. + + + + +Trigger an asynchronous call to CefMediaObserver::OnRoutes on all +registered observers. + + + + +Create a new route between |source| and |sink|. Source and sink must be +valid, compatible (as reported by CefMediaSink::IsCompatibleWith), and a +route between them must not already exist. |callback| will be executed +on success or failure. If route creation succeeds it will also trigger an +asynchronous call to CefMediaObserver::OnRoutes on all registered +observers. + + + + +Trigger an asynchronous call to CefMediaObserver::OnSinks on all +registered observers. + + + + +Add an observer for MediaRouter events. The observer will remain +registered until the returned Registration object is destroyed. + + + + +Returns the MediaRouter object associated with the global request context. +If |callback| is non-NULL it will be executed asnychronously on the UI +thread after the manager's storage has been initialized. Equivalent to +calling CefRequestContext::GetGlobalContext()->GetMediaRouter(). + + + + +Supports discovery of and communication with media devices on the local +network via the Cast and DIAL protocols. The methods of this class may be +called on any browser process thread unless otherwise indicated. + + + + +Called to retrieve an extension resource that would normally be loaded +from disk (e.g. if a file parameter is specified to +chrome.tabs.executeScript). |extension| and |browser| are the source of +the resource request. |file| is the requested relative file path. To +handle the resource request return true and execute |callback| either +synchronously or asynchronously. For the default behavior which reads the +resource from the extension directory on disk return false. Localization +substitutions will not be applied to resources handled via this method. + + + + +Called when the tabId associated with |target_browser| is specified to an +extension API call that accepts a tabId parameter (e.g. chrome.tabs.*). +|extension| and |browser| are the source of the API call. Return true +to allow access of false to deny access. Access to incognito browsers +should not be allowed unless the source extension has incognito access +enabled, in which case |include_incognito| will be true. + + + + +Called when no tabId is specified to an extension API call that accepts a +tabId parameter (e.g. chrome.tabs.*). |extension| and |browser| are the +source of the API call. Return the browser that will be acted on by the +API call or return NULL to act on |browser|. The returned browser must +share the same CefRequestContext as |browser|. Incognito browsers should +not be considered unless the source extension has incognito access +enabled, in which case |include_incognito| will be true. + + + + +Called when an extension API (e.g. chrome.tabs.create) requests creation +of a new browser. |extension| and |browser| are the source of the API +call. |active_browser| may optionally be specified via the windowId +property or returned via the GetActiveBrowser() callback and provides the +default |client| and |settings| values for the new browser. |index| is the +position value optionally specified via the index property. |url| is the +URL that will be loaded in the browser. |active| is true if the new +browser should be active when opened. To allow creation of the browser +optionally modify |windowInfo|, |client| and |settings| and return false. +To cancel creation of the browser return true. Successful creation will be +indicated by a call to CefLifeSpanHandler::OnAfterCreated. Any +modifications to |windowInfo| will be ignored if |active_browser| is +wrapped in a CefBrowserView. + + + + +Called after the CefExtension::Unload request has completed. + + + + +Called if the CefRequestContext::LoadExtension request succeeds. +|extension| is the loaded extension. + + + + +Called if the CefRequestContext::LoadExtension request fails. |result| +will be the error code. + + + + +Implement this interface to handle events related to browser extensions. +The methods of this class will be called on the UI thread. See +CefRequestContext::LoadExtension for information about extension loading. + + + + +Cancel the request. + + + + +Continue the request. Read the resource contents from |stream|. + + + + +Callback interface used for asynchronous continuation of +CefExtensionHandler::GetExtensionResource. + + + + +Unload this extension if it is not an internal extension and is currently +loaded. Will result in a call to CefExtensionHandler::OnExtensionUnloaded +on success. + + + + +Returns true if this extension is currently loaded. Must be called on the +browser process UI thread. + + + + +Returns the request context that loaded this extension. Will return NULL +for internal extensions or if the extension has been unloaded. See the +CefRequestContext::LoadExtension documentation for more information about +loader contexts. Must be called on the browser process UI thread. + + + + +Returns the handler for this extension. Will return NULL for internal +extensions or if no handler was passed to +CefRequestContext::LoadExtension. + + + + +Returns true if this object is the same extension as |that| object. +Extensions are considered the same if identifier, path and loader context +match. + + + + +Returns the extension manifest contents as a CefDictionaryValue object. +See https://developer.chrome.com/extensions/manifest for details. + + + + +Returns the absolute path to the extension directory on disk. This value +will be prefixed with PK_DIR_RESOURCES if a relative path was passed to +CefRequestContext::LoadExtension. + + + + +Returns the unique extension identifier. This is calculated based on the +extension public key, if available, or on the extension path. See +https://developer.chrome.com/extensions/manifest/key for details. + + + + +Object representing an extension. Methods may be called on any thread unless +otherwise indicated. + + + + +Method that will be called upon completion. |num_deleted| will be the +number of cookies that were deleted. + + + + +Interface to implement to be notified of asynchronous completion via +CefCookieManager::DeleteCookies(). + + + + +Method that will be called upon completion. |success| will be true if the +cookie was set successfully. + + + + +Interface to implement to be notified of asynchronous completion via +CefCookieManager::SetCookie(). + + + + +Method that will be called once for each cookie. |count| is the 0-based +index for the current cookie. |total| is the total number of cookies. +Set |deleteCookie| to true to delete the cookie currently being visited. +Return false to stop visiting cookies. This method may never be called if +no cookies are found. + + + + +Interface to implement for visiting cookie values. The methods of this class +will always be called on the UI thread. + + + + +Flush the backing store (if any) to disk. If |callback| is non-NULL it +will be executed asnychronously on the UI thread after the flush is +complete. Returns false if cookies cannot be accessed. + + + + +Delete all cookies that match the specified parameters. If both |url| and +|cookie_name| values are specified all host and domain cookies matching +both will be deleted. If only |url| is specified all host cookies (but not +domain cookies) irrespective of path will be deleted. If |url| is empty +all cookies for all hosts and domains will be deleted. If |callback| is +non-NULL it will be executed asnychronously on the UI thread after the +cookies have been deleted. Returns false if a non-empty invalid URL is +specified or if cookies cannot be accessed. Cookies can alternately be +deleted using the Visit*Cookies() methods. + + + + +Sets a cookie given a valid URL and explicit user-provided cookie +attributes. This function expects each attribute to be well-formed. It +will check for disallowed characters (e.g. the ';' character is disallowed +within the cookie value attribute) and fail without setting the cookie if +such characters are found. If |callback| is non-NULL it will be executed +asnychronously on the UI thread after the cookie has been set. Returns +false if an invalid URL is specified or if cookies cannot be accessed. + + + + +Visit a subset of cookies on the UI thread. The results are filtered by +the given url scheme, host, domain and path. If |includeHttpOnly| is true +HTTP-only cookies will also be included in the results. The returned +cookies are ordered by longest path, then by earliest creation date. +Returns false if cookies cannot be accessed. + + + + +Visit all cookies on the UI thread. The returned cookies are ordered by +longest path, then by earliest creation date. Returns false if cookies +cannot be accessed. + + + + +Returns the global cookie manager. By default data will be stored at +cef_settings_t.cache_path if specified or in memory otherwise. If +|callback| is non-NULL it will be executed asnychronously on the UI thread +after the manager's storage has been initialized. Using this method is +equivalent to calling +CefRequestContext::GetGlobalContext()->GetDefaultCookieManager(). + + + + +Class used for managing cookies. The methods of this class may be called on +any thread unless otherwise indicated. + + + + +Method that will be called once the task is complete. + + + + +Generic callback interface used for asynchronous completion. + + + + +Cancel processing. + + + + +Continue processing. + + + + +Generic callback interface used for asynchronous continuation. + + + + +Generic callback interface used for managing the lifespan of a registration. + + + + +Returns the SSL information for this navigation entry. + + + + +Returns the HTTP status code for the last known successful navigation +response. May be 0 if the response has not yet been received or if the +navigation has not yet completed. + + + + +Returns the time for the last known successful navigation completion. A +navigation may be completed more than once if the page is reloaded. May be +0 if the navigation has not yet completed. + + + + +Returns true if this navigation includes post data. + + + + +Returns the transition type which indicates what the user did to move to +this page from the previous page. + + + + +Returns the title set by the page. This value may be empty. + + + + +Returns the original URL that was entered by the user before any +redirects. + + + + +Returns a display-friendly version of the URL. + + + + +Returns the actual URL of the page. For some pages this may be data: URL +or similar. Use GetDisplayURL() to return a display-friendly version. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Class used to represent an entry in navigation history. + + + + +Returns the X.509 certificate. + + + + +Returns a bitmask containing the page security content status. + + + + +Returns the SSL version used for the SSL connection. + + + + +Returns a bitmask containing any and all problems verifying the server +certificate. + + + + +Returns true if the status is related to a secure SSL/TLS connection. + + + + +Class representing the SSL information for a navigation entry. + + + + +Returns the PEM encoded data for the certificate issuer chain. +If we failed to encode a certificate in the chain it is still +present in the array but is an empty string. + + + + +Returns the DER encoded data for the certificate issuer chain. +If we failed to encode a certificate in the chain it is still +present in the array but is an empty string. + + + + +Returns the number of certificates in the issuer chain. +If 0, the certificate is self-signed. + + + + +Returns the PEM encoded data for the X.509 certificate. + + + + +Returns the DER encoded data for the X.509 certificate. + + + + +Returns the date after which the X.509 certificate is invalid. +CefBaseTime.GetTimeT() will return 0 if no date was specified. + + + + +Returns the date before which the X.509 certificate is invalid. +CefBaseTime.GetTimeT() will return 0 if no date was specified. + + + + +Returns the DER encoded serial number for the X.509 certificate. The value +possibly includes a leading 00 byte. + + + + +Returns the issuer of the X.509 certificate. + + + + +Returns the subject of the X.509 certificate. For HTTPS server +certificates this represents the web server. The common name of the +subject should match the host name of the web server. + + + + +Class representing a X.509 certificate. + + + + +Retrieve the list of domain components. + + + + +Retrieve the list of organization unit names. + + + + +Retrieve the list of organization names. + + + + +Retrieve the list of street addresses. + + + + +Returns the country name. + + + + +Returns the state or province name. + + + + +Returns the locality name. + + + + +Returns the common name. + + + + +Returns a name that can be used to represent the issuer. It tries in this +order: Common Name (CN), Organization Name (O) and Organizational Unit +Name (OU) and returns the first non-empty one found. + + + + +Class representing the issuer or subject field of an X.509 certificate. + + + + +Send a message to the specified |target_process|. Ownership of the message +contents will be transferred and the |message| reference will be +invalidated. Message delivery is not guaranteed in all cases (for example, +if the browser is closing, navigating, or if the target process crashes). +Send an ACK message back from the target process if confirmation is +required. + + + + +Create a new URL request that will be treated as originating from this +frame and the associated browser. Use CefURLRequest::Create instead if you +do not want the request to have this association, in which case it may be +handled differently (see documentation on that method). A request created +with this method may only originate from the browser process, and will +behave as follows: + - It may be intercepted by the client via CefResourceRequestHandler or + CefSchemeHandlerFactory. + - POST data may only contain a single element of type PDE_TYPE_FILE or + PDE_TYPE_BYTES. + +The |request| object will be marked as read-only after calling this +method. + + + + +Visit the DOM document. This method can only be called from the render +process. + + + + +Get the V8 context associated with the frame. This method can only be +called from the render process. + + + + +Returns the browser that this frame belongs to. + + + + +Returns the URL currently loaded in this frame. + + + + +Returns the parent of this frame or NULL if this is the main (top-level) +frame. + + + + +Returns the name for this frame. If the frame has an assigned name (for +example, set via the iframe "name" attribute) then that value will be +returned. Otherwise a unique name will be constructed based on the frame +parent hierarchy. The main (top-level) frame will always have an empty +name value. + + + + +Returns true if this is the focused frame. + + + + +Returns true if this is the main (top-level) frame. + + + + +Execute a string of JavaScript code in this frame. The |script_url| +parameter is the URL where the script in question can be found, if any. +The renderer may request this URL to show the developer the source of the +error. The |start_line| parameter is the base line number to use for +error reporting. + + + + +Load the specified |url|. + + + + +Load the request represented by the |request| object. + +WARNING: This method will fail with "bad IPC message" reason +INVALID_INITIATOR_ORIGIN (213) unless you first navigate to the +request origin using some other mechanism (LoadURL, link click, etc). + + + + +Retrieve this frame's display text as a string sent to the specified +visitor. + + + + +Retrieve this frame's HTML source as a string sent to the specified +visitor. + + + + +Save this frame's HTML source to a temporary file and open it in the +default text viewing application. This method can only be called from the +browser process. + + + + +Execute select all in this frame. + + + + +Execute delete in this frame. + + + + +Execute paste in this frame. + + + + +Execute copy in this frame. + + + + +Execute cut in this frame. + + + + +Execute redo in this frame. + + + + +Execute undo in this frame. + + + + +True if this object is currently attached to a valid frame. + + + + +Class used to represent a frame in the browser window. When used in the +browser process the methods of this class may be called on any thread unless +otherwise indicated in the comments. When used in the render process the +methods of this class may only be called on the main thread. + + + + +Method that will be executed. + + + + +Implement this interface to receive string values asynchronously. + + + + +Read up to |size| bytes into |bytes| and return the number of bytes +actually read. + + + + +Return the number of bytes. + + + + +Return the file name. + + + + +Return the type of this post data element. + + + + +The post data element will represent bytes. The bytes passed +in will be copied. + + + + +The post data element will represent a file. + + + + +Remove all contents from the post data element. + + + + +Returns true if this object is read-only. + + + + +Create a new CefPostDataElement object. + + + + +Post data elements may represent either bytes or files. + + + + +Class used to represent a single element in the request post data. The +methods of this class may be called on any thread. + + + + +Remove all existing post data elements. + + + + +Add the specified post data element. Returns true if the add succeeds. + + + + +Remove the specified post data element. Returns true if the removal +succeeds. + + + + +Retrieve the post data elements. + + + + +Returns the number of existing post data elements. + + + + +Returns true if the underlying POST data includes elements that are not +represented by this CefPostData object (for example, multi-part file +upload data). Modifying CefPostData objects with excluded elements may +result in the request failing. + + + + +Returns true if this object is read-only. + + + + +Create a new CefPostData object. + + + + +Class used to represent post data for a web request. The methods of this +class may be called on any thread. + + + + +Returns the globally unique identifier for this request or 0 if not +specified. Can be used by CefResourceRequestHandler implementations in the +browser process to track a single request across multiple callbacks. + + + + +Get the transition type for this request. Only available in the browser +process and only applies to requests that represent a main frame or +sub-frame navigation. + + + + +Get the resource type for this request. Only available in the browser +process. + + + + +Set the URL to the first party for cookies used in combination with +CefURLRequest. + + + + +Get the URL to the first party for cookies used in combination with +CefURLRequest. + + + + +Set the flags used in combination with CefURLRequest. See +cef_urlrequest_flags_t for supported values. + + + + +Get the flags used in combination with CefURLRequest. See +cef_urlrequest_flags_t for supported values. + + + + +Set all values at one time. + + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. The Referer value cannot be set +using this method. + + + + +Returns the first header value for |name| or an empty string if not found. +Will not return the Referer value if any. Use GetHeaderMap instead if +|name| might have multiple values. + + + + +Set the header values. If a Referer value exists in the header map it will +be removed and ignored. + + + + +Get the header values. Will not include the Referer value if any. + + + + +Set the post data. + + + + +Get the post data. + + + + +Get the referrer policy. + + + + +Get the referrer URL. + + + + +Set the referrer URL and policy. If non-empty the referrer URL must be +fully qualified with an HTTP or HTTPS scheme component. Any username, +password or ref component will be removed. + + + + +Set the request method type. + + + + +Get the request method type. The value will default to POST if post data +is provided and GET otherwise. + + + + +Set the fully qualified URL. + + + + +Get the fully qualified URL. + + + + +Returns true if this object is read-only. + + + + +Create a new CefRequest object. + + + + +Class used to represent a web request. The methods of this class may be +called on any thread. + + + + +Returns the shared memory region. +Returns nullptr when message contains an argument list. + + + + +Returns the list of arguments. +Returns nullptr when message contains a shared memory region. + + + + +Returns the message name. + + + + +Returns a writable copy of this object. +Returns nullptr when message contains a shared memory region. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Create a new CefProcessMessage object with the specified name. + + + + +Class representing a message. Can be used on any process and thread. + + + + +Returns the pointer to the memory. Returns nullptr for invalid instances. +The returned pointer is only valid for the life span of this object. + + + + +Returns the size of the mapping in bytes. Returns 0 for invalid instances. + + + + +Returns true if the mapping is valid. + + + + +Class that wraps platform-dependent share memory region mapping. + + + + +Returns the bounds of the element in device pixels. Use +"window.devicePixelRatio" to convert to/from CSS pixels. + + + + +Returns the inner text of the element. + + + + +Set the value for the element attribute named |attrName|. Returns true on +success. + + + + +Returns a map of all element attributes. + + + + +Returns the element attribute named |attrName|. + + + + +Returns true if this element has an attribute named |attrName|. + + + + +Returns true if this element has attributes. + + + + +Returns the tag name of this element. + + + + +Returns the last child node. + + + + +Return the first child node. + + + + +Returns true if this node has child nodes. + + + + +Returns the next sibling node. + + + + +Returns the previous sibling node. + + + + +Returns the parent node. + + + + +Returns the document associated with this node. + + + + +Returns the contents of this node as markup. + + + + +Set the value of this node. Returns true on success. + + + + +Returns the value of this node. + + + + +Returns the name of this node. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +Returns the type of this form control element node. + + + + +Returns true if this is a form control element node. + + + + +Returns true if this is an editable node. + + + + +Returns true if this is an element node. + + + + +Returns true if this is a text node. + + + + +Returns the type for this node. + + + + +Class used to represent a DOM node. The methods of this class should only be +called on the render process main thread. + + + + +Returns a complete URL based on the document base URL and the specified +partial URL. + + + + +Returns the base URL for the document. + + + + +Returns the contents of this selection as text. + + + + +Returns the contents of this selection as markup. + + + + +Returns the selection offset within the end node. + + + + +Returns the selection offset within the start node. + + + + +Returns true if a portion of the document is selected. + + + + +Returns the node that currently has keyboard focus. + + + + +Returns the document element with the specified ID value. + + + + +Returns the title of an HTML document. + + + + +Returns the HEAD node of an HTML document. + + + + +Returns the BODY node of an HTML document. + + + + +Returns the root document node. + + + + +Returns the document type. + + + + +Class used to represent a DOM document. The methods of this class should +only be called on the render process main thread thread. + + + + +Method executed for visiting the DOM. The document object passed to this +method represents a snapshot of the DOM at the time this method is +executed. DOM objects are only valid for the scope of this method. Do not +keep references to or attempt to access any DOM objects outside the scope +of this method. + + + + +Interface to implement for visiting the DOM. The methods of this class will +be called on the render process main thread. + + + + +Returns true if an image representation of drag data is available. + + + + +Get the image hotspot (drag start location relative to image dimensions). + + + + +Get the image representation of drag data. May return NULL if no image +representation is available. + + + + +Clear list of filenames. + + + + +Add a file that is being dragged into the webview. + + + + +Reset the file contents. You should do this before calling +CefBrowserHost::DragTargetDragEnter as the web view does not allow us to +drag in this kind of data. + + + + +Set the base URL that the fragment came from. + + + + +Set the text/html fragment that is being dragged. + + + + +Set the plain text fragment that is being dragged. + + + + +Set the metadata associated with the link being dragged. + + + + +Set the title associated with the link being dragged. + + + + +Set the link URL that is being dragged. + + + + +Retrieve the list of file names that are being dragged into the browser +window. + + + + +Write the contents of the file being dragged out of the web view into +|writer|. Returns the number of bytes sent to |writer|. If |writer| is +NULL this method will return the size of the file contents in bytes. +Call GetFileName() to get a suggested name for the file. + + + + +Return the name of the file being dragged out of the browser window. + + + + +Return the base URL that the fragment came from. This value is used for +resolving relative URLs and may be empty. + + + + +Return the text/html fragment that is being dragged. + + + + +Return the plain text fragment that is being dragged. + + + + +Return the metadata, if any, associated with the link being dragged. + + + + +Return the title associated with the link being dragged. + + + + +Return the link URL that is being dragged. + + + + +Returns true if the drag data is a file. + + + + +Returns true if the drag data is a text or html fragment. + + + + +Returns true if the drag data is a link. + + + + +Returns true if this object is read-only. + + + + +Returns a copy of the current object. + + + + +Create a new CefDragData object. + + + + +Class used to represent drag data. The methods of this class may be called +on any thread. + + + + +Returns true if this writer performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +writer from. + + + + +Flush the stream. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Returns zero on success and non-zero on +failure. + + + + +Write raw binary data. + + + + +Create a new CefStreamWriter object for a custom handler. + + + + +Create a new CefStreamWriter object for a file. + + + + +Class used to write data to a stream. The methods of this class may be +called on any thread. + + + + +Return true if this handler performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +handler from. + + + + +Flush the stream. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Return zero on success and non-zero on +failure. + + + + +Write raw binary data. + + + + +Interface the client can implement to provide a custom stream writer. The +methods of this class may be called on any thread. + + + + +Returns true if this reader performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +reader from. + + + + +Return non-zero if at end of file. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Returns zero on success and non-zero on +failure. + + + + +Read raw binary data. + + + + +Create a new CefStreamReader object from a custom handler. + + + + +Create a new CefStreamReader object from data. + + + + +Create a new CefStreamReader object from a file. + + + + +Class used to read data from a stream. The methods of this class may be +called on any thread. + + + + +Return true if this handler performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +handler from. + + + + +Return non-zero if at end of file. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Return zero on success and non-zero on +failure. + + + + +Read raw binary data. + + + + +Interface the client can implement to provide a custom stream reader. The +methods of this class may be called on any thread. + + + + +Returns the JPEG representation that most closely matches |scale_factor|. +|quality| determines the compression level with 0 == lowest and 100 == +highest. The JPEG format does not support alpha transparency and the alpha +channel, if any, will be discarded. |pixel_width| and |pixel_height| are +the output representation size in pixel coordinates. Returns a +CefBinaryValue containing the JPEG image data on success or NULL on +failure. + + + + +Returns the PNG representation that most closely matches |scale_factor|. +If |with_transparency| is true any alpha transparency in the image will be +represented in the resulting PNG data. |pixel_width| and |pixel_height| +are the output representation size in pixel coordinates. Returns a +CefBinaryValue containing the PNG image data on success or NULL on +failure. + + + + +Returns the bitmap representation that most closely matches +|scale_factor|. Only 32-bit RGBA/BGRA formats are supported. |color_type| +and |alpha_type| values specify the desired output pixel format. +|pixel_width| and |pixel_height| are the output representation size in +pixel coordinates. Returns a CefBinaryValue containing the pixel data on +success or NULL on failure. + + + + +Returns information for the representation that most closely matches +|scale_factor|. |actual_scale_factor| is the actual scale factor for the +representation. |pixel_width| and |pixel_height| are the representation +size in pixel coordinates. Returns true on success. + + + + +Removes the representation for |scale_factor|. Returns true on success. + + + + +Returns true if this image contains a representation for |scale_factor|. + + + + +Returns the image height in density independent pixel (DIP) units. + + + + +Returns the image width in density independent pixel (DIP) units. + + + + +Create a JPEG image representation for |scale_factor|. |jpeg_data| is the +image data of size |jpeg_data_size|. The JPEG format does not support +transparency so the alpha byte will be set to 0xFF for all pixels. + + + + +Add a PNG image representation for |scale_factor|. |png_data| is the image +data of size |png_data_size|. Any alpha transparency in the PNG data will +be maintained. + + + + +Add a bitmap image representation for |scale_factor|. Only 32-bit +RGBA/BGRA formats are supported. |pixel_width| and |pixel_height| are the +bitmap representation size in pixel coordinates. |pixel_data| is the array +of pixel data and should be |pixel_width| x |pixel_height| x 4 bytes in +size. |color_type| and |alpha_type| values specify the pixel format. + + + + +Returns true if this Image and |that| Image share the same underlying +storage. Will also return true if both images are empty. + + + + +Returns true if this Image is empty. + + + + +Create a new CefImage. It will initially be empty. Use the Add*() methods +to add representations at different scale factors. + + + + +Container for a single image represented at different scale factors. All +image representations should be the same size in density independent pixel +(DIP) units. For example, if the image at scale factor 1.0 is 100x100 pixels +then the image at scale factor 2.0 should be 200x200 pixels -- both images +will display with a DIP size of 100x100 units. The methods of this class can +be called on any browser process thread. + + + + +Sets the value at the specified index as type list. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified index as type dict. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified index as type binary. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified index as type string. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type double. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type int. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type bool. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type null. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index. Returns true if the value was set +successfully. If |value| represents simple data then the underlying data +will be copied and modifications to |value| will not modify this object. +If |value| represents complex data (binary, dictionary or list) then the +underlying data will be referenced and modifications to |value| will +modify this object. + + + + +Returns the value at the specified index as type list. The returned +value will reference existing data and modifications to the value will +modify this object. + + + + +Returns the value at the specified index as type dictionary. The returned +value will reference existing data and modifications to the value will +modify this object. + + + + +Returns the value at the specified index as type binary. The returned +value will reference existing data. + + + + +Returns the value at the specified index as type string. + + + + +Returns the value at the specified index as type double. + + + + +Returns the value at the specified index as type int. + + + + +Returns the value at the specified index as type bool. + + + + +Returns the value at the specified index. For simple types the returned +value will copy existing data and modifications to the value will not +modify this object. For complex types (binary, dictionary and list) the +returned value will reference existing data and modifications to the value +will modify this object. + + + + +Returns the value type at the specified index. + + + + +Removes the value at the specified index. + + + + +Removes all values. Returns true on success. + + + + +Returns the number of values. + + + + +Sets the number of values. If the number of values is expanded all +new value slots will default to type null. Returns true on success. + + + + +Returns a writable copy of this object. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. If true modifications to this object will also affect |that| object +and vice-versa. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is currently owned by another object. + + + + +Returns true if this object is valid. This object may become invalid if +the underlying data is owned by another object (e.g. list or dictionary) +and that other object is then modified or destroyed. Do not call any other +methods if this method returns false. + + + + +Creates a new object that is not owned by any other object. + + + + +Class representing a list value. Can be used on any process and thread. + + + + +Sets the value at the specified key as type list. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified key as type dict. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified key as type binary. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified key as type string. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type double. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type int. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type bool. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type null. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key. Returns true if the value was set +successfully. If |value| represents simple data then the underlying data +will be copied and modifications to |value| will not modify this object. +If |value| represents complex data (binary, dictionary or list) then the +underlying data will be referenced and modifications to |value| will +modify this object. + + + + +Returns the value at the specified key as type list. The returned value +will reference existing data and modifications to the value will modify +this object. + + + + +Returns the value at the specified key as type dictionary. The returned +value will reference existing data and modifications to the value will +modify this object. + + + + +Returns the value at the specified key as type binary. The returned +value will reference existing data. + + + + +Returns the value at the specified key as type string. + + + + +Returns the value at the specified key as type double. + + + + +Returns the value at the specified key as type int. + + + + +Returns the value at the specified key as type bool. + + + + +Returns the value at the specified key. For simple types the returned +value will copy existing data and modifications to the value will not +modify this object. For complex types (binary, dictionary and list) the +returned value will reference existing data and modifications to the value +will modify this object. + + + + +Returns the value type for the specified key. + + + + +Removes the value at the specified key. Returns true is the value was +removed successfully. + + + + +Reads all keys for this dictionary into the specified vector. + + + + +Returns true if the current dictionary has a value for the given key. + + + + +Removes all values. Returns true on success. + + + + +Returns the number of values. + + + + +Returns a writable copy of this object. If |exclude_empty_children| is +true any empty dictionaries or lists will be excluded from the copy. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. If true modifications to this object will also affect |that| object +and vice-versa. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is currently owned by another object. + + + + +Returns true if this object is valid. This object may become invalid if +the underlying data is owned by another object (e.g. list or dictionary) +and that other object is then modified or destroyed. Do not call any other +methods if this method returns false. + + + + +Creates a new object that is not owned by any other object. + + + + +Class representing a dictionary value. Can be used on any process and +thread. + + + + +Read up to |buffer_size| number of bytes into |buffer|. Reading begins at +the specified byte |data_offset|. Returns the number of bytes read. + + + + +Returns the data size. + + + + +Returns a copy of this object. The data in this object will also be +copied. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. + + + + +Returns true if this object is currently owned by another object. + + + + +Returns true if this object is valid. This object may become invalid if +the underlying data is owned by another object (e.g. list or dictionary) +and that other object is then modified or destroyed. Do not call any other +methods if this method returns false. + + + + +Creates a new object that is not owned by any other object. The specified +|data| will be copied. + + + + +Class representing a binary value. Can be used on any process and thread. + + + + +Sets the underlying value as type list. Returns true if the value was set +successfully. This object keeps a reference to |value| and ownership of +the underlying data remains unchanged. + + + + +Sets the underlying value as type dict. Returns true if the value was set +successfully. This object keeps a reference to |value| and ownership of +the underlying data remains unchanged. + + + + +Sets the underlying value as type binary. Returns true if the value was +set successfully. This object keeps a reference to |value| and ownership +of the underlying data remains unchanged. + + + + +Sets the underlying value as type string. Returns true if the value was +set successfully. + + + + +Sets the underlying value as type double. Returns true if the value was +set successfully. + + + + +Sets the underlying value as type int. Returns true if the value was set +successfully. + + + + +Sets the underlying value as type bool. Returns true if the value was set +successfully. + + + + +Sets the underlying value as type null. Returns true if the value was set +successfully. + + + + +Returns the underlying value as type list. The returned reference may +become invalid if the value is owned by another object or if ownership is +transferred to another object in the future. To maintain a reference to +the value after assigning ownership to a dictionary or list pass this +object to the SetValue() method instead of passing the returned reference +to SetList(). + + + + +Returns the underlying value as type dictionary. The returned reference +may become invalid if the value is owned by another object or if ownership +is transferred to another object in the future. To maintain a reference to +the value after assigning ownership to a dictionary or list pass this +object to the SetValue() method instead of passing the returned reference +to SetDictionary(). + + + + +Returns the underlying value as type binary. The returned reference may +become invalid if the value is owned by another object or if ownership is +transferred to another object in the future. To maintain a reference to +the value after assigning ownership to a dictionary or list pass this +object to the SetValue() method instead of passing the returned reference +to SetBinary(). + + + + +Returns the underlying value as type string. + + + + +Returns the underlying value as type double. + + + + +Returns the underlying value as type int. + + + + +Returns the underlying value as type bool. + + + + +Returns the underlying value type. + + + + +Returns a copy of this object. The underlying data will also be copied. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. If true modifications to this object will also affect |that| object +and vice-versa. + + + + +Returns true if the underlying data is read-only. Some APIs may expose +read-only objects. + + + + +Returns true if the underlying data is owned by another object. + + + + +Returns true if the underlying data is valid. This will always be true for +simple types. For complex types (binary, dictionary and list) the +underlying data may become invalid if owned by another object (e.g. list +or dictionary) and that other object is then modified or destroyed. This +value object can be re-used by calling Set*() even if the underlying data +is invalid. + + + + +Creates a new object. + + + + +Class that wraps other data value types. Complex types (binary, dictionary +and list) will be referenced but not owned by this object. Can be used on +any process and thread. + + + + +Method that will be called when the DevTools agent has detached. |browser| +is the originating browser instance. Any method results that were pending +before the agent became detached will not be delivered, and any active +event subscriptions will be canceled. + + + + +Method that will be called when the DevTools agent has attached. |browser| +is the originating browser instance. This will generally occur in response +to the first message sent while the agent is detached. + + + + +Method that will be called on receipt of a DevTools protocol event. +|browser| is the originating browser instance. |method| is the "method" +value. |params| is the UTF8-encoded JSON "params" dictionary value (which +may be empty). |params| is only valid for the scope of this callback and +should be copied if necessary. See the OnDevToolsMessage documentation for +additional details on |params| contents. + + + + +Method that will be called after attempted execution of a DevTools +protocol method. |browser| is the originating browser instance. +|message_id| is the "id" value that identifies the originating method call +message. If the method succeeded |success| will be true and |result| will +be the UTF8-encoded JSON "result" dictionary value (which may be empty). +If the method failed |success| will be false and |result| will be the +UTF8-encoded JSON "error" dictionary value. |result| is only valid for the +scope of this callback and should be copied if necessary. See the +OnDevToolsMessage documentation for additional details on |result| +contents. + + + + +Method that will be called on receipt of a DevTools protocol message. +|browser| is the originating browser instance. |message| is a UTF8-encoded +JSON dictionary representing either a method result or an event. |message| +is only valid for the scope of this callback and should be copied if +necessary. Return true if the message was handled or false if the message +should be further processed and passed to the OnDevToolsMethodResult or +OnDevToolsEvent methods as appropriate. + +Method result dictionaries include an "id" (int) value that identifies the +orginating method call sent from CefBrowserHost::SendDevToolsMessage, and +optionally either a "result" (dictionary) or "error" (dictionary) value. +The "error" dictionary will contain "code" (int) and "message" (string) +values. Event dictionaries include a "method" (string) value and +optionally a "params" (dictionary) value. See the DevTools protocol +documentation at https://chromedevtools.github.io/devtools-protocol/ for +details of supported method calls and the expected "result" or "params" +dictionary contents. JSON dictionaries can be parsed using the +CefParseJSON function if desired, however be aware of performance +considerations when parsing large messages (some of which may exceed 1MB +in size). + + + + +Callback interface for CefBrowserHost::AddDevToolsMessageObserver. The +methods of this class will be called on the browser process UI thread. + + + + +Set to true before calling Windows APIs like TrackPopupMenu that enter a +modal message loop. Set to false after exiting the modal message loop. + + + + +Create the browser using windowless (off-screen) rendering. No window +will be created for the browser and all rendering will occur via the +CefRenderHandler interface. The |parent| value will be used to identify +monitor info and to act as the parent window for dialogs, context menus, +etc. If |parent| is not provided then the main screen monitor will be used +and some functionality that requires a parent window may not function +correctly. In order to create windowless browsers the +CefSettings.windowless_rendering_enabled value must be set to true. +Transparent painting is enabled by default but can be disabled by setting +CefBrowserSettings.background_color to an opaque value. + + + + +Create the browser as a popup window. + + + + +Create the browser as a child window. + + + + +Class representing window information. + + + + +Class representing CefExecuteProcess arguments. + + + + +Set to true (1) before calling Windows APIs like TrackPopupMenu that enter a +modal message loop. Set to false (0) after exiting the modal message loop. + + + + +Class representing CefAudioParameters settings + + + + +Class representing IME composition underline. + + + + +Class representing CefBoxLayout settings. + + + + +Class representing cursor information. + + + + +Class representing the state of a touch handle. + + + + +Class representing popup window features. + + + + +Class representing a touch event. + + + + +Class representing a mouse event. + + + + +Class representing a a keyboard event. + + + + +Class representing the virtual screen information for use when window +rendering is disabled. + + + + +Class representing a draggable region. + + + + +Class representing insets. + + + + +Class representing a range. + + + + +Class representing a size. + + + + +Returns true if the point identified by point_x and point_y falls inside +this rectangle. The point (x, y) is inside the rectangle, but the +point (x + width, y + height) is not. + + + + +Class representing a rectangle. + + + + +Class representing a point. + + + +Request context preferences registered each time a new CefRequestContext +is created. + + +Global preferences registered a single time at application startup. + + +Expired certificate. Loads the "expired_cert.pem" file. + + +Valid certificate using the domain ("localhost"). Loads the +"localhost_cert.pem" file. + + +Valid certificate using the IP (127.0.0.1). Loads the "ok_cert.pem" file. + + + +Ignore the permission request. If the prompt remains unhandled (e.g. +OnShowPermissionPrompt returns false and there is no default permissions +UI) then any related promises may remain unresolved. + + + + +Dismiss the permission request as an explicit user action. + + + + +Deny the permission request as an explicit user action. + + + + +Accept the permission request as an explicit user action. + + + + +Desktop video capture permission. + + + + +Desktop audio capture permission. + + + + +Device video capture permission. + + + + +Device audio capture permission. + + + + +No permission. + + + + +Alpha state. Only set if |flags| contains CEF_THS_FLAG_ALPHA. + + + + +Origin state. Only set if |flags| contains CEF_THS_FLAG_ORIGIN. + + + + +Orientation state. Only set if |flags| contains CEF_THS_FLAG_ORIENTATION. + + + + +Enabled state. Only set if |flags| contains CEF_THS_FLAG_ENABLED. + + + + +Combination of cef_touch_handle_state_flags_t values indicating what state +is set. + + + + +Touch handle id. Increments for each new touch handle. + + + + +Device information for a MediaSink object. + + + + +Number of frames per buffer + + + + +Sample rate + + + +Layout of the audio channels + + + + +Structure representing the audio parameters for setting up the audio +handler. + + + +Max value, must always equal the largest entry ever logged. + + +Front L, Front R, Front C, LFE, Side L, Side R, +Front Height L, Front Height R, Rear Height L, Rear Height R +Will be represented as six channels (5.1) due to eight channel limit +kMaxConcurrentChannels + + +Actual channel layout is specified in the bitstream and the actual channel +count is unknown at Chromium media pipeline level (useful for audio +pass-through mode). + + +Front L, Front R, Side L, Side R, LFE + + +Front L, Front R, Front C. Front C contains the keyboard mic audio. This +layout is only intended for input for WebRTC. The Front C channel +is stripped away in the WebRTC audio input pipeline and never seen outside +of that. + + +Channels are not explicitly mapped to speakers. + + +Front L, Front R, Front C, Side L, Side R, Rear L, Back R, Back C. + + +Front L, Front R, Front C, LFE, Back L, Back R, Front LofC, Front RofC + + +Front L, Front R, Front C, Side L, Side R, Front LofC, Front RofC + + +Stereo L, Stereo R, Side L, Side R, Front LofC, Front RofC, LFE + + +Stereo L, Stereo R, Front C, LFE, Back L, Back R, Rear Center + + +Stereo L, Stereo R, Front C, LFE, Side L, Side R, Rear Center + + +Stereo L, Stereo R, Front C, Rear L, Rear R, Rear C + + +Stereo L, Stereo R, Side L, Side R, Front LofC, Front RofC + + +Stereo L, Stereo R, Front C, Side L, Side R, Back C + + +Stereo L, Stereo R, Front C, Rear C, LFE + + +Stereo L, Stereo R, Front C, LFE + + +Stereo L, Stereo R, LFE + + +Stereo L, Stereo R + + +Front L, Front R, Front C, LFE, Side L, Side R, Front LofC, Front RofC + + +Front L, Front R, Front C, LFE, Side L, Side R, Back L, Back R + + +Front L, Front R, Front C, Side L, Side R, Back L, Back R + + +Front L, Front R, Front C, LFE, Back L, Back R + + +Front L, Front R, Front C, Back L, Back R + + +Front L, Front R, Front C, LFE, Side L, Side R + + +Front L, Front R, Front C, Side L, Side R + + +Front L, Front R, Back L, Back R + + +Front L, Front R, Side L, Side R + + +Front L, Front R, Front C, Back C + + +Front L, Front R, Front C + + +Front L, Front R, Back C + + +Front L, Front R + + +Front C + + + +Style. + + + + +Set to true (1) for thick underline. + + + + +Background color. + + + + +Text color. + + + + +Underline character range. + + + + +Structure representing IME composition underline information. This is a thin +wrapper around Blink's WebCompositionUnderline class and should be kept in +sync with that. + + + + +Structure representing a range. + + + + +If CEF_SCHEME_OPTION_FETCH_ENABLED is set the scheme can perform Fetch API +requests. + + + + +If CEF_SCHEME_OPTION_CSP_BYPASSING is set the scheme can bypass Content- +Security-Policy (CSP) checks. This value should not be set in most cases +where CEF_SCHEME_OPTION_STANDARD is set. + + + + +If CEF_SCHEME_OPTION_CORS_ENABLED is set the scheme can be sent CORS +requests. This value should be set in most cases where +CEF_SCHEME_OPTION_STANDARD is set. + + + + +If CEF_SCHEME_OPTION_SECURE is set the scheme will be treated with the +same security rules as those applied to "https" URLs. For example, loading +this scheme from other secure schemes will not trigger mixed content +warnings. + + + + +If CEF_SCHEME_OPTION_DISPLAY_ISOLATED is set the scheme can only be +displayed from other content hosted with the same scheme. For example, +pages in other origins cannot create iframes or hyperlinks to URLs with +the scheme. For schemes that must be accessible from other schemes don't +set this, set CEF_SCHEME_OPTION_CORS_ENABLED, and use CORS +"Access-Control-Allow-Origin" headers to further restrict access. + + + + +If CEF_SCHEME_OPTION_LOCAL is set the scheme will be treated with the same +security rules as those applied to "file" URLs. Normal pages cannot link +to or access local URLs. Also, by default, local URLs can only perform +XMLHttpRequest calls to the same URL (origin + path) that originated the +request. To allow XMLHttpRequest calls from a local URL to other URLs with +the same origin set the CefSettings.file_access_from_file_urls_allowed +value to true (1). To allow XMLHttpRequest calls from a local URL to all +origins set the CefSettings.universal_access_from_file_urls_allowed value +to true (1). + + + + +If CEF_SCHEME_OPTION_STANDARD is set the scheme will be treated as a +standard scheme. Standard schemes are subject to URL canonicalization and +parsing rules as defined in the Common Internet Scheme Syntax RFC 1738 +Section 3.1 available at http://www.ietf.org/rfc/rfc1738.txt +In particular, the syntax for standard scheme URLs must be of the form: +
+ [scheme]://[username]:[password]@[host]:[port]/[url-path]
+
Standard scheme URLs must have a host component that is a fully +qualified domain name as defined in Section 3.5 of RFC 1034 [13] and +Section 2.1 of RFC 1123. These URLs will be canonicalized to +"scheme://host/path" in the simplest case and +"scheme://username:password@host:port/path" in the most explicit case. For +example, "scheme:host/path" and "scheme:///host/path" will both be +canonicalized to "scheme://host/path". The origin of a standard scheme URL +is the combination of scheme, host and port (i.e., "scheme://host:port" in +the most explicit case). +For non-standard scheme URLs only the "scheme:" component is parsed and +canonicalized. The remainder of the URL will be passed to the handler as- +is. For example, "scheme:///some%20text" will remain the same. +Non-standard scheme URLs cannot be used as a target for form submission. + +
+ + +Align the text's right edge with that of its display area. + + + + +Align the text's center with that of its display area. + + + + +Align the text's left edge with that of its display area. + + + + +Default flex for views when none is specified via CefBoxLayout methods. +Using the preferred size as the basis, free space along the main axis is +distributed to views in the ratio of their flex weights. Similarly, if the +views will overflow the parent, space is subtracted in these ratios. A +flex of 0 means this view is not resized. Flex values must not be +negative. + + + + +Minimum cross axis size. + + + + +Specifies where along the cross axis the child views should be laid out. + + + + +Specifies where along the main axis the child views should be laid out. + + + + +Adds additional space between child views. + + + + +Adds additional space around the child view area. + + + + +Adds additional vertical space between the child view area and the host +view border. + + + + +Adds additional horizontal space between the child view area and the host +view border. + + + + +If true (1) the layout will be horizontal, otherwise the layout will be +vertical. + + + + +Settings used when initializing a CefBoxLayout. + + + + +Child views will be right-aligned. + + + + +Child views will be center-aligned. + + + + +Child views will be left-aligned. + + + + +Child views will be stretched to fit. + + + + +Child views will be right-aligned. + + + + +Child views will be center-aligned. + + + + +Child views will be left-aligned. + + + + +Transparency with post-multiplied alpha component. + + + + +Transparency with pre-multiplied alpha component. + + + + +No transparency. The alpha component is ignored. + + + + +BGRA with 8 bits per pixel (32bits total). + + + + +RGBA with 8 bits per pixel (32bits total). + + + + +An error occurred during filtering. + + + + +Some or all of the pre-filter data was read successfully and all available +filtered output has been written. + + + + +Some or all of the pre-filter data was read successfully but more data is +needed in order to continue filtering (filtered output is pending). + + + +Always the last value in this enumeration. + + + +Always clear the referrer regardless of the request destination. + + + + +Strip the referrer down to the origin, but clear it entirely if the +referrer value is HTTPS and the destination is HTTP. + + + + +Clear the referrer when the request's referrer is cross-origin with the +request's destination. + + + + +Strip the referrer down to the origin regardless of the redirect location. + + + + +Never change the referrer. + + + + +Strip the referrer down to an origin when the origin of the referrer is +different from the destination's origin. + + + + +A slight variant on CLEAR_REFERRER_ON_TRANSITION_FROM_SECURE_TO_INSECURE: +If the request destination is HTTP, an HTTPS referrer will be cleared. If +the request's destination is cross-origin with the referrer (but does not +downgrade), the referrer's granularity will be stripped down to an origin +rather than a full URL. Same-origin requests will send the full referrer. + + + + +Clear the referrer header if the header value is HTTPS but the request +destination is HTTP. This is the default behavior. + + + + +HTML template for the print footer. Only displayed if +|display_header_footer| is true (1). Uses the same format as +|header_template|. + + + + +Set to true (1) to display the header and/or footer. Modify +|header_template| and/or |footer_template| to customize the display. + + + + +Paper ranges to print, one based, e.g., '1-5, 8, 11-13'. Pages are printed +in the document order, not in the order specified, and no more than once. +Defaults to empty string, which implies the entire document is printed. +The page numbers are quietly capped to actual page count of the document, +and ranges beyond the end of the document are ignored. If this results in +no pages to print, an error is reported. It is an error to specify a range +with start greater than end. + + + + +Margins in inches. Only used if |margin_type| is set to +PDF_PRINT_MARGIN_CUSTOM. + + + + +Margin type. + + + + +Set to true (1) to prefer page size as defined by css. Defaults to false +(0), in which case the content will be scaled to fit the paper size. + + + + +Output paper size in inches. If either of these values is less than or +equal to zero then the default paper size (letter, 8.5 x 11 inches) will +be used. + + + + +The percentage to scale the PDF by before printing (e.g. .5 is 50%). +If this value is less than or equal to zero the default value of 1.0 +will be used. + + + + +Set to true (1) to print background graphics. + + + + +Set to true (1) for landscape mode or false (0) for portrait mode. + + + + +Structure representing PDF print settings. These values match the parameters +supported by the DevTools Page.printToPDF function. See +https://chromedevtools.github.io/devtools-protocol/tot/Page/#method-printToPDF + + + + +Custom margins using the |margin_*| values from cef_pdf_print_settings_t. + + + + +No margins. + + + + +Default margins of 1cm (~0.4 inches). + + + + +Return a slightly nicer formatted json string (pads with whitespace to +help with readability). + + + + +This option instructs the writer to write doubles that have no fractional +part as a normal integer (i.e., without using exponential notation +or appending a '.0') as long as the value is within the range of a +64-bit int. + + + + +This option instructs the writer that if a Binary value is encountered, +the value (and key if within a dictionary) will be omitted from the +output, and success will be returned. Otherwise, if a binary value is +encountered, failure will be returned. + + + + +Default behavior. + + + + +Allows commas to exist after the last element in structures. + + + + +Parses the input strictly according to RFC 4627. See comments in +Chromium's base/json/json_reader.h file for known limitations/ +deviations from the RFC. + + + + +URL queries use "+" for space. This flag controls that replacement. + + + + +Unescapes '/' and '\\'. If these characters were unescaped, the resulting +URL won't be the same as the source one. Moreover, they are dangerous to +unescape in strings that will be used as file paths or names. This value +should only be used when slashes don't have special meaning, like data +URLs. + + + + +Convert %20 to spaces. In some places where we're showing URLs, we may +want this. In places where the URL may be copied and pasted out, then +you wouldn't want this since it might not be interpreted in one piece +by other applications. + + + + +Don't unescape anything special, but all normal unescaping will happen. +This is a placeholder and can't be combined with other flags (since it's +just the absence of them). All other unescape rules imply "normal" in +addition to their special meaning. Things like escaped letters, digits, +and most symbols will get unescaped with this mode. + + + + +Don't unescape anything at all. + + + + +Structure representing cursor information. |buffer| will be +|size.width|*|size.height|*4 bytes in size and represents a BGRA image with +an upper-left origin. + + + + +Allows picking a nonexistent file, and prompts to overwrite if the file +already exists. + + + + +Like Open, but selects a folder to open. + + + + +Like Open, but allows picking multiple files to open. + + + + +Requires that the file exists before allowing the user to pick it. + + + +True (1) if browser interface elements should be hidden. + + + +Popup window features. + + + + +The source is a system-generated focus event. + + + + +The source is explicit navigation via the API (LoadURL(), etc). + + + + +True if the focus is currently on an editable field on the page. This is +useful for determining if standard key events should be intercepted. + + + + +Same as |character| but unmodified by any concurrently-held modifiers +(except shift). This is useful for working out shortcut keys. + + + + +The character generated by the keystroke. + + + + +Indicates whether the event is considered a "system key" event (see +http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). +This value will always be false on non-Windows platforms. + + + + +The actual key code genenerated by the platform. + + + + +The Windows key code for the key event. This value is used by the DOM +specification. Sometimes it comes directly from the event (i.e. on +Windows) and sometimes it's determined using a mapping function. See +WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + + + +Bit flags describing any pressed modifier keys. See +cef_event_flags_t for values. + + + + +The type of keyboard event. + + + + +Structure representing keyboard event information. + + + + +Notification that a character was typed. Use this for text input. Key +down events may generate 0, 1, or more than one character event depending +on the key, locale, and operating system. + + + + +Notification that a key was released. + + + + +Notification that a key was pressed. This does not necessarily correspond +to a character depending on the key and language. Use KEYEVENT_CHAR for +character input. + + + + +Notification that a key transitioned from "up" to "down". + + + + +A plugin node is selected. + + + + +A file node is selected. + + + + +An canvas node is selected. + + + + +An audio node is selected. + + + + +A video node is selected. + + + + +An image node is selected. + + + + +No special node is in context. + + + + +An editable element is selected. + + + + +There is a textual or mixed selection that is selected. + + + + +A media node is selected. + + + + +A link is selected. + + + + +A subframe page is selected. + + + + +The top page is selected. + + + + +No node is selected. + + + +Mac OS-X command key. + + + +The device type that caused the event. + + + + +Bit flags describing any pressed modifier keys. See +cef_event_flags_t for values. + + + + +The state of the touch point. Touches begin with one CEF_TET_PRESSED event +followed by zero or more CEF_TET_MOVED events and finally one +CEF_TET_RELEASED or CEF_TET_CANCELLED event. Events not respecting this +order will be ignored. + + + + +The normalized pressure of the pointer input in the range of [0,1]. +Set to 0 if not applicable. + + + + +Rotation angle in radians. Set to 0 if not applicable. + + + + +Y radius in pixels. Set to 0 if not applicable. + + + + +X radius in pixels. Set to 0 if not applicable. + + + + +Y coordinate relative to the top side of the view. + + + + +X coordinate relative to the left side of the view. + + + + +Id of a touch point. Must be unique per touch, can be any number except +-1. Note that a maximum of 16 concurrent touches will be tracked; touches +beyond that will be ignored. + + + + +Structure representing touch event information. + + + + +Bit flags describing any pressed modifier keys. See +cef_event_flags_t for values. + + + + +Y coordinate relative to the top side of the view. + + + + +X coordinate relative to the left side of the view. + + + + +Structure representing mouse event information. + + + + +This is set from the rcWork member of MONITORINFOEX, to whit: + "A RECT structure that specifies the work area rectangle of the + display monitor that can be used by applications, expressed in + virtual-screen coordinates. Windows uses this rectangle to + maximize an application on the monitor. The rest of the area in + rcMonitor contains system windows such as the task bar and side + bars. Note that if the monitor is not the primary display monitor, + some of the rectangle's coordinates may be negative values". +The |rect| and |available_rect| properties are used to determine the +available surface for rendering popup views. + + + + +This is set from the rcMonitor member of MONITORINFOEX, to whit: + "A RECT structure that specifies the display monitor rectangle, + expressed in virtual-screen coordinates. Note that if the monitor + is not the primary display monitor, some of the rectangle's + coordinates may be negative values." +The |rect| and |available_rect| properties are used to determine the +available surface for rendering popup views. + + + + +This can be true for black and white printers. + + + + +The bits per color component. This assumes that the colors are balanced +equally. + + + + +The screen depth in bits per pixel. + + + + +Device scale factor. Specifies the ratio between physical and logical +pixels. + + + + +Screen information used when window rendering is disabled. This structure is +passed as a parameter to CefRenderHandler::GetScreenInfo and should be +filled in by the client. + + + + +Initialize COM using multi-threaded apartments. + + + + +Initialize COM using single-threaded apartments. + + + + +No COM initialization. + + + + +Supports tasks, timers and asynchronous IO events. + + + + +Supports tasks, timers and native UI events (e.g. Windows messages). + + + + +Supports tasks and timers. + + + + +Suitable for low-latency, glitch-resistant audio. + + + + +Suitable for threads which generate data for the display (at ~60Hz). + + + + +Default priority level. + + + + +Suitable for threads that shouldn't disrupt high priority work. + + + + +The main thread in the renderer. Used for all WebKit and V8 interaction. +Tasks may be posted to this thread after +CefRenderProcessHandler::OnWebKitInitialized but are not guaranteed to +run before sub-process termination (sub-processes may be killed at any +time without warning). + + + + +Used to process IPC and network messages. Do not perform blocking tasks on +this thread. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. + + + + +Used to launch and terminate browser processes. + + + + +Used for blocking tasks like file system access that affect UI +immediately after a user interaction. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. +Example: Generating data shown in the UI immediately after a click. + + + + +Used for blocking tasks like file system access that affect UI or +responsiveness of future user interactions. Do not use if an immediate +response to a user interaction is expected. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. +Examples: +- Updating the UI to reflect progress on a long task. +- Loading data that might be shown in the UI after a future user + interaction. + + + + +Used for blocking tasks like file system access where the user won't +notice if the task takes an arbitrarily long time to complete. All tasks +posted after CefBrowserProcessHandler::OnContextInitialized() and before +CefShutdown() are guaranteed to run. + + + + +The main thread in the browser. This will be the same as the main +application thread if CefInitialize() is called with a +CefSettings.multi_threaded_message_loop value of false. Do not perform +blocking tasks on this thread. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. This thread will outlive all other CEF threads. + + + + +Renderer process. + + + + +Browser process. + + + + +True (1) this this region is draggable and false (0) otherwise. + + + + +Bounds of the region. + + + +Structure representing a draggable region. + + + + +Request failed for some reason. + + + + +Request was canceled programatically. + + + + +An IO request is pending, and the caller will be informed when it is +completed. + + + + +Request succeeded. + + + + +Unknown status. + + + + +If set 3XX responses will cause the fetch to halt immediately rather than +continue through the redirect. + + + + +If set 5XX redirect errors will be propagated to the observer instead of +automatically re-tried. This currently only applies for requests +originated in the browser process. + + + + +If set the CefURLRequestClient::OnDownloadData method will not be called. + + + + +If set upload progress events will be generated when a request has a body. + + + + +If set user name, password, and cookies may be sent with the request, and +cookies may be saved from the response. + + + + +If set the cache will not be used at all. Setting this value is equivalent +to specifying the "Cache-Control: no-store" request header. Setting this +value in combination with UR_FLAG_ONLY_FROM_CACHE will cause the request +to fail. + + + + +If set the request will fail if it cannot be served from the cache (or +some equivalent local store). Setting this value is equivalent to +specifying the "Cache-Control: only-if-cached" request header. Setting +this value in combination with UR_FLAG_SKIP_CACHE or UR_FLAG_DISABLE_CACHE +will cause the request to fail. + + + + +If set the cache will be skipped when handling the request. Setting this +value is equivalent to specifying the "Cache-Control: no-cache" request +header. Setting this value in combination with UR_FLAG_ONLY_FROM_CACHE +will cause the request to fail. + + + + +Default behavior. + + + + +General mask defining the bits used for the qualifiers. + + + + +Used to test whether a transition involves a redirect. + + + + +Redirects sent from the server by HTTP headers. + + + + +Redirects caused by JavaScript or a meta refresh tag on the page. + + + + +The last transition in a redirect chain. + + + + +The beginning of a navigation chain. + + + + +The transition originated from an external application; the exact +definition of this is embedder dependent. Chrome runtime and +extension system only. + + + + +User is navigating to the home page. Chrome runtime only. + + + + +Loaded a URL directly via CreateBrowser, LoadURL or LoadRequest. + + + + +Used the Forward or Back function to navigate among browsing history. +Will be ORed to the transition type for the original load. + + + +Qualifiers. +Any of the core values above can be augmented by one or more qualifiers. +These qualifiers further define the transition. + +Attempted to visit a URL but was blocked. + + + + +General mask defining the bits used for the source values. + + + + +Corresponds to a visit generated for a keyword. See description of +TT_KEYWORD for more details. Chrome runtime only. + + + + +The url was generated from a replaceable keyword other than the default +search provider. If the user types a keyword (which also applies to +tab-to-search) in the omnibox this qualifier is applied to the transition +type of the generated url. TemplateURLModel then may generate an +additional visit with a transition type of TT_KEYWORD_GENERATED against +the url 'http://' + keyword. For example, if you do a tab-to-search +against wikipedia the generated url has a transition qualifer of +TT_KEYWORD, and TemplateURLModel generates a visit for 'wikipedia.org' +with a transition type of TT_KEYWORD_GENERATED. Chrome runtime only. + + + + +Source is a "reload" of the page via the Reload function or by re-visiting +the same URL. NOTE: This is distinct from the concept of whether a +particular load uses "reload semantics" (i.e. bypasses cached data). + + + + +Source is a form submission by the user. NOTE: In some situations +submitting a form does not result in this transition type. This can happen +if the form uses a script to submit the contents. + + + + +This is a toplevel navigation. This is any content that is automatically +loaded in a toplevel frame. For example, opening a tab to show the ASH +screen saver, opening the devtools window, opening the NTP after the safe +browsing warning, opening web-based dialog boxes are examples of +AUTO_TOPLEVEL navigations. Chrome runtime only. + + + + +User got to this page by typing in the URL bar and selecting an entry +that did not look like a URL. For example, a match might have the URL +of a Google search result page, but appear like "Search Google for ...". +These are not quite the same as EXPLICIT navigations because the user +didn't type or see the destination URL. Chrome runtime only. +See also TT_KEYWORD. + + + + +Source is a subframe navigation explicitly requested by the user that will +generate new navigation entries in the back/forward list. These are +probably more important than frames that were automatically loaded in +the background because the user probably cares about the fact that this +link was loaded. + + + + +Source is a subframe navigation. This is any content that is automatically +loaded in a non-toplevel frame. For example, if a page consists of several +frames containing ads, those ad URLs will have this transition type. +The user may not even realize the content in these pages is a separate +frame, so may not care about the URL. + + + + +User got to this page through a suggestion in the UI (for example, via the +destinations page). Chrome runtime only. + + + + +Source is some other "explicit" navigation. This is the default value for +navigations where the actual type is unknown. See also +TT_DIRECT_LOAD_FLAG. + + + + +Source is a link click or the JavaScript window.open function. This is +also the default value for requests like sub-resource loads that are not +navigations. + + + + +A sub-frame service worker navigation preload request. + + + + +A main-frame service worker navigation preload request. + + + + +A resource that a plugin requested. + + + + +A report of Content Security Policy violations. + + + + +Main resource of a service worker. + + + + +XMLHttpRequest. + + + + +Favicon. + + + + +Explicitly requested prefetch. + + + + +Main resource of a shared worker. + + + + +Main resource of a dedicated worker. + + + + +Media resource. + + + + +Object (or embed) tag for a plugin, or a resource that a plugin requested. + + + + +Some other subresource. This is the default type if the actual type is +unknown. + + + + +Font. + + + + +Image (jpg/gif/png/etc). + + + + +External script. + + + + +CSS stylesheet. + + + + +Frame or iframe. + + + + +Top level page. + + + + +Not configurable + + + + +Not enumerable + + + + +Not writeable + + + + +Writeable, Enumerable, Configurable + + + + +Creates a new document picture-in-picture window showing a child WebView. + + + + +Activates an existing tab containing the url, rather than navigating. +This is similar to SINGLETON_TAB, but searches across all windows from +the current profile and anonymity (instead of just the current one); +closes the current tab on switching if the current tab was the NTP with +no session history; and behaves like CURRENT_TAB instead of +NEW_FOREGROUND_TAB when no existing tab is found. + + + + +Special case error condition from the renderer. + + + + +New off-the-record (incognito) window. + + + + +Alt key while clicking. + + + + +Shift key while clicking. + + + + +New popup window. + + + + +Middle mouse button or meta/ctrl key while clicking. + + + + +Shift key + Middle mouse button or meta/ctrl key while clicking. + + + + +Indicates that only one tab with the url should exist in the same window. + + + + +Current tab. This is the default in most cases. + + + + +Directory containing application resources. Can be configured via +CefSettings.resources_dir_path. + + + + +"Application Data" directory under the user profile directory on Windows +and "~/Library/Application Support" directory on MacOS. + + + + +"Local Settings\Application Data" directory under the user profile +directory on Windows. + + + + +Path and filename of the module containing the CEF code (usually the +libcef module). + + + + +Path and filename of the current executable. + + + + +Temporary directory. + + + + +Directory containing PK_FILE_MODULE. + + + + +Directory containing PK_FILE_EXE. + + + + +Current directory. + + + + +Out of memory. Some platforms may use TS_PROCESS_CRASHED instead. + + + + +Segmentation fault. + + + + +SIGKILL or task manager kill. + + + + +Non-zero exit status. + + + + +Priority. + + + + +Same site. + + + + +The cookie expiration date is only valid if |has_expires| is true. + + + + +The cookie last access date. This is automatically populated by the system +on access. + + + + +The cookie creation date. This is automatically populated by the system on +cookie creation. + + + + +If |httponly| is true the cookie will only be sent for HTTP requests. + + + + +If |secure| is true the cookie will only be sent for HTTPS requests. + + + + +If |path| is non-empty only URLs at or below the path will get the cookie +value. + + + + +If |domain| is empty a host cookie will be created instead of a domain +cookie. Domain cookies are stored with a leading "." and are visible to +sub-domains whereas host cookies are not. + + + + +The cookie value. + + + + +The cookie name. + + + + +Cookie information. + + + + +Fragment (hash) identifier component (i.e., the string following the '#'). + + + + +Query string component (i.e., everything following the '?'). + + + + +Path component including the first slash following the host. + + + + +Origin contains just the scheme, host, and port from a URL. Equivalent to +clearing any username and password, replacing the path with a slash, and +clearing everything after that. This value will be empty for non-standard +URLs. + + + + +Port number component. + + + + +Host component. This may be a hostname, an IPv4 address or an IPv6 literal +surrounded by square brackets (e.g., "[2001:db8::1]"). + + + + +Password component. + + + + +User name component. + + + + +Scheme component not including the colon (e.g., "http"). + + + + +The complete URL specification. + + + + +URL component parts. + + + + +Continue asynchronously (usually via a callback). + + + + +Continue immediately. + + + + +Cancel immediately. + + + + +Controls whether the Chrome status bubble will be used. Only supported +with the Chrome runtime. For details about the status bubble see +https://www.chromium.org/user-experience/status-bubble/ + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. May be set globally +using the CefSettings.accept_language_list value. If both values are +empty then "en-US,en" will be used. + + + +END values that map to WebPreferences settings. + +Background color used for the browser before a document is loaded and when +no document color is specified. The alpha component must be either fully +opaque (0xFF) or fully transparent (0x00). If the alpha component is fully +opaque then the RGB components will be used as the background color. If +the alpha component is fully transparent for a windowed browser then the +CefSettings.background_color value will be used. If the alpha component is +fully transparent for a windowless (off-screen) browser then transparent +painting will be enabled. + + + + +Controls whether WebGL can be used. Note that WebGL requires hardware +support and may not work on all systems even when enabled. Also +configurable using the "disable-webgl" command-line switch. + + + + +Controls whether databases can be used. Also configurable using the +"disable-databases" command-line switch. + + + + +Controls whether local storage can be used. Also configurable using the +"disable-local-storage" command-line switch. + + + + +Controls whether the tab key can advance focus to links. Also configurable +using the "disable-tab-to-links" command-line switch. + + + + +Controls whether text areas can be resized. Also configurable using the +"disable-text-area-resize" command-line switch. + + + + +Controls whether standalone images will be shrunk to fit the page. Also +configurable using the "image-shrink-standalone-to-fit" command-line +switch. + + + + +Controls whether image URLs will be loaded from the network. A cached +image will still be rendered if requested. Also configurable using the +"disable-image-loading" command-line switch. + + + + +Controls whether DOM pasting is supported in the editor via +execCommand("paste"). The |javascript_access_clipboard| setting must also +be enabled. Also configurable using the "disable-javascript-dom-paste" +command-line switch. + + + + +Controls whether JavaScript can access the clipboard. Also configurable +using the "disable-javascript-access-clipboard" command-line switch. + + + + +Controls whether JavaScript can be used to close windows that were not +opened via JavaScript. JavaScript can still be used to close windows that +were opened via JavaScript or that have no back/forward history. Also +configurable using the "disable-javascript-close-windows" command-line +switch. + + + + +Controls whether JavaScript can be executed. Also configurable using the +"disable-javascript" command-line switch. + + + + +Controls the loading of fonts from remote sources. Also configurable using +the "disable-remote-fonts" command-line switch. + + + + +Default encoding for Web content. If empty "ISO-8859-1" will be used. Also +configurable using the "default-encoding" command-line switch. + + + +BEGIN values that map to WebPreferences settings. + +Font settings. + + + + +The maximum rate in frames per second (fps) that CefRenderHandler::OnPaint +will be called for a windowless browser. The actual fps may be lower if +the browser cannot generate frames at the requested rate. The minimum +value is 1 and the maximum value is 60 (default 30). This value can also +be changed dynamically via CefBrowserHost::SetWindowlessFrameRate. + + + + +Size of this structure. + + + + +Browser initialization settings. Specify NULL or 0 to get the recommended +default values. The consequences of using custom values may not be well +tested. Many of these and other settings can also configured using command- +line switches. + + + + +Comma delimited list of schemes supported by the associated +CefCookieManager. If |cookieable_schemes_exclude_defaults| is false (0) +the default schemes ("http", "https", "ws" and "wss") will also be +supported. Not specifying a |cookieable_schemes_list| value and setting +|cookieable_schemes_exclude_defaults| to true (1) will disable all loading +and saving of cookies. These values will be ignored if |cache_path| +matches the CefSettings.cache_path value. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. Can be set globally +using the CefSettings.accept_language_list value or overridden on a per- +browser basis using the CefBrowserSettings.accept_language_list value. If +all values are empty then "en-US,en" will be used. This value will be +ignored if |cache_path| matches the CefSettings.cache_path value. + + + + +To persist user preferences as a JSON file in the cache path directory set +this value to true (1). Can be set globally using the +CefSettings.persist_user_preferences value. This value will be ignored if +|cache_path| is empty or if it matches the CefSettings.cache_path value. + + + + +To persist session cookies (cookies without an expiry date or validity +interval) by default when using the global cookie manager set this value +to true (1). Session cookies are generally intended to be transient and +most Web browsers do not persist them. Can be set globally using the +CefSettings.persist_session_cookies value. This value will be ignored if +|cache_path| is empty or if it matches the CefSettings.cache_path value. + + + + +The location where cache data for this request context will be stored on +disk. If this value is non-empty then it must be an absolute path that is +either equal to or a child directory of CefSettings.root_cache_path. If +this value is empty then browsers will be created in "incognito mode" +where in-memory caches are used for storage and no data is persisted to +disk. HTML5 databases such as localStorage will only persist across +sessions if a cache path is specified. To share the global browser cache +and related configuration set this value to match the +CefSettings.cache_path value. + + + + +Size of this structure. + + + + +Request context initialization settings. Specify NULL or 0 to get the +recommended default values. + + + + +Comma delimited list of schemes supported by the associated +CefCookieManager. If |cookieable_schemes_exclude_defaults| is false (0) +the default schemes ("http", "https", "ws" and "wss") will also be +supported. Not specifying a |cookieable_schemes_list| value and setting +|cookieable_schemes_exclude_defaults| to true (1) will disable all loading +and saving of cookies. These settings will only impact the global +CefRequestContext. Individual CefRequestContext instances can be +configured via the CefRequestContextSettings.cookieable_schemes_list and +CefRequestContextSettings.cookieable_schemes_exclude_defaults values. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. May be overridden on a +per-browser basis using the CefBrowserSettings.accept_language_list value. +If both values are empty then "en-US,en" will be used. Can be overridden +for individual CefRequestContext instances via the +CefRequestContextSettings.accept_language_list value. + + + + +Background color used for the browser before a document is loaded and when +no document color is specified. The alpha component must be either fully +opaque (0xFF) or fully transparent (0x00). If the alpha component is fully +opaque then the RGB components will be used as the background color. If +the alpha component is fully transparent for a windowed browser then the +default value of opaque white be used. If the alpha component is fully +transparent for a windowless (off-screen) browser then transparent +painting will be enabled. + + + + +The number of stack trace frames to capture for uncaught exceptions. +Specify a positive value to enable the +CefRenderProcessHandler::OnUncaughtException() callback. Specify 0 +(default value) and OnUncaughtException() will not be called. Also +configurable using the "uncaught-exception-stack-size" command-line +switch. + + + + +Set to a value between 1024 and 65535 to enable remote debugging on the +specified port. Also configurable using the "remote-debugging-port" +command-line switch. Remote debugging can be accessed by loading the +chrome://inspect page in Google Chrome. Port numbers 9222 and 9229 are +discoverable by default. Other port numbers may need to be configured via +"Discover network targets" on the Devices tab. + + + + +Set to true (1) to disable loading of pack files for resources and +locales. A resource bundle handler must be provided for the browser and +render processes via CefApp::GetResourceBundleHandler() if loading of pack +files is disabled. Also configurable using the "disable-pack-loading" +command- line switch. + + + + +The fully qualified path for the locales directory. If this value is empty +the locales directory must be located in the module directory. If this +value is non-empty then it must be an absolute path. This value is ignored +on MacOS where pack files are always loaded from the app bundle Resources +directory. Also configurable using the "locales-dir-path" command-line +switch. + + + + +The fully qualified path for the resources directory. If this value is +empty the *.pak files must be located in the module directory on +Windows/Linux or the app bundle Resources directory on MacOS. If this +value is non-empty then it must be an absolute path. Also configurable +using the "resources-dir-path" command-line switch. + + + + +Custom flags that will be used when initializing the V8 JavaScript engine. +The consequences of using custom flags may not be well tested. Also +configurable using the "js-flags" command-line switch. + + + + +The log severity. Only messages of this severity level or higher will be +logged. When set to DISABLE no messages will be written to the log file, +but FATAL messages will still be output to stderr. Also configurable using +the "log-severity" command-line switch with a value of "verbose", "info", +"warning", "error", "fatal" or "disable". + + + + +The directory and file name to use for the debug log. If empty a default +log file name and location will be used. On Windows and Linux a +"debug.log" file will be written in the main executable directory. On +MacOS a "~/Library/Logs/[app name]_debug.log" file will be written where +[app name] is the name of the main app executable. Also configurable using +the "log-file" command-line switch. + + + + +The locale string that will be passed to WebKit. If empty the default +locale of "en-US" will be used. This value is ignored on Linux where +locale is determined using environment variable parsing with the +precedence order: LANGUAGE, LC_ALL, LC_MESSAGES and LANG. Also +configurable using the "lang" command-line switch. + + + + +Value that will be inserted as the product portion of the default +User-Agent string. If empty the Chromium product version will be used. If +|userAgent| is specified this value will be ignored. Also configurable +using the "user-agent-product" command-line switch. + + + + +Value that will be returned as the User-Agent HTTP header. If empty the +default User-Agent string will be used. Also configurable using the +"user-agent" command-line switch. + + + + +To persist user preferences as a JSON file in the cache path directory set +this value to true (1). A |cache_path| value must also be specified +to enable this feature. Also configurable using the +"persist-user-preferences" command-line switch. Can be overridden for +individual CefRequestContext instances via the +CefRequestContextSettings.persist_user_preferences value. + + + + +To persist session cookies (cookies without an expiry date or validity +interval) by default when using the global cookie manager set this value +to true (1). Session cookies are generally intended to be transient and +most Web browsers do not persist them. A |cache_path| value must also be +specified to enable this feature. Also configurable using the +"persist-session-cookies" command-line switch. Can be overridden for +individual CefRequestContext instances via the +CefRequestContextSettings.persist_session_cookies value. + + + + +The location where user data such as the Widevine CDM module and spell +checking dictionary files will be stored on disk. If this value is empty +then the default platform-specific user data directory will be used +("~/.config/cef_user_data" directory on Linux, "~/Library/Application +Support/CEF/User Data" directory on MacOS, "AppData\Local\CEF\User Data" +directory under the user profile directory on Windows). If this value is +non-empty then it must be an absolute path. When using the Chrome runtime +this value will be ignored in favor of the |root_cache_path| value. + + + + +The root directory that all CefSettings.cache_path and +CefRequestContextSettings.cache_path values must have in common. If this +value is empty and CefSettings.cache_path is non-empty then it will +default to the CefSettings.cache_path value. If this value is non-empty +then it must be an absolute path. Failure to set this value correctly may +result in the sandbox blocking read/write access to the cache_path +directory. + + + + +The location where data for the global browser cache will be stored on +disk. If this value is non-empty then it must be an absolute path that is +either equal to or a child directory of CefSettings.root_cache_path. If +this value is empty then browsers will be created in "incognito mode" +where in-memory caches are used for storage and no data is persisted to +disk. HTML5 databases such as localStorage will only persist across +sessions if a cache path is specified. Can be overridden for individual +CefRequestContext instances via the CefRequestContextSettings.cache_path +value. When using the Chrome runtime the "default" profile will be used if +|cache_path| and |root_cache_path| have the same value. + + + + +Set to true (1) to disable configuration of browser process features using +standard CEF and Chromium command-line arguments. Configuration can still +be specified using CEF data structures or via the +CefApp::OnBeforeCommandLineProcessing() method. + + + + +Set to true (1) to enable windowless (off-screen) rendering support. Do +not enable this value if the application does not use windowless rendering +as it may reduce rendering performance on some systems. + + + + +Set to true (1) to control browser process main (UI) thread message pump +scheduling via the CefBrowserProcessHandler::OnScheduleMessagePumpWork() +callback. This option is recommended for use in combination with the +CefDoMessageLoopWork() function in cases where the CEF message loop must +be integrated into an existing application message loop (see additional +comments and warnings on CefDoMessageLoopWork). Enabling this option is +not recommended for most users; leave this option disabled and use either +the CefRunMessageLoop() function or multi_threaded_message_loop if +possible. + + + + +Set to true (1) to have the browser process message loop run in a separate +thread. If false (0) then the CefDoMessageLoopWork() function must be +called from your application message loop. This option is only supported +on Windows and Linux. + + + + +Set to true (1) to enable use of the Chrome runtime in CEF. This feature +is considered experimental and is not recommended for most users at this +time. See issue #2969 for details. + + + + +The path to the main bundle on macOS. If this value is empty then it +defaults to the top-level app bundle. If this value is non-empty then it +must be an absolute path. Also configurable using the "main-bundle-path" +command-line switch. + + + + +The path to the CEF framework directory on macOS. If this value is empty +then the framework must exist at "Contents/Frameworks/Chromium Embedded +Framework.framework" in the top-level app bundle. If this value is +non-empty then it must be an absolute path. Also configurable using the +"framework-dir-path" command-line switch. + + + + +Set to true (1) to disable the sandbox for sub-processes. See +cef_sandbox_win.h for requirements to enable the sandbox on Windows. Also +configurable using the "no-sandbox" command-line switch. + + + + +Size of this structure. + + + + +Initialization settings. Specify NULL or 0 to get the recommended default +values. Many of these and other settings can also configured using command- +line switches. + + + + +Disable or disallow the setting. + + + + +Enable or allow the setting. + + + + +Use the default state for the setting. + + + + +Disable logging to file for all messages, and to stderr for messages with +severity less than FATAL. + + + + +FATAL logging. + + + + +ERROR logging. + + + + +WARNING logging. + + + + +INFO logging. + + + + +DEBUG logging. + + + + +Verbose logging. + + + + +Default logging (currently INFO logging). + + + + +Handle for the new browser window. Only used with windowed rendering. + + + + +Set to true (1) to enable the ability to issue BeginFrame requests from +the client application by calling CefBrowserHost::SendExternalBeginFrame. + + + + +Set to true (1) to enable shared textures for windowless rendering. Only +valid if windowless_rendering_enabled above is also set to true. Currently +only supported on Windows (D3D11). + + + + +Set to true (1) to create the browser using windowless (off-screen) +rendering. No window will be created for the browser and all rendering +will occur via the CefRenderHandler interface. The |parent_window| value +will be used to identify monitor info and to act as the parent window for +dialogs, context menus, etc. If |parent_window| is not provided then the +main screen monitor will be used and some functionality that requires a +parent window may not function correctly. In order to create windowless +browsers the CefSettings.windowless_rendering_enabled value must be set to +true. Transparent painting is enabled by default but can be disabled by +setting CefBrowserSettings.background_color to an opaque value. + + + + +Structure representing window information. + + + + +Structure representing CefExecuteProcess arguments. + + + + +Structure representing insets. + + + + +Structure representing a size. + + + + +Structure representing a rectangle. + + + + +Structure representing a point. + + + + +Creates a copy of an existing string list. + + + + +Free the string list. + + + + +Clear the string list. + + + + +Append a new value at the end of the string list. + + + + +Retrieve the value at the specified zero-based string list index. Returns +true (1) if the value was successfully retrieved. + + + + +Return the number of elements in the string list. + + + + +Allocate a new string map. + + + + +CEF string maps are a set of key/value string pairs. + + + + +Traits implementation for utf16 character strings. + + + + +Traits implementation for utf8 character strings. + + + + +Traits implementation for wide character strings. + + + + +These functions convert utf16 string case using the current ICU locale. This +may change the length of the string in some cases. + + + + +These functions free the string structure allocated by the associated +alloc function. Any string contents will first be cleared. + + + + +These functions allocate a new string structure. They must be freed by +calling the associated free function. + + + + +It is sometimes necessary for the system to allocate string structures with +the expectation that the user will free them. The userfree types act as a +hint that the user is responsible for freeing the structure. + + + + +These functions convert an ASCII string, typically a hardcoded constant, to +a Wide/UTF16 string. Use instead of the UTF8 conversion routines if you know +the string is ASCII. + + + + +These functions convert between UTF-8, -16, and -32 strings. They are +potentially slow so unnecessary conversions should be avoided. The best +possible result will always be written to |output| with the boolean return +value indicating whether the conversion is 100% valid. + + + + +These functions compare two string values with the same results as strcmp(). + + + + +Convenience macros for copying values. + + +These functions clear string values. The structure itself is not freed. + + + + +These functions set string values. If |copy| is true (1) the value will be +copied instead of referenced. It is up to the user to properly manage +the lifespan of references. + + + + +\file +CEF provides functions for converting between UTF-8, -16 and -32 strings. +CEF string types are safe for reading from multiple threads but not for +modification. It is the user's responsibility to provide synchronization if +modifying CEF strings from multiple threads. + + +CEF string type definitions. Whomever allocates |str| is responsible for +providing an appropriate |dtor| implementation that will free the string in +the same memory space. When reusing an existing string structure make sure +to call |dtor| for the old value before assigning new |str| and |dtor| +values. Static strings will have a NULL |dtor| value. Using the below +functions if you want this managed for you. + + + + +Return the delta between this object and |other| in milliseconds. + + + + +Set this object to now. + + + + +Converts to/from a double which is the number of seconds since epoch +(Jan 1, 1970). Webkit uses this format to represent time. A value of 0 +means "not initialized". + + + + +Converts to/from time_t. + + + + +Class representing a time. + + + + +Represents a wall clock time in UTC. Values are not guaranteed to be +monotonically non-decreasing and are subject to large amounts of skew. +Time is stored internally as microseconds since the Windows epoch (1601). + +This is equivalent of Chromium `base::Time` (see base/time/time.h). + + + + +Converts cef_basetime_t to cef_time_t. Returns true (1) on success and +false (0) on failure. + + + + +Converts cef_time_t to cef_basetime_t. Returns true (1) on success and +false (0) on failure. + + + + +Retrieve the delta in milliseconds between two time values. Returns true (1) +on success and false (0) on failure. + + + +Retrieve the current system time. + + + + +Retrieve the current system time. Returns true (1) on success and false (0) +on failure. + + + + +Converts cef_time_t to/from a double which is the number of seconds since +epoch (Jan 1, 1970). Webkit uses this format to represent time. A value of 0 +means "not initialized". Returns true (1) on success and false (0) on +failure. + + + + +Converts cef_time_t to/from time_t. Returns true (1) on success and false +(0) on failure. + + + + +Milliseconds within the current second (0-999) + + + + +Second within the current minute (0-59 plus leap seconds which may take +it up to 60). + + + + +Minute within the current hour (0-59) + + + + +Hour within the current day (0-23) + + + + +1-based day of month (1-31) + + + + +0-based day of week (0 = Sunday, etc.) + + + + +1-based month (values 1 = January, etc.) + + + + +Four or five digit year "2007" (1601 to 30827 on Windows, 1970 to 2038 on +32-bit POSIX) + + + + +Time information. Values should always be in UTC. + + + + +ThreadChecker is a helper class used to help verify that some methods of a +class are called from the same thread. It provides identical functionality +to base::NonThreadSafe, but it is meant to be held as a member variable, +rather than inherited from base::NonThreadSafe. + +While inheriting from base::NonThreadSafe may give a clear indication about +the thread-safety of a class, it may also lead to violations of the style +guide with regard to multiple inheritance. The choice between having a +ThreadChecker member and inheriting from base::NonThreadSafe should be based +on whether: + - Derived classes need to know the thread they belong to, as opposed to + having that functionality fully encapsulated in the base class. + - Derived classes should be able to reassign the base class to another + thread, via DetachFromThread. + +If neither of these are true, then having a ThreadChecker member and calling +CalledOnValidThread is the preferable solution. + +Example: + +
+  class MyClass {
+   public:
+    void Foo() {
+      DCHECK(thread_checker_.CalledOnValidThread());
+      ... (do stuff) ...
+    }
+
+   private:
+    ThreadChecker thread_checker_;
+  }
+
+ +In Release mode, CalledOnValidThread will always return true. + +
+ + +Do nothing implementation, for use in release mode. + +Note: You should almost always use the ThreadChecker class to get the +right version for your build configuration. + + + + +AutoUnlock is a helper that will Release() the |lock| argument in the +constructor, and re-Acquire() it in the destructor. + + + + +A helper class that acquires the given Lock while the AutoLock is in scope. + + + + +A convenient wrapper for an OS specific critical section. The only real +intelligence in this class is in debug mode for the support for the +AssertAcquired() method. + + + + +Gets the current thread reference, which can be used to check if +we're on the right thread quickly. + + + + +Gets the current thread id, which may be useful for logging purposes. + + + + +Used for thread checking and debugging. +Meant to be as fast as possible. +These are produced by PlatformThread::CurrentRef(), and used to later +check if we are on the same thread or not by using ==. These are safe +to copy between threads, but can't be copied to another process as they +have no meaning there. Also, the internal identifier can be re-used +after a thread dies, so a PlatformThreadRef cannot be reliably used +to distinguish a new thread from an old, dead thread. + + + + +Used for logging. Always an integer value. + + + + +Returns the current platform thread handle. + + + + +Returns the current platform thread ID. + + + + +Add a log message. See the LogSeverity defines for supported |severity| +values. + + + + +Gets the current vlog level for the given file (usually taken from +__FILE__). Note that |N| is the size *with* the null terminator. + + + + +Gets the current log level. + + + + +Returns the current reference count (with no barriers). This is subtle, +and should be used only for debugging. + + + + +Return whether the reference count is zero. With conventional object +referencing counting, the object will be destroyed, so the reference count +should never be zero. Hence this is generally used for a debug check. + + + + +Return whether the reference count is one. If the reference count is used +in the conventional way, a refrerence count of 1 implies that the current +thread owns the reference and no other thread shares it. This call +performs the test for a reference count of one, and performs the memory +barrier needed for the owning thread to act on the object, knowing that it +has exclusive access to the object. + + + + +Decrement a reference count, and return whether the result is non-zero. +Insert barriers to ensure that state written before the reference count +became zero will be visible to a thread that has just made the count zero. + + + + +Increment a reference count by "increment", which must exceed 0. +Returns the previous value of the count. + + + + +Increment a reference count. +Returns the previous value of the count. + + + + +Returns true if the underlying POST data includes elements that are not +represented by this IPostData object (for example, multi-part file upload +data). Modifying IPostData objects with excluded elements may result in +the request failing. + + + + +Create a new instance + + PostDataElement + + + +Remove all existing post data elements. + + + + +Remove the specified . + + element to be removed. + Returns true if the add succeeds. + + + +Add the specified . + + element to be added. + Returns true if the add succeeds. + + + +Retrieve the post data elements. + + + + +Returns true if this object is read-only. + + + + +Initializes a new instance of the PostData class. + + + + +Throw exception if Readonly + + Thrown when an exception error condition occurs. + + + +Destructor. + + + + +Finalizer. + + + + +Form Post Data + + + + + +Post an action for execution on the specified thread. + + thread id + action to execute + bool + + + +Post an action for delayed execution on the specified thread. + + thread id + action to execute + delay in ms + bool + + + +Helper method to ensure all ChromiumWebBrowser instances have been +closed/disposed, should be called before Cef.Shutdown. +Disposes all remaning ChromiumWebBrowser instances +then waits for CEF to release it's remaning CefBrowser instances. +Finally a small delay of 50ms to allow for CEF to finish it's cleanup. +Should only be called when MultiThreadedMessageLoop = true; +(Hasn't been tested when when CEF integrates into main message loop). + + The timeout in miliseconds. + + + +Helper method to ensure all ChromiumWebBrowser instances have been +closed/disposed, should be called before Cef.Shutdown. +Disposes all remaning ChromiumWebBrowser instances +then waits for CEF to release it's remaning CefBrowser instances. +Finally a small delay of 50ms to allow for CEF to finish it's cleanup. +Should only be called when MultiThreadedMessageLoop = true; +(Hasn't been tested when when CEF integrates into main message loop). + + + + +WaitForBrowsersToClose is not enabled by default, call this method +before Cef.Initialize to enable. If you aren't calling Cef.Initialize +explicitly then this should be called before creating your first +ChromiumWebBrowser instance. + + + + +Returns the mime type for the specified file extension or an empty string if unknown. + + file extension + Returns the mime type for the specified file extension or an empty string if unknown. + + + +Sets or clears a specific key-value pair from the crash metadata. + + + + +Crash reporting is configured using an INI-style config file named +crash_reporter.cfg. This file must be placed next to +the main application executable. File contents are as follows: + + # Comments start with a hash character and must be on their own line. + + [Config] + ProductName=<Value of the "prod" crash key; defaults to "cef"> + ProductVersion=<Value of the "ver" crash key; defaults to the CEF version> + AppName=<Windows only; App-specific folder name component for storing crash + information; default to "CEF"> + ExternalHandler=<Windows only; Name of the external handler exe to use + instead of re-launching the main exe; default to empty> + ServerURL=<crash server URL; default to empty> + RateLimitEnabled=<True if uploads should be rate limited; default to true> + MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; + default to 5> + MaxDatabaseSizeInMb=<Total crash report disk usage greater than this value + will cause older reports to be deleted; default to 20> + MaxDatabaseAgeInDays=<Crash reports older than this value will be deleted; + default to 5> + + [CrashKeys] + my_key1=<small|medium|large> + my_key2=<small|medium|large> + +Config section: + +If "ProductName" and/or "ProductVersion" are set then the specified values +will be included in the crash dump metadata. + +If "AppName" is set on Windows then crash report information (metrics, +database and dumps) will be stored locally on disk under the +"C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. + +If "ExternalHandler" is set on Windows then the specified exe will be +launched as the crashpad-handler instead of re-launching the main process +exe. The value can be an absolute path or a path relative to the main exe +directory. + +If "ServerURL" is set then crashes will be uploaded as a multi-part POST +request to the specified URL. Otherwise, reports will only be stored locally +on disk. + +If "RateLimitEnabled" is set to true then crash report uploads will be rate +limited as follows: + 1. If "MaxUploadsPerDay" is set to a positive value then at most the + specified number of crashes will be uploaded in each 24 hour period. + 2. If crash upload fails due to a network or server error then an + incremental backoff delay up to a maximum of 24 hours will be applied for + retries. + 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the + "MaxUploadsPerDay" value will be reduced to 1 until the client is + restarted. This helps to avoid an upload flood when the network or + server error is resolved. + +If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage +on disk will be limited to that size in megabytes. For example, on Windows +each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to +about 34 crash reports stored on disk. + +If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older +than the specified age in days will be deleted. + +CrashKeys section: + +Any number of crash keys can be specified for use by the application. Crash +key values will be truncated based on the specified size (small = 63 bytes, +medium = 252 bytes, large = 1008 bytes). The value of crash keys can be set +from any thread or process using the Cef.SetCrashKeyValue function. These +key/value pairs will be sent to the crash server along with the crash dump +file. Medium and large values will be chunked for submission. For example, +if your key is named "mykey" then the value will be broken into ordered +chunks and submitted using keys named "mykey-1", "mykey-2", etc. + + Returns true if crash reporting is enabled. + + + +Helper function (wrapper around the CefColorSetARGB macro) which combines +the 4 color components into an uint32 for use with BackgroundColor property + + Alpha + Red + Green + Blue + Returns the color. + + + +Gets the Global Request Context. Make sure to Dispose of this object when finished. +The earlier possible place to access the IRequestContext is in IBrowserProcessHandler.OnContextInitialized. +Alternative use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + Returns the global request context or null if the RequestContext has not been initialized yet. + + + +Returns true if called on the specified CEF thread. + + Returns true if called on the specified thread. + + + +Clear all scheme handler factories registered with the global request context. +Returns false on error. This function may be called on any thread in the browser process. +Using this function is equivalent to calling Cef.GetGlobalRequestContext().ClearSchemeHandlerFactories(). + + Returns false on error. + + + +This method should only be used by advanced users, if you're unsure then use Cef.Shutdown(). +This function should be called on the main application thread to shut down +the CEF browser process before the application exits. This method simply obtains a lock +and calls the native CefShutdown method, only IsInitialized is checked. All ChromiumWebBrowser +instances MUST be Disposed of before calling this method. If calling this method results in a crash +or hangs then you're likely hanging on to some unmanaged resources or haven't closed all of your browser +instances + + + + +Shuts down CefSharp and the underlying CEF infrastructure. This method is safe to call multiple times; it will only +shut down CEF on the first call (all subsequent calls will be ignored). +This method should be called on the main application thread to shut down the CEF browser process before the application exits. +If you are Using CefSharp.OffScreen then you must call this explicitly before your application exits or it will hang. +This method must be called on the same thread as Initialize. If you don't call Shutdown explicitly then CefSharp.Wpf and CefSharp.WinForms +versions will do their best to call Shutdown for you, if your application is having trouble closing then call thus explicitly. + + + + +Called prior to calling Cef.Shutdown, this diposes of any remaning +ChromiumWebBrowser instances. In WPF this is used from Dispatcher.ShutdownStarted +to release the unmanaged resources held by the ChromiumWebBrowser instances. +Generally speaking you don't need to call this yourself. + + + + +Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. +Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() +The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, +there may be a short delay before you can Get/Write cookies. +To be sure the cookie manager has been initialized use one of the following +- Access the ICookieManager after ICompletionCallback.OnComplete has been called +- Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. +- Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + If non-NULL it will be executed asnychronously on the CEF UI thread after the manager's storage has been initialized. + A the global cookie manager or null if the RequestContext has not yet been initialized. + + + +Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. +Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() +The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, +there may be a short delay before you can Get/Write cookies. +To be sure the cookie manager has been initialized use one of the following +- Use the GetGlobalCookieManager(ICompletionCallback) overload and access the ICookieManager after + ICompletionCallback.OnComplete has been called. +- Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. +- Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + A the global cookie manager or null if the RequestContext has not yet been initialized. + + + Remove all entries from the cross-origin access whitelist. + +Remove all entries from the cross-origin access whitelist. Returns false if +the whitelist cannot be accessed. + + + + Remove entry from cross-origin whitelist + The origin allowed to be accessed by the target protocol/domain. + The target protocol allowed to access the source origin. + The optional target domain allowed to access the source origin. + If set to true would allow a blah.example.com if the + was set to example.com + + +Remove an entry from the cross-origin access whitelist. Returns false if + is invalid or the whitelist cannot be accessed. + + + + Add an entry to the cross-origin whitelist. + The origin allowed to be accessed by the target protocol/domain. + The target protocol allowed to access the source origin. + The optional target domain allowed to access the source origin. + If set to true would allow a blah.example.com if the + was set to example.com + + Returns false if is invalid or the whitelist cannot be accessed. + +The same-origin policy restricts how scripts hosted from different origins +(scheme + domain + port) can communicate. By default, scripts can only access +resources with the same origin. Scripts hosted on the HTTP and HTTPS schemes +(but no other schemes) can use the "Access-Control-Allow-Origin" header to +allow cross-origin requests. For example, https://source.example.com can make +XMLHttpRequest requests on http://target.example.com if the +http://target.example.com request returns an "Access-Control-Allow-Origin: +https://source.example.com" response header. +Scripts in separate frames or iframes and hosted from the same protocol and +domain suffix can execute cross-origin JavaScript if both pages set the +document.domain value to the same domain suffix. For example, +scheme://foo.example.com and scheme://bar.example.com can communicate using +JavaScript if both domains set document.domain="example.com". +This method is used to allow access to origins that would otherwise violate +the same-origin policy. Scripts hosted underneath the fully qualified + URL (like http://www.example.com) will be allowed access to +all resources hosted on the specified and . +If is non-empty and if false only +exact domain matches will be allowed. If contains a top- +level domain component (like "example.com") and is +true sub-domain matches will be allowed. If is empty and + if true all domains and IP addresses will be +allowed. +This method cannot be used to bypass the restrictions on local or display +isolated schemes. See the comments on for more +information. + +This function may be called on any thread. Returns false if +is invalid or the whitelist cannot be accessed. + + + + +This function should be called from the application entry point function to execute a secondary process. +It can be used to run secondary processes from the browser client executable (default behavior) or +from a separate executable specified by the CefSettings.browser_subprocess_path value. +If called for the browser process (identified by no "type" command-line value) it will return immediately with a value of -1. +If called for a recognized secondary process it will block until the process should exit and then return the process exit code. +The |application| parameter may be empty. The |windows_sandbox_info| parameter is only used on Windows and may be NULL (see cef_sandbox_win.h for details). + + + + +Perform a single iteration of CEF message loop processing.This function is +provided for cases where the CEF message loop must be integrated into an +existing application message loop. Use of this function is not recommended +for most users; use CefSettings.MultiThreadedMessageLoop if possible (the default). +When using this function care must be taken to balance performance +against excessive CPU usage. It is recommended to enable the +CefSettings.ExternalMessagePump option when using +this function so that IBrowserProcessHandler.OnScheduleMessagePumpWork() +callbacks can facilitate the scheduling process. This function should only be +called on the main application thread and only if Cef.Initialize() is called +with a CefSettings.MultiThreadedMessageLoop value of false. This function +will not block. + + + + +Quit the CEF message loop that was started by calling Cef.RunMessageLoop(). +This function should only be called on the main application thread and only +if Cef.RunMessageLoop() was used. + + + + +Run the CEF message loop. Use this function instead of an application- +provided message loop to get the best balance between performance and CPU +usage. This function should only be called on the main application thread and +only if Cef.Initialize() is called with a +CefSettings.MultiThreadedMessageLoop value of false. This function will +block until a quit message is received by the system. + + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize/Shutdown MUST be called on your main +application thread (typically the UI thread). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies avaliable, throws exception if any are missing + Implement this interface to provide handler implementations. Null if you don't wish to handle these events + true if successful; otherwise, false. + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize/Shutdown MUST be called on your main +applicaiton thread (Typically the UI thead). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies avaliable, throws exception if any are missing + The handler for functionality specific to the browser process. Null if you don't wish to handle these events + true if successful; otherwise, false. + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize/Shutdown MUST be called on your main +application thread (typically the UI thread). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies avaliable, throws exception if any are missing + true if successful; otherwise, false. + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize and Shutdown MUST be called on your main +application thread (typically the UI thread). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + true if successful; otherwise, false. + + + +Parse the specified url into its component parts. +Uses a GURL to parse the Url. GURL is Google's URL parsing library. + + url + Returns null if the URL is empty or invalid. + + + +Gets a value that indicates the Git Hash for CEF version currently being used. + + The Git Commit Hash + + + Gets a value that indicates the Chromium version currently being used. + The Chromium version. + + + Gets a value that indicates the CEF version currently being used. + The CEF Version + + + Gets a value that indicates the version of CefSharp currently being used. + The CefSharp version. + + + Gets a value that indicates whether CefSharp was shutdown. + true if CefSharp was shutdown; otherwise, false. + + + Gets a value that indicates whether CefSharp is initialized. + true if CefSharp is initialized; otherwise, false. + + + +Global CEF methods are exposed through this class. e.g. CefInitalize maps to Cef.Initialize +CEF API Doc https://magpcss.org/ceforum/apidocs3/projects/(default)/(_globals).html +This class cannot be inherited. + + + + +Registers a custom scheme using the provided settings. + + The CefCustomScheme which provides the details about the scheme. + + + +If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. Can be overridden +for individual RequestContext instances via the +RequestContextSettings.CookieableSchemesList and +RequestContextSettings.CookieableSchemesExcludeDefaults values. + + + + +Comma delimited list of schemes supported by the associated +ICookieManager. If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. Can be overridden +for individual RequestContext instances via the +RequestContextSettings.CookieableSchemesList and +RequestContextSettings.CookieableSchemesExcludeDefaults values. + + + + +Background color used for the browser before a document is loaded and when no document color is specified. The alpha +component must be either fully opaque (0xFF) or fully transparent (0x00). If the alpha component is fully opaque then the RGB +components will be used as the background color. If the alpha component is fully transparent for a WinForms browser then the +default value of opaque white be used. If the alpha component is fully transparent for a windowless (WPF/OffScreen) browser +then transparent painting will be enabled. + + + + +Comma delimited ordered list of language codes without any whitespace that will be used in the "Accept-Language" HTTP header. +May be set globally using the CefSettings.AcceptLanguageList value. If both values are empty then "en-US,en" will be used. + + + + + +To persist user preferences as a JSON file in the cache path directory set this value to true. A CachePath value must also be +specified to enable this feature. Also configurable using the "persist-user-preferences" command-line switch. Can be +overridden for individual RequestContext instances via the RequestContextSettings.PersistUserPreferences value. + + + + +To persist session cookies (cookies without an expiry date or validity interval) by default when using the global cookie +manager set this value to true. Session cookies are generally intended to be transient and most Web browsers do not persist +them. A CachePath value must also be specified to enable this feature. Also configurable using the "persist-session-cookies" +command-line switch. Can be overridden for individual RequestContext instances via the +RequestContextSettings.PersistSessionCookies value. + + + + +Set to true (1) to enable windowless (off-screen) rendering support. Do not enable this value if the application does not use +windowless rendering as it may reduce rendering performance on some systems. + + + + +Value that will be returned as the User-Agent HTTP header. If empty the default User-Agent string will be used. Also +configurable using the "user-agent" command-line switch. + + + + +The number of stack trace frames to capture for uncaught exceptions. Specify a positive value to enable the +CefRenderProcessHandler:: OnUncaughtException() callback. Specify 0 (default value) and OnUncaughtException() will not be +called. Also configurable using the "uncaught-exception-stack-size" command-line switch. + + + + +Set to a value between 1024 and 65535 to enable remote debugging on the specified port. For example, if 8080 is specified the +remote debugging URL will be http://localhost:8080. CEF can be remotely debugged from any CEF or Chrome browser window. Also +configurable using the "remote-debugging-port" command-line switch. + + + + +Value that will be inserted as the product portion of the default User-Agent string. If empty the Chromium product version +will be used. If UserAgent is specified this value will be ignored. Also configurable using the "user-agent-product" command- +line switch. + + + + +Set to true to disable loading of pack files for resources and locales. A resource bundle handler must be provided for the +browser and render processes via CefApp::GetResourceBundleHandler() if loading of pack files is disabled. Also configurable +using the "disable-pack-loading" command- line switch. + + + + +Custom flags that will be used when initializing the V8 JavaScript engine. The consequences of using custom flags may not be +well tested. Also configurable using the "js-flags" command-line switch. + + + + +The log severity. Only messages of this severity level or higher will be logged. When set to + no messages will be written to the log file, but Fatal messages will still be +output to stderr. Also configurable using the "log-severity" command-line switch with a value of "verbose", "info", "warning", +"error", "fatal", "error-report" or "disable". + + + + +The directory and file name to use for the debug log. If empty a default log file name and location will be used. On Windows +a "debug.log" file will be written in the main executable directory. Also configurable using the"log-file" command- line +switch. + + + + +The fully qualified path for the resources directory. If this value is empty the cef.pak and/or devtools_resources.pak files +must be located in the module directory. Also configurable using the "resources-dir-path" command-line switch. + + + + +The fully qualified path for the locales directory. If this value is empty the locales directory must be located in the +module directory. If this value is non-empty then it must be an absolute path. Also configurable using the "locales-dir-path" +command-line switch. + + + + +The locale string that will be passed to WebKit. If empty the default locale of "en-US" will be used. Also configurable using +the "lang" command-line switch. + + + + +The location where user data such as the Widevine CDM module and spell checking dictionary files will be stored on disk. +If this value is empty then "Local Settings\Application Data\CEF\User Data" directory under the user profile directory +will be used. If this value is non-empty then it must be an absolute path. + + + + +The root directory that all CefSettings.CachePath and RequestContextSettings.CachePath values must have in common. If this +value is empty and CefSettings.CachePath is non-empty then it will default to the CefSettings.CachePath value. +If this value is non-empty then it must be an absolute path. Failure to set this value correctly may result in the sandbox +blocking read/write access to the CachePath directory. NOTE: CefSharp does not implement the CHROMIUM SANDBOX. A non-empty +RootCachePath can be used in conjuncation with an empty CefSettings.CachePath in instances where you would like browsers +attached to the Global RequestContext (the default) created in "incognito mode" and instances created with a custom +RequestContext using a disk based cache. + + + + +The location where data for the global browser cache will be stored on disk. In this value is non-empty then it must be +an absolute path that is must be either equal to or a child directory of CefSettings.RootCachePath (if RootCachePath is +empty it will default to this value). If the value is empty then browsers will be created in "incognito mode" where +in-memory caches are used for storage and no data is persisted to disk. HTML5 databases such as localStorage will only +persist across sessions if a cache path is specified. Can be overridden for individual RequestContext instances via the +RequestContextSettings.CachePath value. + + + + +The path to a separate executable that will be launched for sub-processes. By default the browser process executable is used. +See the comments on Cef.ExecuteProcess() for details. If this value is non-empty then it must be an absolute path. +Also configurable using the "browser-subprocess-path" command-line switch. +Defaults to using the provided CefSharp.BrowserSubprocess.exe instance + + + + +Set to true to have the browser process message loop run in a separate thread. If false than the CefDoMessageLoopWork() +function must be called from your application message loop. This option is only supported on Windows. The default value is +true. + + + + +Set to true to control browser process main (UI) thread message pump scheduling via the +IBrowserProcessHandler.OnScheduleMessagePumpWork callback. This option is recommended for use in combination with the +Cef.DoMessageLoopWork() function in cases where the CEF message loop must be integrated into an existing application message +loop (see additional comments and warnings on Cef.DoMessageLoopWork). Enabling this option is not recommended for most users; +leave this option disabled and use either MultiThreadedMessageLoop (the default) if possible. + + + + +Set to true to disable configuration of browser process features using standard CEF and Chromium command-line arguments. +Configuration can still be specified using CEF data structures or by adding to CefCommandLineArgs. + + + + +**Experimental** +Set to true to enable use of the Chrome runtime in CEF. This feature is +considered experimental and is not recommended for most users at this time. +See issue https://github.com/chromiumembedded/cef/issues/2969 + + + + +Add custom command line argumens to this collection, they will be added in OnBeforeCommandLineProcessing. The +CefSettings.CommandLineArgsDisabled value can be used to start with an empty command-line object. Any values specified in +CefSettings that equate to command-line arguments will be set before this method is called. + + + + +Add Customs schemes to this collection. + + + + +Destructor. + + + + +Finalizer. + + + + +Default Constructor. + + + + +CefCustomScheme collection + + + + +CefSettings unmanaged pointer + + + + +Command Line Arguments Dictionary. + + + + +Initialization settings. Many of these and other settings can also configured using command-line switches. +WPF/WinForms/OffScreen each have their own CefSettings implementation that sets +relevant settings e.g. OffScreen starts with audio muted. + + + + +Constructor. + + The popup features. + + + +Class representing popup window features. + + + + + + + + +Get the image hotspot (drag start location relative to image dimensions). + + + + +Get the image representation of drag data. +May return NULL if no image representation is available. + + + + +Returns the image width in density independent pixel(DIP) units. + + + + +Removes the representation for scaleFactor. + + + true for success + + + +Returns true if this Image and that Image share the same underlying storage. + + image to compare + returns true if share same underlying storage + + + +Returns true if this Image is empty. + + + + + +Returns true if this image contains a representation for scaleFactor. + + + + + + +Returns the image height in density independent pixel(DIP) units. + + + + +Returns information for the representation that most closely matches scaleFactor. + + scale factor + actual scale factor + pixel width + pixel height + return if information found for scale factor + + + +Returns the PNG representation that most closely matches scaleFactor. + + scale factor + is the PNG transparent + pixel width + pixel height + A stream represending the PNG or null. + + + +Returns the JPEG representation that most closely matches scaleFactor. + + scale factor + image quality + pixel width + pixel height + A stream representing the JPEG or null. + + + +Returns the bitmap representation that most closely matches scaleFactor. + + scale factor + color type + alpha type + pixel width + pixel height + A stream represending the bitmap or null. + + + +Return the handler for functionality specific to the render process. This +method is called on the render process main thread. + + + + +Return the handler for functionality specific to the browser process. This +method is called on multiple threads in the browser process. + + + + +Return the handler for resource bundle events. If +cef_settings_t.pack_loading_disabled is true a handler must be returned. +If no handler is returned resources will be loaded from pack files. This +method is called by the browser and render processes on multiple threads. + + + + +Provides an opportunity to register custom schemes. Do not keep a +reference to the |registrar| object. This method is called on the main +thread for each process and the registered schemes should be the same +across all processes. + + + + +Provides an opportunity to view and/or modify command-line arguments +before processing by CEF and Chromium. The |process_type| value will be +empty for the browser process. Do not keep a reference to the +CefCommandLine object passed to this method. The +cef_settings_t.command_line_args_disabled value can be used to start with +an empty command-line object. Any values specified in CefSettings that +equate to command-line arguments will be set before this method is called. +Be cautious when using this method to modify command-line arguments for +non-browser processes as this may result in undefined behavior including +crashes. + + + + +Implement this interface to provide handler implementations. Methods will be +called by the process and/or thread indicated. + + + + +Quit the CEF message loop that was started by calling CefRunMessageLoop(). +This function should only be called on the main application thread and only +if CefRunMessageLoop() was used. + + + + +Run the CEF message loop. Use this function instead of an application- +provided message loop to get the best balance between performance and CPU +usage. This function should only be called on the main application thread +and only if CefInitialize() is called with a +cef_settings_t.multi_threaded_message_loop value of false. This function +will block until a quit message is received by the system. + + + + +Perform a single iteration of CEF message loop processing. This function is +provided for cases where the CEF message loop must be integrated into an +existing application message loop. Use of this function is not recommended +for most users; use either the CefRunMessageLoop() function or +cef_settings_t.multi_threaded_message_loop if possible. When using this +function care must be taken to balance performance against excessive CPU +usage. It is recommended to enable the cef_settings_t.external_message_pump +option when using this function so that +CefBrowserProcessHandler::OnScheduleMessagePumpWork() callbacks can +facilitate the scheduling process. This function should only be called on +the main application thread and only if CefInitialize() is called with a +cef_settings_t.multi_threaded_message_loop value of false. This function +will not block. + + + + +This function should be called on the main application thread to shut down +the CEF browser process before the application exits. + + + + +This function should be called on the main application thread to initialize +the CEF browser process. The |application| parameter may be empty. A return +value of true indicates that it succeeded and false indicates that it +failed. The |windows_sandbox_info| parameter is only used on Windows and may +be NULL (see cef_sandbox_win.h for details). + + + + +This function should be called from the application entry point function to +execute a secondary process. It can be used to run secondary processes from +the browser client executable (default behavior) or from a separate +executable specified by the cef_settings_t.browser_subprocess_path value. If +called for the browser process (identified by no "type" command-line value) +it will return immediately with a value of -1. If called for a recognized +secondary process it will block until the process should exit and then +return the process exit code. The |application| parameter may be empty. The +|windows_sandbox_info| parameter is only used on Windows and may be NULL +(see cef_sandbox_win.h for details). + + + + +Called to retrieve data for the specified |resource_id| nearest the scale +factor |scale_factor|. To provide the resource data set |data| and +|data_size| to the data pointer and size respectively and return true. To +use the default resource data return false. The resource data will not be +copied and must remain resident in memory. Include cef_pack_resources.h +for a listing of valid resource ID values. + + + + +Called to retrieve data for the specified scale independent |resource_id|. +To provide the resource data set |data| and |data_size| to the data +pointer and size respectively and return true. To use the default resource +data return false. The resource data will not be copied and must remain +resident in memory. Include cef_pack_resources.h for a listing of valid +resource ID values. + + + + +Called to retrieve a localized translation for the specified |string_id|. +To provide the translation set |string| to the translation string and +return true. To use the default translation return false. Include +cef_pack_strings.h for a listing of valid string ID values. + + + + +Class used to implement a custom resource bundle interface. See CefSettings +for additional options related to resource bundle loading. The methods of +this class may be called on multiple threads. + + + + +Called when a new message is received from a different process. Return +true if the message was handled or false otherwise. It is safe to keep a +reference to |message| outside of this callback. + + + + +Called when a new node in the the browser gets focus. The |node| value may +be empty if no specific node has gained focus. The node object passed to +this method represents a snapshot of the DOM at the time this method is +executed. DOM objects are only valid for the scope of this method. Do not +keep references to or attempt to access any DOM objects outside the scope +of this method. + + + + +Called for global uncaught exceptions in a frame. Execution of this +callback is disabled by default. To enable set +cef_settings_t.uncaught_exception_stack_size > 0. + + + + +Called immediately before the V8 context for a frame is released. No +references to the context should be kept after this method is called. + + + + +Called immediately after the V8 context for a frame has been created. To +retrieve the JavaScript 'window' object use the CefV8Context::GetGlobal() +method. V8 handles can only be accessed from the thread on which they are +created. A task runner for posting tasks on the associated thread can be +retrieved via the CefV8Context::GetTaskRunner() method. + + + + +Return the handler for browser load status events. + + + + +Called before a browser is destroyed. + + + + +Called after a browser has been created. When browsing cross-origin a new +browser will be created before the old browser with the same identifier is +destroyed. |extra_info| is an optional read-only value originating from +CefBrowserHost::CreateBrowser(), CefBrowserHost::CreateBrowserSync(), +CefLifeSpanHandler::OnBeforePopup() or +CefBrowserView::CreateBrowserView(). + + + + +Called after WebKit has been initialized. + + + + +Class used to implement render process callbacks. The methods of this class +will be called on the render process main thread (TID_RENDERER) unless +otherwise indicated. + + + + +Return the default client for use with a newly created browser window. If +null is returned the browser will be unmanaged (no callbacks will be +executed for that browser) and application shutdown will be blocked until +the browser window is closed manually. This method is currently only used +with the chrome runtime. + + + + +Called before a child process is launched. Will be called on the browser +process UI thread when launching a render process and on the browser +process IO thread when launching a GPU process. Provides an opportunity to +modify the child process command line. Do not keep a reference to +|command_line| outside of this method. + + + + +Called on the browser process UI thread immediately after the CEF context +has been initialized. + + + + +Provides an opportunity to register custom preferences prior to +global and request context initialization. + +If |type| is CEF_PREFERENCES_TYPE_GLOBAL the registered preferences can be +accessed via CefPreferenceManager::GetGlobalPreferences after +OnContextInitialized is called. Global preferences are registered a single +time at application startup. See related cef_settings_t.cache_path and +cef_settings_t.persist_user_preferences configuration. + +If |type| is CEF_PREFERENCES_TYPE_REQUEST_CONTEXT the preferences can be +accessed via the CefRequestContext after +CefRequestContextHandler::OnRequestContextInitialized is called. Request +context preferences are registered each time a new CefRequestContext is +created. It is intended but not required that all request contexts have +the same registered preferences. See related +cef_request_context_settings_t.cache_path and +cef_request_context_settings_t.persist_user_preferences configuration. + +Do not keep a reference to the |registrar| object. This method is called +on the browser process UI thread. + + + + +Class used to implement browser process callbacks. The methods of this class +will be called on the browser process main thread unless otherwise +indicated. + + + + +Insert a command before the current command. +Common for debuggers, like "valgrind" or "gdb --args". + + + + +Add an argument to the end of the command line. + + + + +Get the remaining command line arguments. + + + + +True if there are remaining command line arguments. + + + + +Add a switch with the specified value to the end of the command line. If +the switch has no value pass an empty value string. + + + + +Add a switch to the end of the command line. + + + + +Returns the map of switch names and values. If a switch has no value an +empty string is returned. + + + + +Returns the value associated with the given switch. If the switch has no +value or isn't present this method returns the empty string. + + + + +Returns true if the command line contains the given switch. + + + + +Returns true if the command line has switches. + + + + +Set the program part of the command line string (the first item). + + + + +Get the program part of the command line string (the first item). + + + + +Constructs and returns the represented command line string. Use this +method cautiously because quoting behavior is unclear. + + + + +Retrieve the original command line string as a vector of strings. +The argv array: +`{ program, [(--|-|/)switch[=value]]*, [--], [argument]* }` + + + + +Reset the command-line switches and arguments but leave the program +component unchanged. + + + + +Initialize the command line with the string returned by calling +GetCommandLineW(). This method is only supported on Windows. + + + + +Initialize the command line with the specified |argc| and |argv| values. +The first argument must be the name of the program. This method is only +supported on non-Windows platforms. + + + + +Returns a writable copy of this object. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Returns the singleton global CefCommandLine object. The returned object +will be read-only. + + + + +Create a new CefCommandLine instance. + + + + +Class used to create and/or parse command line arguments. Arguments with +"--", "-" and, on Windows, "/" prefixes are considered switches. Switches +will always precede any arguments without switch prefixes. Switches can +optionally have a value specified using the "=" delimiter (e.g. +"-switch=value"). An argument of "--" will terminate switch parsing with all +subsequent tokens, regardless of prefix, being interpreted as non-switch +arguments. Switch names should be lowercase ASCII and will be converted to +such if necessary. Switch values will retain the original case and UTF8 +encoding. This class can be used before CefInitialize() is called. + + + + +Called when a new message is received from a different process. Return +true if the message was handled or false otherwise. It is safe to keep a +reference to |message| outside of this callback. + + + +Called when a new message is received from a different process. Return +true if the message was handled or false otherwise. It is safe to keep a +reference to |message| outside of this callback. + + + + +Return the handler for browser request events. + + + +Return the handler for browser request events. + + + + +Return the handler for off-screen rendering events. + + + +Return the handler for off-screen rendering events. + + + + +Return the handler for printing on Linux. If a print handler is not +provided then printing will not be supported on the Linux platform. + + + +Return the handler for printing on Linux. If a print handler is not +provided then printing will not be supported on the Linux platform. + + + + +Return the handler for browser load status events. + + + +Return the handler for browser load status events. + + + + +Return the handler for browser life span events. + + + +Return the handler for browser life span events. + + + + +Return the handler for keyboard events. + + + +Return the handler for keyboard events. + + + + +Return the handler for JavaScript dialogs. If no handler is provided the +default implementation will be used. + + + +Return the handler for JavaScript dialogs. If no handler is provided the +default implementation will be used. + + + + +Return the handler for permission requests. + + + +Return the handler for permission requests. + + + + +Return the handler for events related to CefFrame lifespan. This method +will be called once during CefBrowser creation and the result will be +cached for performance reasons. + + + +Return the handler for events related to CefFrame lifespan. This method +will be called once during CefBrowser creation and the result will be +cached for performance reasons. + + + + +Return the handler for focus events. + + + +Return the handler for focus events. + + + + +Return the handler for find result events. + + + +Return the handler for find result events. + + + + +Return the handler for drag events. + + + +Return the handler for drag events. + + + + +Return the handler for download events. If no handler is returned +downloads will not be allowed. + + + +Return the handler for download events. If no handler is returned +downloads will not be allowed. + + + + +Return the handler for browser display state events. + + + +Return the handler for browser display state events. + + + + +Return the handler for dialogs. If no handler is provided the default +implementation will be used. + + + +Return the handler for dialogs. If no handler is provided the default +implementation will be used. + + + + +Return the handler for context menus. If no handler is provided the +default implementation will be used. + + + +Return the handler for context menus. If no handler is provided the +default implementation will be used. + + + + +Return the handler for commands. If no handler is provided the default +implementation will be used. + + + +Return the handler for commands. If no handler is provided the default +implementation will be used. + + + + +Return the handler for audio rendering events. + + + +Return the handler for audio rendering events. + + + + +Implement this interface to provide handler implementations. + + + +Implement this interface to provide handler implementations. + + + + +Called on the browser process UI thread when the window.document object of +the main frame has been created. + + + + +Called on the browser process UI thread when the render process +terminates unexpectedly. |status| indicates how the process +terminated. + + + + +Called on the browser process UI thread when the render view associated +with |browser| is ready to receive/handle IPC messages in the render +process. + + + + +Called on the UI thread when a client certificate is being requested for +authentication. Return false to use the default behavior and automatically +select the first certificate available. Return true and call +CefSelectClientCertificateCallback::Select either in this method or at a +later time to select a certificate. Do not call Select or call it with +NULL to continue without using any certificate. |isProxy| indicates +whether the host is an HTTPS proxy or the origin server. |host| and |port| +contains the hostname and port of the SSL server. |certificates| is the +list of certificates to choose from; this list has already been pruned by +Chromium so that it only contains certificates from issuers that the +server trusts. + + + + +Called on the UI thread to handle requests for URLs with an invalid +SSL certificate. Return true and call CefCallback methods either in this +method or at a later time to continue or cancel the request. Return false +to cancel the request immediately. If +cef_settings_t.ignore_certificate_errors is set all invalid certificates +will be accepted without calling this method. + + + + +Called on the IO thread when the browser needs credentials from the user. +|origin_url| is the origin making this authentication request. |isProxy| +indicates whether the host is a proxy server. |host| contains the hostname +and |port| contains the port number. |realm| is the realm of the challenge +and may be empty. |scheme| is the authentication scheme used, such as +"basic" or "digest", and will be empty if the source of the request is an +FTP server. Return true to continue the request and call +CefAuthCallback::Continue() either in this method or at a later time when +the authentication information is available. Return false to cancel the +request immediately. + + + + +Called on the browser process IO thread before a resource request is +initiated. The |browser| and |frame| values represent the source of the +request. |request| represents the request contents and cannot be modified +in this callback. |is_navigation| will be true if the resource request is +a navigation. |is_download| will be true if the resource request is a +download. |request_initiator| is the origin (scheme + domain) of the page +that initiated the request. Set |disable_default_handling| to true to +disable default handling of the request, in which case it will need to be +handled via CefResourceRequestHandler::GetResourceHandler or it will be +canceled. To allow the resource load to proceed with default handling +return NULL. To specify a handler for the resource return a +CefResourceRequestHandler object. If this callback returns NULL the same +method will be called on the associated CefRequestContextHandler, if any. + + + + +Called on the UI thread before OnBeforeBrowse in certain limited cases +where navigating a new or different browser might be desirable. This +includes user-initiated navigation that might open in a special way (e.g. +links clicked via middle-click or ctrl + left-click) and certain types of +cross-origin navigation initiated from the renderer process (e.g. +navigating the top-level frame to/from a file URL). The |browser| and +|frame| values represent the source of the navigation. The +|target_disposition| value indicates where the user intended to navigate +the browser based on standard Chromium behaviors (e.g. current tab, +new tab, etc). The |user_gesture| value will be true if the browser +navigated via explicit user gesture (e.g. clicking a link) or false if it +navigated automatically (e.g. via the DomContentLoaded event). Return true +to cancel the navigation or false to allow the navigation to proceed in +the source browser's top-level frame. + + + + +Called on the UI thread before browser navigation. Return true to cancel +the navigation or false to allow the navigation to proceed. The |request| +object cannot be modified in this callback. +CefLoadHandler::OnLoadingStateChange will be called twice in all cases. +If the navigation is allowed CefLoadHandler::OnLoadStart and +CefLoadHandler::OnLoadEnd will be called. If the navigation is canceled +CefLoadHandler::OnLoadError will be called with an |errorCode| value of +ERR_ABORTED. The |user_gesture| value will be true if the browser +navigated via explicit user gesture (e.g. clicking a link) or false if it +navigated automatically (e.g. via the DomContentLoaded event). + + + + +Implement this interface to handle events related to browser requests. The +methods of this class will be called on the thread indicated. + + + + +Chooses the specified certificate for client certificate authentication. +NULL value means that no client certificate should be used. + + + + +Callback interface used to select a client certificate for authentication. + + + + +Returns true if the certificate status represents an error. + + + + +Returns the X.509 certificate. + + + + +Returns a bitmask containing any and all problems verifying the server +certificate. + + + + +Class representing SSL information. + + + + +Called when an on-screen keyboard should be shown or hidden for the +specified |browser|. |input_mode| specifies what kind of keyboard +should be opened. If |input_mode| is CEF_TEXT_INPUT_MODE_NONE, any +existing keyboard for this browser should be hidden. + + + + +Called when text selection has changed for the specified |browser|. +|selected_text| is the currently selected text and |selected_range| is +the character range. + + + + +Called when the IME composition range has changed. |selected_range| is the +range of characters that have been selected. |character_bounds| is the +bounds of each character in view coordinates. + + + + +Called when the scroll offset has changed. + + + + +Called when the user starts dragging content in the web view. Contextual +information about the dragged content is supplied by |drag_data|. +(|x|, |y|) is the drag start location in screen coordinates. +OS APIs that run a system message loop may be used within the +StartDragging call. + +Return false to abort the drag operation. Don't call any of +CefBrowserHost::DragSource*Ended* methods after returning false. + +Return true to handle the drag operation. Call +CefBrowserHost::DragSourceEndedAt and DragSourceSystemDragEnded either +synchronously or asynchronously to inform the web view that the drag +operation has ended. + + + + +Called when touch handle state is updated. The client is responsible for +rendering the touch handles. + + + + +Called to retrieve the size of the touch handle for the specified +|orientation|. + + + + +Called when an element has been rendered to the shared texture handle. +|type| indicates whether the element is the view or the popup widget. +|dirtyRects| contains the set of rectangles in pixel coordinates that need +to be repainted. |shared_handle| is the handle for a D3D11 Texture2D that +can be accessed via ID3D11Device using the OpenSharedResource method. This +method is only called when CefWindowInfo::shared_texture_enabled is set to +true, and is currently only supported on Windows. + + + + +Called when an element should be painted. Pixel values passed to this +method are scaled relative to view coordinates based on the value of +CefScreenInfo.device_scale_factor returned from GetScreenInfo. |type| +indicates whether the element is the view or the popup widget. |buffer| +contains the pixel data for the whole image. |dirtyRects| contains the set +of rectangles in pixel coordinates that need to be repainted. |buffer| +will be |width|*|height|*4 bytes in size and represents a BGRA image with +an upper-left origin. This method is only called when +CefWindowInfo::shared_texture_enabled is set to false. + + + + +Called when the browser wants to move or resize the popup widget. |rect| +contains the new location and size in view coordinates. + + + + +Called when the browser wants to show or hide the popup widget. The popup +should be shown if |show| is true and hidden if |show| is false. + + + + +Called to allow the client to fill in the CefScreenInfo object with +appropriate values. Return true if the |screen_info| structure has been +modified. + +If the screen info rectangle is left empty the rectangle from GetViewRect +will be used. If the rectangle is still empty or invalid popups may not be +drawn correctly. + + + + +Called to retrieve the translation from view DIP coordinates to screen +coordinates. Windows/Linux should provide screen device (pixel) +coordinates and MacOS should provide screen DIP coordinates. Return true +if the requested coordinates were provided. + + + + +Called to retrieve the view rectangle in screen DIP coordinates. This +method must always provide a non-empty rectangle. + + + + +Called to retrieve the root window rectangle in screen DIP coordinates. +Return true if the rectangle was provided. If this method returns false +the rectangle from GetViewRect will be used. + + + + +Return the handler for accessibility notifications. If no handler is +provided the default implementation will be used. + + + + +Implement this interface to handle events when window rendering is disabled. +The methods of this class will be called on the UI thread. + + + + +Called after renderer process sends accessibility location changes to the +browser process. + + + + +Called after renderer process sends accessibility tree changes to the +browser process. + + + + +Implement this interface to receive accessibility notification when +accessibility events have been registered. The methods of this class will +be called on the UI thread. + + + + +Return the PDF paper size in device units. Used in combination with +CefBrowserHost::PrintToPDF(). + + + + +Reset client state related to printing. + + + + +Send the print job to the printer. Execute |callback| once the job is +completed. Return true if the job will proceed or false to cancel the job +immediately. + + + + +Show the print dialog. Execute |callback| once the dialog is dismissed. +Return true if the dialog will be displayed or false to cancel the +printing immediately. + + + + +Synchronize |settings| with client state. If |get_defaults| is true then +populate |settings| with the default print settings. Do not keep a +reference to |settings| outside of this callback. + + + + +Called when printing has started for the specified |browser|. This method +will be called before the other OnPrint*() methods and irrespective of how +printing was initiated (e.g. CefBrowserHost::Print(), JavaScript +window.print() or PDF extension print button). + + + + +Implement this interface to handle printing on Linux. Each browser will have +only one print job in progress at a time. The methods of this class will be +called on the browser process UI thread. + + + + +Indicate completion of the print job. + + + + +Callback interface for asynchronous continuation of print job requests. + + + + +Cancel the printing. + + + + +Continue printing with the specified |settings|. + + + + +Callback interface for asynchronous continuation of print dialog requests. + + + + +Get the duplex mode. + + + + +Set the duplex mode. + + + + +Get the number of copies. + + + + +Set the number of copies. + + + + +Get the color model. + + + + +Set the color model. + + + + +Returns true if pages will be collated. + + + + +Set whether pages will be collated. + + + + +Returns true if only the selection will be printed. + + + + +Set whether only the selection will be printed. + + + + +Retrieve the page ranges. + + + + +Returns the number of page ranges that currently exist. + + + + +Set the page ranges. + + + + +Get the DPI (dots per inch). + + + + +Set the DPI (dots per inch). + + + + +Get the device name. + + + + +Set the device name. + + + + +Set the printer printable area in device units. +Some platforms already provide flipped area. Set |landscape_needs_flip| +to false on those platforms to avoid double flipping. + + + + +Returns true if the orientation is landscape. + + + + +Set the page orientation. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Create a new CefPrintSettings object. + + + + +Class representing print settings. + + + + +Called when a permission prompt handled via OnShowPermissionPrompt is +dismissed. |prompt_id| will match the value that was passed to +OnShowPermissionPrompt. |result| will be the value passed to +CefPermissionPromptCallback::Continue or CEF_PERMISSION_RESULT_IGNORE if +the dialog was dismissed for other reasons such as navigation, browser +closure, etc. This method will not be called if OnShowPermissionPrompt +returned false for |prompt_id|. + + + + +Called when a page should show a permission prompt. |prompt_id| uniquely +identifies the prompt. |requesting_origin| is the URL origin requesting +permission. |requested_permissions| is a combination of values from +cef_permission_request_types_t that represent the requested permissions. +Return true and call CefPermissionPromptCallback::Continue either in this +method or at a later time to continue or cancel the request. Return false +to proceed with default handling. With the Chrome runtime, default +handling will display the permission prompt UI. With the Alloy runtime, +default handling is CEF_PERMISSION_RESULT_IGNORE. + + + + +Called when a page requests permission to access media. +|requesting_origin| is the URL origin requesting permission. +|requested_permissions| is a combination of values from +cef_media_access_permission_types_t that represent the requested +permissions. Return true and call CefMediaAccessCallback methods either in +this method or at a later time to continue or cancel the request. Return +false to proceed with default handling. With the Chrome runtime, default +handling will display the permission request UI. With the Alloy runtime, +default handling will deny the request. This method will not be called if +the "--enable-media-stream" command-line switch is used to grant all +permissions. + + + + +Implement this interface to handle events related to permission requests. +The methods of this class will be called on the browser process UI thread. + + + + +Complete the permissions request with the specified |result|. + + + + +Callback interface used for asynchronous continuation of permission prompts. + + + + +Cancel the media access request. + + + + +Call to allow or deny media access. If this callback was initiated in +response to a getUserMedia (indicated by +CEF_MEDIA_PERMISSION_DEVICE_AUDIO_CAPTURE and/or +CEF_MEDIA_PERMISSION_DEVICE_VIDEO_CAPTURE being set) then +|allowed_permissions| must match |required_permissions| passed to +OnRequestMediaAccessPermission. + + + + +Callback interface used for asynchronous continuation of media access +permission requests. + + + + +Called when a navigation fails or is canceled. This method may be called +by itself if before commit or in combination with OnLoadStart/OnLoadEnd if +after commit. |errorCode| is the error code number, |errorText| is the +error text and |failedUrl| is the URL that failed to load. +See net\base\net_error_list.h for complete descriptions of the error +codes. + + + + +Called when the browser is done loading a frame. The |frame| value will +never be empty -- call the IsMain() method to check if this frame is the +main frame. Multiple frames may be loading at the same time. Sub-frames +may start or continue loading after the main frame load has ended. This +method will not be called for same page navigations (fragments, history +state, etc.) or for navigations that fail or are canceled before commit. +For notification of overall browser load status use OnLoadingStateChange +instead. + + + + +Called after a navigation has been committed and before the browser begins +loading contents in the frame. The |frame| value will never be empty -- +call the IsMain() method to check if this frame is the main frame. +|transition_type| provides information about the source of the navigation +and an accurate value is only available in the browser process. Multiple +frames may be loading at the same time. Sub-frames may start or continue +loading after the main frame load has ended. This method will not be +called for same page navigations (fragments, history state, etc.) or for +navigations that fail or are canceled before commit. For notification of +overall browser load status use OnLoadingStateChange instead. + + + + +Called when the loading state has changed. This callback will be executed +twice -- once when loading is initiated either programmatically or by user +action, and once when loading is terminated due to completion, +cancellation of failure. It will be called before any calls to OnLoadStart +and after all calls to OnLoadError and/or OnLoadEnd. + + + + +Implement this interface to handle events related to browser load status. +The methods of this class will be called on the browser process UI thread or +render process main thread (TID_RENDERER). + + + + +Called just before a browser is destroyed. Release all references to the +browser object and do not attempt to execute any methods on the browser +object (other than IsValid, GetIdentifier or IsSame) after this callback +returns. CefFrameHandler callbacks related to final main frame destruction +will arrive after this callback and CefBrowser::IsValid will return false +at that time. Any in-progress network requests associated with |browser| +will be aborted when the browser is destroyed, and +CefResourceRequestHandler callbacks related to those requests may still +arrive on the IO thread after this callback. See CefFrameHandler and +DoClose() documentation for additional usage information. + + + + +Called when a browser has recieved a request to close. This may result +directly from a call to CefBrowserHost::*CloseBrowser() or indirectly if +the browser is parented to a top-level window created by CEF and the user +attempts to close that window (by clicking the 'X', for example). The +DoClose() method will be called after the JavaScript 'onunload' event has +been fired. + +An application should handle top-level owner window close notifications by +calling CefBrowserHost::TryCloseBrowser() or +CefBrowserHost::CloseBrowser(false) instead of allowing the window to +close immediately (see the examples below). This gives CEF an opportunity +to process the 'onbeforeunload' event and optionally cancel the close +before DoClose() is called. + +When windowed rendering is enabled CEF will internally create a window or +view to host the browser. In that case returning false from DoClose() will +send the standard close notification to the browser's top-level owner +window (e.g. WM_CLOSE on Windows, performClose: on OS X, "delete_event" on +Linux or CefWindowDelegate::CanClose() callback from Views). If the +browser's host window/view has already been destroyed (via view hierarchy +tear-down, for example) then DoClose() will not be called for that browser +since is no longer possible to cancel the close. + +When windowed rendering is disabled returning false from DoClose() will +cause the browser object to be destroyed immediately. + +If the browser's top-level owner window requires a non-standard close +notification then send that notification from DoClose() and return true. + +The CefLifeSpanHandler::OnBeforeClose() method will be called after +DoClose() (if DoClose() is called) and immediately before the browser +object is destroyed. The application should only exit after +OnBeforeClose() has been called for all existing browsers. + +The below examples describe what should happen during window close when +the browser is parented to an application-provided top-level window. + +Example 1: Using CefBrowserHost::TryCloseBrowser(). This is recommended +for clients using standard close handling and windows created on the +browser process UI thread. +1. User clicks the window close button which sends a close notification + to the application's top-level window. +2. Application's top-level window receives the close notification and + calls TryCloseBrowser() (which internally calls CloseBrowser(false)). + TryCloseBrowser() returns false so the client cancels the window + close. +3. JavaScript 'onbeforeunload' handler executes and shows the close + confirmation dialog (which can be overridden via + CefJSDialogHandler::OnBeforeUnloadDialog()). +4. User approves the close. +5. JavaScript 'onunload' handler executes. +6. CEF sends a close notification to the application's top-level window + (because DoClose() returned false by default). +7. Application's top-level window receives the close notification and + calls TryCloseBrowser(). TryCloseBrowser() returns true so the client + allows the window close. +8. Application's top-level window is destroyed. +9. Application's OnBeforeClose() handler is called and the browser object + is destroyed. +10. Application exits by calling CefQuitMessageLoop() if no other browsers + exist. + +Example 2: Using CefBrowserHost::CloseBrowser(false) and implementing the +DoClose() callback. This is recommended for clients using non-standard +close handling or windows that were not created on the browser process UI +thread. +1. User clicks the window close button which sends a close notification + to the application's top-level window. +2. Application's top-level window receives the close notification and: + A. Calls CefBrowserHost::CloseBrowser(false). + B. Cancels the window close. +3. JavaScript 'onbeforeunload' handler executes and shows the close + confirmation dialog (which can be overridden via + CefJSDialogHandler::OnBeforeUnloadDialog()). +4. User approves the close. +5. JavaScript 'onunload' handler executes. +6. Application's DoClose() handler is called. Application will: + A. Set a flag to indicate that the next close attempt will be allowed. + B. Return false. +7. CEF sends an close notification to the application's top-level window. +8. Application's top-level window receives the close notification and + allows the window to close based on the flag from #6B. +9. Application's top-level window is destroyed. +10. Application's OnBeforeClose() handler is called and the browser object + is destroyed. +11. Application exits by calling CefQuitMessageLoop() if no other browsers + exist. + + + + +Called after a new browser is created. It is now safe to begin performing +actions with |browser|. CefFrameHandler callbacks related to initial main +frame creation will arrive before this callback. See CefFrameHandler +documentation for additional usage information. + + + + +Called on the UI thread before a new popup browser is created. The +|browser| and |frame| values represent the source of the popup request. +The |target_url| and |target_frame_name| values indicate where the popup +browser should navigate and may be empty if not specified with the +request. The |target_disposition| value indicates where the user intended +to open the popup (e.g. current tab, new tab, etc). The |user_gesture| +value will be true if the popup was opened via explicit user gesture (e.g. +clicking a link) or false if the popup opened automatically (e.g. via the +DomContentLoaded event). The |popupFeatures| structure contains additional +information about the requested popup window. To allow creation of the +popup browser optionally modify |windowInfo|, |client|, |settings| and +|no_javascript_access| and return false. To cancel creation of the popup +browser return true. The |client| and |settings| values will default to +the source browser's values. If the |no_javascript_access| value is set to +false the new browser will not be scriptable and may not be hosted in the +same renderer process as the source browser. Any modifications to +|windowInfo| will be ignored if the parent browser is wrapped in a +CefBrowserView. Popup browser creation will be canceled if the parent +browser is destroyed before the popup browser creation completes +(indicated by a call to OnAfterCreated for the popup browser). The +|extra_info| parameter provides an opportunity to specify extra +information specific to the created popup browser that will be passed to +CefRenderProcessHandler::OnBrowserCreated() in the render process. + + + + +Implement this interface to handle events related to browser life span. The +methods of this class will be called on the UI thread unless otherwise +indicated. + + + + +Called after the renderer and JavaScript in the page has had a chance to +handle the event. |event| contains information about the keyboard event. +|os_event| is the operating system event message, if any. Return true if +the keyboard event was handled or false otherwise. + + + + +Called before a keyboard event is sent to the renderer. |event| contains +information about the keyboard event. |os_event| is the operating system +event message, if any. Return true if the event was handled or false +otherwise. If the event will be handled in OnKeyEvent() as a keyboard +shortcut set |is_keyboard_shortcut| to true and return false. + + + + +Implement this interface to handle events related to keyboard input. The +methods of this class will be called on the UI thread. + + + + +Called when the dialog is closed. + + + + +Called to cancel any pending dialogs and reset any saved dialog state. +Will be called due to events like page navigation irregardless of whether +any dialogs are currently pending. + + + + +Called to run a dialog asking the user if they want to leave a page. +Return false to use the default dialog implementation. Return true if the +application will use a custom dialog or if the callback has been executed +immediately. Custom dialogs may be either modal or modeless. If a custom +dialog is used the application must execute |callback| once the custom +dialog is dismissed. + + + + +Called to run a JavaScript dialog. If |origin_url| is non-empty it can be +passed to the CefFormatUrlForSecurityDisplay function to retrieve a secure +and user-friendly display string. The |default_prompt_text| value will be +specified for prompt dialogs only. Set |suppress_message| to true and +return false to suppress the message (suppressing messages is preferable +to immediately executing the callback as this is used to detect presumably +malicious behavior like spamming alert messages in onbeforeunload). Set +|suppress_message| to false and return false to use the default +implementation (the default implementation will show one modal dialog at a +time and suppress any additional dialog requests until the displayed +dialog is dismissed). Return true if the application will use a custom +dialog or if the callback has been executed immediately. Custom dialogs +may be either modal or modeless. If a custom dialog is used the +application must execute |callback| once the custom dialog is dismissed. + + + + +Implement this interface to handle events related to JavaScript dialogs. The +methods of this class will be called on the UI thread. + + + + +Continue the JS dialog request. Set |success| to true if the OK button was +pressed. The |user_input| value should be specified for prompt dialogs. + + + + +Callback interface used for asynchronous continuation of JavaScript dialog +requests. + + + + +Called when the main frame changes due to (a) initial browser creation, +(b) final browser destruction, (c) cross-origin navigation or (d) +re-navigation after renderer process termination (due to crashes, etc). +|old_frame| will be NULL and |new_frame| will be non-NULL when a main +frame is assigned to |browser| for the first time. |old_frame| will be +non-NULL and |new_frame| will be NULL and when a main frame is removed +from |browser| for the last time. Both |old_frame| and |new_frame| will be +non-NULL for cross-origin navigations or re-navigation after renderer +process termination. This method will be called after OnFrameCreated() for +|new_frame| and/or after OnFrameDetached() for |old_frame|. If called +after CefLifeSpanHandler::OnBeforeClose() during browser destruction then +CefBrowser::IsValid() will return false for |browser|. + + + + +Called when a frame loses its connection to the renderer process and will +be destroyed. Any pending or future commands will be discarded and +CefFrame::IsValid() will now return false for |frame|. If called after +CefLifeSpanHandler::OnBeforeClose() during browser destruction then +CefBrowser::IsValid() will return false for |browser|. + + + + +Called when a frame can begin routing commands to/from the associated +renderer process. |reattached| will be true if the frame was re-attached +after exiting the BackForwardCache. Any commands that were queued have now +been dispatched. + + + + +Called when a new frame is created. This will be the first notification +that references |frame|. Any commands that require transport to the +associated renderer process (LoadRequest, SendProcessMessage, GetSource, +etc.) will be queued until OnFrameAttached is called for |frame|. + + + + +Implement this interface to handle events related to CefFrame life span. The +order of callbacks is: + +(1) During initial CefBrowserHost creation and navigation of the main frame: +- CefFrameHandler::OnFrameCreated => The initial main frame object has been + created. Any commands will be queued until the frame is attached. +- CefFrameHandler::OnMainFrameChanged => The initial main frame object has + been assigned to the browser. +- CefLifeSpanHandler::OnAfterCreated => The browser is now valid and can be + used. +- CefFrameHandler::OnFrameAttached => The initial main frame object is now + connected to its peer in the renderer process. Commands can be routed. + +(2) During further CefBrowserHost navigation/loading of the main frame + and/or sub-frames: +- CefFrameHandler::OnFrameCreated => A new main frame or sub-frame object + has been created. Any commands will be queued until the frame is attached. +- CefFrameHandler::OnFrameAttached => A new main frame or sub-frame object + is now connected to its peer in the renderer process. Commands can be + routed. +- CefFrameHandler::OnFrameDetached => An existing main frame or sub-frame + object has lost its connection to the renderer process. If multiple + objects are detached at the same time then notifications will be sent for + any sub-frame objects before the main frame object. Commands can no longer + be routed and will be discarded. +- CefFrameHandler::OnMainFrameChanged => A new main frame object has been + assigned to the browser. This will only occur with cross-origin navigation + or re-navigation after renderer process termination (due to crashes, etc). + +(3) During final CefBrowserHost destruction of the main frame: +- CefFrameHandler::OnFrameDetached => Any sub-frame objects have lost their + connection to the renderer process. Commands can no longer be routed and + will be discarded. +- CefLifeSpanHandler::OnBeforeClose => The browser has been destroyed. +- CefFrameHandler::OnFrameDetached => The main frame object have lost its + connection to the renderer process. Notifications will be sent for any + sub-frame objects before the main frame object. Commands can no longer be + routed and will be discarded. +- CefFrameHandler::OnMainFrameChanged => The final main frame object has + been removed from the browser. + +Cross-origin navigation and/or loading receives special handling. + +When the main frame navigates to a different origin the OnMainFrameChanged +callback (2) will be executed with the old and new main frame objects. + +When a new sub-frame is loaded in, or an existing sub-frame is navigated to, +a different origin from the parent frame, a temporary sub-frame object will +first be created in the parent's renderer process. That temporary sub-frame +will then be discarded after the real cross-origin sub-frame is created in +the new/target renderer process. The client will receive cross-origin +navigation callbacks (2) for the transition from the temporary sub-frame to +the real sub-frame. The temporary sub-frame will not recieve or execute +commands during this transitional period (any sent commands will be +discarded). + +When a new popup browser is created in a different origin from the parent +browser, a temporary main frame object for the popup will first be created +in the parent's renderer process. That temporary main frame will then be +discarded after the real cross-origin main frame is created in the +new/target renderer process. The client will recieve creation and initial +navigation callbacks (1) for the temporary main frame, followed by +cross-origin navigation callbacks (2) for the transition from the temporary +main frame to the real main frame. The temporary main frame may receive and +execute commands during this transitional period (any sent commands may be +executed, but the behavior is potentially undesirable since they execute in +the parent browser's renderer process and not the new/target renderer +process). + +Callbacks will not be executed for placeholders that may be created during +pre-commit navigation for sub-frames that do not yet exist in the renderer +process. Placeholders will have CefFrame::GetIdentifier() == -4. + +The methods of this class will be called on the UI thread unless otherwise +indicated. + + + + +Called when the browser component has received focus. + + + + +Called when the browser component is requesting focus. |source| indicates +where the focus request is originating from. Return false to allow the +focus to be set or true to cancel setting the focus. + + + + +Called when the browser component is about to loose focus. For instance, +if focus was on the last HTML element and the user pressed the TAB key. +|next| will be true if the browser is giving focus to the next component +and false if the browser is giving focus to the previous component. + + + + +Implement this interface to handle events related to focus. The methods of +this class will be called on the UI thread. + + + + +Called to report find results returned by CefBrowserHost::Find(). +|identifer| is a unique incremental identifier for the currently active +search, |count| is the number of matches currently identified, +|selectionRect| is the location of where the match was found (in window +coordinates), |activeMatchOrdinal| is the current position in the search +results, and |finalUpdate| is true if this is the last find notification. + + + + +Implement this interface to handle events related to find results. The +methods of this class will be called on the UI thread. + + + + +Called whenever draggable regions for the browser window change. These can +be specified using the '-webkit-app-region: drag/no-drag' CSS-property. If +draggable regions are never defined in a document this method will also +never be called. If the last draggable region is removed from a document +this method will be called with an empty vector. + + + + +Called when an external drag event enters the browser window. |dragData| +contains the drag event data and |mask| represents the type of drag +operation. Return false for default drag handling behavior or true to +cancel the drag event. + + + + +Implement this interface to handle events related to dragging. The methods +of this class will be called on the UI thread. + + + + +Called when the browser's access to an audio and/or video source has +changed. + + + + +Called when the browser's cursor has changed. If |type| is CT_CUSTOM then +|custom_cursor_info| will be populated with the custom cursor information. +Return true if the cursor change was handled or false for default +handling. + + + + +Called when the overall page loading progress has changed. |progress| +ranges from 0.0 to 1.0. + + + + +Called when auto-resize is enabled via +CefBrowserHost::SetAutoResizeEnabled and the contents have auto-resized. +|new_size| will be the desired size in view coordinates. Return true if +the resize was handled or false for default handling. + + + + +Called to display a console message. Return true to stop the message from +being output to the console. + + + + +Called when the browser receives a status message. |value| contains the +text that will be displayed in the status message. + + + + +Called when the browser is about to display a tooltip. |text| contains the +text that will be displayed in the tooltip. To handle the display of the +tooltip yourself return true. Otherwise, you can optionally modify |text| +and then return false to allow the browser to display the tooltip. +When window rendering is disabled the application is responsible for +drawing tooltips and the return value is ignored. + + + + +Called when web content in the page has toggled fullscreen mode. If +|fullscreen| is true the content will automatically be sized to fill the +browser content area. If |fullscreen| is false the content will +automatically return to its original size and position. The client is +responsible for resizing the browser if desired. + + + + +Called when the page icon changes. + + + + +Called when the page title changes. + + + + +Called when a frame's address has changed. + + + + +Implement this interface to handle events related to browser display state. +The methods of this class will be called on the UI thread. + + + + +Called to run a file chooser dialog. |mode| represents the type of dialog +to display. |title| to the title to be used for the dialog and may be +empty to show the default title ("Open" or "Save" depending on the mode). +|default_file_path| is the path with optional directory and/or file name +component that should be initially selected in the dialog. +|accept_filters| are used to restrict the selectable file types and may +any combination of (a) valid lower-cased MIME types (e.g. "text/*" or +"image/*"), (b) individual file extensions (e.g. ".txt" or ".png"), or (c) +combined description and file extension delimited using "|" and ";" (e.g. +"Image Types|.png;.gif;.jpg"). To display a custom dialog return true and +execute |callback| either inline or at a later time. To display the +default dialog return false. + + + + +Implement this interface to handle dialog events. The methods of this class +will be called on the browser process UI thread. + + + + +Cancel the file selection. + + + + +Continue the file selection. |file_paths| should be a single value or a +list of values depending on the dialog mode. An empty |file_paths| value +is treated the same as calling Cancel(). + + + + +Callback interface for asynchronous continuation of file dialog requests. + + + + +Returns true if the context menu contains items specified by the renderer +process. + + + +Returns true if the context menu contains items specified by the renderer +process. + + + + +Returns flags representing the actions supported by the editable node, if +any, that the context menu was invoked on. + + + +Returns flags representing the actions supported by the editable node, if +any, that the context menu was invoked on. + + + + +Returns true if the context menu was invoked on an editable node where +spell-check is enabled. + + + +Returns true if the context menu was invoked on an editable node where +spell-check is enabled. + + + + +Returns true if the context menu was invoked on an editable node. + + + +Returns true if the context menu was invoked on an editable node. + + + + +Returns true if suggestions exist, false otherwise. Fills in |suggestions| +from the spell check service for the misspelled word if there is one. + + + +Returns true if suggestions exist, false otherwise. Fills in |suggestions| +from the spell check service for the misspelled word if there is one. + + + + +Returns the text of the misspelled word, if any, that the context menu was +invoked on. + + + +Returns the text of the misspelled word, if any, that the context menu was +invoked on. + + + + +Returns the text of the selection, if any, that the context menu was +invoked on. + + + +Returns the text of the selection, if any, that the context menu was +invoked on. + + + + +Returns flags representing the actions supported by the media element, if +any, that the context menu was invoked on. + + + +Returns flags representing the actions supported by the media element, if +any, that the context menu was invoked on. + + + + +Returns the type of context node that the context menu was invoked on. + + + +Returns the type of context node that the context menu was invoked on. + + + + +Returns the character encoding of the subframe that the context menu was +invoked on. + + + +Returns the character encoding of the subframe that the context menu was +invoked on. + + + + +Returns the URL of the subframe that the context menu was invoked on. + + + +Returns the URL of the subframe that the context menu was invoked on. + + + + +Returns the URL of the top level page that the context menu was invoked +on. + + + +Returns the URL of the top level page that the context menu was invoked +on. + + + + +Returns the title text or the alt text if the context menu was invoked on +an image. + + + +Returns the title text or the alt text if the context menu was invoked on +an image. + + + + +Returns true if the context menu was invoked on an image which has +non-empty contents. + + + +Returns true if the context menu was invoked on an image which has +non-empty contents. + + + + +Returns the source URL, if any, for the element that the context menu was +invoked on. Example of elements with source URLs are img, audio, and +video. + + + +Returns the source URL, if any, for the element that the context menu was +invoked on. Example of elements with source URLs are img, audio, and +video. + + + + +Returns the link URL, if any, to be used ONLY for "copy link address". We +don't validate this field in the frontend process. + + + +Returns the link URL, if any, to be used ONLY for "copy link address". We +don't validate this field in the frontend process. + + + + +Returns the URL of the link, if any, that encloses the node that the +context menu was invoked on. + + + +Returns the URL of the link, if any, that encloses the node that the +context menu was invoked on. + + + + +Returns flags representing the type of node that the context menu was +invoked on. + + + +Returns flags representing the type of node that the context menu was +invoked on. + + + + +Returns the Y coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + +Returns the Y coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + + +Returns the X coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + +Returns the X coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + + +Provides information about the context menu state. The methods of this class +can only be accessed on browser process the UI thread. + + + +Provides information about the context menu state. The methods of this class +can only be accessed on browser process the UI thread. + + + + +Called when the quick menu for a windowless browser is dismissed +irregardless of whether the menu was canceled or a command was selected. + + + +Called when the quick menu for a windowless browser is dismissed +irregardless of whether the menu was canceled or a command was selected. + + + + +Called to execute a command selected from the quick menu for a windowless +browser. Return true if the command was handled or false for the default +implementation. See cef_menu_id_t for command IDs that have default +implementations. + + + +Called to execute a command selected from the quick menu for a windowless +browser. Return true if the command was handled or false for the default +implementation. See cef_menu_id_t for command IDs that have default +implementations. + + + + +Called to allow custom display of the quick menu for a windowless browser. +|location| is the top left corner of the selected region. |size| is the +size of the selected region. |edit_state_flags| is a combination of flags +that represent the state of the quick menu. Return true if the menu will +be handled and execute |callback| either synchronously or asynchronously +with the selected command ID. Return false to cancel the menu. + + + +Called to allow custom display of the quick menu for a windowless browser. +|location| is the top left corner of the selected region. |size| is the +size of the selected region. |edit_state_flags| is a combination of flags +that represent the state of the quick menu. Return true if the menu will +be handled and execute |callback| either synchronously or asynchronously +with the selected command ID. Return false to cancel the menu. + + + + +Called when the context menu is dismissed irregardless of whether the menu +was canceled or a command was selected. + + + +Called when the context menu is dismissed irregardless of whether the menu +was canceled or a command was selected. + + + + +Called to execute a command selected from the context menu. Return true if +the command was handled or false for the default implementation. See +cef_menu_id_t for the command ids that have default implementations. All +user-defined command ids should be between MENU_ID_USER_FIRST and +MENU_ID_USER_LAST. |params| will have the same values as what was passed +to OnBeforeContextMenu(). Do not keep a reference to |params| outside of +this callback. + + + +Called to execute a command selected from the context menu. Return true if +the command was handled or false for the default implementation. See +cef_menu_id_t for the command ids that have default implementations. All +user-defined command ids should be between MENU_ID_USER_FIRST and +MENU_ID_USER_LAST. |params| will have the same values as what was passed +to OnBeforeContextMenu(). Do not keep a reference to |params| outside of +this callback. + + + + +Called to allow custom display of the context menu. |params| provides +information about the context menu state. |model| contains the context +menu model resulting from OnBeforeContextMenu. For custom display return +true and execute |callback| either synchronously or asynchronously with +the selected command ID. For default display return false. Do not keep +references to |params| or |model| outside of this callback. + + + +Called to allow custom display of the context menu. |params| provides +information about the context menu state. |model| contains the context +menu model resulting from OnBeforeContextMenu. For custom display return +true and execute |callback| either synchronously or asynchronously with +the selected command ID. For default display return false. Do not keep +references to |params| or |model| outside of this callback. + + + + +Called before a context menu is displayed. |params| provides information +about the context menu state. |model| initially contains the default +context menu. The |model| can be cleared to show no context menu or +modified to show a custom menu. Do not keep references to |params| or +|model| outside of this callback. + + + +Called before a context menu is displayed. |params| provides information +about the context menu state. |model| initially contains the default +context menu. The |model| can be cleared to show no context menu or +modified to show a custom menu. Do not keep references to |params| or +|model| outside of this callback. + + + + +Implement this interface to handle context menu events. The methods of this +class will be called on the UI thread. + + + +Implement this interface to handle context menu events. The methods of this +class will be called on the UI thread. + + + + +Cancel quick menu display. + + + +Cancel quick menu display. + + + + +Complete quick menu display by selecting the specified |command_id| and +|event_flags|. + + + +Complete quick menu display by selecting the specified |command_id| and +|event_flags|. + + + + +Callback interface used for continuation of custom quick menu display. + + + +Callback interface used for continuation of custom quick menu display. + + + + +Cancel context menu display. + + + +Cancel context menu display. + + + + +Complete context menu display by selecting the specified |command_id| and +|event_flags|. + + + +Complete context menu display by selecting the specified |command_id| and +|event_flags|. + + + + +Callback interface used for continuation of custom context menu display. + + + +Callback interface used for continuation of custom context menu display. + + + + +Returns in |color| the color that was explicitly set for |command_id| and +|color_type|. Specify an |index| value of -1 to return the default color +in |color|. If a color was not set then 0 will be returned in |color|. +Returns true on success. + + + + +Returns in |color| the color that was explicitly set for |command_id| and +|color_type|. If a color was not set then 0 will be returned in |color|. +Returns true on success. + + + + +Set the explicit color for |command_id| and |index| to |color|. Specify a +|color| value of 0 to remove the explicit color. Specify an |index| value +of -1 to set the default color for items that do not have an explicit +color set. If no explicit color or default color is set for |color_type| +then the system color will be used. Returns true on success. + + + + +Set the explicit color for |command_id| and |color_type| to |color|. +Specify a |color| value of 0 to remove the explicit color. If no explicit +color or default color is set for |color_type| then the system color will +be used. Returns true on success. + + + + +Retrieves the keyboard accelerator for the specified |index|. Returns true +on success. + + + + +Retrieves the keyboard accelerator for the specified |command_id|. Returns +true on success. + + + + +Remove the keyboard accelerator at the specified |index|. Returns true on +success. + + + + +Remove the keyboard accelerator for the specified |command_id|. Returns +true on success. + + + + +Set the keyboard accelerator at the specified |index|. |key_code| can be +any virtual key or character value. Returns true on success. + + + + +Set the keyboard accelerator for the specified |command_id|. |key_code| +can be any virtual key or character value. Returns true on success. + + + + +Returns true if the specified |index| has a keyboard accelerator assigned. + + + + +Returns true if the specified |command_id| has a keyboard accelerator +assigned. + + + + +Check the specified |index|. Only applies to check and radio items. +Returns true on success. + + + + +Check the specified |command_id|. Only applies to check and radio items. +Returns true on success. + + + + +Returns true if the specified |index| is checked. Only applies to check +and radio items. + + + + +Returns true if the specified |command_id| is checked. Only applies to +check and radio items. + + + + +Change the enabled status at the specified |index|. Returns true on +success. + + + + +Change the enabled status of the specified |command_id|. Returns true on +success. + + + + +Returns true if the specified |index| is enabled. + + + + +Returns true if the specified |command_id| is enabled. + + + + +Change the visibility at the specified |index|. Returns true on success. + + + + +Change the visibility of the specified |command_id|. Returns true on +success. + + + + +Returns true if the specified |index| is visible. + + + + +Returns true if the specified |command_id| is visible. + + + + +Returns the submenu at the specified |index| or empty if invalid. + + + + +Returns the submenu for the specified |command_id| or empty if invalid. + + + + +Sets the group id at the specified |index|. Returns true on success. + + + + +Sets the group id for the specified |command_id|. Returns true on success. + + + + +Returns the group id at the specified |index| or -1 if invalid. + + + + +Returns the group id for the specified |command_id| or -1 if invalid. + + + + +Returns the item type at the specified |index|. + + + + +Returns the item type for the specified |command_id|. + + + + +Set the label at the specified |index|. Returns true on success. + + + + +Sets the label for the specified |command_id|. Returns true on success. + + + + +Returns the label at the specified |index| or empty if not found due to +invalid range or the index being a separator. + + + + +Returns the label for the specified |command_id| or empty if not found. + + + + +Sets the command id at the specified |index|. Returns true on success. + + + + +Returns the command id at the specified |index| or -1 if not found due to +invalid range or the index being a separator. + + + + +Returns the index associated with the specified |command_id| or -1 if not +found due to the command id not existing in the menu. + + + + +Removes the item at the specified |index|. Returns true on success. + + + + +Removes the item with the specified |command_id|. Returns true on success. + + + + +Insert a sub-menu in the menu at the specified |index|. The new sub-menu +is returned. + + + + +Insert a radio item in the menu at the specified |index|. Only a single +item with the specified |group_id| can be checked at a time. Returns true +on success. + + + + +Insert a check item in the menu at the specified |index|. Returns true on +success. + + + + +Insert an item in the menu at the specified |index|. Returns true on +success. + + + + +Insert a separator in the menu at the specified |index|. Returns true on +success. + + + + +Add a sub-menu to the menu. The new sub-menu is returned. + + + + +Add a radio item to the menu. Only a single item with the specified +|group_id| can be checked at a time. Returns true on success. + + + + +Add a check item to the menu. Returns true on success. + + + + +Add an item to the menu. Returns true on success. + + + + +Add a separator to the menu. Returns true on success. + + + + +Returns the number of items in this menu. + + + + +Clears the menu. Returns true on success. + + + + +Returns true if this menu is a submenu. + + + + +Create a new MenuModel with the specified |delegate|. + + + + +Supports creation and modification of menus. See cef_menu_id_t for the +command ids that have default implementations. All user-defined command ids +should be between MENU_ID_USER_FIRST and MENU_ID_USER_LAST. The methods of +this class can only be accessed on the browser process the UI thread. + + + + +Optionally modify a menu item label. Return true if |label| was modified. + + + + +The menu has closed. + + + + +The menu is about to show. + + + + +Called on unhandled close submenu keyboard commands. |is_rtl| will be true +if the menu is displaying a right-to-left language. + + + + +Called on unhandled open submenu keyboard commands. |is_rtl| will be true +if the menu is displaying a right-to-left language. + + + + +Called when the user moves the mouse outside the menu and over the owning +window. + + + + +Perform the action associated with the specified |command_id| and +optional |event_flags|. + + + + +Implement this interface to handle menu model events. The methods of this +class will be called on the browser process UI thread unless otherwise +indicated. + + + + +Called during browser creation to check if a Chrome toolbar button +should be visible. Only called for buttons that would be visible by +default. Only used with the Chrome runtime. + + + + +Called during browser creation to check if a Chrome page action icon +should be visible. Only called for icons that would be visible by default. +Only used with the Chrome runtime. + + + + +Called to check if a Chrome app menu item should be enabled. Values for +|command_id| can be found in the cef_command_ids.h file. Only called for +menu items that would be enabled by default. Only used with the Chrome +runtime. + + + + +Called to check if a Chrome app menu item should be visible. Values for +|command_id| can be found in the cef_command_ids.h file. Only called for +menu items that would be visible by default. Only used with the Chrome +runtime. + + + + +Called to execute a Chrome command triggered via menu selection or +keyboard shortcut. Values for |command_id| can be found in the +cef_command_ids.h file. |disposition| provides information about the +intended command target. Return true if the command was handled or false +for the default implementation. For context menu commands this will be +called after CefContextMenuHandler::OnContextMenuCommand. Only used with +the Chrome runtime. + + + + +Implement this interface to handle events related to commands. The methods +of this class will be called on the UI thread. + + + + +Called on the UI or audio stream thread when an error occurred. During the +stream creation phase this callback will be called on the UI thread while +in the capturing phase it will be called on the audio stream thread. The +stream will be stopped immediately. + + + + +Called on the UI thread when the stream has stopped. OnAudioSteamStopped +will always be called after OnAudioStreamStarted; both methods may be +called multiple times for the same stream. + + + + +Called on the audio stream thread when a PCM packet is received for the +stream. |data| is an array representing the raw PCM data as a floating +point type, i.e. 4-byte value(s). |frames| is the number of frames in the +PCM packet. |pts| is the presentation timestamp (in milliseconds since the +Unix Epoch) and represents the time at which the decompressed packet +should be presented to the user. Based on |frames| and the +|channel_layout| value passed to OnAudioStreamStarted you can calculate +the size of the |data| array in bytes. + + + + +Called on a browser audio capture thread when the browser starts +streaming audio. OnAudioStreamStopped will always be called after +OnAudioStreamStarted; both methods may be called multiple times +for the same browser. |params| contains the audio parameters like +sample rate and channel layout. |channels| is the number of channels. + + + + +Called on the UI thread to allow configuration of audio stream parameters. +Return true to proceed with audio stream capture, or false to cancel it. +All members of |params| can optionally be configured here, but they are +also pre-filled with some sensible defaults. + + + + +Implement this interface to handle audio events. + + + +ref + + + +Interface that should be implemented by the CefUrlRequest client. +The methods of this class will be called on the same thread that created +the request unless otherwise documented. + + + +Called on the IO thread when the browser needs credentials from the user. +|isProxy| indicates whether the host is a proxy server. |host| contains +the hostname and |port| contains the port number. Return true to continue +the request and call CefAuthCallback::Continue() when the authentication +information is available. If the request has an associated browser/frame +then returning false will result in a call to GetAuthCredentials on the +CefRequestHandler associated with that browser, if any. Otherwise, +returning false will cancel the request immediately. This method will only +be called for requests initiated from the browser process. + + + +Called on the IO thread when the browser needs credentials from the user. +|isProxy| indicates whether the host is a proxy server. |host| contains +the hostname and |port| contains the port number. Return true to continue +the request and call CefAuthCallback::Continue() when the authentication +information is available. If the request has an associated browser/frame +then returning false will result in a call to GetAuthCredentials on the +CefRequestHandler associated with that browser, if any. Otherwise, +returning false will cancel the request immediately. This method will only +be called for requests initiated from the browser process. + + + + +Called when some part of the response is read. |data| contains the current +bytes received since the last call. This method will not be called if the +UR_FLAG_NO_DOWNLOAD_DATA flag is set on the request. + + + +Called when some part of the response is read. |data| contains the current +bytes received since the last call. This method will not be called if the +UR_FLAG_NO_DOWNLOAD_DATA flag is set on the request. + + + + +Notifies the client of download progress. |current| denotes the number of +bytes received up to the call and |total| is the expected total size of +the response (or -1 if not determined). + + + +Notifies the client of download progress. |current| denotes the number of +bytes received up to the call and |total| is the expected total size of +the response (or -1 if not determined). + + + + +Notifies the client of upload progress. |current| denotes the number of +bytes sent so far and |total| is the total size of uploading data (or -1 +if chunked upload is enabled). This method will only be called if the +UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + + +Notifies the client of upload progress. |current| denotes the number of +bytes sent so far and |total| is the total size of uploading data (or -1 +if chunked upload is enabled). This method will only be called if the +UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + + + +Notifies the client that the request has completed. Use the +CefURLRequest::GetRequestStatus method to determine if the request was +successful or not. + + + +Notifies the client that the request has completed. Use the +CefURLRequest::GetRequestStatus method to determine if the request was +successful or not. + + + + +Interface that should be implemented by the CefURLRequest client. The +methods of this class will be called on the same thread that created the +request unless otherwise documented. + + + +Interface that should be implemented by the CefURLRequest client. The +methods of this class will be called on the same thread that created the +request unless otherwise documented. + + + + +Cancel the request. + + + +Cancel the request. + + + + +Returns true if the response body was served from the cache. This includes +responses for which revalidation was required. + + + +Returns true if the response body was served from the cache. This includes +responses for which revalidation was required. + + + + +Returns the response, or NULL if no response information is available. +Response information will only be available after the upload has +completed. The returned object is read-only and should not be modified. + + + +Returns the response, or NULL if no response information is available. +Response information will only be available after the upload has +completed. The returned object is read-only and should not be modified. + + + + +Returns the request error if status is UR_CANCELED or UR_FAILED, or 0 +otherwise. + + + +Returns the request error if status is UR_CANCELED or UR_FAILED, or 0 +otherwise. + + + + +Returns the request status. + + + +Returns the request status. + + + + +Returns the client. + + + +Returns the client. + + + + +Returns the request object used to create this URL request. The returned +object is read-only and should not be modified. + + + +Returns the request object used to create this URL request. The returned +object is read-only and should not be modified. + + + + +Create a new URL request that is not associated with a specific browser or +frame. Use CefFrame::CreateURLRequest instead if you want the request to +have this association, in which case it may be handled differently (see +documentation on that method). A request created with this method may only +originate from the browser process, and will behave as follows: + - It may be intercepted by the client via CefResourceRequestHandler or + CefSchemeHandlerFactory. + - POST data may only contain only a single element of type PDE_TYPE_FILE + or PDE_TYPE_BYTES. + - If |request_context| is empty the global request context will be used. + +The |request| object will be marked as read-only after calling this +method. + + + +Create a new URL request that is not associated with a specific browser or +frame. Use CefFrame::CreateURLRequest instead if you want the request to +have this association, in which case it may be handled differently (see +documentation on that method). A request created with this method may only +originate from the browser process, and will behave as follows: + - It may be intercepted by the client via CefResourceRequestHandler or + CefSchemeHandlerFactory. + - POST data may only contain only a single element of type PDE_TYPE_FILE + or PDE_TYPE_BYTES. + - If |request_context| is empty the global request context will be used. + +The |request| object will be marked as read-only after calling this +method. + + + + +Class used to make a URL request. URL requests are not associated with a +browser instance so no CefClient callbacks will be executed. URL requests +can be created on any valid CEF thread in either the browser or render +process. Once created the methods of the URL request object must be accessed +on the same thread that created it. + + + +Class used to make a URL request. URL requests are not associated with a +browser instance so no CefClient callbacks will be executed. URL requests +can be created on any valid CEF thread in either the browser or render +process. Once created the methods of the URL request object must be accessed +on the same thread that created it. + + + + +Cancel the authentication request. + + + +Cancel the authentication request. + + + + +Continue the authentication request. + + + +Continue the authentication request. + + + + +Callback interface used for asynchronous continuation of authentication +requests. + + + +Callback interface used for asynchronous continuation of authentication +requests. + + + + +Called when a download's status or progress information has been updated. +This may be called multiple times before and after OnBeforeDownload(). +Execute |callback| either asynchronously or in this method to cancel the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + +Called when a download's status or progress information has been updated. +This may be called multiple times before and after OnBeforeDownload(). +Execute |callback| either asynchronously or in this method to cancel the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + + +Called before a download begins. |suggested_name| is the suggested name +for the download file. By default the download will be canceled. Execute +|callback| either asynchronously or in this method to continue the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + +Called before a download begins. |suggested_name| is the suggested name +for the download file. By default the download will be canceled. Execute +|callback| either asynchronously or in this method to continue the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + + +Called before a download begins in response to a user-initiated action +(e.g. alt + link click or link click that returns a `Content-Disposition: +attachment` response from the server). |url| is the target download URL +and |request_method| is the target method (GET, POST, etc). Return true to +proceed with the download or false to cancel the download. + + + +Called before a download begins in response to a user-initiated action +(e.g. alt + link click or link click that returns a `Content-Disposition: +attachment` response from the server). |url| is the target download URL +and |request_method| is the target method (GET, POST, etc). Return true to +proceed with the download or false to cancel the download. + + + + +Class used to handle file downloads. The methods of this class will called +on the browser process UI thread. + + + +Class used to handle file downloads. The methods of this class will called +on the browser process UI thread. + + + + +Call to resume the download. + + + +Call to resume the download. + + + + +Call to pause the download. + + + +Call to pause the download. + + + + +Call to cancel the download. + + + +Call to cancel the download. + + + + +Callback interface used to asynchronously cancel a download. + + + +Callback interface used to asynchronously cancel a download. + + + + +Call to continue the download. Set |download_path| to the full file path +for the download including the file name or leave blank to use the +suggested name and the default temp directory. Set |show_dialog| to true +if you do wish to show the default "Save As" dialog. + + + +Call to continue the download. Set |download_path| to the full file path +for the download including the file name or leave blank to use the +suggested name and the default temp directory. Set |show_dialog| to true +if you do wish to show the default "Save As" dialog. + + + + +Callback interface used to asynchronously continue a download. + + + +Callback interface used to asynchronously continue a download. + + + + +True if dispose should be called after this object is used + + + + +Gets a value indicating if the browser settings has been disposed. + + + + +The maximum rate in frames per second (fps) that CefRenderHandler::OnPaint +will be called for a windowless browser. The actual fps may be lower if +the browser cannot generate frames at the requested rate. The minimum +value is 1 and the maximum value is 60 (default 30). This value can also be +changed dynamically via IBrowserHost.SetWindowlessFrameRate. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. May be overridden on a +per-browser basis using the CefBrowserSettings.AcceptLanguageList value. +If both values are empty then "en-US,en" will be used. Can be overridden +for individual RequestContext instances via the +RequestContextSettings.AcceptLanguageList value. + + + + +Background color used for the browser before a document is loaded and when no document color +is specified. The alpha component must be either fully opaque (0xFF) or fully transparent (0x00). +If the alpha component is fully opaque then the RGB components will be used as the background +color. If the alpha component is fully transparent for a WinForms browser then the +CefSettings.BackgroundColor value will be used. If the alpha component is fully transparent +for a windowless (WPF/OffScreen) browser then transparent painting will be enabled. + + + + +Controls whether WebGL can be used. Note that WebGL requires hardware +support and may not work on all systems even when enabled. Also +configurable using the "disable-webgl" command-line switch. + + + + +Controls whether databases can be used. Also configurable using the +"disable-databases" command-line switch. + + + + +Controls whether local storage can be used. Also configurable using the +"disable-local-storage" command-line switch. + + + + +Controls whether the tab key can advance focus to links. Also configurable +using the "disable-tab-to-links" command-line switch. + + + + +Controls whether text areas can be resized. Also configurable using the +"disable-text-area-resize" command-line switch. + + + + +Controls whether standalone images will be shrunk to fit the page. Also +configurable using the "image-shrink-standalone-to-fit" command-line +switch. + + + + +Controls whether image URLs will be loaded from the network. A cached image +will still be rendered if requested. Also configurable using the +"disable-image-loading" command-line switch. + + + + +Controls whether DOM pasting is supported in the editor via +execCommand("paste"). The |javascript_access_clipboard| setting must also +be enabled. Also configurable using the "disable-javascript-dom-paste" +command-line switch. + + + + +Controls whether JavaScript can access the clipboard. Also configurable +using the "disable-javascript-access-clipboard" command-line switch. + + + + +Controls whether JavaScript can be used to close windows that were not +opened via JavaScript. JavaScript can still be used to close windows that +were opened via JavaScript. Also configurable using the +"disable-javascript-close-windows" command-line switch. + + + + +Controls whether JavaScript can be executed. (Used to Enable/Disable javascript) +Also configurable using the "disable-javascript" command-line switch. + + + + +Controls the loading of fonts from remote sources. Also configurable using +the "disable-remote-fonts" command-line switch. + + + + +Default encoding for Web content. If empty "ISO-8859-1" will be used. Also +configurable using the "default-encoding" command-line switch. + + + + +MinimumLogicalFontSize + + + + +MinimumFontSize + + + + +DefaultFixedFontSize + + + + +DefaultFontSize + + + + +FantasyFontFamily + + + + +CursiveFontFamily + + + + +SansSerifFontFamily + + + + +SerifFontFamily + + + + +FixedFontFamily + + + + +StandardFontFamily + + + + +Destructor. + + + + +Finalizer. + + + + +Default Constructor + + + + +Internal Constructor + + + + +Browser initialization settings. Specify NULL or 0 to get the recommended +default values. The consequences of using custom values may not be well +tested. Many of these and other settings can also configured using command- +line switches. + + + + +Returns the mime type. + + + +Returns the mime type. + + + + +Returns the content disposition. + + + +Returns the content disposition. + + + + +Returns the suggested file name. + + + +Returns the suggested file name. + + + + +Returns the original URL before any redirections. + + + +Returns the original URL before any redirections. + + + + +Returns the URL. + + + +Returns the URL. + + + + +Returns the unique identifier for this download. + + + +Returns the unique identifier for this download. + + + + +Returns the full path to the downloaded or downloading file. + + + +Returns the full path to the downloaded or downloading file. + + + + +Returns the time that the download ended. + + + +Returns the time that the download ended. + + + + +Returns the time that the download started. + + + +Returns the time that the download started. + + + + +Returns the number of received bytes. + + + +Returns the number of received bytes. + + + + +Returns the total number of bytes. + + + +Returns the total number of bytes. + + + + +Returns the rough percent complete or -1 if the receive total size is +unknown. + + + +Returns the rough percent complete or -1 if the receive total size is +unknown. + + + + +Returns a simple speed estimate in bytes/s. + + + +Returns a simple speed estimate in bytes/s. + + + + +Returns true if the download has been canceled or interrupted. + + + +Returns true if the download has been canceled or interrupted. + + + + +Returns true if the download is complete. + + + +Returns true if the download is complete. + + + + +Returns true if the download is in progress. + + + +Returns true if the download is in progress. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Class used to represent a download item. + + + +Class used to represent a download item. + + + + +Load the request represented by the |request| object. + + + + +Create a new object with explicit response values. + + + + +Create a new object with default response values. + + + + +Implementation of the CefResourceHandler class for reading from a CefStream. + + + + +Return a new resource handler instance to handle the request or an empty +reference to allow default handling of the request. |browser| and |frame| +will be the browser window and frame respectively that originated the +request or NULL if the request did not originate from a browser window +(for example, if the request came from CefURLRequest). The |request| +object passed to this method cannot be modified. + + + +Return a new resource handler instance to handle the request or an empty +reference to allow default handling of the request. |browser| and |frame| +will be the browser window and frame respectively that originated the +request or NULL if the request did not originate from a browser window +(for example, if the request came from CefURLRequest). The |request| +object passed to this method cannot be modified. + + + + +Class that creates CefResourceHandler instances for handling scheme +requests. The methods of this class will always be called on the IO thread. + + + +Class that creates CefResourceHandler instances for handling scheme +requests. The methods of this class will always be called on the IO thread. + + + + +Register a custom scheme. This method should not be called for the +built-in HTTP, HTTPS, FILE, FTP, ABOUT and DATA schemes. + +See cef_scheme_options_t for possible values for |options|. + +This function may be called on any thread. It should only be called once +per unique |scheme_name| value. If |scheme_name| is already registered or +if an error occurs this method will return false. + + + +Register a custom scheme. This method should not be called for the +built-in HTTP, HTTPS, FILE, FTP, ABOUT and DATA schemes. + +See cef_scheme_options_t for possible values for |options|. + +This function may be called on any thread. It should only be called once +per unique |scheme_name| value. If |scheme_name| is already registered or +if an error occurs this method will return false. + + + + +Class that manages custom scheme registrations. + + + +Class that manages custom scheme registrations. + + + + +Clear all scheme handler factories registered with the global request +context. Returns false on error. This function may be called on any thread +in the browser process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->ClearSchemeHandlerFactories(). + + + +Clear all scheme handler factories registered with the global request +context. Returns false on error. This function may be called on any thread +in the browser process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->ClearSchemeHandlerFactories(). + + + + +Register a scheme handler factory with the global request context. An empty +|domain_name| value for a standard scheme will cause the factory to match +all domain names. The |domain_name| value will be ignored for non-standard +schemes. If |scheme_name| is a built-in scheme and no handler is returned by +|factory| then the built-in scheme handler factory will be called. If +|scheme_name| is a custom scheme then you must also implement the +CefApp::OnRegisterCustomSchemes() method in all processes. This function may +be called multiple times to change or remove the factory that matches the +specified |scheme_name| and optional |domain_name|. Returns false if an +error occurs. This function may be called on any thread in the browser +process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->RegisterSchemeHandlerFactory(). + + + +Register a scheme handler factory with the global request context. An empty +|domain_name| value for a standard scheme will cause the factory to match +all domain names. The |domain_name| value will be ignored for non-standard +schemes. If |scheme_name| is a built-in scheme and no handler is returned by +|factory| then the built-in scheme handler factory will be called. If +|scheme_name| is a custom scheme then you must also implement the +CefApp::OnRegisterCustomSchemes() method in all processes. This function may +be called multiple times to change or remove the factory that matches the +specified |scheme_name| and optional |domain_name|. Returns false if an +error occurs. This function may be called on any thread in the browser +process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->RegisterSchemeHandlerFactory(). + + + + + + + +Generates a JSON string from the specified root |node| which should be a +dictionary or list value. Returns an empty string on failure. This method +requires exclusive access to |node| including any underlying data. + + + + +Parses the specified |json_string| and returns a dictionary or list +representation. If JSON parsing fails this method returns NULL and populates +|error_msg_out| with a formatted error message. + + + + +Parses the specified UTF8-encoded |json| buffer of size |json_size| and +returns a dictionary or list representation. If JSON parsing fails this +method returns NULL. + + + + +Parses the specified |json_string| and returns a dictionary or list +representation. If JSON parsing fails this method returns NULL. + + + + +Unescapes |text| and returns the result. Unescaping consists of looking for +the exact pattern "%XX" where each X is a hex digit and converting to the +character with the numerical value of those digits (e.g. "i%20=%203%3b" +unescapes to "i = 3;"). If |convert_to_utf8| is true this function will +attempt to interpret the initial decoded result as UTF-8. If the result is +convertable into UTF-8 it will be returned as converted. Otherwise the +initial decoded result will be returned. The |unescape_rule| parameter +supports further customization the decoding process. + + + + +Escapes characters in |text| which are unsuitable for use as a query +parameter value. Everything except alphanumerics and -_.!~*'() will be +converted to "%XX". If |use_plus| is true spaces will change to "+". The +result is basically the same as encodeURIComponent in Javacript. + + + + +Decodes the base64 encoded string |data|. The returned value will be NULL if +the decoding fails. + + + + +Encodes |data| as a base64 string. + + + + +Get the extensions associated with the given mime type. This should be +passed in lower case. There could be multiple extensions for a given mime +type, like "html,htm" for "text/html", or "txt,text,html,..." for "text/*". +Any existing elements in the provided vector will not be erased. + + + + +Returns the mime type for the specified file extension or an empty string if +unknown. + + + + +This is a convenience function for formatting a URL in a concise and human- +friendly way to help users make security-related decisions (or in other +circumstances when people need to distinguish sites, origins, or otherwise- +simplified URLs from each other). Internationalized domain names (IDN) may +be presented in Unicode if the conversion is considered safe. The returned +value will (a) omit the path for standard schemes, excepting file and +filesystem, and (b) omit the port if it is the default for the scheme. Do +not use this for URLs which will be parsed or sent to other applications. + + + + +Creates a URL from the specified |parts|, which must contain a non-empty +spec or a non-empty host and path (at a minimum), but not both. +Returns false if |parts| isn't initialized as described. + + + + +Parse the specified |url| into its component parts. +Returns false if the URL is empty or invalid. + + + + +Combines specified |base_url| and |relative_url| into |resolved_url|. +Returns false if one of the URLs is empty or invalid. + + + + +Gets the inner most instance + + current instance + + + +Load an extension. If extension resources will be read from disk using the default load implementation then rootDirectoy +should be the absolute path to the extension resources directory and manifestJson should be null. +If extension resources will be provided by the client (e.g. via IRequestHandler and/or IExtensionHandler) then rootDirectory +should be a path component unique to the extension (if not absolute this will be internally prefixed with the PK_DIR_RESOURCES path) +and manifestJson should contain the contents that would otherwise be read from the "manifest.json" file on disk. +The loaded extension will be accessible in all contexts sharing the same storage (HasExtension returns true). +However, only the context on which this method was called is considered the loader (DidLoadExtension returns true) and only the +loader will receive IRequestContextHandler callbacks for the extension. will be +called on load success or will be called on load failure. +If the extension specifies a background script via the "background" manifest key then +will be called to create the background browser. See that method for additional information about background scripts. +For visible extension views the client application should evaluate the manifest to determine the correct extension URL to load and then pass +that URL to the IBrowserHost.CreateBrowser* function after the extension has loaded. For example, the client can look for the "browser_action" +manifest key as documented at https://developer.chrome.com/extensions/browserAction. Extension URLs take the form "chrome-extension:///". +Browsers that host extensions differ from normal browsers as follows: - Can access chrome.* JavaScript APIs if allowed by the manifest. +Visit chrome://extensions-support for the list of extension APIs currently supported by CEF. - Main frame navigation to non-extension +content is blocked. +- Pinch-zooming is disabled. +- returns the hosted extension. +- CefBrowserHost::IsBackgroundHost returns true for background hosts. See https://developer.chrome.com/extensions for extension implementation and usage documentation. + + If extension resources will be read from disk using the default load implementation then rootDirectoy +should be the absolute path to the extension resources directory and manifestJson should be null + If extension resources will be provided by the client then rootDirectory should be a path component unique to the extension +and manifestJson should contain the contents that would otherwise be read from the manifest.json file on disk + handle events related to browser extensions + + + +Returns true if this context has access to the extension identified by extensionId. +This may not be the context that was used to load the extension (see DidLoadExtension). +This method must be called on the CEF UI thread. + + extension id + Returns true if this context has access to the extension identified by extensionId + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Retrieve the list of all extensions that this context has access to (see HasExtension). + will be populated with the list of extension ID values. +This method must be called on the CEF UI thread. + + output a list of extensions Ids + returns true on success otherwise false + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns the extension matching extensionId or null if no matching extension is accessible in this context (see HasExtension). +This method must be called on the CEF UI thread. + + extension Id + Returns the extension matching extensionId or null if no matching extension is accessible in this context + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns true if this context was used to load the extension identified by extensionId. Other contexts sharing the same storage will also have access to the extension (see HasExtension). +This method must be called on the CEF UI thread. + + Returns true if this context was used to load the extension identified by extensionId + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Attempts to resolve origin to a list of associated IP addresses. + + host name to resolve + A task that represents the Resoolve Host operation. The value of the TResult parameter contains ResolveCallbackResult. + + + +Clears all active and idle connections that Chromium currently has. +This is only recommended if you have released all other CEF objects but +don't yet want to call Cef.Shutdown(). + + If is non-NULL it will be executed on the CEF UI thread after +completion. This param is optional + + + +Clears all HTTP authentication credentials that were added as part of handling +. + + If is non-NULL it will be executed on the CEF UI thread after +completion. This param is optional + + + +Clears all certificate exceptions that were added as part of handling +. If you call this it is +recommended that you also call or you risk not +being prompted again for server certificates if you reconnect quickly. + + If is non-NULL it will be executed on the CEF UI thread after +completion. This param is optional + + + +Set the value associated with preference name. If value is null the +preference will be restored to its default value. If setting the preference +fails then error will be populated with a detailed description of the +problem. This method must be called on the CEF UI thread. +Preferences set via the command-line usually cannot be modified. + + preference key + preference value + out error + Returns true if the value is set successfully and false otherwise. + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns true if the preference with the specified name can be modified +using SetPreference. As one example preferences set via the command-line +usually cannot be modified. This method must be called on the CEF UI thread. + + preference key + Returns true if the preference with the specified name can be modified +using SetPreference + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns all preferences as a dictionary. The returned +object contains a copy of the underlying preference values and +modifications to the returned object will not modify the underlying +preference values. This method must be called on the browser process UI +thread. + + If true then +preferences currently at their default value will be included. + Preferences (dictionary can have sub dictionaries) + + + +Returns the value for the preference with the specified name. Returns +NULL if the preference does not exist. The returned object contains a copy +of the underlying preference value and modifications to the returned object +will not modify the underlying preference value. This method must be called +on the CEF UI thread. + + preference name + Returns the value for the preference with the specified name + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns true if a preference with the specified name exists. This method +must be called on the CEF UI thread. + + name of preference + bool if the preference exists + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns the cache path for this object. If empty an "incognito mode" +in-memory cache is being used. + + + + +Clear all registered scheme handler factories. + + Returns false on error. + + + +Register a scheme handler factory for the specified schemeName and optional domainName. +An empty domainName value for a standard scheme will cause the factory to match all domain +names. The domainName value will be ignored for non-standard schemes. If schemeName is +a built-in scheme and no handler is returned by factory then the built-in scheme handler +factory will be called. If schemeName is a custom scheme then you must also implement the +IApp.OnRegisterCustomSchemes() method in all processes. This function may be called multiple +times to change or remove the factory that matches the specified schemeName and optional +domainName. + + Scheme Name + Optional domain name + Scheme handler factory + Returns false if an error occurs. + + + +Returns true if this object is the global context. The global context is +used by default when creating a browser or URL request with a NULL context +argument. + + + + +Returns the default cookie manager for this object. This will be the global +cookie manager if this object is the global request context. + + If callback is non-NULL it will be executed asnychronously on the CEF IO thread +after the manager's storage has been initialized. + Returns the default cookie manager for this object + + + +Returns true if this object is sharing the same storage as the specified context. + + context to compare + Returns true if same storage + + + +Returns true if this object is pointing to the same context object. + + context to compare + Returns true if the same + + + +Creates a new context object that shares storage with other and uses an +optional handler. + + shares storage with this RequestContext + optional requestContext handler + Returns a new RequestContext + + +Creates a new context object that shares storage with | other | and uses an optional | handler | . + + + +A request context provides request handling for a set of related browser objects. +A request context is specified when creating a new browser object via the CefBrowserHost +static factory methods. Browser objects with different request contexts will never be +hosted in the same render process. Browser objects with the same request context may or +may not be hosted in the same render process depending on the process model. +Browser objects created indirectly via the JavaScript window.open function or targeted +links will share the same render process and the same request context as the source browser. +When running in single-process mode there is only a single render process (the main process) +and so all browsers created in single-process mode will share the same request context. +This will be the first request context passed into a CefBrowserHost static factory method +and all other request context objects will be ignored. + + + + +Called on the browser process IO thread before a resource request is +initiated. The |browser| and |frame| values represent the source of the +request, and may be NULL for requests originating from service workers or +CefURLRequest. |request| represents the request contents and cannot be +modified in this callback. |is_navigation| will be true if the resource +request is a navigation. |is_download| will be true if the resource +request is a download. |request_initiator| is the origin (scheme + domain) +of the page that initiated the request. Set |disable_default_handling| to +true to disable default handling of the request, in which case it will +need to be handled via CefResourceRequestHandler::GetResourceHandler or it +will be canceled. To allow the resource load to proceed with default +handling return NULL. To specify a handler for the resource return a +CefResourceRequestHandler object. This method will not be called if the +client associated with |browser| returns a non-NULL value from +CefRequestHandler::GetResourceRequestHandler for the same request +(identified by CefRequest::GetIdentifier). + + + + +Called on the browser process UI thread immediately after the request +context has been initialized. + + + + +Implement this interface to provide handler implementations. The handler +instance will not be released until all objects related to the context have +been destroyed. + + + + +Called on the IO thread after a resource response is received. The +|browser| and |frame| values represent the source of the request, and may +be NULL for requests originating from service workers or CefURLRequest. +|request| cannot be modified in this callback. Return true if the +specified cookie returned with the response can be saved or false +otherwise. + + + + +Called on the IO thread before a resource request is sent. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. |request| +cannot be modified in this callback. Return true if the specified cookie +can be sent with the request or false otherwise. + + + + +Implement this interface to filter cookies that may be sent or received from +resource requests. The methods of this class will be called on the IO thread +unless otherwise indicated. + + + + +Called on the IO thread to handle requests for URLs with an unknown +protocol component. The |browser| and |frame| values represent the source +of the request, and may be NULL for requests originating from service +workers or CefURLRequest. |request| cannot be modified in this callback. +Set |allow_os_execution| to true to attempt execution via the registered +OS protocol handler, if any. SECURITY WARNING: YOU SHOULD USE THIS METHOD +TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR OTHER URL ANALYSIS BEFORE +ALLOWING OS EXECUTION. + + + + +Called on the IO thread when a resource load has completed. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. |request| +and |response| represent the request and response respectively and cannot +be modified in this callback. |status| indicates the load completion +status. |received_content_length| is the number of response bytes actually +read. This method will be called for all requests, including requests that +are aborted due to CEF shutdown or destruction of the associated browser. +In cases where the associated browser is destroyed this callback may +arrive after the CefLifeSpanHandler::OnBeforeClose callback for that +browser. The CefFrame::IsValid method can be used to test for this +situation, and care should be taken not to call |browser| or |frame| +methods that modify state (like LoadURL, SendProcessMessage, etc.) if the +frame is invalid. + + + + +Called on the IO thread to optionally filter resource response content. +The |browser| and |frame| values represent the source of the request, and +may be NULL for requests originating from service workers or +CefURLRequest. |request| and |response| represent the request and response +respectively and cannot be modified in this callback. + + + + +Called on the IO thread when a resource response is received. The +|browser| and |frame| values represent the source of the request, and may +be NULL for requests originating from service workers or CefURLRequest. To +allow the resource load to proceed without modification return false. To +redirect or retry the resource load optionally modify |request| and return +true. Modification of the request URL will be treated as a redirect. +Requests handled using the default network loader cannot be redirected in +this callback. The |response| object cannot be modified in this callback. + +WARNING: Redirecting using this method is deprecated. Use +OnBeforeResourceLoad or GetResourceHandler to perform redirects. + + + + +Called on the IO thread when a resource load is redirected. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. The +|request| parameter will contain the old URL and other request-related +information. The |response| parameter will contain the response that +resulted in the redirect. The |new_url| parameter will contain the new URL +and can be changed if desired. The |request| and |response| objects cannot +be modified in this callback. + + + + +Called on the IO thread before a resource is loaded. The |browser| and +|frame| values represent the source of the request, and may be NULL for +requests originating from service workers or CefURLRequest. To allow the +resource to load using the default network loader return NULL. To specify +a handler for the resource return a CefResourceHandler object. The +|request| object cannot not be modified in this callback. + + + + +Called on the IO thread before a resource request is loaded. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. To +redirect or change the resource load optionally modify |request|. +Modification of the request URL will be treated as a redirect. Return +RV_CONTINUE to continue the request immediately. Return RV_CONTINUE_ASYNC +and call CefCallback methods at a later time to continue or cancel the +request asynchronously. Return RV_CANCEL to cancel the request +immediately. + + + + +Called on the IO thread before a resource request is loaded. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. To +optionally filter cookies for the request return a CefCookieAccessFilter +object. The |request| object cannot not be modified in this callback. + + + + +Implement this interface to handle events related to browser requests. The +methods of this class will be called on the IO thread unless otherwise +indicated. + + + + +Called to filter a chunk of data. Expected usage is as follows: + + 1. Read input data from |data_in| and set |data_in_read| to the number of + bytes that were read up to a maximum of |data_in_size|. |data_in| will + be NULL if |data_in_size| is zero. + 2. Write filtered output data to |data_out| and set |data_out_written| to + the number of bytes that were written up to a maximum of + |data_out_size|. If no output data was written then all data must be + read from |data_in| (user must set |data_in_read| = |data_in_size|). + 3. Return RESPONSE_FILTER_DONE if all output data was written or + RESPONSE_FILTER_NEED_MORE_DATA if output data is still pending. + +This method will be called repeatedly until the input buffer has been +fully read (user sets |data_in_read| = |data_in_size|) and there is no +more input data to filter (the resource response is complete). This method +may then be called an additional time with an empty input buffer if the +user filled the output buffer (set |data_out_written| = |data_out_size|) +and returned RESPONSE_FILTER_NEED_MORE_DATA to indicate that output data +is still pending. + +Calls to this method will stop when one of the following conditions is +met: + + 1. There is no more input data to filter (the resource response is + complete) and the user sets |data_out_written| = 0 or returns + RESPONSE_FILTER_DONE to indicate that all data has been written, or; + 2. The user returns RESPONSE_FILTER_ERROR to indicate an error. + +Do not keep a reference to the buffers passed to this method. + + + + +Initialize the response filter. Will only be called a single time. The +filter will not be installed if this method returns false. + + + + +Implement this interface to filter resource response content. The methods of +this class will be called on the browser process IO thread. + + + + +Request processing has been canceled. + + + + +Read response data. If data is available immediately copy up to +|bytes_to_read| bytes into |data_out|, set |bytes_read| to the number of +bytes copied, and return true. To read the data at a later time set +|bytes_read| to 0, return true and call CefCallback::Continue() when the +data is available. To indicate response completion return false. + +WARNING: This method is deprecated. Use Skip and Read instead. + + + + +Retrieve response header information. If the response length is not known +set |response_length| to -1 and ReadResponse() will be called until it +returns false. If the response length is known set |response_length| +to a positive value and ReadResponse() will be called until it returns +false or the specified number of bytes have been read. Use the |response| +object to set the mime type, http status code and other optional header +values. To redirect the request to a new URL set |redirectUrl| to the new +URL. |redirectUrl| can be either a relative or fully qualified URL. +It is also possible to set |response| to a redirect http status code +and pass the new URL via a Location header. Likewise with |redirectUrl| it +is valid to set a relative or fully qualified URL as the Location header +value. If an error occured while setting up the request you can call +SetError() on |response| to indicate the error condition. + + + + +Begin processing the request. To handle the request return true and call +CefCallback::Continue() once the response header information is available +(CefCallback::Continue() can also be called from inside this method if +header information is available immediately). To cancel the request return +false. + +WARNING: This method is deprecated. Use Open instead. + + + + +Open the response stream. To handle the request immediately set +|handle_request| to true and return true. To decide at a later time set +|handle_request| to false, return true, and execute |callback| to continue +or cancel the request. To cancel the request immediately set +|handle_request| to true and return false. This method will be called in +sequence but not from a dedicated thread. For backwards compatibility set +|handle_request| to false and return false and the ProcessRequest method +will be called. + + + + +Class used to implement a custom request handler interface. The methods of +this class will be called on the IO thread unless otherwise indicated. + + + + +Callback for asynchronous continuation of CefResourceHandler::Read(). + + + + +Callback for asynchronous continuation of CefResourceHandler::Skip(). + + + + +Set the resolved URL after redirects or changed as a result of HSTS. + + + +Set the resolved URL after redirects or changed as a result of HSTS. + + + +Set the resolved URL after redirects or changed as a result of HSTS. + + + + +Get the resolved URL after redirects or changed as a result of HSTS. + + + +Get the resolved URL after redirects or changed as a result of HSTS. + + + +Get the resolved URL after redirects or changed as a result of HSTS. + + + + +Set all response header fields. + + + +Set all response header fields. + + + +Set all response header fields. + + + + +Get all response header fields. + + + +Get all response header fields. + + + +Get all response header fields. + + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. + + + + +Get the value for the specified response header field. + + + +Get the value for the specified response header field. + + + +Get the value for the specified response header field. + + + + +Set the response charset. + + + +Set the response charset. + + + +Set the response charset. + + + + +Get the response charset. + + + +Get the response charset. + + + +Get the response charset. + + + + +Set the response mime type. + + + +Set the response mime type. + + + +Set the response mime type. + + + + +Get the response mime type. + + + +Get the response mime type. + + + +Get the response mime type. + + + + +Set the response status text. + + + +Set the response status text. + + + +Set the response status text. + + + + +Get the response status text. + + + +Get the response status text. + + + +Get the response status text. + + + + +Set the response status code. + + + +Set the response status code. + + + +Set the response status code. + + + + +Get the response status code. + + + +Get the response status code. + + + +Get the response status code. + + + + +Set the response error code. This can be used by custom scheme handlers +to return errors during initial request processing. + + + +Set the response error code. This can be used by custom scheme handlers +to return errors during initial request processing. + + + +Set the response error code. This can be used by custom scheme handlers +to return errors during initial request processing. + + + + +Get the response error code. Returns ERR_NONE if there was no error. + + + +Get the response error code. Returns ERR_NONE if there was no error. + + + +Get the response error code. Returns ERR_NONE if there was no error. + + + + +Returns true if this object is read-only. + + + +Returns true if this object is read-only. + + + +Returns true if this object is read-only. + + + + +Create a new CefResponse object. + + + +Create a new CefResponse object. + + + +Create a new CefResponse object. + + + + +Class used to represent a web response. The methods of this class may be +called on any thread. + + + +Class used to represent a web response. The methods of this class may be +called on any thread. + + + +Class used to represent a web response. The methods of this class may be +called on any thread. + + + + +If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. This value will be ignored if + matches the value. + + + + +Comma delimited list of schemes supported by the associated +ICookieManager. If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. This value will be ignored if + matches the value. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. Can be set globally +using the CefSettings.accept_language_list value or overridden on a per- +browser basis using the BrowserSettings.AcceptLanguageList value. If +all values are empty then "en-US,en" will be used. This value will be +ignored if CachePath matches the CefSettings.CachePath value. + + + + +The location where cache data for this request context will be stored on +disk. If this value is non-empty then it must be an absolute path that is +either equal to or a child directory of CefSettings.RootCachePath. +If the value is empty then browsers will be created in "incognito mode" +where in-memory caches are used for storage and no data is persisted to disk. +HTML5 databases such as localStorage will only persist across sessions if a +cache path is specified. To share the global browser cache and related +configuration set this value to match the CefSettings.CachePath value. + + + + +To persist user preferences as a JSON file in the cache path directory set +this value to true. Can be set globally using the +CefSettings.PersistUserPreferences value. This value will be ignored if +CachePath is empty or if it matches the CefSettings.CachePath value. + + + + +To persist session cookies (cookies without an expiry date or validity +interval) by default when using the global cookie manager set this value to +true. Session cookies are generally intended to be transient and most +Web browsers do not persist them. Can be set globally using the +CefSettings.PersistSessionCookies value. This value will be ignored if +CachePath is empty or if it matches the CefSettings.CachePath value. + + + + +Initializes a new instance of the RequestContextSettings class. + + + + +RequestContextSettings + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
\ No newline at end of file diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.Core.dll b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.Core.dll new file mode 100644 index 0000000..8285506 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.Core.dll differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.Core.pdb b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.Core.pdb new file mode 100644 index 0000000..9c20158 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.Core.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.exe b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.exe new file mode 100644 index 0000000..c23b092 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.exe differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.pdb b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.pdb new file mode 100644 index 0000000..10a95ea Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.BrowserSubprocess.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.dll b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.dll new file mode 100644 index 0000000..1f473fa Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.dll differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.pdb b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.pdb new file mode 100644 index 0000000..8c454d8 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.xml b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.xml new file mode 100644 index 0000000..6da1116 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/CefSharp/x86/CefSharp.Core.Runtime.xml @@ -0,0 +1,12825 @@ + + + + "CefSharp.Core.Runtime" + + + + +Returns true if the underlying POST data includes elements that are not +represented by this IPostData object (for example, multi-part file upload +data). Modifying IPostData objects with excluded elements may result in +the request failing. + + + + +Create a new instance + + PostDataElement + + + +Remove all existing post data elements. + + + + +Remove the specified . + + element to be removed. + Returns true if the add succeeds. + + + +Add the specified . + + element to be added. + Returns true if the add succeeds. + + + +Retrieve the post data elements. + + + + +Returns true if this object is read-only. + + + + +Initializes a new instance of the PostData class. + + + + +Throw exception if Readonly + + Thrown when an exception error condition occurs. + + + +Destructor. + + + + +Finalizer. + + + + +Form Post Data + + + + + +Constructor. + + The popup features. + + + +Class representing popup window features. + + + + + + + + +Post an action for execution on the specified thread. + + thread id + action to execute + bool + + + +Post an action for delayed execution on the specified thread. + + thread id + action to execute + delay in ms + bool + + + +Helper method to ensure all ChromiumWebBrowser instances have been +closed/disposed, should be called before Cef.Shutdown. +Disposes all remaning ChromiumWebBrowser instances +then waits for CEF to release it's remaning CefBrowser instances. +Finally a small delay of 50ms to allow for CEF to finish it's cleanup. +Should only be called when MultiThreadedMessageLoop = true; +(Hasn't been tested when when CEF integrates into main message loop). + + The timeout in miliseconds. + + + +Helper method to ensure all ChromiumWebBrowser instances have been +closed/disposed, should be called before Cef.Shutdown. +Disposes all remaning ChromiumWebBrowser instances +then waits for CEF to release it's remaning CefBrowser instances. +Finally a small delay of 50ms to allow for CEF to finish it's cleanup. +Should only be called when MultiThreadedMessageLoop = true; +(Hasn't been tested when when CEF integrates into main message loop). + + + + +WaitForBrowsersToClose is not enabled by default, call this method +before Cef.Initialize to enable. If you aren't calling Cef.Initialize +explicitly then this should be called before creating your first +ChromiumWebBrowser instance. + + + + +Returns the mime type for the specified file extension or an empty string if unknown. + + file extension + Returns the mime type for the specified file extension or an empty string if unknown. + + + +Sets or clears a specific key-value pair from the crash metadata. + + + + +Crash reporting is configured using an INI-style config file named +crash_reporter.cfg. This file must be placed next to +the main application executable. File contents are as follows: + + # Comments start with a hash character and must be on their own line. + + [Config] + ProductName=<Value of the "prod" crash key; defaults to "cef"> + ProductVersion=<Value of the "ver" crash key; defaults to the CEF version> + AppName=<Windows only; App-specific folder name component for storing crash + information; default to "CEF"> + ExternalHandler=<Windows only; Name of the external handler exe to use + instead of re-launching the main exe; default to empty> + ServerURL=<crash server URL; default to empty> + RateLimitEnabled=<True if uploads should be rate limited; default to true> + MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; + default to 5> + MaxDatabaseSizeInMb=<Total crash report disk usage greater than this value + will cause older reports to be deleted; default to 20> + MaxDatabaseAgeInDays=<Crash reports older than this value will be deleted; + default to 5> + + [CrashKeys] + my_key1=<small|medium|large> + my_key2=<small|medium|large> + +Config section: + +If "ProductName" and/or "ProductVersion" are set then the specified values +will be included in the crash dump metadata. + +If "AppName" is set on Windows then crash report information (metrics, +database and dumps) will be stored locally on disk under the +"C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. + +If "ExternalHandler" is set on Windows then the specified exe will be +launched as the crashpad-handler instead of re-launching the main process +exe. The value can be an absolute path or a path relative to the main exe +directory. + +If "ServerURL" is set then crashes will be uploaded as a multi-part POST +request to the specified URL. Otherwise, reports will only be stored locally +on disk. + +If "RateLimitEnabled" is set to true then crash report uploads will be rate +limited as follows: + 1. If "MaxUploadsPerDay" is set to a positive value then at most the + specified number of crashes will be uploaded in each 24 hour period. + 2. If crash upload fails due to a network or server error then an + incremental backoff delay up to a maximum of 24 hours will be applied for + retries. + 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the + "MaxUploadsPerDay" value will be reduced to 1 until the client is + restarted. This helps to avoid an upload flood when the network or + server error is resolved. + +If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage +on disk will be limited to that size in megabytes. For example, on Windows +each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to +about 34 crash reports stored on disk. + +If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older +than the specified age in days will be deleted. + +CrashKeys section: + +Any number of crash keys can be specified for use by the application. Crash +key values will be truncated based on the specified size (small = 63 bytes, +medium = 252 bytes, large = 1008 bytes). The value of crash keys can be set +from any thread or process using the Cef.SetCrashKeyValue function. These +key/value pairs will be sent to the crash server along with the crash dump +file. Medium and large values will be chunked for submission. For example, +if your key is named "mykey" then the value will be broken into ordered +chunks and submitted using keys named "mykey-1", "mykey-2", etc. + + Returns true if crash reporting is enabled. + + + +Helper function (wrapper around the CefColorSetARGB macro) which combines +the 4 color components into an uint32 for use with BackgroundColor property + + Alpha + Red + Green + Blue + Returns the color. + + + +Gets the Global Request Context. Make sure to Dispose of this object when finished. +The earlier possible place to access the IRequestContext is in IBrowserProcessHandler.OnContextInitialized. +Alternative use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + Returns the global request context or null if the RequestContext has not been initialized yet. + + + +Returns true if called on the specified CEF thread. + + Returns true if called on the specified thread. + + + +Clear all scheme handler factories registered with the global request context. +Returns false on error. This function may be called on any thread in the browser process. +Using this function is equivalent to calling Cef.GetGlobalRequestContext().ClearSchemeHandlerFactories(). + + Returns false on error. + + + +This method should only be used by advanced users, if you're unsure then use Cef.Shutdown(). +This function should be called on the main application thread to shut down +the CEF browser process before the application exits. This method simply obtains a lock +and calls the native CefShutdown method, only IsInitialized is checked. All ChromiumWebBrowser +instances MUST be Disposed of before calling this method. If calling this method results in a crash +or hangs then you're likely hanging on to some unmanaged resources or haven't closed all of your browser +instances + + + + +Shuts down CefSharp and the underlying CEF infrastructure. This method is safe to call multiple times; it will only +shut down CEF on the first call (all subsequent calls will be ignored). +This method should be called on the main application thread to shut down the CEF browser process before the application exits. +If you are Using CefSharp.OffScreen then you must call this explicitly before your application exits or it will hang. +This method must be called on the same thread as Initialize. If you don't call Shutdown explicitly then CefSharp.Wpf and CefSharp.WinForms +versions will do their best to call Shutdown for you, if your application is having trouble closing then call thus explicitly. + + + + +Called prior to calling Cef.Shutdown, this diposes of any remaning +ChromiumWebBrowser instances. In WPF this is used from Dispatcher.ShutdownStarted +to release the unmanaged resources held by the ChromiumWebBrowser instances. +Generally speaking you don't need to call this yourself. + + + + +Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. +Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() +The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, +there may be a short delay before you can Get/Write cookies. +To be sure the cookie manager has been initialized use one of the following +- Access the ICookieManager after ICompletionCallback.OnComplete has been called +- Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. +- Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + If non-NULL it will be executed asnychronously on the CEF UI thread after the manager's storage has been initialized. + A the global cookie manager or null if the RequestContext has not yet been initialized. + + + +Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. +Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() +The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, +there may be a short delay before you can Get/Write cookies. +To be sure the cookie manager has been initialized use one of the following +- Use the GetGlobalCookieManager(ICompletionCallback) overload and access the ICookieManager after + ICompletionCallback.OnComplete has been called. +- Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. +- Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + A the global cookie manager or null if the RequestContext has not yet been initialized. + + + Remove all entries from the cross-origin access whitelist. + +Remove all entries from the cross-origin access whitelist. Returns false if +the whitelist cannot be accessed. + + + + Remove entry from cross-origin whitelist + The origin allowed to be accessed by the target protocol/domain. + The target protocol allowed to access the source origin. + The optional target domain allowed to access the source origin. + If set to true would allow a blah.example.com if the + was set to example.com + + +Remove an entry from the cross-origin access whitelist. Returns false if + is invalid or the whitelist cannot be accessed. + + + + Add an entry to the cross-origin whitelist. + The origin allowed to be accessed by the target protocol/domain. + The target protocol allowed to access the source origin. + The optional target domain allowed to access the source origin. + If set to true would allow a blah.example.com if the + was set to example.com + + Returns false if is invalid or the whitelist cannot be accessed. + +The same-origin policy restricts how scripts hosted from different origins +(scheme + domain + port) can communicate. By default, scripts can only access +resources with the same origin. Scripts hosted on the HTTP and HTTPS schemes +(but no other schemes) can use the "Access-Control-Allow-Origin" header to +allow cross-origin requests. For example, https://source.example.com can make +XMLHttpRequest requests on http://target.example.com if the +http://target.example.com request returns an "Access-Control-Allow-Origin: +https://source.example.com" response header. +Scripts in separate frames or iframes and hosted from the same protocol and +domain suffix can execute cross-origin JavaScript if both pages set the +document.domain value to the same domain suffix. For example, +scheme://foo.example.com and scheme://bar.example.com can communicate using +JavaScript if both domains set document.domain="example.com". +This method is used to allow access to origins that would otherwise violate +the same-origin policy. Scripts hosted underneath the fully qualified + URL (like http://www.example.com) will be allowed access to +all resources hosted on the specified and . +If is non-empty and if false only +exact domain matches will be allowed. If contains a top- +level domain component (like "example.com") and is +true sub-domain matches will be allowed. If is empty and + if true all domains and IP addresses will be +allowed. +This method cannot be used to bypass the restrictions on local or display +isolated schemes. See the comments on for more +information. + +This function may be called on any thread. Returns false if +is invalid or the whitelist cannot be accessed. + + + + +This function should be called from the application entry point function to execute a secondary process. +It can be used to run secondary processes from the browser client executable (default behavior) or +from a separate executable specified by the CefSettings.browser_subprocess_path value. +If called for the browser process (identified by no "type" command-line value) it will return immediately with a value of -1. +If called for a recognized secondary process it will block until the process should exit and then return the process exit code. +The |application| parameter may be empty. The |windows_sandbox_info| parameter is only used on Windows and may be NULL (see cef_sandbox_win.h for details). + + + + +Perform a single iteration of CEF message loop processing.This function is +provided for cases where the CEF message loop must be integrated into an +existing application message loop. Use of this function is not recommended +for most users; use CefSettings.MultiThreadedMessageLoop if possible (the default). +When using this function care must be taken to balance performance +against excessive CPU usage. It is recommended to enable the +CefSettings.ExternalMessagePump option when using +this function so that IBrowserProcessHandler.OnScheduleMessagePumpWork() +callbacks can facilitate the scheduling process. This function should only be +called on the main application thread and only if Cef.Initialize() is called +with a CefSettings.MultiThreadedMessageLoop value of false. This function +will not block. + + + + +Quit the CEF message loop that was started by calling Cef.RunMessageLoop(). +This function should only be called on the main application thread and only +if Cef.RunMessageLoop() was used. + + + + +Run the CEF message loop. Use this function instead of an application- +provided message loop to get the best balance between performance and CPU +usage. This function should only be called on the main application thread and +only if Cef.Initialize() is called with a +CefSettings.MultiThreadedMessageLoop value of false. This function will +block until a quit message is received by the system. + + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize/Shutdown MUST be called on your main +application thread (typically the UI thread). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies avaliable, throws exception if any are missing + Implement this interface to provide handler implementations. Null if you don't wish to handle these events + true if successful; otherwise, false. + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize/Shutdown MUST be called on your main +applicaiton thread (Typically the UI thead). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies avaliable, throws exception if any are missing + The handler for functionality specific to the browser process. Null if you don't wish to handle these events + true if successful; otherwise, false. + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize/Shutdown MUST be called on your main +application thread (typically the UI thread). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies avaliable, throws exception if any are missing + true if successful; otherwise, false. + + + +Initializes CefSharp with user-provided settings. +It's important to note that Initialize and Shutdown MUST be called on your main +application thread (typically the UI thread). If you call them on different +threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + true if successful; otherwise, false. + + + +Parse the specified url into its component parts. +Uses a GURL to parse the Url. GURL is Google's URL parsing library. + + url + Returns null if the URL is empty or invalid. + + + +Gets a value that indicates the Git Hash for CEF version currently being used. + + The Git Commit Hash + + + Gets a value that indicates the Chromium version currently being used. + The Chromium version. + + + Gets a value that indicates the CEF version currently being used. + The CEF Version + + + Gets a value that indicates the version of CefSharp currently being used. + The CefSharp version. + + + Gets a value that indicates whether CefSharp was shutdown. + true if CefSharp was shutdown; otherwise, false. + + + Gets a value that indicates whether CefSharp is initialized. + true if CefSharp is initialized; otherwise, false. + + + +Global CEF methods are exposed through this class. e.g. CefInitalize maps to Cef.Initialize +CEF API Doc https://magpcss.org/ceforum/apidocs3/projects/(default)/(_globals).html +This class cannot be inherited. + + + + +Create a new object with explicit response values. + + + + +Create a new object with default response values. + + + + +Implementation of the CefResourceHandler class for reading from a CefStream. + + + + +Registers a custom scheme using the provided settings. + + The CefCustomScheme which provides the details about the scheme. + + + +If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. Can be overridden +for individual RequestContext instances via the +RequestContextSettings.CookieableSchemesList and +RequestContextSettings.CookieableSchemesExcludeDefaults values. + + + + +Comma delimited list of schemes supported by the associated +ICookieManager. If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. Can be overridden +for individual RequestContext instances via the +RequestContextSettings.CookieableSchemesList and +RequestContextSettings.CookieableSchemesExcludeDefaults values. + + + + +Background color used for the browser before a document is loaded and when no document color is specified. The alpha +component must be either fully opaque (0xFF) or fully transparent (0x00). If the alpha component is fully opaque then the RGB +components will be used as the background color. If the alpha component is fully transparent for a WinForms browser then the +default value of opaque white be used. If the alpha component is fully transparent for a windowless (WPF/OffScreen) browser +then transparent painting will be enabled. + + + + +Comma delimited ordered list of language codes without any whitespace that will be used in the "Accept-Language" HTTP header. +May be set globally using the CefSettings.AcceptLanguageList value. If both values are empty then "en-US,en" will be used. + + + + + +To persist user preferences as a JSON file in the cache path directory set this value to true. A CachePath value must also be +specified to enable this feature. Also configurable using the "persist-user-preferences" command-line switch. Can be +overridden for individual RequestContext instances via the RequestContextSettings.PersistUserPreferences value. + + + + +To persist session cookies (cookies without an expiry date or validity interval) by default when using the global cookie +manager set this value to true. Session cookies are generally intended to be transient and most Web browsers do not persist +them. A CachePath value must also be specified to enable this feature. Also configurable using the "persist-session-cookies" +command-line switch. Can be overridden for individual RequestContext instances via the +RequestContextSettings.PersistSessionCookies value. + + + + +Set to true (1) to enable windowless (off-screen) rendering support. Do not enable this value if the application does not use +windowless rendering as it may reduce rendering performance on some systems. + + + + +Value that will be returned as the User-Agent HTTP header. If empty the default User-Agent string will be used. Also +configurable using the "user-agent" command-line switch. + + + + +The number of stack trace frames to capture for uncaught exceptions. Specify a positive value to enable the +CefRenderProcessHandler:: OnUncaughtException() callback. Specify 0 (default value) and OnUncaughtException() will not be +called. Also configurable using the "uncaught-exception-stack-size" command-line switch. + + + + +Set to a value between 1024 and 65535 to enable remote debugging on the specified port. For example, if 8080 is specified the +remote debugging URL will be http://localhost:8080. CEF can be remotely debugged from any CEF or Chrome browser window. Also +configurable using the "remote-debugging-port" command-line switch. + + + + +Value that will be inserted as the product portion of the default User-Agent string. If empty the Chromium product version +will be used. If UserAgent is specified this value will be ignored. Also configurable using the "user-agent-product" command- +line switch. + + + + +Set to true to disable loading of pack files for resources and locales. A resource bundle handler must be provided for the +browser and render processes via CefApp::GetResourceBundleHandler() if loading of pack files is disabled. Also configurable +using the "disable-pack-loading" command- line switch. + + + + +Custom flags that will be used when initializing the V8 JavaScript engine. The consequences of using custom flags may not be +well tested. Also configurable using the "js-flags" command-line switch. + + + + +The log severity. Only messages of this severity level or higher will be logged. When set to + no messages will be written to the log file, but Fatal messages will still be +output to stderr. Also configurable using the "log-severity" command-line switch with a value of "verbose", "info", "warning", +"error", "fatal", "error-report" or "disable". + + + + +The directory and file name to use for the debug log. If empty a default log file name and location will be used. On Windows +a "debug.log" file will be written in the main executable directory. Also configurable using the"log-file" command- line +switch. + + + + +The fully qualified path for the resources directory. If this value is empty the cef.pak and/or devtools_resources.pak files +must be located in the module directory. Also configurable using the "resources-dir-path" command-line switch. + + + + +The fully qualified path for the locales directory. If this value is empty the locales directory must be located in the +module directory. If this value is non-empty then it must be an absolute path. Also configurable using the "locales-dir-path" +command-line switch. + + + + +The locale string that will be passed to WebKit. If empty the default locale of "en-US" will be used. Also configurable using +the "lang" command-line switch. + + + + +The location where user data such as the Widevine CDM module and spell checking dictionary files will be stored on disk. +If this value is empty then "Local Settings\Application Data\CEF\User Data" directory under the user profile directory +will be used. If this value is non-empty then it must be an absolute path. + + + + +The root directory that all CefSettings.CachePath and RequestContextSettings.CachePath values must have in common. If this +value is empty and CefSettings.CachePath is non-empty then it will default to the CefSettings.CachePath value. +If this value is non-empty then it must be an absolute path. Failure to set this value correctly may result in the sandbox +blocking read/write access to the CachePath directory. NOTE: CefSharp does not implement the CHROMIUM SANDBOX. A non-empty +RootCachePath can be used in conjuncation with an empty CefSettings.CachePath in instances where you would like browsers +attached to the Global RequestContext (the default) created in "incognito mode" and instances created with a custom +RequestContext using a disk based cache. + + + + +The location where data for the global browser cache will be stored on disk. In this value is non-empty then it must be +an absolute path that is must be either equal to or a child directory of CefSettings.RootCachePath (if RootCachePath is +empty it will default to this value). If the value is empty then browsers will be created in "incognito mode" where +in-memory caches are used for storage and no data is persisted to disk. HTML5 databases such as localStorage will only +persist across sessions if a cache path is specified. Can be overridden for individual RequestContext instances via the +RequestContextSettings.CachePath value. + + + + +The path to a separate executable that will be launched for sub-processes. By default the browser process executable is used. +See the comments on Cef.ExecuteProcess() for details. If this value is non-empty then it must be an absolute path. +Also configurable using the "browser-subprocess-path" command-line switch. +Defaults to using the provided CefSharp.BrowserSubprocess.exe instance + + + + +Set to true to have the browser process message loop run in a separate thread. If false than the CefDoMessageLoopWork() +function must be called from your application message loop. This option is only supported on Windows. The default value is +true. + + + + +Set to true to control browser process main (UI) thread message pump scheduling via the +IBrowserProcessHandler.OnScheduleMessagePumpWork callback. This option is recommended for use in combination with the +Cef.DoMessageLoopWork() function in cases where the CEF message loop must be integrated into an existing application message +loop (see additional comments and warnings on Cef.DoMessageLoopWork). Enabling this option is not recommended for most users; +leave this option disabled and use either MultiThreadedMessageLoop (the default) if possible. + + + + +Set to true to disable configuration of browser process features using standard CEF and Chromium command-line arguments. +Configuration can still be specified using CEF data structures or by adding to CefCommandLineArgs. + + + + +**Experimental** +Set to true to enable use of the Chrome runtime in CEF. This feature is +considered experimental and is not recommended for most users at this time. +See issue https://github.com/chromiumembedded/cef/issues/2969 + + + + +Add custom command line argumens to this collection, they will be added in OnBeforeCommandLineProcessing. The +CefSettings.CommandLineArgsDisabled value can be used to start with an empty command-line object. Any values specified in +CefSettings that equate to command-line arguments will be set before this method is called. + + + + +Add Customs schemes to this collection. + + + + +Destructor. + + + + +Finalizer. + + + + +Default Constructor. + + + + +CefCustomScheme collection + + + + +CefSettings unmanaged pointer + + + + +Command Line Arguments Dictionary. + + + + +Initialization settings. Many of these and other settings can also configured using command-line switches. +WPF/WinForms/OffScreen each have their own CefSettings implementation that sets +relevant settings e.g. OffScreen starts with audio muted. + + + + +Generates a JSON string from the specified root |node| which should be a +dictionary or list value. Returns an empty string on failure. This method +requires exclusive access to |node| including any underlying data. + + + + +Parses the specified |json_string| and returns a dictionary or list +representation. If JSON parsing fails this method returns NULL and populates +|error_msg_out| with a formatted error message. + + + + +Parses the specified UTF8-encoded |json| buffer of size |json_size| and +returns a dictionary or list representation. If JSON parsing fails this +method returns NULL. + + + + +Parses the specified |json_string| and returns a dictionary or list +representation. If JSON parsing fails this method returns NULL. + + + + +Unescapes |text| and returns the result. Unescaping consists of looking for +the exact pattern "%XX" where each X is a hex digit and converting to the +character with the numerical value of those digits (e.g. "i%20=%203%3b" +unescapes to "i = 3;"). If |convert_to_utf8| is true this function will +attempt to interpret the initial decoded result as UTF-8. If the result is +convertable into UTF-8 it will be returned as converted. Otherwise the +initial decoded result will be returned. The |unescape_rule| parameter +supports further customization the decoding process. + + + + +Escapes characters in |text| which are unsuitable for use as a query +parameter value. Everything except alphanumerics and -_.!~*'() will be +converted to "%XX". If |use_plus| is true spaces will change to "+". The +result is basically the same as encodeURIComponent in Javacript. + + + + +Decodes the base64 encoded string |data|. The returned value will be NULL if +the decoding fails. + + + + +Encodes |data| as a base64 string. + + + + +Get the extensions associated with the given mime type. This should be +passed in lower case. There could be multiple extensions for a given mime +type, like "html,htm" for "text/html", or "txt,text,html,..." for "text/*". +Any existing elements in the provided vector will not be erased. + + + + +Returns the mime type for the specified file extension or an empty string if +unknown. + + + + +This is a convenience function for formatting a URL in a concise and human- +friendly way to help users make security-related decisions (or in other +circumstances when people need to distinguish sites, origins, or otherwise- +simplified URLs from each other). Internationalized domain names (IDN) may +be presented in Unicode if the conversion is considered safe. The returned +value will (a) omit the path for standard schemes, excepting file and +filesystem, and (b) omit the port if it is the default for the scheme. Do +not use this for URLs which will be parsed or sent to other applications. + + + + +Creates a URL from the specified |parts|, which must contain a non-empty +spec or a non-empty host and path (at a minimum), but not both. +Returns false if |parts| isn't initialized as described. + + + + +Parse the specified |url| into its component parts. +Returns false if the URL is empty or invalid. + + + + +Combines specified |base_url| and |relative_url| into |resolved_url|. +Returns false if one of the URLs is empty or invalid. + + + +ref + + + +Interface that should be implemented by the CefUrlRequest client. +The methods of this class will be called on the same thread that created +the request unless otherwise documented. + + + +Called on the IO thread when the browser needs credentials from the user. +|isProxy| indicates whether the host is a proxy server. |host| contains +the hostname and |port| contains the port number. Return true to continue +the request and call CefAuthCallback::Continue() when the authentication +information is available. If the request has an associated browser/frame +then returning false will result in a call to GetAuthCredentials on the +CefRequestHandler associated with that browser, if any. Otherwise, +returning false will cancel the request immediately. This method will only +be called for requests initiated from the browser process. + + + +Called on the IO thread when the browser needs credentials from the user. +|isProxy| indicates whether the host is a proxy server. |host| contains +the hostname and |port| contains the port number. Return true to continue +the request and call CefAuthCallback::Continue() when the authentication +information is available. If the request has an associated browser/frame +then returning false will result in a call to GetAuthCredentials on the +CefRequestHandler associated with that browser, if any. Otherwise, +returning false will cancel the request immediately. This method will only +be called for requests initiated from the browser process. + + + + +Called when some part of the response is read. |data| contains the current +bytes received since the last call. This method will not be called if the +UR_FLAG_NO_DOWNLOAD_DATA flag is set on the request. + + + +Called when some part of the response is read. |data| contains the current +bytes received since the last call. This method will not be called if the +UR_FLAG_NO_DOWNLOAD_DATA flag is set on the request. + + + + +Notifies the client of download progress. |current| denotes the number of +bytes received up to the call and |total| is the expected total size of +the response (or -1 if not determined). + + + +Notifies the client of download progress. |current| denotes the number of +bytes received up to the call and |total| is the expected total size of +the response (or -1 if not determined). + + + + +Notifies the client of upload progress. |current| denotes the number of +bytes sent so far and |total| is the total size of uploading data (or -1 +if chunked upload is enabled). This method will only be called if the +UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + + +Notifies the client of upload progress. |current| denotes the number of +bytes sent so far and |total| is the total size of uploading data (or -1 +if chunked upload is enabled). This method will only be called if the +UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + + + +Notifies the client that the request has completed. Use the +CefURLRequest::GetRequestStatus method to determine if the request was +successful or not. + + + +Notifies the client that the request has completed. Use the +CefURLRequest::GetRequestStatus method to determine if the request was +successful or not. + + + + +Interface that should be implemented by the CefURLRequest client. The +methods of this class will be called on the same thread that created the +request unless otherwise documented. + + + +Interface that should be implemented by the CefURLRequest client. The +methods of this class will be called on the same thread that created the +request unless otherwise documented. + + + + +Cancel the request. + + + +Cancel the request. + + + + +Returns true if the response body was served from the cache. This includes +responses for which revalidation was required. + + + +Returns true if the response body was served from the cache. This includes +responses for which revalidation was required. + + + + +Returns the response, or NULL if no response information is available. +Response information will only be available after the upload has +completed. The returned object is read-only and should not be modified. + + + +Returns the response, or NULL if no response information is available. +Response information will only be available after the upload has +completed. The returned object is read-only and should not be modified. + + + + +Returns the request error if status is UR_CANCELED or UR_FAILED, or 0 +otherwise. + + + +Returns the request error if status is UR_CANCELED or UR_FAILED, or 0 +otherwise. + + + + +Returns the request status. + + + +Returns the request status. + + + + +Returns the client. + + + +Returns the client. + + + + +Returns the request object used to create this URL request. The returned +object is read-only and should not be modified. + + + +Returns the request object used to create this URL request. The returned +object is read-only and should not be modified. + + + + +Create a new URL request that is not associated with a specific browser or +frame. Use CefFrame::CreateURLRequest instead if you want the request to +have this association, in which case it may be handled differently (see +documentation on that method). A request created with this method may only +originate from the browser process, and will behave as follows: + - It may be intercepted by the client via CefResourceRequestHandler or + CefSchemeHandlerFactory. + - POST data may only contain only a single element of type PDE_TYPE_FILE + or PDE_TYPE_BYTES. + - If |request_context| is empty the global request context will be used. + +The |request| object will be marked as read-only after calling this +method. + + + +Create a new URL request that is not associated with a specific browser or +frame. Use CefFrame::CreateURLRequest instead if you want the request to +have this association, in which case it may be handled differently (see +documentation on that method). A request created with this method may only +originate from the browser process, and will behave as follows: + - It may be intercepted by the client via CefResourceRequestHandler or + CefSchemeHandlerFactory. + - POST data may only contain only a single element of type PDE_TYPE_FILE + or PDE_TYPE_BYTES. + - If |request_context| is empty the global request context will be used. + +The |request| object will be marked as read-only after calling this +method. + + + + +Class used to make a URL request. URL requests are not associated with a +browser instance so no CefClient callbacks will be executed. URL requests +can be created on any valid CEF thread in either the browser or render +process. Once created the methods of the URL request object must be accessed +on the same thread that created it. + + + +Class used to make a URL request. URL requests are not associated with a +browser instance so no CefClient callbacks will be executed. URL requests +can be created on any valid CEF thread in either the browser or render +process. Once created the methods of the URL request object must be accessed +on the same thread that created it. + + + + +Load the request represented by the |request| object. + + + + + + + +Get the image hotspot (drag start location relative to image dimensions). + + + + +Get the image representation of drag data. +May return NULL if no image representation is available. + + + + +Returns the image width in density independent pixel(DIP) units. + + + + +Removes the representation for scaleFactor. + + + true for success + + + +Returns true if this Image and that Image share the same underlying storage. + + image to compare + returns true if share same underlying storage + + + +Returns true if this Image is empty. + + + + + +Returns true if this image contains a representation for scaleFactor. + + + + + + +Returns the image height in density independent pixel(DIP) units. + + + + +Returns information for the representation that most closely matches scaleFactor. + + scale factor + actual scale factor + pixel width + pixel height + return if information found for scale factor + + + +Returns the PNG representation that most closely matches scaleFactor. + + scale factor + is the PNG transparent + pixel width + pixel height + A stream represending the PNG or null. + + + +Returns the JPEG representation that most closely matches scaleFactor. + + scale factor + image quality + pixel width + pixel height + A stream representing the JPEG or null. + + + +Returns the bitmap representation that most closely matches scaleFactor. + + scale factor + color type + alpha type + pixel width + pixel height + A stream represending the bitmap or null. + + + +Return the handler for functionality specific to the render process. This +method is called on the render process main thread. + + + + +Return the handler for functionality specific to the browser process. This +method is called on multiple threads in the browser process. + + + + +Return the handler for resource bundle events. If +cef_settings_t.pack_loading_disabled is true a handler must be returned. +If no handler is returned resources will be loaded from pack files. This +method is called by the browser and render processes on multiple threads. + + + + +Provides an opportunity to register custom schemes. Do not keep a +reference to the |registrar| object. This method is called on the main +thread for each process and the registered schemes should be the same +across all processes. + + + + +Provides an opportunity to view and/or modify command-line arguments +before processing by CEF and Chromium. The |process_type| value will be +empty for the browser process. Do not keep a reference to the +CefCommandLine object passed to this method. The +cef_settings_t.command_line_args_disabled value can be used to start with +an empty command-line object. Any values specified in CefSettings that +equate to command-line arguments will be set before this method is called. +Be cautious when using this method to modify command-line arguments for +non-browser processes as this may result in undefined behavior including +crashes. + + + + +Implement this interface to provide handler implementations. Methods will be +called by the process and/or thread indicated. + + + + +Quit the CEF message loop that was started by calling CefRunMessageLoop(). +This function should only be called on the main application thread and only +if CefRunMessageLoop() was used. + + + + +Run the CEF message loop. Use this function instead of an application- +provided message loop to get the best balance between performance and CPU +usage. This function should only be called on the main application thread +and only if CefInitialize() is called with a +cef_settings_t.multi_threaded_message_loop value of false. This function +will block until a quit message is received by the system. + + + + +Perform a single iteration of CEF message loop processing. This function is +provided for cases where the CEF message loop must be integrated into an +existing application message loop. Use of this function is not recommended +for most users; use either the CefRunMessageLoop() function or +cef_settings_t.multi_threaded_message_loop if possible. When using this +function care must be taken to balance performance against excessive CPU +usage. It is recommended to enable the cef_settings_t.external_message_pump +option when using this function so that +CefBrowserProcessHandler::OnScheduleMessagePumpWork() callbacks can +facilitate the scheduling process. This function should only be called on +the main application thread and only if CefInitialize() is called with a +cef_settings_t.multi_threaded_message_loop value of false. This function +will not block. + + + + +This function should be called on the main application thread to shut down +the CEF browser process before the application exits. + + + + +This function should be called on the main application thread to initialize +the CEF browser process. The |application| parameter may be empty. A return +value of true indicates that it succeeded and false indicates that it +failed. The |windows_sandbox_info| parameter is only used on Windows and may +be NULL (see cef_sandbox_win.h for details). + + + + +This function should be called from the application entry point function to +execute a secondary process. It can be used to run secondary processes from +the browser client executable (default behavior) or from a separate +executable specified by the cef_settings_t.browser_subprocess_path value. If +called for the browser process (identified by no "type" command-line value) +it will return immediately with a value of -1. If called for a recognized +secondary process it will block until the process should exit and then +return the process exit code. The |application| parameter may be empty. The +|windows_sandbox_info| parameter is only used on Windows and may be NULL +(see cef_sandbox_win.h for details). + + + + +Return a new resource handler instance to handle the request or an empty +reference to allow default handling of the request. |browser| and |frame| +will be the browser window and frame respectively that originated the +request or NULL if the request did not originate from a browser window +(for example, if the request came from CefURLRequest). The |request| +object passed to this method cannot be modified. + + + +Return a new resource handler instance to handle the request or an empty +reference to allow default handling of the request. |browser| and |frame| +will be the browser window and frame respectively that originated the +request or NULL if the request did not originate from a browser window +(for example, if the request came from CefURLRequest). The |request| +object passed to this method cannot be modified. + + + + +Class that creates CefResourceHandler instances for handling scheme +requests. The methods of this class will always be called on the IO thread. + + + +Class that creates CefResourceHandler instances for handling scheme +requests. The methods of this class will always be called on the IO thread. + + + + +Register a custom scheme. This method should not be called for the +built-in HTTP, HTTPS, FILE, FTP, ABOUT and DATA schemes. + +See cef_scheme_options_t for possible values for |options|. + +This function may be called on any thread. It should only be called once +per unique |scheme_name| value. If |scheme_name| is already registered or +if an error occurs this method will return false. + + + +Register a custom scheme. This method should not be called for the +built-in HTTP, HTTPS, FILE, FTP, ABOUT and DATA schemes. + +See cef_scheme_options_t for possible values for |options|. + +This function may be called on any thread. It should only be called once +per unique |scheme_name| value. If |scheme_name| is already registered or +if an error occurs this method will return false. + + + + +Class that manages custom scheme registrations. + + + +Class that manages custom scheme registrations. + + + + +Clear all scheme handler factories registered with the global request +context. Returns false on error. This function may be called on any thread +in the browser process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->ClearSchemeHandlerFactories(). + + + +Clear all scheme handler factories registered with the global request +context. Returns false on error. This function may be called on any thread +in the browser process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->ClearSchemeHandlerFactories(). + + + + +Register a scheme handler factory with the global request context. An empty +|domain_name| value for a standard scheme will cause the factory to match +all domain names. The |domain_name| value will be ignored for non-standard +schemes. If |scheme_name| is a built-in scheme and no handler is returned by +|factory| then the built-in scheme handler factory will be called. If +|scheme_name| is a custom scheme then you must also implement the +CefApp::OnRegisterCustomSchemes() method in all processes. This function may +be called multiple times to change or remove the factory that matches the +specified |scheme_name| and optional |domain_name|. Returns false if an +error occurs. This function may be called on any thread in the browser +process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->RegisterSchemeHandlerFactory(). + + + +Register a scheme handler factory with the global request context. An empty +|domain_name| value for a standard scheme will cause the factory to match +all domain names. The |domain_name| value will be ignored for non-standard +schemes. If |scheme_name| is a built-in scheme and no handler is returned by +|factory| then the built-in scheme handler factory will be called. If +|scheme_name| is a custom scheme then you must also implement the +CefApp::OnRegisterCustomSchemes() method in all processes. This function may +be called multiple times to change or remove the factory that matches the +specified |scheme_name| and optional |domain_name|. Returns false if an +error occurs. This function may be called on any thread in the browser +process. Using this function is equivalent to calling +CefRequestContext::GetGlobalContext()->RegisterSchemeHandlerFactory(). + + + + +Called to retrieve data for the specified |resource_id| nearest the scale +factor |scale_factor|. To provide the resource data set |data| and +|data_size| to the data pointer and size respectively and return true. To +use the default resource data return false. The resource data will not be +copied and must remain resident in memory. Include cef_pack_resources.h +for a listing of valid resource ID values. + + + + +Called to retrieve data for the specified scale independent |resource_id|. +To provide the resource data set |data| and |data_size| to the data +pointer and size respectively and return true. To use the default resource +data return false. The resource data will not be copied and must remain +resident in memory. Include cef_pack_resources.h for a listing of valid +resource ID values. + + + + +Called to retrieve a localized translation for the specified |string_id|. +To provide the translation set |string| to the translation string and +return true. To use the default translation return false. Include +cef_pack_strings.h for a listing of valid string ID values. + + + + +Class used to implement a custom resource bundle interface. See CefSettings +for additional options related to resource bundle loading. The methods of +this class may be called on multiple threads. + + + + +Called when a new message is received from a different process. Return +true if the message was handled or false otherwise. It is safe to keep a +reference to |message| outside of this callback. + + + + +Called when a new node in the the browser gets focus. The |node| value may +be empty if no specific node has gained focus. The node object passed to +this method represents a snapshot of the DOM at the time this method is +executed. DOM objects are only valid for the scope of this method. Do not +keep references to or attempt to access any DOM objects outside the scope +of this method. + + + + +Called for global uncaught exceptions in a frame. Execution of this +callback is disabled by default. To enable set +cef_settings_t.uncaught_exception_stack_size > 0. + + + + +Called immediately before the V8 context for a frame is released. No +references to the context should be kept after this method is called. + + + + +Called immediately after the V8 context for a frame has been created. To +retrieve the JavaScript 'window' object use the CefV8Context::GetGlobal() +method. V8 handles can only be accessed from the thread on which they are +created. A task runner for posting tasks on the associated thread can be +retrieved via the CefV8Context::GetTaskRunner() method. + + + + +Return the handler for browser load status events. + + + + +Called before a browser is destroyed. + + + + +Called after a browser has been created. When browsing cross-origin a new +browser will be created before the old browser with the same identifier is +destroyed. |extra_info| is an optional read-only value originating from +CefBrowserHost::CreateBrowser(), CefBrowserHost::CreateBrowserSync(), +CefLifeSpanHandler::OnBeforePopup() or +CefBrowserView::CreateBrowserView(). + + + + +Called after WebKit has been initialized. + + + + +Class used to implement render process callbacks. The methods of this class +will be called on the render process main thread (TID_RENDERER) unless +otherwise indicated. + + + + +Return the default client for use with a newly created browser window. If +null is returned the browser will be unmanaged (no callbacks will be +executed for that browser) and application shutdown will be blocked until +the browser window is closed manually. This method is currently only used +with the chrome runtime. + + + + +Called before a child process is launched. Will be called on the browser +process UI thread when launching a render process and on the browser +process IO thread when launching a GPU process. Provides an opportunity to +modify the child process command line. Do not keep a reference to +|command_line| outside of this method. + + + + +Called on the browser process UI thread immediately after the CEF context +has been initialized. + + + + +Provides an opportunity to register custom preferences prior to +global and request context initialization. + +If |type| is CEF_PREFERENCES_TYPE_GLOBAL the registered preferences can be +accessed via CefPreferenceManager::GetGlobalPreferences after +OnContextInitialized is called. Global preferences are registered a single +time at application startup. See related cef_settings_t.cache_path and +cef_settings_t.persist_user_preferences configuration. + +If |type| is CEF_PREFERENCES_TYPE_REQUEST_CONTEXT the preferences can be +accessed via the CefRequestContext after +CefRequestContextHandler::OnRequestContextInitialized is called. Request +context preferences are registered each time a new CefRequestContext is +created. It is intended but not required that all request contexts have +the same registered preferences. See related +cef_request_context_settings_t.cache_path and +cef_request_context_settings_t.persist_user_preferences configuration. + +Do not keep a reference to the |registrar| object. This method is called +on the browser process UI thread. + + + + +Class used to implement browser process callbacks. The methods of this class +will be called on the browser process main thread unless otherwise +indicated. + + + + +Insert a command before the current command. +Common for debuggers, like "valgrind" or "gdb --args". + + + + +Add an argument to the end of the command line. + + + + +Get the remaining command line arguments. + + + + +True if there are remaining command line arguments. + + + + +Add a switch with the specified value to the end of the command line. If +the switch has no value pass an empty value string. + + + + +Add a switch to the end of the command line. + + + + +Returns the map of switch names and values. If a switch has no value an +empty string is returned. + + + + +Returns the value associated with the given switch. If the switch has no +value or isn't present this method returns the empty string. + + + + +Returns true if the command line contains the given switch. + + + + +Returns true if the command line has switches. + + + + +Set the program part of the command line string (the first item). + + + + +Get the program part of the command line string (the first item). + + + + +Constructs and returns the represented command line string. Use this +method cautiously because quoting behavior is unclear. + + + + +Retrieve the original command line string as a vector of strings. +The argv array: +`{ program, [(--|-|/)switch[=value]]*, [--], [argument]* }` + + + + +Reset the command-line switches and arguments but leave the program +component unchanged. + + + + +Initialize the command line with the string returned by calling +GetCommandLineW(). This method is only supported on Windows. + + + + +Initialize the command line with the specified |argc| and |argv| values. +The first argument must be the name of the program. This method is only +supported on non-Windows platforms. + + + + +Returns a writable copy of this object. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Returns the singleton global CefCommandLine object. The returned object +will be read-only. + + + + +Create a new CefCommandLine instance. + + + + +Class used to create and/or parse command line arguments. Arguments with +"--", "-" and, on Windows, "/" prefixes are considered switches. Switches +will always precede any arguments without switch prefixes. Switches can +optionally have a value specified using the "=" delimiter (e.g. +"-switch=value"). An argument of "--" will terminate switch parsing with all +subsequent tokens, regardless of prefix, being interpreted as non-switch +arguments. Switch names should be lowercase ASCII and will be converted to +such if necessary. Switch values will retain the original case and UTF8 +encoding. This class can be used before CefInitialize() is called. + + + + +Gets the inner most instance + + current instance + + + +Load an extension. If extension resources will be read from disk using the default load implementation then rootDirectoy +should be the absolute path to the extension resources directory and manifestJson should be null. +If extension resources will be provided by the client (e.g. via IRequestHandler and/or IExtensionHandler) then rootDirectory +should be a path component unique to the extension (if not absolute this will be internally prefixed with the PK_DIR_RESOURCES path) +and manifestJson should contain the contents that would otherwise be read from the "manifest.json" file on disk. +The loaded extension will be accessible in all contexts sharing the same storage (HasExtension returns true). +However, only the context on which this method was called is considered the loader (DidLoadExtension returns true) and only the +loader will receive IRequestContextHandler callbacks for the extension. will be +called on load success or will be called on load failure. +If the extension specifies a background script via the "background" manifest key then +will be called to create the background browser. See that method for additional information about background scripts. +For visible extension views the client application should evaluate the manifest to determine the correct extension URL to load and then pass +that URL to the IBrowserHost.CreateBrowser* function after the extension has loaded. For example, the client can look for the "browser_action" +manifest key as documented at https://developer.chrome.com/extensions/browserAction. Extension URLs take the form "chrome-extension:///". +Browsers that host extensions differ from normal browsers as follows: - Can access chrome.* JavaScript APIs if allowed by the manifest. +Visit chrome://extensions-support for the list of extension APIs currently supported by CEF. - Main frame navigation to non-extension +content is blocked. +- Pinch-zooming is disabled. +- returns the hosted extension. +- CefBrowserHost::IsBackgroundHost returns true for background hosts. See https://developer.chrome.com/extensions for extension implementation and usage documentation. + + If extension resources will be read from disk using the default load implementation then rootDirectoy +should be the absolute path to the extension resources directory and manifestJson should be null + If extension resources will be provided by the client then rootDirectory should be a path component unique to the extension +and manifestJson should contain the contents that would otherwise be read from the manifest.json file on disk + handle events related to browser extensions + + + +Returns true if this context has access to the extension identified by extensionId. +This may not be the context that was used to load the extension (see DidLoadExtension). +This method must be called on the CEF UI thread. + + extension id + Returns true if this context has access to the extension identified by extensionId + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Retrieve the list of all extensions that this context has access to (see HasExtension). + will be populated with the list of extension ID values. +This method must be called on the CEF UI thread. + + output a list of extensions Ids + returns true on success otherwise false + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns the extension matching extensionId or null if no matching extension is accessible in this context (see HasExtension). +This method must be called on the CEF UI thread. + + extension Id + Returns the extension matching extensionId or null if no matching extension is accessible in this context + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns true if this context was used to load the extension identified by extensionId. Other contexts sharing the same storage will also have access to the extension (see HasExtension). +This method must be called on the CEF UI thread. + + Returns true if this context was used to load the extension identified by extensionId + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Attempts to resolve origin to a list of associated IP addresses. + + host name to resolve + A task that represents the Resoolve Host operation. The value of the TResult parameter contains ResolveCallbackResult. + + + +Clears all active and idle connections that Chromium currently has. +This is only recommended if you have released all other CEF objects but +don't yet want to call Cef.Shutdown(). + + If is non-NULL it will be executed on the CEF UI thread after +completion. This param is optional + + + +Clears all HTTP authentication credentials that were added as part of handling +. + + If is non-NULL it will be executed on the CEF UI thread after +completion. This param is optional + + + +Clears all certificate exceptions that were added as part of handling +. If you call this it is +recommended that you also call or you risk not +being prompted again for server certificates if you reconnect quickly. + + If is non-NULL it will be executed on the CEF UI thread after +completion. This param is optional + + + +Set the value associated with preference name. If value is null the +preference will be restored to its default value. If setting the preference +fails then error will be populated with a detailed description of the +problem. This method must be called on the CEF UI thread. +Preferences set via the command-line usually cannot be modified. + + preference key + preference value + out error + Returns true if the value is set successfully and false otherwise. + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns true if the preference with the specified name can be modified +using SetPreference. As one example preferences set via the command-line +usually cannot be modified. This method must be called on the CEF UI thread. + + preference key + Returns true if the preference with the specified name can be modified +using SetPreference + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns all preferences as a dictionary. The returned +object contains a copy of the underlying preference values and +modifications to the returned object will not modify the underlying +preference values. This method must be called on the browser process UI +thread. + + If true then +preferences currently at their default value will be included. + Preferences (dictionary can have sub dictionaries) + + + +Returns the value for the preference with the specified name. Returns +NULL if the preference does not exist. The returned object contains a copy +of the underlying preference value and modifications to the returned object +will not modify the underlying preference value. This method must be called +on the CEF UI thread. + + preference name + Returns the value for the preference with the specified name + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns true if a preference with the specified name exists. This method +must be called on the CEF UI thread. + + name of preference + bool if the preference exists + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both +executed on the CEF UI thread, so can be called directly. +When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main +application thread will be the CEF UI thread. + + + +Returns the cache path for this object. If empty an "incognito mode" +in-memory cache is being used. + + + + +Clear all registered scheme handler factories. + + Returns false on error. + + + +Register a scheme handler factory for the specified schemeName and optional domainName. +An empty domainName value for a standard scheme will cause the factory to match all domain +names. The domainName value will be ignored for non-standard schemes. If schemeName is +a built-in scheme and no handler is returned by factory then the built-in scheme handler +factory will be called. If schemeName is a custom scheme then you must also implement the +IApp.OnRegisterCustomSchemes() method in all processes. This function may be called multiple +times to change or remove the factory that matches the specified schemeName and optional +domainName. + + Scheme Name + Optional domain name + Scheme handler factory + Returns false if an error occurs. + + + +Returns true if this object is the global context. The global context is +used by default when creating a browser or URL request with a NULL context +argument. + + + + +Returns the default cookie manager for this object. This will be the global +cookie manager if this object is the global request context. + + If callback is non-NULL it will be executed asnychronously on the CEF IO thread +after the manager's storage has been initialized. + Returns the default cookie manager for this object + + + +Returns true if this object is sharing the same storage as the specified context. + + context to compare + Returns true if same storage + + + +Returns true if this object is pointing to the same context object. + + context to compare + Returns true if the same + + + +Creates a new context object that shares storage with other and uses an +optional handler. + + shares storage with this RequestContext + optional requestContext handler + Returns a new RequestContext + + +Creates a new context object that shares storage with | other | and uses an optional | handler | . + + + +A request context provides request handling for a set of related browser objects. +A request context is specified when creating a new browser object via the CefBrowserHost +static factory methods. Browser objects with different request contexts will never be +hosted in the same render process. Browser objects with the same request context may or +may not be hosted in the same render process depending on the process model. +Browser objects created indirectly via the JavaScript window.open function or targeted +links will share the same render process and the same request context as the source browser. +When running in single-process mode there is only a single render process (the main process) +and so all browsers created in single-process mode will share the same request context. +This will be the first request context passed into a CefBrowserHost static factory method +and all other request context objects will be ignored. + + + + +Called on the browser process IO thread before a resource request is +initiated. The |browser| and |frame| values represent the source of the +request, and may be NULL for requests originating from service workers or +CefURLRequest. |request| represents the request contents and cannot be +modified in this callback. |is_navigation| will be true if the resource +request is a navigation. |is_download| will be true if the resource +request is a download. |request_initiator| is the origin (scheme + domain) +of the page that initiated the request. Set |disable_default_handling| to +true to disable default handling of the request, in which case it will +need to be handled via CefResourceRequestHandler::GetResourceHandler or it +will be canceled. To allow the resource load to proceed with default +handling return NULL. To specify a handler for the resource return a +CefResourceRequestHandler object. This method will not be called if the +client associated with |browser| returns a non-NULL value from +CefRequestHandler::GetResourceRequestHandler for the same request +(identified by CefRequest::GetIdentifier). + + + + +Called on the browser process UI thread immediately after the request +context has been initialized. + + + + +Implement this interface to provide handler implementations. The handler +instance will not be released until all objects related to the context have +been destroyed. + + + + +If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. This value will be ignored if + matches the value. + + + + +Comma delimited list of schemes supported by the associated +ICookieManager. If CookieableSchemesExcludeDefaults is false the +default schemes ("http", "https", "ws" and "wss") will also be supported. +Specifying a CookieableSchemesList value and setting +CookieableSchemesExcludeDefaults to true will disable all loading +and saving of cookies for this manager. This value will be ignored if + matches the value. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. Can be set globally +using the CefSettings.accept_language_list value or overridden on a per- +browser basis using the BrowserSettings.AcceptLanguageList value. If +all values are empty then "en-US,en" will be used. This value will be +ignored if CachePath matches the CefSettings.CachePath value. + + + + +The location where cache data for this request context will be stored on +disk. If this value is non-empty then it must be an absolute path that is +either equal to or a child directory of CefSettings.RootCachePath. +If the value is empty then browsers will be created in "incognito mode" +where in-memory caches are used for storage and no data is persisted to disk. +HTML5 databases such as localStorage will only persist across sessions if a +cache path is specified. To share the global browser cache and related +configuration set this value to match the CefSettings.CachePath value. + + + + +To persist user preferences as a JSON file in the cache path directory set +this value to true. Can be set globally using the +CefSettings.PersistUserPreferences value. This value will be ignored if +CachePath is empty or if it matches the CefSettings.CachePath value. + + + + +To persist session cookies (cookies without an expiry date or validity +interval) by default when using the global cookie manager set this value to +true. Session cookies are generally intended to be transient and most +Web browsers do not persist them. Can be set globally using the +CefSettings.PersistSessionCookies value. This value will be ignored if +CachePath is empty or if it matches the CefSettings.CachePath value. + + + + +Initializes a new instance of the RequestContextSettings class. + + + + +RequestContextSettings + + + + +True if dispose should be called after this object is used + + + + +Gets a value indicating if the browser settings has been disposed. + + + + +The maximum rate in frames per second (fps) that CefRenderHandler::OnPaint +will be called for a windowless browser. The actual fps may be lower if +the browser cannot generate frames at the requested rate. The minimum +value is 1 and the maximum value is 60 (default 30). This value can also be +changed dynamically via IBrowserHost.SetWindowlessFrameRate. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. May be overridden on a +per-browser basis using the CefBrowserSettings.AcceptLanguageList value. +If both values are empty then "en-US,en" will be used. Can be overridden +for individual RequestContext instances via the +RequestContextSettings.AcceptLanguageList value. + + + + +Background color used for the browser before a document is loaded and when no document color +is specified. The alpha component must be either fully opaque (0xFF) or fully transparent (0x00). +If the alpha component is fully opaque then the RGB components will be used as the background +color. If the alpha component is fully transparent for a WinForms browser then the +CefSettings.BackgroundColor value will be used. If the alpha component is fully transparent +for a windowless (WPF/OffScreen) browser then transparent painting will be enabled. + + + + +Controls whether WebGL can be used. Note that WebGL requires hardware +support and may not work on all systems even when enabled. Also +configurable using the "disable-webgl" command-line switch. + + + + +Controls whether databases can be used. Also configurable using the +"disable-databases" command-line switch. + + + + +Controls whether local storage can be used. Also configurable using the +"disable-local-storage" command-line switch. + + + + +Controls whether the tab key can advance focus to links. Also configurable +using the "disable-tab-to-links" command-line switch. + + + + +Controls whether text areas can be resized. Also configurable using the +"disable-text-area-resize" command-line switch. + + + + +Controls whether standalone images will be shrunk to fit the page. Also +configurable using the "image-shrink-standalone-to-fit" command-line +switch. + + + + +Controls whether image URLs will be loaded from the network. A cached image +will still be rendered if requested. Also configurable using the +"disable-image-loading" command-line switch. + + + + +Controls whether DOM pasting is supported in the editor via +execCommand("paste"). The |javascript_access_clipboard| setting must also +be enabled. Also configurable using the "disable-javascript-dom-paste" +command-line switch. + + + + +Controls whether JavaScript can access the clipboard. Also configurable +using the "disable-javascript-access-clipboard" command-line switch. + + + + +Controls whether JavaScript can be used to close windows that were not +opened via JavaScript. JavaScript can still be used to close windows that +were opened via JavaScript. Also configurable using the +"disable-javascript-close-windows" command-line switch. + + + + +Controls whether JavaScript can be executed. (Used to Enable/Disable javascript) +Also configurable using the "disable-javascript" command-line switch. + + + + +Controls the loading of fonts from remote sources. Also configurable using +the "disable-remote-fonts" command-line switch. + + + + +Default encoding for Web content. If empty "ISO-8859-1" will be used. Also +configurable using the "default-encoding" command-line switch. + + + + +MinimumLogicalFontSize + + + + +MinimumFontSize + + + + +DefaultFixedFontSize + + + + +DefaultFontSize + + + + +FantasyFontFamily + + + + +CursiveFontFamily + + + + +SansSerifFontFamily + + + + +SerifFontFamily + + + + +FixedFontFamily + + + + +StandardFontFamily + + + + +Destructor. + + + + +Finalizer. + + + + +Default Constructor + + + + +Internal Constructor + + + + +Browser initialization settings. Specify NULL or 0 to get the recommended +default values. The consequences of using custom values may not be well +tested. Many of these and other settings can also configured using command- +line switches. + + + + +Called when a new message is received from a different process. Return +true if the message was handled or false otherwise. It is safe to keep a +reference to |message| outside of this callback. + + + +Called when a new message is received from a different process. Return +true if the message was handled or false otherwise. It is safe to keep a +reference to |message| outside of this callback. + + + + +Return the handler for browser request events. + + + +Return the handler for browser request events. + + + + +Return the handler for off-screen rendering events. + + + +Return the handler for off-screen rendering events. + + + + +Return the handler for printing on Linux. If a print handler is not +provided then printing will not be supported on the Linux platform. + + + +Return the handler for printing on Linux. If a print handler is not +provided then printing will not be supported on the Linux platform. + + + + +Return the handler for browser load status events. + + + +Return the handler for browser load status events. + + + + +Return the handler for browser life span events. + + + +Return the handler for browser life span events. + + + + +Return the handler for keyboard events. + + + +Return the handler for keyboard events. + + + + +Return the handler for JavaScript dialogs. If no handler is provided the +default implementation will be used. + + + +Return the handler for JavaScript dialogs. If no handler is provided the +default implementation will be used. + + + + +Return the handler for permission requests. + + + +Return the handler for permission requests. + + + + +Return the handler for events related to CefFrame lifespan. This method +will be called once during CefBrowser creation and the result will be +cached for performance reasons. + + + +Return the handler for events related to CefFrame lifespan. This method +will be called once during CefBrowser creation and the result will be +cached for performance reasons. + + + + +Return the handler for focus events. + + + +Return the handler for focus events. + + + + +Return the handler for find result events. + + + +Return the handler for find result events. + + + + +Return the handler for drag events. + + + +Return the handler for drag events. + + + + +Return the handler for download events. If no handler is returned +downloads will not be allowed. + + + +Return the handler for download events. If no handler is returned +downloads will not be allowed. + + + + +Return the handler for browser display state events. + + + +Return the handler for browser display state events. + + + + +Return the handler for dialogs. If no handler is provided the default +implementation will be used. + + + +Return the handler for dialogs. If no handler is provided the default +implementation will be used. + + + + +Return the handler for context menus. If no handler is provided the +default implementation will be used. + + + +Return the handler for context menus. If no handler is provided the +default implementation will be used. + + + + +Return the handler for commands. If no handler is provided the default +implementation will be used. + + + +Return the handler for commands. If no handler is provided the default +implementation will be used. + + + + +Return the handler for audio rendering events. + + + +Return the handler for audio rendering events. + + + + +Implement this interface to provide handler implementations. + + + +Implement this interface to provide handler implementations. + + + + +Called on the browser process UI thread when the window.document object of +the main frame has been created. + + + + +Called on the browser process UI thread when the render process +terminates unexpectedly. |status| indicates how the process +terminated. + + + + +Called on the browser process UI thread when the render view associated +with |browser| is ready to receive/handle IPC messages in the render +process. + + + + +Called on the UI thread when a client certificate is being requested for +authentication. Return false to use the default behavior and automatically +select the first certificate available. Return true and call +CefSelectClientCertificateCallback::Select either in this method or at a +later time to select a certificate. Do not call Select or call it with +NULL to continue without using any certificate. |isProxy| indicates +whether the host is an HTTPS proxy or the origin server. |host| and |port| +contains the hostname and port of the SSL server. |certificates| is the +list of certificates to choose from; this list has already been pruned by +Chromium so that it only contains certificates from issuers that the +server trusts. + + + + +Called on the UI thread to handle requests for URLs with an invalid +SSL certificate. Return true and call CefCallback methods either in this +method or at a later time to continue or cancel the request. Return false +to cancel the request immediately. If +cef_settings_t.ignore_certificate_errors is set all invalid certificates +will be accepted without calling this method. + + + + +Called on the IO thread when the browser needs credentials from the user. +|origin_url| is the origin making this authentication request. |isProxy| +indicates whether the host is a proxy server. |host| contains the hostname +and |port| contains the port number. |realm| is the realm of the challenge +and may be empty. |scheme| is the authentication scheme used, such as +"basic" or "digest", and will be empty if the source of the request is an +FTP server. Return true to continue the request and call +CefAuthCallback::Continue() either in this method or at a later time when +the authentication information is available. Return false to cancel the +request immediately. + + + + +Called on the browser process IO thread before a resource request is +initiated. The |browser| and |frame| values represent the source of the +request. |request| represents the request contents and cannot be modified +in this callback. |is_navigation| will be true if the resource request is +a navigation. |is_download| will be true if the resource request is a +download. |request_initiator| is the origin (scheme + domain) of the page +that initiated the request. Set |disable_default_handling| to true to +disable default handling of the request, in which case it will need to be +handled via CefResourceRequestHandler::GetResourceHandler or it will be +canceled. To allow the resource load to proceed with default handling +return NULL. To specify a handler for the resource return a +CefResourceRequestHandler object. If this callback returns NULL the same +method will be called on the associated CefRequestContextHandler, if any. + + + + +Called on the UI thread before OnBeforeBrowse in certain limited cases +where navigating a new or different browser might be desirable. This +includes user-initiated navigation that might open in a special way (e.g. +links clicked via middle-click or ctrl + left-click) and certain types of +cross-origin navigation initiated from the renderer process (e.g. +navigating the top-level frame to/from a file URL). The |browser| and +|frame| values represent the source of the navigation. The +|target_disposition| value indicates where the user intended to navigate +the browser based on standard Chromium behaviors (e.g. current tab, +new tab, etc). The |user_gesture| value will be true if the browser +navigated via explicit user gesture (e.g. clicking a link) or false if it +navigated automatically (e.g. via the DomContentLoaded event). Return true +to cancel the navigation or false to allow the navigation to proceed in +the source browser's top-level frame. + + + + +Called on the UI thread before browser navigation. Return true to cancel +the navigation or false to allow the navigation to proceed. The |request| +object cannot be modified in this callback. +CefLoadHandler::OnLoadingStateChange will be called twice in all cases. +If the navigation is allowed CefLoadHandler::OnLoadStart and +CefLoadHandler::OnLoadEnd will be called. If the navigation is canceled +CefLoadHandler::OnLoadError will be called with an |errorCode| value of +ERR_ABORTED. The |user_gesture| value will be true if the browser +navigated via explicit user gesture (e.g. clicking a link) or false if it +navigated automatically (e.g. via the DomContentLoaded event). + + + + +Implement this interface to handle events related to browser requests. The +methods of this class will be called on the thread indicated. + + + + +Chooses the specified certificate for client certificate authentication. +NULL value means that no client certificate should be used. + + + + +Callback interface used to select a client certificate for authentication. + + + + +Returns true if the certificate status represents an error. + + + + +Returns the X.509 certificate. + + + + +Returns a bitmask containing any and all problems verifying the server +certificate. + + + + +Class representing SSL information. + + + + +Called on the IO thread after a resource response is received. The +|browser| and |frame| values represent the source of the request, and may +be NULL for requests originating from service workers or CefURLRequest. +|request| cannot be modified in this callback. Return true if the +specified cookie returned with the response can be saved or false +otherwise. + + + + +Called on the IO thread before a resource request is sent. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. |request| +cannot be modified in this callback. Return true if the specified cookie +can be sent with the request or false otherwise. + + + + +Implement this interface to filter cookies that may be sent or received from +resource requests. The methods of this class will be called on the IO thread +unless otherwise indicated. + + + + +Called on the IO thread to handle requests for URLs with an unknown +protocol component. The |browser| and |frame| values represent the source +of the request, and may be NULL for requests originating from service +workers or CefURLRequest. |request| cannot be modified in this callback. +Set |allow_os_execution| to true to attempt execution via the registered +OS protocol handler, if any. SECURITY WARNING: YOU SHOULD USE THIS METHOD +TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR OTHER URL ANALYSIS BEFORE +ALLOWING OS EXECUTION. + + + + +Called on the IO thread when a resource load has completed. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. |request| +and |response| represent the request and response respectively and cannot +be modified in this callback. |status| indicates the load completion +status. |received_content_length| is the number of response bytes actually +read. This method will be called for all requests, including requests that +are aborted due to CEF shutdown or destruction of the associated browser. +In cases where the associated browser is destroyed this callback may +arrive after the CefLifeSpanHandler::OnBeforeClose callback for that +browser. The CefFrame::IsValid method can be used to test for this +situation, and care should be taken not to call |browser| or |frame| +methods that modify state (like LoadURL, SendProcessMessage, etc.) if the +frame is invalid. + + + + +Called on the IO thread to optionally filter resource response content. +The |browser| and |frame| values represent the source of the request, and +may be NULL for requests originating from service workers or +CefURLRequest. |request| and |response| represent the request and response +respectively and cannot be modified in this callback. + + + + +Called on the IO thread when a resource response is received. The +|browser| and |frame| values represent the source of the request, and may +be NULL for requests originating from service workers or CefURLRequest. To +allow the resource load to proceed without modification return false. To +redirect or retry the resource load optionally modify |request| and return +true. Modification of the request URL will be treated as a redirect. +Requests handled using the default network loader cannot be redirected in +this callback. The |response| object cannot be modified in this callback. + +WARNING: Redirecting using this method is deprecated. Use +OnBeforeResourceLoad or GetResourceHandler to perform redirects. + + + + +Called on the IO thread when a resource load is redirected. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. The +|request| parameter will contain the old URL and other request-related +information. The |response| parameter will contain the response that +resulted in the redirect. The |new_url| parameter will contain the new URL +and can be changed if desired. The |request| and |response| objects cannot +be modified in this callback. + + + + +Called on the IO thread before a resource is loaded. The |browser| and +|frame| values represent the source of the request, and may be NULL for +requests originating from service workers or CefURLRequest. To allow the +resource to load using the default network loader return NULL. To specify +a handler for the resource return a CefResourceHandler object. The +|request| object cannot not be modified in this callback. + + + + +Called on the IO thread before a resource request is loaded. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. To +redirect or change the resource load optionally modify |request|. +Modification of the request URL will be treated as a redirect. Return +RV_CONTINUE to continue the request immediately. Return RV_CONTINUE_ASYNC +and call CefCallback methods at a later time to continue or cancel the +request asynchronously. Return RV_CANCEL to cancel the request +immediately. + + + + +Called on the IO thread before a resource request is loaded. The |browser| +and |frame| values represent the source of the request, and may be NULL +for requests originating from service workers or CefURLRequest. To +optionally filter cookies for the request return a CefCookieAccessFilter +object. The |request| object cannot not be modified in this callback. + + + + +Implement this interface to handle events related to browser requests. The +methods of this class will be called on the IO thread unless otherwise +indicated. + + + + +Called to filter a chunk of data. Expected usage is as follows: + + 1. Read input data from |data_in| and set |data_in_read| to the number of + bytes that were read up to a maximum of |data_in_size|. |data_in| will + be NULL if |data_in_size| is zero. + 2. Write filtered output data to |data_out| and set |data_out_written| to + the number of bytes that were written up to a maximum of + |data_out_size|. If no output data was written then all data must be + read from |data_in| (user must set |data_in_read| = |data_in_size|). + 3. Return RESPONSE_FILTER_DONE if all output data was written or + RESPONSE_FILTER_NEED_MORE_DATA if output data is still pending. + +This method will be called repeatedly until the input buffer has been +fully read (user sets |data_in_read| = |data_in_size|) and there is no +more input data to filter (the resource response is complete). This method +may then be called an additional time with an empty input buffer if the +user filled the output buffer (set |data_out_written| = |data_out_size|) +and returned RESPONSE_FILTER_NEED_MORE_DATA to indicate that output data +is still pending. + +Calls to this method will stop when one of the following conditions is +met: + + 1. There is no more input data to filter (the resource response is + complete) and the user sets |data_out_written| = 0 or returns + RESPONSE_FILTER_DONE to indicate that all data has been written, or; + 2. The user returns RESPONSE_FILTER_ERROR to indicate an error. + +Do not keep a reference to the buffers passed to this method. + + + + +Initialize the response filter. Will only be called a single time. The +filter will not be installed if this method returns false. + + + + +Implement this interface to filter resource response content. The methods of +this class will be called on the browser process IO thread. + + + + +Request processing has been canceled. + + + + +Read response data. If data is available immediately copy up to +|bytes_to_read| bytes into |data_out|, set |bytes_read| to the number of +bytes copied, and return true. To read the data at a later time set +|bytes_read| to 0, return true and call CefCallback::Continue() when the +data is available. To indicate response completion return false. + +WARNING: This method is deprecated. Use Skip and Read instead. + + + + +Retrieve response header information. If the response length is not known +set |response_length| to -1 and ReadResponse() will be called until it +returns false. If the response length is known set |response_length| +to a positive value and ReadResponse() will be called until it returns +false or the specified number of bytes have been read. Use the |response| +object to set the mime type, http status code and other optional header +values. To redirect the request to a new URL set |redirectUrl| to the new +URL. |redirectUrl| can be either a relative or fully qualified URL. +It is also possible to set |response| to a redirect http status code +and pass the new URL via a Location header. Likewise with |redirectUrl| it +is valid to set a relative or fully qualified URL as the Location header +value. If an error occured while setting up the request you can call +SetError() on |response| to indicate the error condition. + + + + +Begin processing the request. To handle the request return true and call +CefCallback::Continue() once the response header information is available +(CefCallback::Continue() can also be called from inside this method if +header information is available immediately). To cancel the request return +false. + +WARNING: This method is deprecated. Use Open instead. + + + + +Open the response stream. To handle the request immediately set +|handle_request| to true and return true. To decide at a later time set +|handle_request| to false, return true, and execute |callback| to continue +or cancel the request. To cancel the request immediately set +|handle_request| to true and return false. This method will be called in +sequence but not from a dedicated thread. For backwards compatibility set +|handle_request| to false and return false and the ProcessRequest method +will be called. + + + + +Class used to implement a custom request handler interface. The methods of +this class will be called on the IO thread unless otherwise indicated. + + + + +Callback for asynchronous continuation of CefResourceHandler::Read(). + + + + +Callback for asynchronous continuation of CefResourceHandler::Skip(). + + + + +Cancel the authentication request. + + + +Cancel the authentication request. + + + + +Continue the authentication request. + + + +Continue the authentication request. + + + + +Callback interface used for asynchronous continuation of authentication +requests. + + + +Callback interface used for asynchronous continuation of authentication +requests. + + + + +Called when an on-screen keyboard should be shown or hidden for the +specified |browser|. |input_mode| specifies what kind of keyboard +should be opened. If |input_mode| is CEF_TEXT_INPUT_MODE_NONE, any +existing keyboard for this browser should be hidden. + + + + +Called when text selection has changed for the specified |browser|. +|selected_text| is the currently selected text and |selected_range| is +the character range. + + + + +Called when the IME composition range has changed. |selected_range| is the +range of characters that have been selected. |character_bounds| is the +bounds of each character in view coordinates. + + + + +Called when the scroll offset has changed. + + + + +Called when the user starts dragging content in the web view. Contextual +information about the dragged content is supplied by |drag_data|. +(|x|, |y|) is the drag start location in screen coordinates. +OS APIs that run a system message loop may be used within the +StartDragging call. + +Return false to abort the drag operation. Don't call any of +CefBrowserHost::DragSource*Ended* methods after returning false. + +Return true to handle the drag operation. Call +CefBrowserHost::DragSourceEndedAt and DragSourceSystemDragEnded either +synchronously or asynchronously to inform the web view that the drag +operation has ended. + + + + +Called when touch handle state is updated. The client is responsible for +rendering the touch handles. + + + + +Called to retrieve the size of the touch handle for the specified +|orientation|. + + + + +Called when an element has been rendered to the shared texture handle. +|type| indicates whether the element is the view or the popup widget. +|dirtyRects| contains the set of rectangles in pixel coordinates that need +to be repainted. |shared_handle| is the handle for a D3D11 Texture2D that +can be accessed via ID3D11Device using the OpenSharedResource method. This +method is only called when CefWindowInfo::shared_texture_enabled is set to +true, and is currently only supported on Windows. + + + + +Called when an element should be painted. Pixel values passed to this +method are scaled relative to view coordinates based on the value of +CefScreenInfo.device_scale_factor returned from GetScreenInfo. |type| +indicates whether the element is the view or the popup widget. |buffer| +contains the pixel data for the whole image. |dirtyRects| contains the set +of rectangles in pixel coordinates that need to be repainted. |buffer| +will be |width|*|height|*4 bytes in size and represents a BGRA image with +an upper-left origin. This method is only called when +CefWindowInfo::shared_texture_enabled is set to false. + + + + +Called when the browser wants to move or resize the popup widget. |rect| +contains the new location and size in view coordinates. + + + + +Called when the browser wants to show or hide the popup widget. The popup +should be shown if |show| is true and hidden if |show| is false. + + + + +Called to allow the client to fill in the CefScreenInfo object with +appropriate values. Return true if the |screen_info| structure has been +modified. + +If the screen info rectangle is left empty the rectangle from GetViewRect +will be used. If the rectangle is still empty or invalid popups may not be +drawn correctly. + + + + +Called to retrieve the translation from view DIP coordinates to screen +coordinates. Windows/Linux should provide screen device (pixel) +coordinates and MacOS should provide screen DIP coordinates. Return true +if the requested coordinates were provided. + + + + +Called to retrieve the view rectangle in screen DIP coordinates. This +method must always provide a non-empty rectangle. + + + + +Called to retrieve the root window rectangle in screen DIP coordinates. +Return true if the rectangle was provided. If this method returns false +the rectangle from GetViewRect will be used. + + + + +Return the handler for accessibility notifications. If no handler is +provided the default implementation will be used. + + + + +Implement this interface to handle events when window rendering is disabled. +The methods of this class will be called on the UI thread. + + + + +Called after renderer process sends accessibility location changes to the +browser process. + + + + +Called after renderer process sends accessibility tree changes to the +browser process. + + + + +Implement this interface to receive accessibility notification when +accessibility events have been registered. The methods of this class will +be called on the UI thread. + + + + +Return the PDF paper size in device units. Used in combination with +CefBrowserHost::PrintToPDF(). + + + + +Reset client state related to printing. + + + + +Send the print job to the printer. Execute |callback| once the job is +completed. Return true if the job will proceed or false to cancel the job +immediately. + + + + +Show the print dialog. Execute |callback| once the dialog is dismissed. +Return true if the dialog will be displayed or false to cancel the +printing immediately. + + + + +Synchronize |settings| with client state. If |get_defaults| is true then +populate |settings| with the default print settings. Do not keep a +reference to |settings| outside of this callback. + + + + +Called when printing has started for the specified |browser|. This method +will be called before the other OnPrint*() methods and irrespective of how +printing was initiated (e.g. CefBrowserHost::Print(), JavaScript +window.print() or PDF extension print button). + + + + +Implement this interface to handle printing on Linux. Each browser will have +only one print job in progress at a time. The methods of this class will be +called on the browser process UI thread. + + + + +Indicate completion of the print job. + + + + +Callback interface for asynchronous continuation of print job requests. + + + + +Cancel the printing. + + + + +Continue printing with the specified |settings|. + + + + +Callback interface for asynchronous continuation of print dialog requests. + + + + +Get the duplex mode. + + + + +Set the duplex mode. + + + + +Get the number of copies. + + + + +Set the number of copies. + + + + +Get the color model. + + + + +Set the color model. + + + + +Returns true if pages will be collated. + + + + +Set whether pages will be collated. + + + + +Returns true if only the selection will be printed. + + + + +Set whether only the selection will be printed. + + + + +Retrieve the page ranges. + + + + +Returns the number of page ranges that currently exist. + + + + +Set the page ranges. + + + + +Get the DPI (dots per inch). + + + + +Set the DPI (dots per inch). + + + + +Get the device name. + + + + +Set the device name. + + + + +Set the printer printable area in device units. +Some platforms already provide flipped area. Set |landscape_needs_flip| +to false on those platforms to avoid double flipping. + + + + +Returns true if the orientation is landscape. + + + + +Set the page orientation. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Create a new CefPrintSettings object. + + + + +Class representing print settings. + + + + +Called when a permission prompt handled via OnShowPermissionPrompt is +dismissed. |prompt_id| will match the value that was passed to +OnShowPermissionPrompt. |result| will be the value passed to +CefPermissionPromptCallback::Continue or CEF_PERMISSION_RESULT_IGNORE if +the dialog was dismissed for other reasons such as navigation, browser +closure, etc. This method will not be called if OnShowPermissionPrompt +returned false for |prompt_id|. + + + + +Called when a page should show a permission prompt. |prompt_id| uniquely +identifies the prompt. |requesting_origin| is the URL origin requesting +permission. |requested_permissions| is a combination of values from +cef_permission_request_types_t that represent the requested permissions. +Return true and call CefPermissionPromptCallback::Continue either in this +method or at a later time to continue or cancel the request. Return false +to proceed with default handling. With the Chrome runtime, default +handling will display the permission prompt UI. With the Alloy runtime, +default handling is CEF_PERMISSION_RESULT_IGNORE. + + + + +Called when a page requests permission to access media. +|requesting_origin| is the URL origin requesting permission. +|requested_permissions| is a combination of values from +cef_media_access_permission_types_t that represent the requested +permissions. Return true and call CefMediaAccessCallback methods either in +this method or at a later time to continue or cancel the request. Return +false to proceed with default handling. With the Chrome runtime, default +handling will display the permission request UI. With the Alloy runtime, +default handling will deny the request. This method will not be called if +the "--enable-media-stream" command-line switch is used to grant all +permissions. + + + + +Implement this interface to handle events related to permission requests. +The methods of this class will be called on the browser process UI thread. + + + + +Complete the permissions request with the specified |result|. + + + + +Callback interface used for asynchronous continuation of permission prompts. + + + + +Cancel the media access request. + + + + +Call to allow or deny media access. If this callback was initiated in +response to a getUserMedia (indicated by +CEF_MEDIA_PERMISSION_DEVICE_AUDIO_CAPTURE and/or +CEF_MEDIA_PERMISSION_DEVICE_VIDEO_CAPTURE being set) then +|allowed_permissions| must match |required_permissions| passed to +OnRequestMediaAccessPermission. + + + + +Callback interface used for asynchronous continuation of media access +permission requests. + + + + +Called when a navigation fails or is canceled. This method may be called +by itself if before commit or in combination with OnLoadStart/OnLoadEnd if +after commit. |errorCode| is the error code number, |errorText| is the +error text and |failedUrl| is the URL that failed to load. +See net\base\net_error_list.h for complete descriptions of the error +codes. + + + + +Called when the browser is done loading a frame. The |frame| value will +never be empty -- call the IsMain() method to check if this frame is the +main frame. Multiple frames may be loading at the same time. Sub-frames +may start or continue loading after the main frame load has ended. This +method will not be called for same page navigations (fragments, history +state, etc.) or for navigations that fail or are canceled before commit. +For notification of overall browser load status use OnLoadingStateChange +instead. + + + + +Called after a navigation has been committed and before the browser begins +loading contents in the frame. The |frame| value will never be empty -- +call the IsMain() method to check if this frame is the main frame. +|transition_type| provides information about the source of the navigation +and an accurate value is only available in the browser process. Multiple +frames may be loading at the same time. Sub-frames may start or continue +loading after the main frame load has ended. This method will not be +called for same page navigations (fragments, history state, etc.) or for +navigations that fail or are canceled before commit. For notification of +overall browser load status use OnLoadingStateChange instead. + + + + +Called when the loading state has changed. This callback will be executed +twice -- once when loading is initiated either programmatically or by user +action, and once when loading is terminated due to completion, +cancellation of failure. It will be called before any calls to OnLoadStart +and after all calls to OnLoadError and/or OnLoadEnd. + + + + +Implement this interface to handle events related to browser load status. +The methods of this class will be called on the browser process UI thread or +render process main thread (TID_RENDERER). + + + + +Called just before a browser is destroyed. Release all references to the +browser object and do not attempt to execute any methods on the browser +object (other than IsValid, GetIdentifier or IsSame) after this callback +returns. CefFrameHandler callbacks related to final main frame destruction +will arrive after this callback and CefBrowser::IsValid will return false +at that time. Any in-progress network requests associated with |browser| +will be aborted when the browser is destroyed, and +CefResourceRequestHandler callbacks related to those requests may still +arrive on the IO thread after this callback. See CefFrameHandler and +DoClose() documentation for additional usage information. + + + + +Called when a browser has recieved a request to close. This may result +directly from a call to CefBrowserHost::*CloseBrowser() or indirectly if +the browser is parented to a top-level window created by CEF and the user +attempts to close that window (by clicking the 'X', for example). The +DoClose() method will be called after the JavaScript 'onunload' event has +been fired. + +An application should handle top-level owner window close notifications by +calling CefBrowserHost::TryCloseBrowser() or +CefBrowserHost::CloseBrowser(false) instead of allowing the window to +close immediately (see the examples below). This gives CEF an opportunity +to process the 'onbeforeunload' event and optionally cancel the close +before DoClose() is called. + +When windowed rendering is enabled CEF will internally create a window or +view to host the browser. In that case returning false from DoClose() will +send the standard close notification to the browser's top-level owner +window (e.g. WM_CLOSE on Windows, performClose: on OS X, "delete_event" on +Linux or CefWindowDelegate::CanClose() callback from Views). If the +browser's host window/view has already been destroyed (via view hierarchy +tear-down, for example) then DoClose() will not be called for that browser +since is no longer possible to cancel the close. + +When windowed rendering is disabled returning false from DoClose() will +cause the browser object to be destroyed immediately. + +If the browser's top-level owner window requires a non-standard close +notification then send that notification from DoClose() and return true. + +The CefLifeSpanHandler::OnBeforeClose() method will be called after +DoClose() (if DoClose() is called) and immediately before the browser +object is destroyed. The application should only exit after +OnBeforeClose() has been called for all existing browsers. + +The below examples describe what should happen during window close when +the browser is parented to an application-provided top-level window. + +Example 1: Using CefBrowserHost::TryCloseBrowser(). This is recommended +for clients using standard close handling and windows created on the +browser process UI thread. +1. User clicks the window close button which sends a close notification + to the application's top-level window. +2. Application's top-level window receives the close notification and + calls TryCloseBrowser() (which internally calls CloseBrowser(false)). + TryCloseBrowser() returns false so the client cancels the window + close. +3. JavaScript 'onbeforeunload' handler executes and shows the close + confirmation dialog (which can be overridden via + CefJSDialogHandler::OnBeforeUnloadDialog()). +4. User approves the close. +5. JavaScript 'onunload' handler executes. +6. CEF sends a close notification to the application's top-level window + (because DoClose() returned false by default). +7. Application's top-level window receives the close notification and + calls TryCloseBrowser(). TryCloseBrowser() returns true so the client + allows the window close. +8. Application's top-level window is destroyed. +9. Application's OnBeforeClose() handler is called and the browser object + is destroyed. +10. Application exits by calling CefQuitMessageLoop() if no other browsers + exist. + +Example 2: Using CefBrowserHost::CloseBrowser(false) and implementing the +DoClose() callback. This is recommended for clients using non-standard +close handling or windows that were not created on the browser process UI +thread. +1. User clicks the window close button which sends a close notification + to the application's top-level window. +2. Application's top-level window receives the close notification and: + A. Calls CefBrowserHost::CloseBrowser(false). + B. Cancels the window close. +3. JavaScript 'onbeforeunload' handler executes and shows the close + confirmation dialog (which can be overridden via + CefJSDialogHandler::OnBeforeUnloadDialog()). +4. User approves the close. +5. JavaScript 'onunload' handler executes. +6. Application's DoClose() handler is called. Application will: + A. Set a flag to indicate that the next close attempt will be allowed. + B. Return false. +7. CEF sends an close notification to the application's top-level window. +8. Application's top-level window receives the close notification and + allows the window to close based on the flag from #6B. +9. Application's top-level window is destroyed. +10. Application's OnBeforeClose() handler is called and the browser object + is destroyed. +11. Application exits by calling CefQuitMessageLoop() if no other browsers + exist. + + + + +Called after a new browser is created. It is now safe to begin performing +actions with |browser|. CefFrameHandler callbacks related to initial main +frame creation will arrive before this callback. See CefFrameHandler +documentation for additional usage information. + + + + +Called on the UI thread before a new popup browser is created. The +|browser| and |frame| values represent the source of the popup request. +The |target_url| and |target_frame_name| values indicate where the popup +browser should navigate and may be empty if not specified with the +request. The |target_disposition| value indicates where the user intended +to open the popup (e.g. current tab, new tab, etc). The |user_gesture| +value will be true if the popup was opened via explicit user gesture (e.g. +clicking a link) or false if the popup opened automatically (e.g. via the +DomContentLoaded event). The |popupFeatures| structure contains additional +information about the requested popup window. To allow creation of the +popup browser optionally modify |windowInfo|, |client|, |settings| and +|no_javascript_access| and return false. To cancel creation of the popup +browser return true. The |client| and |settings| values will default to +the source browser's values. If the |no_javascript_access| value is set to +false the new browser will not be scriptable and may not be hosted in the +same renderer process as the source browser. Any modifications to +|windowInfo| will be ignored if the parent browser is wrapped in a +CefBrowserView. Popup browser creation will be canceled if the parent +browser is destroyed before the popup browser creation completes +(indicated by a call to OnAfterCreated for the popup browser). The +|extra_info| parameter provides an opportunity to specify extra +information specific to the created popup browser that will be passed to +CefRenderProcessHandler::OnBrowserCreated() in the render process. + + + + +Implement this interface to handle events related to browser life span. The +methods of this class will be called on the UI thread unless otherwise +indicated. + + + + +Called after the renderer and JavaScript in the page has had a chance to +handle the event. |event| contains information about the keyboard event. +|os_event| is the operating system event message, if any. Return true if +the keyboard event was handled or false otherwise. + + + + +Called before a keyboard event is sent to the renderer. |event| contains +information about the keyboard event. |os_event| is the operating system +event message, if any. Return true if the event was handled or false +otherwise. If the event will be handled in OnKeyEvent() as a keyboard +shortcut set |is_keyboard_shortcut| to true and return false. + + + + +Implement this interface to handle events related to keyboard input. The +methods of this class will be called on the UI thread. + + + + +Called when the dialog is closed. + + + + +Called to cancel any pending dialogs and reset any saved dialog state. +Will be called due to events like page navigation irregardless of whether +any dialogs are currently pending. + + + + +Called to run a dialog asking the user if they want to leave a page. +Return false to use the default dialog implementation. Return true if the +application will use a custom dialog or if the callback has been executed +immediately. Custom dialogs may be either modal or modeless. If a custom +dialog is used the application must execute |callback| once the custom +dialog is dismissed. + + + + +Called to run a JavaScript dialog. If |origin_url| is non-empty it can be +passed to the CefFormatUrlForSecurityDisplay function to retrieve a secure +and user-friendly display string. The |default_prompt_text| value will be +specified for prompt dialogs only. Set |suppress_message| to true and +return false to suppress the message (suppressing messages is preferable +to immediately executing the callback as this is used to detect presumably +malicious behavior like spamming alert messages in onbeforeunload). Set +|suppress_message| to false and return false to use the default +implementation (the default implementation will show one modal dialog at a +time and suppress any additional dialog requests until the displayed +dialog is dismissed). Return true if the application will use a custom +dialog or if the callback has been executed immediately. Custom dialogs +may be either modal or modeless. If a custom dialog is used the +application must execute |callback| once the custom dialog is dismissed. + + + + +Implement this interface to handle events related to JavaScript dialogs. The +methods of this class will be called on the UI thread. + + + + +Continue the JS dialog request. Set |success| to true if the OK button was +pressed. The |user_input| value should be specified for prompt dialogs. + + + + +Callback interface used for asynchronous continuation of JavaScript dialog +requests. + + + + +Called when the main frame changes due to (a) initial browser creation, +(b) final browser destruction, (c) cross-origin navigation or (d) +re-navigation after renderer process termination (due to crashes, etc). +|old_frame| will be NULL and |new_frame| will be non-NULL when a main +frame is assigned to |browser| for the first time. |old_frame| will be +non-NULL and |new_frame| will be NULL and when a main frame is removed +from |browser| for the last time. Both |old_frame| and |new_frame| will be +non-NULL for cross-origin navigations or re-navigation after renderer +process termination. This method will be called after OnFrameCreated() for +|new_frame| and/or after OnFrameDetached() for |old_frame|. If called +after CefLifeSpanHandler::OnBeforeClose() during browser destruction then +CefBrowser::IsValid() will return false for |browser|. + + + + +Called when a frame loses its connection to the renderer process and will +be destroyed. Any pending or future commands will be discarded and +CefFrame::IsValid() will now return false for |frame|. If called after +CefLifeSpanHandler::OnBeforeClose() during browser destruction then +CefBrowser::IsValid() will return false for |browser|. + + + + +Called when a frame can begin routing commands to/from the associated +renderer process. |reattached| will be true if the frame was re-attached +after exiting the BackForwardCache. Any commands that were queued have now +been dispatched. + + + + +Called when a new frame is created. This will be the first notification +that references |frame|. Any commands that require transport to the +associated renderer process (LoadRequest, SendProcessMessage, GetSource, +etc.) will be queued until OnFrameAttached is called for |frame|. + + + + +Implement this interface to handle events related to CefFrame life span. The +order of callbacks is: + +(1) During initial CefBrowserHost creation and navigation of the main frame: +- CefFrameHandler::OnFrameCreated => The initial main frame object has been + created. Any commands will be queued until the frame is attached. +- CefFrameHandler::OnMainFrameChanged => The initial main frame object has + been assigned to the browser. +- CefLifeSpanHandler::OnAfterCreated => The browser is now valid and can be + used. +- CefFrameHandler::OnFrameAttached => The initial main frame object is now + connected to its peer in the renderer process. Commands can be routed. + +(2) During further CefBrowserHost navigation/loading of the main frame + and/or sub-frames: +- CefFrameHandler::OnFrameCreated => A new main frame or sub-frame object + has been created. Any commands will be queued until the frame is attached. +- CefFrameHandler::OnFrameAttached => A new main frame or sub-frame object + is now connected to its peer in the renderer process. Commands can be + routed. +- CefFrameHandler::OnFrameDetached => An existing main frame or sub-frame + object has lost its connection to the renderer process. If multiple + objects are detached at the same time then notifications will be sent for + any sub-frame objects before the main frame object. Commands can no longer + be routed and will be discarded. +- CefFrameHandler::OnMainFrameChanged => A new main frame object has been + assigned to the browser. This will only occur with cross-origin navigation + or re-navigation after renderer process termination (due to crashes, etc). + +(3) During final CefBrowserHost destruction of the main frame: +- CefFrameHandler::OnFrameDetached => Any sub-frame objects have lost their + connection to the renderer process. Commands can no longer be routed and + will be discarded. +- CefLifeSpanHandler::OnBeforeClose => The browser has been destroyed. +- CefFrameHandler::OnFrameDetached => The main frame object have lost its + connection to the renderer process. Notifications will be sent for any + sub-frame objects before the main frame object. Commands can no longer be + routed and will be discarded. +- CefFrameHandler::OnMainFrameChanged => The final main frame object has + been removed from the browser. + +Cross-origin navigation and/or loading receives special handling. + +When the main frame navigates to a different origin the OnMainFrameChanged +callback (2) will be executed with the old and new main frame objects. + +When a new sub-frame is loaded in, or an existing sub-frame is navigated to, +a different origin from the parent frame, a temporary sub-frame object will +first be created in the parent's renderer process. That temporary sub-frame +will then be discarded after the real cross-origin sub-frame is created in +the new/target renderer process. The client will receive cross-origin +navigation callbacks (2) for the transition from the temporary sub-frame to +the real sub-frame. The temporary sub-frame will not recieve or execute +commands during this transitional period (any sent commands will be +discarded). + +When a new popup browser is created in a different origin from the parent +browser, a temporary main frame object for the popup will first be created +in the parent's renderer process. That temporary main frame will then be +discarded after the real cross-origin main frame is created in the +new/target renderer process. The client will recieve creation and initial +navigation callbacks (1) for the temporary main frame, followed by +cross-origin navigation callbacks (2) for the transition from the temporary +main frame to the real main frame. The temporary main frame may receive and +execute commands during this transitional period (any sent commands may be +executed, but the behavior is potentially undesirable since they execute in +the parent browser's renderer process and not the new/target renderer +process). + +Callbacks will not be executed for placeholders that may be created during +pre-commit navigation for sub-frames that do not yet exist in the renderer +process. Placeholders will have CefFrame::GetIdentifier() == -4. + +The methods of this class will be called on the UI thread unless otherwise +indicated. + + + + +Called when the browser component has received focus. + + + + +Called when the browser component is requesting focus. |source| indicates +where the focus request is originating from. Return false to allow the +focus to be set or true to cancel setting the focus. + + + + +Called when the browser component is about to loose focus. For instance, +if focus was on the last HTML element and the user pressed the TAB key. +|next| will be true if the browser is giving focus to the next component +and false if the browser is giving focus to the previous component. + + + + +Implement this interface to handle events related to focus. The methods of +this class will be called on the UI thread. + + + + +Called to report find results returned by CefBrowserHost::Find(). +|identifer| is a unique incremental identifier for the currently active +search, |count| is the number of matches currently identified, +|selectionRect| is the location of where the match was found (in window +coordinates), |activeMatchOrdinal| is the current position in the search +results, and |finalUpdate| is true if this is the last find notification. + + + + +Implement this interface to handle events related to find results. The +methods of this class will be called on the UI thread. + + + + +Called whenever draggable regions for the browser window change. These can +be specified using the '-webkit-app-region: drag/no-drag' CSS-property. If +draggable regions are never defined in a document this method will also +never be called. If the last draggable region is removed from a document +this method will be called with an empty vector. + + + + +Called when an external drag event enters the browser window. |dragData| +contains the drag event data and |mask| represents the type of drag +operation. Return false for default drag handling behavior or true to +cancel the drag event. + + + + +Implement this interface to handle events related to dragging. The methods +of this class will be called on the UI thread. + + + + +Called when a download's status or progress information has been updated. +This may be called multiple times before and after OnBeforeDownload(). +Execute |callback| either asynchronously or in this method to cancel the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + +Called when a download's status or progress information has been updated. +This may be called multiple times before and after OnBeforeDownload(). +Execute |callback| either asynchronously or in this method to cancel the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + + +Called before a download begins. |suggested_name| is the suggested name +for the download file. By default the download will be canceled. Execute +|callback| either asynchronously or in this method to continue the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + +Called before a download begins. |suggested_name| is the suggested name +for the download file. By default the download will be canceled. Execute +|callback| either asynchronously or in this method to continue the +download if desired. Do not keep a reference to |download_item| outside of +this method. + + + + +Called before a download begins in response to a user-initiated action +(e.g. alt + link click or link click that returns a `Content-Disposition: +attachment` response from the server). |url| is the target download URL +and |request_method| is the target method (GET, POST, etc). Return true to +proceed with the download or false to cancel the download. + + + +Called before a download begins in response to a user-initiated action +(e.g. alt + link click or link click that returns a `Content-Disposition: +attachment` response from the server). |url| is the target download URL +and |request_method| is the target method (GET, POST, etc). Return true to +proceed with the download or false to cancel the download. + + + + +Class used to handle file downloads. The methods of this class will called +on the browser process UI thread. + + + +Class used to handle file downloads. The methods of this class will called +on the browser process UI thread. + + + + +Call to resume the download. + + + +Call to resume the download. + + + + +Call to pause the download. + + + +Call to pause the download. + + + + +Call to cancel the download. + + + +Call to cancel the download. + + + + +Callback interface used to asynchronously cancel a download. + + + +Callback interface used to asynchronously cancel a download. + + + + +Call to continue the download. Set |download_path| to the full file path +for the download including the file name or leave blank to use the +suggested name and the default temp directory. Set |show_dialog| to true +if you do wish to show the default "Save As" dialog. + + + +Call to continue the download. Set |download_path| to the full file path +for the download including the file name or leave blank to use the +suggested name and the default temp directory. Set |show_dialog| to true +if you do wish to show the default "Save As" dialog. + + + + +Callback interface used to asynchronously continue a download. + + + +Callback interface used to asynchronously continue a download. + + + + +Called when the browser's access to an audio and/or video source has +changed. + + + + +Called when the browser's cursor has changed. If |type| is CT_CUSTOM then +|custom_cursor_info| will be populated with the custom cursor information. +Return true if the cursor change was handled or false for default +handling. + + + + +Called when the overall page loading progress has changed. |progress| +ranges from 0.0 to 1.0. + + + + +Called when auto-resize is enabled via +CefBrowserHost::SetAutoResizeEnabled and the contents have auto-resized. +|new_size| will be the desired size in view coordinates. Return true if +the resize was handled or false for default handling. + + + + +Called to display a console message. Return true to stop the message from +being output to the console. + + + + +Called when the browser receives a status message. |value| contains the +text that will be displayed in the status message. + + + + +Called when the browser is about to display a tooltip. |text| contains the +text that will be displayed in the tooltip. To handle the display of the +tooltip yourself return true. Otherwise, you can optionally modify |text| +and then return false to allow the browser to display the tooltip. +When window rendering is disabled the application is responsible for +drawing tooltips and the return value is ignored. + + + + +Called when web content in the page has toggled fullscreen mode. If +|fullscreen| is true the content will automatically be sized to fill the +browser content area. If |fullscreen| is false the content will +automatically return to its original size and position. The client is +responsible for resizing the browser if desired. + + + + +Called when the page icon changes. + + + + +Called when the page title changes. + + + + +Called when a frame's address has changed. + + + + +Implement this interface to handle events related to browser display state. +The methods of this class will be called on the UI thread. + + + + +Called to run a file chooser dialog. |mode| represents the type of dialog +to display. |title| to the title to be used for the dialog and may be +empty to show the default title ("Open" or "Save" depending on the mode). +|default_file_path| is the path with optional directory and/or file name +component that should be initially selected in the dialog. +|accept_filters| are used to restrict the selectable file types and may +any combination of (a) valid lower-cased MIME types (e.g. "text/*" or +"image/*"), (b) individual file extensions (e.g. ".txt" or ".png"), or (c) +combined description and file extension delimited using "|" and ";" (e.g. +"Image Types|.png;.gif;.jpg"). To display a custom dialog return true and +execute |callback| either inline or at a later time. To display the +default dialog return false. + + + + +Implement this interface to handle dialog events. The methods of this class +will be called on the browser process UI thread. + + + + +Cancel the file selection. + + + + +Continue the file selection. |file_paths| should be a single value or a +list of values depending on the dialog mode. An empty |file_paths| value +is treated the same as calling Cancel(). + + + + +Callback interface for asynchronous continuation of file dialog requests. + + + + +Returns true if the context menu contains items specified by the renderer +process. + + + +Returns true if the context menu contains items specified by the renderer +process. + + + + +Returns flags representing the actions supported by the editable node, if +any, that the context menu was invoked on. + + + +Returns flags representing the actions supported by the editable node, if +any, that the context menu was invoked on. + + + + +Returns true if the context menu was invoked on an editable node where +spell-check is enabled. + + + +Returns true if the context menu was invoked on an editable node where +spell-check is enabled. + + + + +Returns true if the context menu was invoked on an editable node. + + + +Returns true if the context menu was invoked on an editable node. + + + + +Returns true if suggestions exist, false otherwise. Fills in |suggestions| +from the spell check service for the misspelled word if there is one. + + + +Returns true if suggestions exist, false otherwise. Fills in |suggestions| +from the spell check service for the misspelled word if there is one. + + + + +Returns the text of the misspelled word, if any, that the context menu was +invoked on. + + + +Returns the text of the misspelled word, if any, that the context menu was +invoked on. + + + + +Returns the text of the selection, if any, that the context menu was +invoked on. + + + +Returns the text of the selection, if any, that the context menu was +invoked on. + + + + +Returns flags representing the actions supported by the media element, if +any, that the context menu was invoked on. + + + +Returns flags representing the actions supported by the media element, if +any, that the context menu was invoked on. + + + + +Returns the type of context node that the context menu was invoked on. + + + +Returns the type of context node that the context menu was invoked on. + + + + +Returns the character encoding of the subframe that the context menu was +invoked on. + + + +Returns the character encoding of the subframe that the context menu was +invoked on. + + + + +Returns the URL of the subframe that the context menu was invoked on. + + + +Returns the URL of the subframe that the context menu was invoked on. + + + + +Returns the URL of the top level page that the context menu was invoked +on. + + + +Returns the URL of the top level page that the context menu was invoked +on. + + + + +Returns the title text or the alt text if the context menu was invoked on +an image. + + + +Returns the title text or the alt text if the context menu was invoked on +an image. + + + + +Returns true if the context menu was invoked on an image which has +non-empty contents. + + + +Returns true if the context menu was invoked on an image which has +non-empty contents. + + + + +Returns the source URL, if any, for the element that the context menu was +invoked on. Example of elements with source URLs are img, audio, and +video. + + + +Returns the source URL, if any, for the element that the context menu was +invoked on. Example of elements with source URLs are img, audio, and +video. + + + + +Returns the link URL, if any, to be used ONLY for "copy link address". We +don't validate this field in the frontend process. + + + +Returns the link URL, if any, to be used ONLY for "copy link address". We +don't validate this field in the frontend process. + + + + +Returns the URL of the link, if any, that encloses the node that the +context menu was invoked on. + + + +Returns the URL of the link, if any, that encloses the node that the +context menu was invoked on. + + + + +Returns flags representing the type of node that the context menu was +invoked on. + + + +Returns flags representing the type of node that the context menu was +invoked on. + + + + +Returns the Y coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + +Returns the Y coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + + +Returns the X coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + +Returns the X coordinate of the mouse where the context menu was invoked. +Coords are relative to the associated RenderView's origin. + + + + +Provides information about the context menu state. The methods of this class +can only be accessed on browser process the UI thread. + + + +Provides information about the context menu state. The methods of this class +can only be accessed on browser process the UI thread. + + + + +Called when the quick menu for a windowless browser is dismissed +irregardless of whether the menu was canceled or a command was selected. + + + +Called when the quick menu for a windowless browser is dismissed +irregardless of whether the menu was canceled or a command was selected. + + + + +Called to execute a command selected from the quick menu for a windowless +browser. Return true if the command was handled or false for the default +implementation. See cef_menu_id_t for command IDs that have default +implementations. + + + +Called to execute a command selected from the quick menu for a windowless +browser. Return true if the command was handled or false for the default +implementation. See cef_menu_id_t for command IDs that have default +implementations. + + + + +Called to allow custom display of the quick menu for a windowless browser. +|location| is the top left corner of the selected region. |size| is the +size of the selected region. |edit_state_flags| is a combination of flags +that represent the state of the quick menu. Return true if the menu will +be handled and execute |callback| either synchronously or asynchronously +with the selected command ID. Return false to cancel the menu. + + + +Called to allow custom display of the quick menu for a windowless browser. +|location| is the top left corner of the selected region. |size| is the +size of the selected region. |edit_state_flags| is a combination of flags +that represent the state of the quick menu. Return true if the menu will +be handled and execute |callback| either synchronously or asynchronously +with the selected command ID. Return false to cancel the menu. + + + + +Called when the context menu is dismissed irregardless of whether the menu +was canceled or a command was selected. + + + +Called when the context menu is dismissed irregardless of whether the menu +was canceled or a command was selected. + + + + +Called to execute a command selected from the context menu. Return true if +the command was handled or false for the default implementation. See +cef_menu_id_t for the command ids that have default implementations. All +user-defined command ids should be between MENU_ID_USER_FIRST and +MENU_ID_USER_LAST. |params| will have the same values as what was passed +to OnBeforeContextMenu(). Do not keep a reference to |params| outside of +this callback. + + + +Called to execute a command selected from the context menu. Return true if +the command was handled or false for the default implementation. See +cef_menu_id_t for the command ids that have default implementations. All +user-defined command ids should be between MENU_ID_USER_FIRST and +MENU_ID_USER_LAST. |params| will have the same values as what was passed +to OnBeforeContextMenu(). Do not keep a reference to |params| outside of +this callback. + + + + +Called to allow custom display of the context menu. |params| provides +information about the context menu state. |model| contains the context +menu model resulting from OnBeforeContextMenu. For custom display return +true and execute |callback| either synchronously or asynchronously with +the selected command ID. For default display return false. Do not keep +references to |params| or |model| outside of this callback. + + + +Called to allow custom display of the context menu. |params| provides +information about the context menu state. |model| contains the context +menu model resulting from OnBeforeContextMenu. For custom display return +true and execute |callback| either synchronously or asynchronously with +the selected command ID. For default display return false. Do not keep +references to |params| or |model| outside of this callback. + + + + +Called before a context menu is displayed. |params| provides information +about the context menu state. |model| initially contains the default +context menu. The |model| can be cleared to show no context menu or +modified to show a custom menu. Do not keep references to |params| or +|model| outside of this callback. + + + +Called before a context menu is displayed. |params| provides information +about the context menu state. |model| initially contains the default +context menu. The |model| can be cleared to show no context menu or +modified to show a custom menu. Do not keep references to |params| or +|model| outside of this callback. + + + + +Implement this interface to handle context menu events. The methods of this +class will be called on the UI thread. + + + +Implement this interface to handle context menu events. The methods of this +class will be called on the UI thread. + + + + +Cancel quick menu display. + + + +Cancel quick menu display. + + + + +Complete quick menu display by selecting the specified |command_id| and +|event_flags|. + + + +Complete quick menu display by selecting the specified |command_id| and +|event_flags|. + + + + +Callback interface used for continuation of custom quick menu display. + + + +Callback interface used for continuation of custom quick menu display. + + + + +Cancel context menu display. + + + +Cancel context menu display. + + + + +Complete context menu display by selecting the specified |command_id| and +|event_flags|. + + + +Complete context menu display by selecting the specified |command_id| and +|event_flags|. + + + + +Callback interface used for continuation of custom context menu display. + + + +Callback interface used for continuation of custom context menu display. + + + + +Returns in |color| the color that was explicitly set for |command_id| and +|color_type|. Specify an |index| value of -1 to return the default color +in |color|. If a color was not set then 0 will be returned in |color|. +Returns true on success. + + + + +Returns in |color| the color that was explicitly set for |command_id| and +|color_type|. If a color was not set then 0 will be returned in |color|. +Returns true on success. + + + + +Set the explicit color for |command_id| and |index| to |color|. Specify a +|color| value of 0 to remove the explicit color. Specify an |index| value +of -1 to set the default color for items that do not have an explicit +color set. If no explicit color or default color is set for |color_type| +then the system color will be used. Returns true on success. + + + + +Set the explicit color for |command_id| and |color_type| to |color|. +Specify a |color| value of 0 to remove the explicit color. If no explicit +color or default color is set for |color_type| then the system color will +be used. Returns true on success. + + + + +Retrieves the keyboard accelerator for the specified |index|. Returns true +on success. + + + + +Retrieves the keyboard accelerator for the specified |command_id|. Returns +true on success. + + + + +Remove the keyboard accelerator at the specified |index|. Returns true on +success. + + + + +Remove the keyboard accelerator for the specified |command_id|. Returns +true on success. + + + + +Set the keyboard accelerator at the specified |index|. |key_code| can be +any virtual key or character value. Returns true on success. + + + + +Set the keyboard accelerator for the specified |command_id|. |key_code| +can be any virtual key or character value. Returns true on success. + + + + +Returns true if the specified |index| has a keyboard accelerator assigned. + + + + +Returns true if the specified |command_id| has a keyboard accelerator +assigned. + + + + +Check the specified |index|. Only applies to check and radio items. +Returns true on success. + + + + +Check the specified |command_id|. Only applies to check and radio items. +Returns true on success. + + + + +Returns true if the specified |index| is checked. Only applies to check +and radio items. + + + + +Returns true if the specified |command_id| is checked. Only applies to +check and radio items. + + + + +Change the enabled status at the specified |index|. Returns true on +success. + + + + +Change the enabled status of the specified |command_id|. Returns true on +success. + + + + +Returns true if the specified |index| is enabled. + + + + +Returns true if the specified |command_id| is enabled. + + + + +Change the visibility at the specified |index|. Returns true on success. + + + + +Change the visibility of the specified |command_id|. Returns true on +success. + + + + +Returns true if the specified |index| is visible. + + + + +Returns true if the specified |command_id| is visible. + + + + +Returns the submenu at the specified |index| or empty if invalid. + + + + +Returns the submenu for the specified |command_id| or empty if invalid. + + + + +Sets the group id at the specified |index|. Returns true on success. + + + + +Sets the group id for the specified |command_id|. Returns true on success. + + + + +Returns the group id at the specified |index| or -1 if invalid. + + + + +Returns the group id for the specified |command_id| or -1 if invalid. + + + + +Returns the item type at the specified |index|. + + + + +Returns the item type for the specified |command_id|. + + + + +Set the label at the specified |index|. Returns true on success. + + + + +Sets the label for the specified |command_id|. Returns true on success. + + + + +Returns the label at the specified |index| or empty if not found due to +invalid range or the index being a separator. + + + + +Returns the label for the specified |command_id| or empty if not found. + + + + +Sets the command id at the specified |index|. Returns true on success. + + + + +Returns the command id at the specified |index| or -1 if not found due to +invalid range or the index being a separator. + + + + +Returns the index associated with the specified |command_id| or -1 if not +found due to the command id not existing in the menu. + + + + +Removes the item at the specified |index|. Returns true on success. + + + + +Removes the item with the specified |command_id|. Returns true on success. + + + + +Insert a sub-menu in the menu at the specified |index|. The new sub-menu +is returned. + + + + +Insert a radio item in the menu at the specified |index|. Only a single +item with the specified |group_id| can be checked at a time. Returns true +on success. + + + + +Insert a check item in the menu at the specified |index|. Returns true on +success. + + + + +Insert an item in the menu at the specified |index|. Returns true on +success. + + + + +Insert a separator in the menu at the specified |index|. Returns true on +success. + + + + +Add a sub-menu to the menu. The new sub-menu is returned. + + + + +Add a radio item to the menu. Only a single item with the specified +|group_id| can be checked at a time. Returns true on success. + + + + +Add a check item to the menu. Returns true on success. + + + + +Add an item to the menu. Returns true on success. + + + + +Add a separator to the menu. Returns true on success. + + + + +Returns the number of items in this menu. + + + + +Clears the menu. Returns true on success. + + + + +Returns true if this menu is a submenu. + + + + +Create a new MenuModel with the specified |delegate|. + + + + +Supports creation and modification of menus. See cef_menu_id_t for the +command ids that have default implementations. All user-defined command ids +should be between MENU_ID_USER_FIRST and MENU_ID_USER_LAST. The methods of +this class can only be accessed on the browser process the UI thread. + + + + +Optionally modify a menu item label. Return true if |label| was modified. + + + + +The menu has closed. + + + + +The menu is about to show. + + + + +Called on unhandled close submenu keyboard commands. |is_rtl| will be true +if the menu is displaying a right-to-left language. + + + + +Called on unhandled open submenu keyboard commands. |is_rtl| will be true +if the menu is displaying a right-to-left language. + + + + +Called when the user moves the mouse outside the menu and over the owning +window. + + + + +Perform the action associated with the specified |command_id| and +optional |event_flags|. + + + + +Implement this interface to handle menu model events. The methods of this +class will be called on the browser process UI thread unless otherwise +indicated. + + + + +Called during browser creation to check if a Chrome toolbar button +should be visible. Only called for buttons that would be visible by +default. Only used with the Chrome runtime. + + + + +Called during browser creation to check if a Chrome page action icon +should be visible. Only called for icons that would be visible by default. +Only used with the Chrome runtime. + + + + +Called to check if a Chrome app menu item should be enabled. Values for +|command_id| can be found in the cef_command_ids.h file. Only called for +menu items that would be enabled by default. Only used with the Chrome +runtime. + + + + +Called to check if a Chrome app menu item should be visible. Values for +|command_id| can be found in the cef_command_ids.h file. Only called for +menu items that would be visible by default. Only used with the Chrome +runtime. + + + + +Called to execute a Chrome command triggered via menu selection or +keyboard shortcut. Values for |command_id| can be found in the +cef_command_ids.h file. |disposition| provides information about the +intended command target. Return true if the command was handled or false +for the default implementation. For context menu commands this will be +called after CefContextMenuHandler::OnContextMenuCommand. Only used with +the Chrome runtime. + + + + +Implement this interface to handle events related to commands. The methods +of this class will be called on the UI thread. + + + + +Called on the UI or audio stream thread when an error occurred. During the +stream creation phase this callback will be called on the UI thread while +in the capturing phase it will be called on the audio stream thread. The +stream will be stopped immediately. + + + + +Called on the UI thread when the stream has stopped. OnAudioSteamStopped +will always be called after OnAudioStreamStarted; both methods may be +called multiple times for the same stream. + + + + +Called on the audio stream thread when a PCM packet is received for the +stream. |data| is an array representing the raw PCM data as a floating +point type, i.e. 4-byte value(s). |frames| is the number of frames in the +PCM packet. |pts| is the presentation timestamp (in milliseconds since the +Unix Epoch) and represents the time at which the decompressed packet +should be presented to the user. Based on |frames| and the +|channel_layout| value passed to OnAudioStreamStarted you can calculate +the size of the |data| array in bytes. + + + + +Called on a browser audio capture thread when the browser starts +streaming audio. OnAudioStreamStopped will always be called after +OnAudioStreamStarted; both methods may be called multiple times +for the same browser. |params| contains the audio parameters like +sample rate and channel layout. |channels| is the number of channels. + + + + +Called on the UI thread to allow configuration of audio stream parameters. +Return true to proceed with audio stream capture, or false to cancel it. +All members of |params| can optionally be configured here, but they are +also pre-filled with some sensible defaults. + + + + +Implement this interface to handle audio events. + + + + +Creates a detailed expection string from a provided Cef V8 exception. + + The exception which will be used as base for the message + + + +Assigns the provided cef_string_t object from the given .NET string. + + The cef_string_t that should be updated. + The .NET string whose value should be used to update cefStr. + + + +Converts a .NET List of strings to native (unmanaged) format. + + The List of strings that should be converted. + An unmanaged representation of the provided List of strings, or an empty List if the input is a nullptr. + + + +Converts a .NET string to native (unmanaged) format. Note that this method does not allocate a new copy of the + + The string that should be converted. + An unmanaged representation of the provided string, or an empty string if the input string is a nullptr. + + + +Converts an unmanaged vector of strings to a (managed) .NET List of strings. + + The vector of strings that should be converted. + A .NET List of strings. + + + +Converts an unmanaged string to a (managed) .NET string. + + The string that should be converted. + A .NET string. + + + +Converts an unmanaged string to a (managed) .NET string. + + The string that should be converted. + A .NET string. + + + +Returns true if the function was called as a constructor via "new". + + + + +Returns true if the function was compiled using eval(). + + + + +Returns the 1-based column offset on the line for the function call or 0 +if unknown. + + + + +Returns the 1-based line number for the function call or 0 if unknown. + + + + +Returns the name of the function. + + + + +Returns the name of the resource script that contains the function or the +sourceURL value if the script name is undefined and its source ends with +a "//@ sourceURL=..." string. + + + + +Returns the name of the resource script that contains the function. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Class representing a V8 stack frame handle. V8 handles can only be accessed +from the thread on which they are created. Valid threads for creating a V8 +handle include the render process main thread (TID_RENDERER) and WebWorker +threads. A task runner for posting tasks on the associated thread can be +retrieved via the CefV8Context::GetTaskRunner() method. + + + + +Returns the stack frame at the specified 0-based index. + + + + +Returns the number of stack frames. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Returns the stack trace for the currently active context. |frame_limit| is +the maximum number of frames that will be captured. + + + + +Class representing a V8 stack trace handle. V8 handles can only be accessed +from the thread on which they are created. Valid threads for creating a V8 +handle include the render process main thread (TID_RENDERER) and WebWorker +threads. A task runner for posting tasks on the associated thread can be +retrieved via the CefV8Context::GetTaskRunner() method. + + + + +Reject the Promise using the current V8 context. This method should only +be called from within the scope of a CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. Returns true on success. Returns false if this +method is called incorrectly or an exception is thrown. + + + + +Resolve the Promise using the current V8 context. This method should only +be called from within the scope of a CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. |arg| is the argument passed to the resolved +promise. Returns true on success. Returns false if this method is called +incorrectly or an exception is thrown. + + + + +Execute the function using the specified V8 context. |object| is the +receiver ('this' object) of the function. If |object| is empty the +specified context's global object will be used. |arguments| is the list of +arguments that will be passed to the function. Returns the function return +value on success. Returns NULL if this method is called incorrectly or an +exception is thrown. + + + + +Execute the function using the current V8 context. This method should only +be called from within the scope of a CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. |object| is the receiver ('this' object) of the +function. If |object| is empty the current context's global object will be +used. |arguments| is the list of arguments that will be passed to the +function. Returns the function return value on success. Returns NULL if +this method is called incorrectly or an exception is thrown. + + + + +Returns the function handler or NULL if not a CEF-created function. + + + + +Returns the function name. + + + + +Prevent the ArrayBuffer from using it's memory block by setting the length +to zero. This operation cannot be undone. If the ArrayBuffer was created +with CreateArrayBuffer then CefV8ArrayBufferReleaseCallback::ReleaseBuffer +will be called to release the underlying buffer. + + + + +Returns the ReleaseCallback object associated with the ArrayBuffer or NULL +if the ArrayBuffer was not created with CreateArrayBuffer. + + + + +Returns the number of elements in the array. + + + + +Adjusts the amount of registered external memory for the object. Used to +give V8 an indication of the amount of externally allocated memory that is +kept alive by JavaScript objects. V8 uses this information to decide when +to perform global garbage collection. Each CefV8Value tracks the amount of +external memory associated with it and automatically decreases the global +total by the appropriate amount on its destruction. |change_in_bytes| +specifies the number of bytes to adjust by. This method returns the number +of bytes associated with the object after the adjustment. This method can +only be called on user created objects. + + + + +Returns the amount of externally allocated memory registered for the +object. + + + + +Returns the user data, if any, assigned to this object. + + + + +Sets the user data for this object and returns true on success. Returns +false if this method is called incorrectly. This method can only be called +on user created objects. + + + + +Read the keys for the object's values into the specified vector. Integer- +based keys will also be returned as strings. + + + + +Registers an identifier and returns true on success. Access to the +identifier will be forwarded to the CefV8Accessor instance passed to +CefV8Value::CreateObject(). Returns false if this method is called +incorrectly or an exception is thrown. For read-only values this method +will return true even though assignment failed. + + + + +Associates a value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly or an +exception is thrown. For read-only values this method will return true +even though assignment failed. + + + + +Associates a value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly or an +exception is thrown. For read-only values this method will return true +even though assignment failed. + + + + +Returns the value with the specified identifier on success. Returns NULL +if this method is called incorrectly or an exception is thrown. + + + + +Returns the value with the specified identifier on success. Returns NULL +if this method is called incorrectly or an exception is thrown. + + + + +Deletes the value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly, deletion +fails or an exception is thrown. For read-only and don't-delete values +this method will return true even though deletion failed. + + + + +Deletes the value with the specified identifier and returns true on +success. Returns false if this method is called incorrectly or an +exception is thrown. For read-only and don't-delete values this method +will return true even though deletion failed. + + + + +Returns true if the object has a value with the specified identifier. + + + + +Returns true if the object has a value with the specified identifier. + + + + +Set whether this object will re-throw future exceptions. By default +exceptions are not re-thrown. If a exception is re-thrown the current +context should not be accessed again until after the exception has been +caught and not re-thrown. Returns true on success. This attribute exists +only in the scope of the current CEF value object. + + + + +Returns true if this object will re-throw future exceptions. This +attribute exists only in the scope of the current CEF value object. + + + + +Clears the last exception and returns true on success. + + + + +Returns the exception resulting from the last method call. This attribute +exists only in the scope of the current CEF value object. + + + + +Returns true if the last method call resulted in an exception. This +attribute exists only in the scope of the current CEF value object. + + + +OBJECT METHODS - These methods are only available on objects. Arrays and +functions are also objects. String- and integer-based keys can be used +interchangably with the framework converting between them as necessary. + +Returns true if this is a user created object. + + + + +Return a string value. + + + + +Return a Date value. + + + + +Return a double value. + + + + +Return an unsigned int value. + + + + +Return an int value. + + + + +Return a bool value. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +True if the value type is a Promise. + + + + +True if the value type is function. + + + + +True if the value type is an ArrayBuffer. + + + + +True if the value type is array. + + + + +True if the value type is object. + + + + +True if the value type is string. + + + + +True if the value type is Date. + + + + +True if the value type is double. + + + + +True if the value type is unsigned int. + + + + +True if the value type is int. + + + + +True if the value type is bool. + + + + +True if the value type is null. + + + + +True if the value type is undefined. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Create a new CefV8Value object of type Promise. This method should only be +called from within the scope of a CefRenderProcessHandler, CefV8Handler or +CefV8Accessor callback, or in combination with calling Enter() and Exit() +on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type function. This method should only +be called from within the scope of a CefRenderProcessHandler, CefV8Handler +or CefV8Accessor callback, or in combination with calling Enter() and +Exit() on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type ArrayBuffer which wraps the +provided |buffer| of size |length| bytes. The ArrayBuffer is externalized, +meaning that it does not own |buffer|. The caller is responsible for +freeing |buffer| when requested via a call to +CefV8ArrayBufferReleaseCallback::ReleaseBuffer. This method should only +be called from within the scope of a CefRenderProcessHandler, CefV8Handler +or CefV8Accessor callback, or in combination with calling Enter() and +Exit() on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type array with the specified |length|. +If |length| is negative the returned array will have length 0. This method +should only be called from within the scope of a CefRenderProcessHandler, +CefV8Handler or CefV8Accessor callback, or in combination with calling +Enter() and Exit() on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type object with optional accessor +and/or interceptor. This method should only be called from within the +scope of a CefRenderProcessHandler, CefV8Handler or CefV8Accessor +callback, or in combination with calling Enter() and Exit() on a stored +CefV8Context reference. + + + + +Create a new CefV8Value object of type string. + + + + +Create a new CefV8Value object of type Date. This method should only be +called from within the scope of a CefRenderProcessHandler, CefV8Handler or +CefV8Accessor callback, or in combination with calling Enter() and Exit() +on a stored CefV8Context reference. + + + + +Create a new CefV8Value object of type double. + + + + +Create a new CefV8Value object of type unsigned int. + + + + +Create a new CefV8Value object of type int. + + + + +Create a new CefV8Value object of type bool. + + + + +Create a new CefV8Value object of type null. + + + + +Create a new CefV8Value object of type undefined. + + + + +Class representing a V8 value handle. V8 handles can only be accessed from +the thread on which they are created. Valid threads for creating a V8 handle +include the render process main thread (TID_RENDERER) and WebWorker threads. +A task runner for posting tasks on the associated thread can be retrieved +via the CefV8Context::GetTaskRunner() method. + + + + +Called to release |buffer| when the ArrayBuffer JS object is garbage +collected. |buffer| is the value that was passed to CreateArrayBuffer +along with this object. + + + + +Callback interface that is passed to CefV8Value::CreateArrayBuffer. + + + + +Returns the index within the line of the last character where the error +occurred. + + + + +Returns the index within the line of the first character where the error +occurred. + + + + +Returns the index within the script of the last character where the error +occurred. + + + + +Returns the index within the script of the first character where the error +occurred. + + + + +Returns the 1-based number of the line where the error occurred or 0 if +the line number is unknown. + + + + +Returns the resource name for the script from where the function causing +the error originates. + + + + +Returns the line of source code that the exception occurred within. + + + + +Returns the exception message. + + + + +Class representing a V8 exception. The methods of this class may be called +on any render process thread. + + + + +Handle assignment of the interceptor value identified by |index|. |object| +is the receiver ('this' object) of the interceptor. |value| is the new +value being assigned to the interceptor. If assignment fails, set +|exception| to the exception that will be thrown. +Return true if interceptor assignment was handled, false otherwise. + + + + +Handle assignment of the interceptor value identified by |name|. |object| +is the receiver ('this' object) of the interceptor. |value| is the new +value being assigned to the interceptor. If assignment fails, set +|exception| to the exception that will be thrown. This setter will always +be called, even when the property has an associated accessor. +Return true if interceptor assignment was handled, false otherwise. + + + + +Handle retrieval of the interceptor value identified by |index|. |object| +is the receiver ('this' object) of the interceptor. If retrieval succeeds, +set |retval| to the return value. If the requested value does not exist, +don't set either |retval| or |exception|. If retrieval fails, set +|exception| to the exception that will be thrown. +Return true if interceptor retrieval was handled, false otherwise. + + + + +Handle retrieval of the interceptor value identified by |name|. |object| +is the receiver ('this' object) of the interceptor. If retrieval succeeds, +set |retval| to the return value. If the requested value does not exist, +don't set either |retval| or |exception|. If retrieval fails, set +|exception| to the exception that will be thrown. If the property has an +associated accessor, it will be called only if you don't set |retval|. +Return true if interceptor retrieval was handled, false otherwise. + + + + +Interface that should be implemented to handle V8 interceptor calls. The +methods of this class will be called on the thread associated with the V8 +interceptor. Interceptor's named property handlers (with first argument of +type CefString) are called when object is indexed by string. Indexed +property handlers (with first argument of type int) are called when object +is indexed by integer. + + + + +Handle assignment of the accessor value identified by |name|. |object| is +the receiver ('this' object) of the accessor. |value| is the new value +being assigned to the accessor. If assignment fails set |exception| to the +exception that will be thrown. Return true if accessor assignment was +handled. + + + + +Handle retrieval the accessor value identified by |name|. |object| is the +receiver ('this' object) of the accessor. If retrieval succeeds set +|retval| to the return value. If retrieval fails set |exception| to the +exception that will be thrown. Return true if accessor retrieval was +handled. + + + + +Interface that should be implemented to handle V8 accessor calls. Accessor +identifiers are registered by calling CefV8Value::SetValue(). The methods +of this class will be called on the thread associated with the V8 accessor. + + + + +Handle execution of the function identified by |name|. |object| is the +receiver ('this' object) of the function. |arguments| is the list of +arguments passed to the function. If execution succeeds set |retval| to +the function return value. If execution fails set |exception| to the +exception that will be thrown. Return true if execution was handled. + + + + +Interface that should be implemented to handle V8 function calls. The +methods of this class will be called on the thread associated with the V8 +function. + + + + +Execute a string of JavaScript code in this V8 context. The |script_url| +parameter is the URL where the script in question can be found, if any. +The |start_line| parameter is the base line number to use for error +reporting. On success |retval| will be set to the return value, if any, +and the function will return true. On failure |exception| will be set to +the exception, if any, and the function will return false. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +Exit this context. Call this method only after calling Enter(). Returns +true if the scope was exited successfully. + + + + +Enter this context. A context must be explicitly entered before creating a +V8 Object, Array, Function or Date asynchronously. Exit() must be called +the same number of times as Enter() before releasing this context. V8 +objects belong to the context in which they are created. Returns true if +the scope was entered successfully. + + + + +Returns the global object for this context. The context must be entered +before calling this method. + + + + +Returns the frame for this context. This method will return an empty +reference for WebWorker contexts. + + + + +Returns the browser for this context. This method will return an empty +reference for WebWorker contexts. + + + + +Returns true if the underlying handle is valid and it can be accessed on +the current thread. Do not call any other methods if this method returns +false. + + + + +Returns the task runner associated with this context. V8 handles can only +be accessed from the thread on which they are created. This method can be +called on any render process thread. + + + + +Returns true if V8 is currently inside a context. + + + + +Returns the entered (bottom) context object in the V8 context stack. + + + + +Returns the current (top) context object in the V8 context stack. + + + + +Class representing a V8 context handle. V8 handles can only be accessed from +the thread on which they are created. Valid threads for creating a V8 handle +include the render process main thread (TID_RENDERER) and WebWorker threads. +A task runner for posting tasks on the associated thread can be retrieved +via the CefV8Context::GetTaskRunner() method. + + + + +Register a new V8 extension with the specified JavaScript extension code and +handler. Functions implemented by the handler are prototyped using the +keyword 'native'. The calling of a native function is restricted to the +scope in which the prototype of the native function is defined. This +function may only be called on the render process main thread. + +Example JavaScript extension code: +
+  // create the 'example' global object if it doesn't already exist.
+  if (!example)
+    example = {};
+  // create the 'example.test' global object if it doesn't already exist.
+  if (!example.test)
+    example.test = {};
+  (function() {
+    // Define the function 'example.test.myfunction'.
+    example.test.myfunction = function() {
+      // Call CefV8Handler::Execute() with the function name 'MyFunction'
+      // and no arguments.
+      native function MyFunction();
+      return MyFunction();
+    };
+    // Define the getter function for parameter 'example.test.myparam'.
+    example.test.__defineGetter__('myparam', function() {
+      // Call CefV8Handler::Execute() with the function name 'GetMyParam'
+      // and no arguments.
+      native function GetMyParam();
+      return GetMyParam();
+    });
+    // Define the setter function for parameter 'example.test.myparam'.
+    example.test.__defineSetter__('myparam', function(b) {
+      // Call CefV8Handler::Execute() with the function name 'SetMyParam'
+      // and a single argument.
+      native function SetMyParam();
+      if(b) SetMyParam(b);
+    });
+
+    // Extension definitions can also contain normal JavaScript variables
+    // and functions.
+    var myint = 0;
+    example.test.increment = function() {
+      myint += 1;
+      return myint;
+    };
+  })();
+
+ +Example usage in the page: +
+  // Call the function.
+  example.test.myfunction();
+  // Set the parameter.
+  example.test.myparam = value;
+  // Get the parameter.
+  value = example.test.myparam;
+  // Call another function.
+  example.test.increment();
+
+ + +Post a task for delayed execution on the specified thread. Equivalent to +using CefTaskRunner::GetForThread(threadId)->PostDelayedTask(task, +delay_ms). + + + + +Post a task for execution on the specified thread. Equivalent to +using CefTaskRunner::GetForThread(threadId)->PostTask(task). + + + + +Returns true if called on the specified thread. Equivalent to using +CefTaskRunner::GetForThread(threadId)->BelongsToCurrentThread(). + + + + +Post a task for delayed execution on the thread associated with this task +runner. Execution will occur asynchronously. Delayed tasks are not +supported on V8 WebWorker threads and will be executed without the +specified delay. + + + + +Post a task for execution on the thread associated with this task runner. +Execution will occur asynchronously. + + + + +Returns true if this task runner is for the specified CEF thread. + + + + +Returns true if this task runner belongs to the current thread. + + + + +Returns true if this object is pointing to the same task runner as |that| +object. + + + + +Returns the task runner for the specified CEF thread. + + + + +Returns the task runner for the current thread. Only CEF threads will have +task runners. An empty reference will be returned if this method is called +on an invalid thread. + + + + +Class that asynchronously executes tasks on the associated thread. It is +safe to call the methods of this class on any thread. + +CEF maintains multiple internal threads that are used for handling different +types of tasks in different processes. The cef_thread_id_t definitions in +cef_types.h list the common CEF threads. Task runners are also available for +other CEF threads as appropriate (for example, V8 WebWorker threads). + + + + +Method that will be executed on the target thread. + + + + +Implement this interface for asynchronous task execution. If the task is +posted successfully and if the associated message loop is still running then +the Execute() method will be called on the target thread. If the task fails +to post then the task object may be destroyed on the source thread instead +of the target thread. For this reason be cautious when performing work in +the task object destructor. + + + + +Returns true if the browser's audio is muted. This method can only be +called on the UI thread. + + + + +Set whether the browser's audio is muted. + + + + +Returns true if this browser is hosting an extension background script. +Background hosts do not have a window and are not displayable. See +CefRequestContext::LoadExtension for details. + + + + +Returns the extension hosted in this browser or NULL if no extension is +hosted. See CefRequestContext::LoadExtension for details. + + + + +Enable notifications of auto resize via CefDisplayHandler::OnAutoResize. +Notifications are disabled by default. |min_size| and |max_size| define +the range of allowed sizes. + + + + +Set accessibility state for all frames. |accessibility_state| may be +default, enabled or disabled. If |accessibility_state| is STATE_DEFAULT +then accessibility will be disabled by default and the state may be +further controlled with the "force-renderer-accessibility" and +"disable-renderer-accessibility" command-line switches. If +|accessibility_state| is STATE_ENABLED then accessibility will be enabled. +If |accessibility_state| is STATE_DISABLED then accessibility will be +completely disabled. + +For windowed browsers accessibility will be enabled in Complete mode +(which corresponds to kAccessibilityModeComplete in Chromium). In this +mode all platform accessibility objects will be created and managed by +Chromium's internal implementation. The client needs only to detect the +screen reader and call this method appropriately. For example, on macOS +the client can handle the @"AXEnhancedUserInterface" accessibility +attribute to detect VoiceOver state changes and on Windows the client can +handle WM_GETOBJECT with OBJID_CLIENT to detect accessibility readers. + +For windowless browsers accessibility will be enabled in TreeOnly mode +(which corresponds to kAccessibilityModeWebContentsOnly in Chromium). In +this mode renderer accessibility is enabled, the full tree is computed, +and events are passed to CefAccessibiltyHandler, but platform +accessibility objects are not created. The client may implement platform +accessibility objects using CefAccessibiltyHandler callbacks if desired. + + + + +Returns the current visible navigation entry for this browser. This method +can only be called on the UI thread. + + + + +Call this method when the drag operation started by a +CefRenderHandler::StartDragging call has completed. This method may be +called immediately without first calling DragSourceEndedAt to cancel a +drag operation. If the web view is both the drag source and the drag +target then all DragTarget* methods should be called before DragSource* +mthods. +This method is only used when window rendering is disabled. + + + + +Call this method when the drag operation started by a +CefRenderHandler::StartDragging call has ended either in a drop or +by being cancelled. |x| and |y| are mouse coordinates relative to the +upper-left corner of the view. If the web view is both the drag source +and the drag target then all DragTarget* methods should be called before +DragSource* mthods. +This method is only used when window rendering is disabled. + + + + +Call this method when the user completes the drag operation by dropping +the object onto the web view (after calling DragTargetDragEnter). +The object being dropped is |drag_data|, given as an argument to +the previous DragTargetDragEnter call. +This method is only used when window rendering is disabled. + + + + +Call this method when the user drags the mouse out of the web view (after +calling DragTargetDragEnter). +This method is only used when window rendering is disabled. + + + + +Call this method each time the mouse is moved across the web view during +a drag operation (after calling DragTargetDragEnter and before calling +DragTargetDragLeave/DragTargetDrop). +This method is only used when window rendering is disabled. + + + + +Call this method when the user drags the mouse into the web view (before +calling DragTargetDragOver/DragTargetLeave/DragTargetDrop). +|drag_data| should not contain file contents as this type of data is not +allowed to be dragged into the web view. File contents can be removed +using CefDragData::ResetFileContents (for example, if |drag_data| comes +from CefRenderHandler::StartDragging). This method is only used when +window rendering is disabled. + + + + +Cancels the existing composition and discards the composition node +contents without applying them. See comments on ImeSetComposition for +usage. +This method is only used when window rendering is disabled. + + + + +Completes the existing composition by applying the current composition +node contents. If |keep_selection| is false the current selection, if any, +will be discarded. See comments on ImeSetComposition for usage. This +method is only used when window rendering is disabled. + + + + +Completes the existing composition by optionally inserting the specified +|text| into the composition node. |replacement_range| is an optional range +of the existing text that will be replaced. |relative_cursor_pos| is where +the cursor will be positioned relative to the current cursor position. See +comments on ImeSetComposition for usage. The |replacement_range| and +|relative_cursor_pos| values are only used on OS X. +This method is only used when window rendering is disabled. + + + + +Begins a new composition or updates the existing composition. Blink has a +special node (a composition node) that allows the input method to change +text without affecting other DOM nodes. |text| is the optional text that +will be inserted into the composition node. |underlines| is an optional +set of ranges that will be underlined in the resulting text. +|replacement_range| is an optional range of the existing text that will be +replaced. |selection_range| is an optional range of the resulting text +that will be selected after insertion or replacement. The +|replacement_range| value is only used on OS X. + +This method may be called multiple times as the composition changes. When +the client is done making changes the composition should either be +canceled or completed. To cancel the composition call +ImeCancelComposition. To complete the composition call either +ImeCommitText or ImeFinishComposingText. Completion is usually signaled +when: + +1. The client receives a WM_IME_COMPOSITION message with a GCS_RESULTSTR + flag (on Windows), or; +2. The client receives a "commit" signal of GtkIMContext (on Linux), or; +3. insertText of NSTextInput is called (on Mac). + +This method is only used when window rendering is disabled. + + + + +Set the maximum rate in frames per second (fps) that CefRenderHandler:: +OnPaint will be called for a windowless browser. The actual fps may be +lower if the browser cannot generate frames at the requested rate. The +minimum value is 1 and the maximum value is 60 (default 30). Can also be +set at browser creation via CefBrowserSettings.windowless_frame_rate. + + + + +Returns the maximum rate in frames per second (fps) that +CefRenderHandler::OnPaint will be called for a windowless browser. The +actual fps may be lower if the browser cannot generate frames at the +requested rate. The minimum value is 1 and the maximum value is 60 +(default 30). This method can only be called on the UI thread. + + + + +Notify the browser that the window hosting it is about to be moved or +resized. This method is only used on Windows and Linux. + + + + +Send a capture lost event to the browser. + + + + +Send a touch event to the browser for a windowless browser. + + + + +Send a mouse wheel event to the browser. The |x| and |y| coordinates are +relative to the upper-left corner of the view. The |deltaX| and |deltaY| +values represent the movement delta in the X and Y directions +respectively. In order to scroll inside select popups with window +rendering disabled CefRenderHandler::GetScreenPoint should be implemented +properly. + + + + +Send a mouse move event to the browser. The |x| and |y| coordinates are +relative to the upper-left corner of the view. + + + + +Send a mouse click event to the browser. The |x| and |y| coordinates are +relative to the upper-left corner of the view. + + + + +Send a key event to the browser. + + + + +Issue a BeginFrame request to Chromium. Only valid when +CefWindowInfo::external_begin_frame_enabled is set to true. + + + + +Invalidate the view. The browser will call CefRenderHandler::OnPaint +asynchronously. This method is only used when window rendering is +disabled. + + + + +Send a notification to the browser that the screen info has changed. The +browser will then call CefRenderHandler::GetScreenInfo to update the +screen information with the new values. This simulates moving the webview +window from one display to another, or changing the properties of the +current display. This method is only used when window rendering is +disabled. + + + + +Notify the browser that it has been hidden or shown. Layouting and +CefRenderHandler::OnPaint notification will stop when the browser is +hidden. This method is only used when window rendering is disabled. + + + + +Notify the browser that the widget has been resized. The browser will +first call CefRenderHandler::GetViewRect to get the new size and then call +CefRenderHandler::OnPaint asynchronously with the updated regions. This +method is only used when window rendering is disabled. + + + + +Returns true if window rendering is disabled. + + + + +Add the specified |word| to the spelling dictionary. + + + + +If a misspelled word is currently selected in an editable node calling +this method will replace it with the specified |word|. + + + + +Retrieve a snapshot of current navigation entries as values sent to the +specified visitor. If |current_only| is true only the current navigation +entry will be sent, otherwise all navigation entries will be sent. + + + + +Add an observer for DevTools protocol messages (method results and +events). The observer will remain registered until the returned +Registration object is destroyed. See the SendDevToolsMessage +documentation for additional usage information. + + + + +Execute a method call over the DevTools protocol. This is a more +structured version of SendDevToolsMessage. |message_id| is an incremental +number that uniquely identifies the message (pass 0 to have the next +number assigned automatically based on previous values). |method| is the +method name. |params| are the method parameters, which may be empty. See +the DevTools protocol documentation (linked above) for details of +supported methods and the expected |params| dictionary contents. This +method will return the assigned message ID if called on the UI thread and +the message was successfully submitted for validation, otherwise 0. See +the SendDevToolsMessage documentation for additional usage information. + + + + +Returns true if this browser currently has an associated DevTools browser. +Must be called on the browser process UI thread. + + + + +Explicitly close the associated DevTools browser, if any. + + + + +Open developer tools (DevTools) in its own browser. The DevTools browser +will remain associated with this browser. If the DevTools browser is +already open then it will be focused, in which case the |windowInfo|, +|client| and |settings| parameters will be ignored. If +|inspect_element_at| is non-empty then the element at the specified (x,y) +location will be inspected. The |windowInfo| parameter will be ignored if +this browser is wrapped in a CefBrowserView. + + + + +Cancel all searches that are currently going on. + + + + +Search for |searchText|. |forward| indicates whether to search forward or +backward within the page. |matchCase| indicates whether the search should +be case-sensitive. |findNext| indicates whether this is the first request +or a follow-up. The search will be restarted if |searchText| or +|matchCase| change. The search will be stopped if |searchText| is empty. +The CefFindHandler instance, if any, returned via +CefClient::GetFindHandler will be called to report find results. + + + + +Print the current browser contents to the PDF file specified by |path| and +execute |callback| on completion. The caller is responsible for deleting +|path| when done. For PDF printing to work on Linux you must implement the +CefPrintHandler::GetPdfPaperSize method. + + + + +Print the current browser contents. + + + + +Download the file at |url| using CefDownloadHandler. + + + + +Call to run a file chooser dialog. Only a single file chooser dialog may +be pending at any given time. |mode| represents the type of dialog to +display. |title| to the title to be used for the dialog and may be empty +to show the default title ("Open" or "Save" depending on the mode). +|default_file_path| is the path with optional directory and/or file name +component that will be initially selected in the dialog. |accept_filters| +are used to restrict the selectable file types and may any combination of +(a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), (b) +individual file extensions (e.g. +".txt" or ".png"), or (c) combined description and file extension +delimited using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg"). +|callback| will be executed after the dialog is dismissed or immediately +if another dialog is already pending. The dialog will be initiated +asynchronously on the UI thread. + + + + +Change the zoom level to the specified value. Specify 0.0 to reset the +zoom level. If called on the UI thread the change will be applied +immediately. Otherwise, the change will be applied asynchronously on the +UI thread. + + + + +Get the current zoom level. The default zoom level is 0.0. This method can +only be called on the UI thread. + + + + +Returns the request context for this browser. + + + + +Returns the client for this browser. + + + + +Returns true if this browser is wrapped in a CefBrowserView. + + + + +Retrieve the window handle (if any) of the browser that opened this +browser. Will return NULL for non-popup browsers or if this browser is +wrapped in a CefBrowserView. This method can be used in combination with +custom handling of modal windows. + + + + +Retrieve the window handle (if any) for this browser. If this browser is +wrapped in a CefBrowserView this method should be called on the browser +process UI thread and it will return the handle for the top-level native +window. + + + + +Set whether the browser is focused. + + + + +Helper for closing a browser. Call this method from the top-level window +close handler (if any). Internally this calls CloseBrowser(false) if the +close has not yet been initiated. This method returns false while the +close is pending and true after the close has completed. See +CloseBrowser() and CefLifeSpanHandler::DoClose() documentation for +additional usage information. This method must be called on the browser +process UI thread. + + + + +Request that the browser close. The JavaScript 'onbeforeunload' event will +be fired. If |force_close| is false the event handler, if any, will be +allowed to prompt the user and the user can optionally cancel the close. +If |force_close| is true the prompt will not be displayed and the close +will proceed. Results in a call to CefLifeSpanHandler::DoClose() if the +event handler allows the close or if |force_close| is true. See +CefLifeSpanHandler::DoClose() documentation for additional usage +information. + + + + +Returns the hosted browser object. + + + + +Create a new browser using the window parameters specified by +|windowInfo|. If |request_context| is empty the global request context +will be used. This method can only be called on the browser process UI +thread. The optional |extra_info| parameter provides an opportunity to +specify extra information specific to the created browser that will be +passed to CefRenderProcessHandler::OnBrowserCreated() in the render +process. + + + + +Create a new browser using the window parameters specified by +|windowInfo|. All values will be copied internally and the actual window +(if any) will be created on the UI thread. If |request_context| is empty +the global request context will be used. This method can be called on any +browser process thread and will not block. The optional |extra_info| +parameter provides an opportunity to specify extra information specific to +the created browser that will be passed to +CefRenderProcessHandler::OnBrowserCreated() in the render process. + + + + +Class used to represent the browser process aspects of a browser. The +methods of this class can only be called in the browser process. They may be +called on any thread in that process unless otherwise indicated in the +comments. + + + + +Method that will be executed when the image download has completed. +|image_url| is the URL that was downloaded and |http_status_code| is the +resulting HTTP status code. |image| is the resulting image, possibly at +multiple scale factors, or empty if the download failed. + + + + +Callback interface for CefBrowserHost::DownloadImage. The methods of this +class will be called on the browser process UI thread. + + + + +Method that will be executed when the PDF printing has completed. |path| +is the output path. |ok| will be true if the printing completed +successfully or false otherwise. + + + + +Callback interface for CefBrowserHost::PrintToPDF. The methods of this class +will be called on the browser process UI thread. + + + + +Method that will be executed. Do not keep a reference to |entry| outside +of this callback. Return true to continue visiting entries or false to +stop. |current| is true if this entry is the currently loaded navigation +entry. |index| is the 0-based index of this entry and |total| is the total +number of entries. + + + + +Callback interface for CefBrowserHost::GetNavigationEntries. The methods of +this class will be called on the browser process UI thread. + + + + +Called asynchronously after the file dialog is dismissed. +|file_paths| will be a single value or a list of values depending on the +dialog mode. If the selection was cancelled |file_paths| will be empty. + + + + +Callback interface for CefBrowserHost::RunFileDialog. The methods of this +class will be called on the browser process UI thread. + + + + +Returns the names of all existing frames. + + + + +Returns the identifiers of all existing frames. + + + + +Returns the number of frames that currently exist. + + + + +Returns the frame with the specified name, or NULL if not found. + + + + +Returns the frame with the specified identifier, or NULL if not found. + + + + +Returns the focused frame for the browser. + + + + +Returns the main (top-level) frame for the browser. In the browser process +this will return a valid object until after +CefLifeSpanHandler::OnBeforeClose is called. In the renderer process this +will return NULL if the main frame is hosted in a different renderer +process (e.g. for cross-origin sub-frames). The main frame object will +change during cross-origin navigation or re-navigation after renderer +process termination (due to crashes, etc). + + + + +Returns true if a document has been loaded in the browser. + + + + +Returns true if the browser is a popup. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +Returns the globally unique identifier for this browser. This value is +also used as the tabId for extension APIs. + + + + +Stop loading the page. + + + + +Reload the current page ignoring any cached data. + + + + +Reload the current page. + + + + +Returns true if the browser is currently loading. + + + + +Navigate forwards. + + + + +Returns true if the browser can navigate forwards. + + + + +Navigate backwards. + + + + +Returns true if the browser can navigate backwards. + + + + +Returns the browser host object. This method can only be called in the +browser process. + + + + +True if this object is currently valid. This will return false after +CefLifeSpanHandler::OnBeforeClose is called. + + + + +Class used to represent a browser. When used in the browser process the +methods of this class may be called on any thread unless otherwise indicated +in the comments. When used in the render process the methods of this class +may only be called on the main thread. + + + + +Returns the MediaRouter object associated with this context. If +|callback| is non-NULL it will be executed asnychronously on the UI thread +after the manager's context has been initialized. + + + + +Returns the extension matching |extension_id| or NULL if no matching +extension is accessible in this context (see HasExtension). This method +must be called on the browser process UI thread. + + + + +Retrieve the list of all extensions that this context has access to (see +HasExtension). |extension_ids| will be populated with the list of +extension ID values. Returns true on success. This method must be called +on the browser process UI thread. + + + + +Returns true if this context has access to the extension identified by +|extension_id|. This may not be the context that was used to load the +extension (see DidLoadExtension). This method must be called on the +browser process UI thread. + + + + +Returns true if this context was used to load the extension identified by +|extension_id|. Other contexts sharing the same storage will also have +access to the extension (see HasExtension). This method must be called on +the browser process UI thread. + + + + +Attempts to resolve |origin| to a list of associated IP addresses. +|callback| will be executed on the UI thread after completion. + + + + +Clears all active and idle connections that Chromium currently has. +This is only recommended if you have released all other CEF objects but +don't yet want to call CefShutdown(). If |callback| is non-NULL it will be +executed on the UI thread after completion. + + + + +Clears all HTTP authentication credentials that were added as part of +handling GetAuthCredentials. If |callback| is non-NULL it will be executed +on the UI thread after completion. + + + + +Clears all certificate exceptions that were added as part of handling +CefRequestHandler::OnCertificateError(). If you call this it is +recommended that you also call CloseAllConnections() or you risk not +being prompted again for server certificates if you reconnect quickly. +If |callback| is non-NULL it will be executed on the UI thread after +completion. + + + + +Clear all registered scheme handler factories. Returns false on error. +This function may be called on any thread in the browser process. + + + + +Register a scheme handler factory for the specified |scheme_name| and +optional |domain_name|. An empty |domain_name| value for a standard scheme +will cause the factory to match all domain names. The |domain_name| value +will be ignored for non-standard schemes. If |scheme_name| is a built-in +scheme and no handler is returned by |factory| then the built-in scheme +handler factory will be called. If |scheme_name| is a custom scheme then +you must also implement the CefApp::OnRegisterCustomSchemes() method in +all processes. This function may be called multiple times to change or +remove the factory that matches the specified |scheme_name| and optional +|domain_name|. Returns false if an error occurs. This function may be +called on any thread in the browser process. + + + + +Returns the cookie manager for this object. If |callback| is non-NULL it +will be executed asnychronously on the UI thread after the manager's +storage has been initialized. + + + + +Returns the cache path for this object. If empty an "incognito mode" +in-memory cache is being used. + + + + +Returns the handler for this context if any. + + + + +Returns true if this object is the global context. The global context is +used by default when creating a browser or URL request with a NULL context +argument. + + + + +Returns true if this object is sharing the same storage as |that| object. + + + + +Returns true if this object is pointing to the same context as |that| +object. + + + + +Creates a new context object that shares storage with |other| and uses an +optional |handler|. + + + + +Creates a new context object with the specified |settings| and optional +|handler|. + + + + +Returns the global context object. + + + + +A request context provides request handling for a set of related browser +or URL request objects. A request context can be specified when creating a +new browser via the CefBrowserHost static factory methods or when creating a +new URL request via the CefURLRequest static factory methods. Browser +objects with different request contexts will never be hosted in the same +render process. Browser objects with the same request context may or may not +be hosted in the same render process depending on the process model. Browser +objects created indirectly via the JavaScript window.open function or +targeted links will share the same render process and the same request +context as the source browser. When running in single-process mode there is +only a single render process (the main process) and so all browsers created +in single-process mode will share the same request context. This will be the +first request context passed into a CefBrowserHost static factory method and +all other request context objects will be ignored. + + + + +Called on the UI thread after the ResolveHost request has completed. +|result| will be the result code. |resolved_ips| will be the list of +resolved IP addresses or empty if the resolution failed. + + + + +Callback interface for CefRequestContext::ResolveHost. + + + + +Set the |value| associated with preference |name|. Returns true if the +value is set successfully and false otherwise. If |value| is NULL the +preference will be restored to its default value. If setting the +preference fails then |error| will be populated with a detailed +description of the problem. This method must be called on the browser +process UI thread. + + + + +Returns true if the preference with the specified |name| can be modified +using SetPreference. As one example preferences set via the command-line +usually cannot be modified. This method must be called on the browser +process UI thread. + + + + +Returns all preferences as a dictionary. If |include_defaults| is true +then preferences currently at their default value will be included. The +returned object contains a copy of the underlying preference values and +modifications to the returned object will not modify the underlying +preference values. This method must be called on the browser process UI +thread. + + + + +Returns the value for the preference with the specified |name|. Returns +NULL if the preference does not exist. The returned object contains a copy +of the underlying preference value and modifications to the returned +object will not modify the underlying preference value. This method must +be called on the browser process UI thread. + + + + +Returns true if a preference with the specified |name| exists. This method +must be called on the browser process UI thread. + + + + +Returns the global preference manager object. + + + + +Manage access to preferences. Many built-in preferences are registered by +Chromium. Custom preferences can be registered in +CefBrowserProcessHandler::OnRegisterCustomPreferences. + + + + +Register a preference with the specified |name| and |default_value|. To +avoid conflicts with built-in preferences the |name| value should contain +an application-specific prefix followed by a period (e.g. "myapp.value"). +The contents of |default_value| will be copied. The data type for the +preference will be inferred from |default_value|'s type and cannot be +changed after registration. Returns true on success. Returns false if +|name| is already registered or if |default_value| has an invalid type. +This method must be called from within the scope of the +CefBrowserProcessHandler::OnRegisterCustomPreferences callback. + + + + +Class that manages custom preference registrations. + + + + +Returns true if this source outputs its content via DIAL. + + + + +Returns true if this source outputs its content via Cast. + + + + +Returns the ID (media source URN or URL) for this source. + + + + +Represents a source from which media can be routed. Instances of this object +are retrieved via CefMediaRouter::GetSource. The methods of this class may +be called on any browser process thread unless otherwise indicated. + + + + +Method that will be executed asyncronously once device information has +been retrieved. + + + + +Callback interface for CefMediaSink::GetDeviceInfo. The methods of this +class will be called on the browser process UI thread. + + + + +Returns true if this sink is compatible with |source|. + + + + +Returns true if this sink accepts content via DIAL. + + + + +Returns true if this sink accepts content via Cast. + + + + +Asynchronously retrieves device info. + + + + +Returns the icon type for this sink. + + + + +Returns the name of this sink. + + + + +Returns the ID for this sink. + + + + +Represents a sink to which media can be routed. Instances of this object are +retrieved via CefMediaObserver::OnSinks. The methods of this class may +be called on any browser process thread unless otherwise indicated. + + + + +Method that will be executed when the route creation has finished. +|result| will be CEF_MRCR_OK if the route creation succeeded. |error| will +be a description of the error if the route creation failed. |route| is the +resulting route, or empty if the route creation failed. + + + + +Callback interface for CefMediaRouter::CreateRoute. The methods of this +class will be called on the browser process UI thread. + + + + +Terminate this route. Will result in an asynchronous call to +CefMediaObserver::OnRoutes on all registered observers. + + + + +Send a message over this route. |message| will be copied if necessary. + + + + +Returns the sink associated with this route. + + + + +Returns the source associated with this route. + + + + +Returns the ID for this route. + + + + +Represents the route between a media source and sink. Instances of this +object are created via CefMediaRouter::CreateRoute and retrieved via +CefMediaObserver::OnRoutes. Contains the status and metadata of a +routing operation. The methods of this class may be called on any browser +process thread unless otherwise indicated. + + + + +A message was recieved over |route|. |message| is only valid for +the scope of this callback and should be copied if necessary. + + + + +The connection state of |route| has changed. + + + + +The list of available media routes has changed or +CefMediaRouter::NotifyCurrentRoutes was called. + + + + +The list of available media sinks has changed or +CefMediaRouter::NotifyCurrentSinks was called. + + + + +Implemented by the client to observe MediaRouter events and registered via +CefMediaRouter::AddObserver. The methods of this class will be called on the +browser process UI thread. + + + + +Trigger an asynchronous call to CefMediaObserver::OnRoutes on all +registered observers. + + + + +Create a new route between |source| and |sink|. Source and sink must be +valid, compatible (as reported by CefMediaSink::IsCompatibleWith), and a +route between them must not already exist. |callback| will be executed +on success or failure. If route creation succeeds it will also trigger an +asynchronous call to CefMediaObserver::OnRoutes on all registered +observers. + + + + +Trigger an asynchronous call to CefMediaObserver::OnSinks on all +registered observers. + + + + +Add an observer for MediaRouter events. The observer will remain +registered until the returned Registration object is destroyed. + + + + +Returns the MediaRouter object associated with the global request context. +If |callback| is non-NULL it will be executed asnychronously on the UI +thread after the manager's storage has been initialized. Equivalent to +calling CefRequestContext::GetGlobalContext()->GetMediaRouter(). + + + + +Supports discovery of and communication with media devices on the local +network via the Cast and DIAL protocols. The methods of this class may be +called on any browser process thread unless otherwise indicated. + + + + +Called to retrieve an extension resource that would normally be loaded +from disk (e.g. if a file parameter is specified to +chrome.tabs.executeScript). |extension| and |browser| are the source of +the resource request. |file| is the requested relative file path. To +handle the resource request return true and execute |callback| either +synchronously or asynchronously. For the default behavior which reads the +resource from the extension directory on disk return false. Localization +substitutions will not be applied to resources handled via this method. + + + + +Called when the tabId associated with |target_browser| is specified to an +extension API call that accepts a tabId parameter (e.g. chrome.tabs.*). +|extension| and |browser| are the source of the API call. Return true +to allow access of false to deny access. Access to incognito browsers +should not be allowed unless the source extension has incognito access +enabled, in which case |include_incognito| will be true. + + + + +Called when no tabId is specified to an extension API call that accepts a +tabId parameter (e.g. chrome.tabs.*). |extension| and |browser| are the +source of the API call. Return the browser that will be acted on by the +API call or return NULL to act on |browser|. The returned browser must +share the same CefRequestContext as |browser|. Incognito browsers should +not be considered unless the source extension has incognito access +enabled, in which case |include_incognito| will be true. + + + + +Called when an extension API (e.g. chrome.tabs.create) requests creation +of a new browser. |extension| and |browser| are the source of the API +call. |active_browser| may optionally be specified via the windowId +property or returned via the GetActiveBrowser() callback and provides the +default |client| and |settings| values for the new browser. |index| is the +position value optionally specified via the index property. |url| is the +URL that will be loaded in the browser. |active| is true if the new +browser should be active when opened. To allow creation of the browser +optionally modify |windowInfo|, |client| and |settings| and return false. +To cancel creation of the browser return true. Successful creation will be +indicated by a call to CefLifeSpanHandler::OnAfterCreated. Any +modifications to |windowInfo| will be ignored if |active_browser| is +wrapped in a CefBrowserView. + + + + +Called after the CefExtension::Unload request has completed. + + + + +Called if the CefRequestContext::LoadExtension request succeeds. +|extension| is the loaded extension. + + + + +Called if the CefRequestContext::LoadExtension request fails. |result| +will be the error code. + + + + +Implement this interface to handle events related to browser extensions. +The methods of this class will be called on the UI thread. See +CefRequestContext::LoadExtension for information about extension loading. + + + + +Cancel the request. + + + + +Continue the request. Read the resource contents from |stream|. + + + + +Callback interface used for asynchronous continuation of +CefExtensionHandler::GetExtensionResource. + + + + +Unload this extension if it is not an internal extension and is currently +loaded. Will result in a call to CefExtensionHandler::OnExtensionUnloaded +on success. + + + + +Returns true if this extension is currently loaded. Must be called on the +browser process UI thread. + + + + +Returns the request context that loaded this extension. Will return NULL +for internal extensions or if the extension has been unloaded. See the +CefRequestContext::LoadExtension documentation for more information about +loader contexts. Must be called on the browser process UI thread. + + + + +Returns the handler for this extension. Will return NULL for internal +extensions or if no handler was passed to +CefRequestContext::LoadExtension. + + + + +Returns true if this object is the same extension as |that| object. +Extensions are considered the same if identifier, path and loader context +match. + + + + +Returns the extension manifest contents as a CefDictionaryValue object. +See https://developer.chrome.com/extensions/manifest for details. + + + + +Returns the absolute path to the extension directory on disk. This value +will be prefixed with PK_DIR_RESOURCES if a relative path was passed to +CefRequestContext::LoadExtension. + + + + +Returns the unique extension identifier. This is calculated based on the +extension public key, if available, or on the extension path. See +https://developer.chrome.com/extensions/manifest/key for details. + + + + +Object representing an extension. Methods may be called on any thread unless +otherwise indicated. + + + + +Method that will be called upon completion. |num_deleted| will be the +number of cookies that were deleted. + + + + +Interface to implement to be notified of asynchronous completion via +CefCookieManager::DeleteCookies(). + + + + +Method that will be called upon completion. |success| will be true if the +cookie was set successfully. + + + + +Interface to implement to be notified of asynchronous completion via +CefCookieManager::SetCookie(). + + + + +Method that will be called once for each cookie. |count| is the 0-based +index for the current cookie. |total| is the total number of cookies. +Set |deleteCookie| to true to delete the cookie currently being visited. +Return false to stop visiting cookies. This method may never be called if +no cookies are found. + + + + +Interface to implement for visiting cookie values. The methods of this class +will always be called on the UI thread. + + + + +Flush the backing store (if any) to disk. If |callback| is non-NULL it +will be executed asnychronously on the UI thread after the flush is +complete. Returns false if cookies cannot be accessed. + + + + +Delete all cookies that match the specified parameters. If both |url| and +|cookie_name| values are specified all host and domain cookies matching +both will be deleted. If only |url| is specified all host cookies (but not +domain cookies) irrespective of path will be deleted. If |url| is empty +all cookies for all hosts and domains will be deleted. If |callback| is +non-NULL it will be executed asnychronously on the UI thread after the +cookies have been deleted. Returns false if a non-empty invalid URL is +specified or if cookies cannot be accessed. Cookies can alternately be +deleted using the Visit*Cookies() methods. + + + + +Sets a cookie given a valid URL and explicit user-provided cookie +attributes. This function expects each attribute to be well-formed. It +will check for disallowed characters (e.g. the ';' character is disallowed +within the cookie value attribute) and fail without setting the cookie if +such characters are found. If |callback| is non-NULL it will be executed +asnychronously on the UI thread after the cookie has been set. Returns +false if an invalid URL is specified or if cookies cannot be accessed. + + + + +Visit a subset of cookies on the UI thread. The results are filtered by +the given url scheme, host, domain and path. If |includeHttpOnly| is true +HTTP-only cookies will also be included in the results. The returned +cookies are ordered by longest path, then by earliest creation date. +Returns false if cookies cannot be accessed. + + + + +Visit all cookies on the UI thread. The returned cookies are ordered by +longest path, then by earliest creation date. Returns false if cookies +cannot be accessed. + + + + +Returns the global cookie manager. By default data will be stored at +cef_settings_t.cache_path if specified or in memory otherwise. If +|callback| is non-NULL it will be executed asnychronously on the UI thread +after the manager's storage has been initialized. Using this method is +equivalent to calling +CefRequestContext::GetGlobalContext()->GetDefaultCookieManager(). + + + + +Class used for managing cookies. The methods of this class may be called on +any thread unless otherwise indicated. + + + + +Method that will be called once the task is complete. + + + + +Generic callback interface used for asynchronous completion. + + + + +Cancel processing. + + + + +Continue processing. + + + + +Generic callback interface used for asynchronous continuation. + + + + +Generic callback interface used for managing the lifespan of a registration. + + + + +Returns the SSL information for this navigation entry. + + + + +Returns the HTTP status code for the last known successful navigation +response. May be 0 if the response has not yet been received or if the +navigation has not yet completed. + + + + +Returns the time for the last known successful navigation completion. A +navigation may be completed more than once if the page is reloaded. May be +0 if the navigation has not yet completed. + + + + +Returns true if this navigation includes post data. + + + + +Returns the transition type which indicates what the user did to move to +this page from the previous page. + + + + +Returns the title set by the page. This value may be empty. + + + + +Returns the original URL that was entered by the user before any +redirects. + + + + +Returns a display-friendly version of the URL. + + + + +Returns the actual URL of the page. For some pages this may be data: URL +or similar. Use GetDisplayURL() to return a display-friendly version. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Class used to represent an entry in navigation history. + + + + +Returns the X.509 certificate. + + + + +Returns a bitmask containing the page security content status. + + + + +Returns the SSL version used for the SSL connection. + + + + +Returns a bitmask containing any and all problems verifying the server +certificate. + + + + +Returns true if the status is related to a secure SSL/TLS connection. + + + + +Class representing the SSL information for a navigation entry. + + + + +Returns the PEM encoded data for the certificate issuer chain. +If we failed to encode a certificate in the chain it is still +present in the array but is an empty string. + + + + +Returns the DER encoded data for the certificate issuer chain. +If we failed to encode a certificate in the chain it is still +present in the array but is an empty string. + + + + +Returns the number of certificates in the issuer chain. +If 0, the certificate is self-signed. + + + + +Returns the PEM encoded data for the X.509 certificate. + + + + +Returns the DER encoded data for the X.509 certificate. + + + + +Returns the date after which the X.509 certificate is invalid. +CefBaseTime.GetTimeT() will return 0 if no date was specified. + + + + +Returns the date before which the X.509 certificate is invalid. +CefBaseTime.GetTimeT() will return 0 if no date was specified. + + + + +Returns the DER encoded serial number for the X.509 certificate. The value +possibly includes a leading 00 byte. + + + + +Returns the issuer of the X.509 certificate. + + + + +Returns the subject of the X.509 certificate. For HTTPS server +certificates this represents the web server. The common name of the +subject should match the host name of the web server. + + + + +Class representing a X.509 certificate. + + + + +Retrieve the list of domain components. + + + + +Retrieve the list of organization unit names. + + + + +Retrieve the list of organization names. + + + + +Retrieve the list of street addresses. + + + + +Returns the country name. + + + + +Returns the state or province name. + + + + +Returns the locality name. + + + + +Returns the common name. + + + + +Returns a name that can be used to represent the issuer. It tries in this +order: Common Name (CN), Organization Name (O) and Organizational Unit +Name (OU) and returns the first non-empty one found. + + + + +Class representing the issuer or subject field of an X.509 certificate. + + + + +Send a message to the specified |target_process|. Ownership of the message +contents will be transferred and the |message| reference will be +invalidated. Message delivery is not guaranteed in all cases (for example, +if the browser is closing, navigating, or if the target process crashes). +Send an ACK message back from the target process if confirmation is +required. + + + + +Create a new URL request that will be treated as originating from this +frame and the associated browser. Use CefURLRequest::Create instead if you +do not want the request to have this association, in which case it may be +handled differently (see documentation on that method). A request created +with this method may only originate from the browser process, and will +behave as follows: + - It may be intercepted by the client via CefResourceRequestHandler or + CefSchemeHandlerFactory. + - POST data may only contain a single element of type PDE_TYPE_FILE or + PDE_TYPE_BYTES. + +The |request| object will be marked as read-only after calling this +method. + + + + +Visit the DOM document. This method can only be called from the render +process. + + + + +Get the V8 context associated with the frame. This method can only be +called from the render process. + + + + +Returns the browser that this frame belongs to. + + + + +Returns the URL currently loaded in this frame. + + + + +Returns the parent of this frame or NULL if this is the main (top-level) +frame. + + + + +Returns the name for this frame. If the frame has an assigned name (for +example, set via the iframe "name" attribute) then that value will be +returned. Otherwise a unique name will be constructed based on the frame +parent hierarchy. The main (top-level) frame will always have an empty +name value. + + + + +Returns true if this is the focused frame. + + + + +Returns true if this is the main (top-level) frame. + + + + +Execute a string of JavaScript code in this frame. The |script_url| +parameter is the URL where the script in question can be found, if any. +The renderer may request this URL to show the developer the source of the +error. The |start_line| parameter is the base line number to use for +error reporting. + + + + +Load the specified |url|. + + + + +Load the request represented by the |request| object. + +WARNING: This method will fail with "bad IPC message" reason +INVALID_INITIATOR_ORIGIN (213) unless you first navigate to the +request origin using some other mechanism (LoadURL, link click, etc). + + + + +Retrieve this frame's display text as a string sent to the specified +visitor. + + + + +Retrieve this frame's HTML source as a string sent to the specified +visitor. + + + + +Save this frame's HTML source to a temporary file and open it in the +default text viewing application. This method can only be called from the +browser process. + + + + +Execute select all in this frame. + + + + +Execute delete in this frame. + + + + +Execute paste in this frame. + + + + +Execute copy in this frame. + + + + +Execute cut in this frame. + + + + +Execute redo in this frame. + + + + +Execute undo in this frame. + + + + +True if this object is currently attached to a valid frame. + + + + +Class used to represent a frame in the browser window. When used in the +browser process the methods of this class may be called on any thread unless +otherwise indicated in the comments. When used in the render process the +methods of this class may only be called on the main thread. + + + + +Method that will be executed. + + + + +Implement this interface to receive string values asynchronously. + + + + +Read up to |size| bytes into |bytes| and return the number of bytes +actually read. + + + + +Return the number of bytes. + + + + +Return the file name. + + + + +Return the type of this post data element. + + + + +The post data element will represent bytes. The bytes passed +in will be copied. + + + + +The post data element will represent a file. + + + + +Remove all contents from the post data element. + + + + +Returns true if this object is read-only. + + + + +Create a new CefPostDataElement object. + + + + +Post data elements may represent either bytes or files. + + + + +Class used to represent a single element in the request post data. The +methods of this class may be called on any thread. + + + + +Remove all existing post data elements. + + + + +Add the specified post data element. Returns true if the add succeeds. + + + + +Remove the specified post data element. Returns true if the removal +succeeds. + + + + +Retrieve the post data elements. + + + + +Returns the number of existing post data elements. + + + + +Returns true if the underlying POST data includes elements that are not +represented by this CefPostData object (for example, multi-part file +upload data). Modifying CefPostData objects with excluded elements may +result in the request failing. + + + + +Returns true if this object is read-only. + + + + +Create a new CefPostData object. + + + + +Class used to represent post data for a web request. The methods of this +class may be called on any thread. + + + + +Returns the globally unique identifier for this request or 0 if not +specified. Can be used by CefResourceRequestHandler implementations in the +browser process to track a single request across multiple callbacks. + + + + +Get the transition type for this request. Only available in the browser +process and only applies to requests that represent a main frame or +sub-frame navigation. + + + + +Get the resource type for this request. Only available in the browser +process. + + + + +Set the URL to the first party for cookies used in combination with +CefURLRequest. + + + + +Get the URL to the first party for cookies used in combination with +CefURLRequest. + + + + +Set the flags used in combination with CefURLRequest. See +cef_urlrequest_flags_t for supported values. + + + + +Get the flags used in combination with CefURLRequest. See +cef_urlrequest_flags_t for supported values. + + + + +Set all values at one time. + + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. The Referer value cannot be set +using this method. + + + + +Returns the first header value for |name| or an empty string if not found. +Will not return the Referer value if any. Use GetHeaderMap instead if +|name| might have multiple values. + + + + +Set the header values. If a Referer value exists in the header map it will +be removed and ignored. + + + + +Get the header values. Will not include the Referer value if any. + + + + +Set the post data. + + + + +Get the post data. + + + + +Get the referrer policy. + + + + +Get the referrer URL. + + + + +Set the referrer URL and policy. If non-empty the referrer URL must be +fully qualified with an HTTP or HTTPS scheme component. Any username, +password or ref component will be removed. + + + + +Set the request method type. + + + + +Get the request method type. The value will default to POST if post data +is provided and GET otherwise. + + + + +Set the fully qualified URL. + + + + +Get the fully qualified URL. + + + + +Returns true if this object is read-only. + + + + +Create a new CefRequest object. + + + + +Class used to represent a web request. The methods of this class may be +called on any thread. + + + + +Returns the shared memory region. +Returns nullptr when message contains an argument list. + + + + +Returns the list of arguments. +Returns nullptr when message contains a shared memory region. + + + + +Returns the message name. + + + + +Returns a writable copy of this object. +Returns nullptr when message contains a shared memory region. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Create a new CefProcessMessage object with the specified name. + + + + +Class representing a message. Can be used on any process and thread. + + + + +Returns the pointer to the memory. Returns nullptr for invalid instances. +The returned pointer is only valid for the life span of this object. + + + + +Returns the size of the mapping in bytes. Returns 0 for invalid instances. + + + + +Returns true if the mapping is valid. + + + + +Class that wraps platform-dependent share memory region mapping. + + + + +Returns the bounds of the element in device pixels. Use +"window.devicePixelRatio" to convert to/from CSS pixels. + + + + +Returns the inner text of the element. + + + + +Set the value for the element attribute named |attrName|. Returns true on +success. + + + + +Returns a map of all element attributes. + + + + +Returns the element attribute named |attrName|. + + + + +Returns true if this element has an attribute named |attrName|. + + + + +Returns true if this element has attributes. + + + + +Returns the tag name of this element. + + + + +Returns the last child node. + + + + +Return the first child node. + + + + +Returns true if this node has child nodes. + + + + +Returns the next sibling node. + + + + +Returns the previous sibling node. + + + + +Returns the parent node. + + + + +Returns the document associated with this node. + + + + +Returns the contents of this node as markup. + + + + +Set the value of this node. Returns true on success. + + + + +Returns the value of this node. + + + + +Returns the name of this node. + + + + +Returns true if this object is pointing to the same handle as |that| +object. + + + + +Returns the type of this form control element node. + + + + +Returns true if this is a form control element node. + + + + +Returns true if this is an editable node. + + + + +Returns true if this is an element node. + + + + +Returns true if this is a text node. + + + + +Returns the type for this node. + + + + +Class used to represent a DOM node. The methods of this class should only be +called on the render process main thread. + + + + +Returns a complete URL based on the document base URL and the specified +partial URL. + + + + +Returns the base URL for the document. + + + + +Returns the contents of this selection as text. + + + + +Returns the contents of this selection as markup. + + + + +Returns the selection offset within the end node. + + + + +Returns the selection offset within the start node. + + + + +Returns true if a portion of the document is selected. + + + + +Returns the node that currently has keyboard focus. + + + + +Returns the document element with the specified ID value. + + + + +Returns the title of an HTML document. + + + + +Returns the HEAD node of an HTML document. + + + + +Returns the BODY node of an HTML document. + + + + +Returns the root document node. + + + + +Returns the document type. + + + + +Class used to represent a DOM document. The methods of this class should +only be called on the render process main thread thread. + + + + +Method executed for visiting the DOM. The document object passed to this +method represents a snapshot of the DOM at the time this method is +executed. DOM objects are only valid for the scope of this method. Do not +keep references to or attempt to access any DOM objects outside the scope +of this method. + + + + +Interface to implement for visiting the DOM. The methods of this class will +be called on the render process main thread. + + + + +Returns true if an image representation of drag data is available. + + + + +Get the image hotspot (drag start location relative to image dimensions). + + + + +Get the image representation of drag data. May return NULL if no image +representation is available. + + + + +Clear list of filenames. + + + + +Add a file that is being dragged into the webview. + + + + +Reset the file contents. You should do this before calling +CefBrowserHost::DragTargetDragEnter as the web view does not allow us to +drag in this kind of data. + + + + +Set the base URL that the fragment came from. + + + + +Set the text/html fragment that is being dragged. + + + + +Set the plain text fragment that is being dragged. + + + + +Set the metadata associated with the link being dragged. + + + + +Set the title associated with the link being dragged. + + + + +Set the link URL that is being dragged. + + + + +Retrieve the list of file names that are being dragged into the browser +window. + + + + +Write the contents of the file being dragged out of the web view into +|writer|. Returns the number of bytes sent to |writer|. If |writer| is +NULL this method will return the size of the file contents in bytes. +Call GetFileName() to get a suggested name for the file. + + + + +Return the name of the file being dragged out of the browser window. + + + + +Return the base URL that the fragment came from. This value is used for +resolving relative URLs and may be empty. + + + + +Return the text/html fragment that is being dragged. + + + + +Return the plain text fragment that is being dragged. + + + + +Return the metadata, if any, associated with the link being dragged. + + + + +Return the title associated with the link being dragged. + + + + +Return the link URL that is being dragged. + + + + +Returns true if the drag data is a file. + + + + +Returns true if the drag data is a text or html fragment. + + + + +Returns true if the drag data is a link. + + + + +Returns true if this object is read-only. + + + + +Returns a copy of the current object. + + + + +Create a new CefDragData object. + + + + +Class used to represent drag data. The methods of this class may be called +on any thread. + + + + +Returns true if this writer performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +writer from. + + + + +Flush the stream. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Returns zero on success and non-zero on +failure. + + + + +Write raw binary data. + + + + +Create a new CefStreamWriter object for a custom handler. + + + + +Create a new CefStreamWriter object for a file. + + + + +Class used to write data to a stream. The methods of this class may be +called on any thread. + + + + +Return true if this handler performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +handler from. + + + + +Flush the stream. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Return zero on success and non-zero on +failure. + + + + +Write raw binary data. + + + + +Interface the client can implement to provide a custom stream writer. The +methods of this class may be called on any thread. + + + + +Returns true if this reader performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +reader from. + + + + +Return non-zero if at end of file. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Returns zero on success and non-zero on +failure. + + + + +Read raw binary data. + + + + +Create a new CefStreamReader object from a custom handler. + + + + +Create a new CefStreamReader object from data. + + + + +Create a new CefStreamReader object from a file. + + + + +Class used to read data from a stream. The methods of this class may be +called on any thread. + + + + +Return true if this handler performs work like accessing the file system +which may block. Used as a hint for determining the thread to access the +handler from. + + + + +Return non-zero if at end of file. + + + + +Return the current offset position. + + + + +Seek to the specified offset position. |whence| may be any one of +SEEK_CUR, SEEK_END or SEEK_SET. Return zero on success and non-zero on +failure. + + + + +Read raw binary data. + + + + +Interface the client can implement to provide a custom stream reader. The +methods of this class may be called on any thread. + + + + +Returns the JPEG representation that most closely matches |scale_factor|. +|quality| determines the compression level with 0 == lowest and 100 == +highest. The JPEG format does not support alpha transparency and the alpha +channel, if any, will be discarded. |pixel_width| and |pixel_height| are +the output representation size in pixel coordinates. Returns a +CefBinaryValue containing the JPEG image data on success or NULL on +failure. + + + + +Returns the PNG representation that most closely matches |scale_factor|. +If |with_transparency| is true any alpha transparency in the image will be +represented in the resulting PNG data. |pixel_width| and |pixel_height| +are the output representation size in pixel coordinates. Returns a +CefBinaryValue containing the PNG image data on success or NULL on +failure. + + + + +Returns the bitmap representation that most closely matches +|scale_factor|. Only 32-bit RGBA/BGRA formats are supported. |color_type| +and |alpha_type| values specify the desired output pixel format. +|pixel_width| and |pixel_height| are the output representation size in +pixel coordinates. Returns a CefBinaryValue containing the pixel data on +success or NULL on failure. + + + + +Returns information for the representation that most closely matches +|scale_factor|. |actual_scale_factor| is the actual scale factor for the +representation. |pixel_width| and |pixel_height| are the representation +size in pixel coordinates. Returns true on success. + + + + +Removes the representation for |scale_factor|. Returns true on success. + + + + +Returns true if this image contains a representation for |scale_factor|. + + + + +Returns the image height in density independent pixel (DIP) units. + + + + +Returns the image width in density independent pixel (DIP) units. + + + + +Create a JPEG image representation for |scale_factor|. |jpeg_data| is the +image data of size |jpeg_data_size|. The JPEG format does not support +transparency so the alpha byte will be set to 0xFF for all pixels. + + + + +Add a PNG image representation for |scale_factor|. |png_data| is the image +data of size |png_data_size|. Any alpha transparency in the PNG data will +be maintained. + + + + +Add a bitmap image representation for |scale_factor|. Only 32-bit +RGBA/BGRA formats are supported. |pixel_width| and |pixel_height| are the +bitmap representation size in pixel coordinates. |pixel_data| is the array +of pixel data and should be |pixel_width| x |pixel_height| x 4 bytes in +size. |color_type| and |alpha_type| values specify the pixel format. + + + + +Returns true if this Image and |that| Image share the same underlying +storage. Will also return true if both images are empty. + + + + +Returns true if this Image is empty. + + + + +Create a new CefImage. It will initially be empty. Use the Add*() methods +to add representations at different scale factors. + + + + +Container for a single image represented at different scale factors. All +image representations should be the same size in density independent pixel +(DIP) units. For example, if the image at scale factor 1.0 is 100x100 pixels +then the image at scale factor 2.0 should be 200x200 pixels -- both images +will display with a DIP size of 100x100 units. The methods of this class can +be called on any browser process thread. + + + + +Sets the value at the specified index as type list. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified index as type dict. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified index as type binary. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified index as type string. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type double. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type int. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type bool. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index as type null. Returns true if the +value was set successfully. + + + + +Sets the value at the specified index. Returns true if the value was set +successfully. If |value| represents simple data then the underlying data +will be copied and modifications to |value| will not modify this object. +If |value| represents complex data (binary, dictionary or list) then the +underlying data will be referenced and modifications to |value| will +modify this object. + + + + +Returns the value at the specified index as type list. The returned +value will reference existing data and modifications to the value will +modify this object. + + + + +Returns the value at the specified index as type dictionary. The returned +value will reference existing data and modifications to the value will +modify this object. + + + + +Returns the value at the specified index as type binary. The returned +value will reference existing data. + + + + +Returns the value at the specified index as type string. + + + + +Returns the value at the specified index as type double. + + + + +Returns the value at the specified index as type int. + + + + +Returns the value at the specified index as type bool. + + + + +Returns the value at the specified index. For simple types the returned +value will copy existing data and modifications to the value will not +modify this object. For complex types (binary, dictionary and list) the +returned value will reference existing data and modifications to the value +will modify this object. + + + + +Returns the value type at the specified index. + + + + +Removes the value at the specified index. + + + + +Removes all values. Returns true on success. + + + + +Returns the number of values. + + + + +Sets the number of values. If the number of values is expanded all +new value slots will default to type null. Returns true on success. + + + + +Returns a writable copy of this object. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. If true modifications to this object will also affect |that| object +and vice-versa. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is currently owned by another object. + + + + +Returns true if this object is valid. This object may become invalid if +the underlying data is owned by another object (e.g. list or dictionary) +and that other object is then modified or destroyed. Do not call any other +methods if this method returns false. + + + + +Creates a new object that is not owned by any other object. + + + + +Class representing a list value. Can be used on any process and thread. + + + + +Sets the value at the specified key as type list. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified key as type dict. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified key as type binary. Returns true if the +value was set successfully. If |value| is currently owned by another +object then the value will be copied and the |value| reference will not +change. Otherwise, ownership will be transferred to this object and the +|value| reference will be invalidated. + + + + +Sets the value at the specified key as type string. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type double. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type int. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type bool. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key as type null. Returns true if the +value was set successfully. + + + + +Sets the value at the specified key. Returns true if the value was set +successfully. If |value| represents simple data then the underlying data +will be copied and modifications to |value| will not modify this object. +If |value| represents complex data (binary, dictionary or list) then the +underlying data will be referenced and modifications to |value| will +modify this object. + + + + +Returns the value at the specified key as type list. The returned value +will reference existing data and modifications to the value will modify +this object. + + + + +Returns the value at the specified key as type dictionary. The returned +value will reference existing data and modifications to the value will +modify this object. + + + + +Returns the value at the specified key as type binary. The returned +value will reference existing data. + + + + +Returns the value at the specified key as type string. + + + + +Returns the value at the specified key as type double. + + + + +Returns the value at the specified key as type int. + + + + +Returns the value at the specified key as type bool. + + + + +Returns the value at the specified key. For simple types the returned +value will copy existing data and modifications to the value will not +modify this object. For complex types (binary, dictionary and list) the +returned value will reference existing data and modifications to the value +will modify this object. + + + + +Returns the value type for the specified key. + + + + +Removes the value at the specified key. Returns true is the value was +removed successfully. + + + + +Reads all keys for this dictionary into the specified vector. + + + + +Returns true if the current dictionary has a value for the given key. + + + + +Removes all values. Returns true on success. + + + + +Returns the number of values. + + + + +Returns a writable copy of this object. If |exclude_empty_children| is +true any empty dictionaries or lists will be excluded from the copy. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. If true modifications to this object will also affect |that| object +and vice-versa. + + + + +Returns true if the values of this object are read-only. Some APIs may +expose read-only objects. + + + + +Returns true if this object is currently owned by another object. + + + + +Returns true if this object is valid. This object may become invalid if +the underlying data is owned by another object (e.g. list or dictionary) +and that other object is then modified or destroyed. Do not call any other +methods if this method returns false. + + + + +Creates a new object that is not owned by any other object. + + + + +Class representing a dictionary value. Can be used on any process and +thread. + + + + +Read up to |buffer_size| number of bytes into |buffer|. Reading begins at +the specified byte |data_offset|. Returns the number of bytes read. + + + + +Returns the data size. + + + + +Returns a copy of this object. The data in this object will also be +copied. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. + + + + +Returns true if this object is currently owned by another object. + + + + +Returns true if this object is valid. This object may become invalid if +the underlying data is owned by another object (e.g. list or dictionary) +and that other object is then modified or destroyed. Do not call any other +methods if this method returns false. + + + + +Creates a new object that is not owned by any other object. The specified +|data| will be copied. + + + + +Class representing a binary value. Can be used on any process and thread. + + + + +Sets the underlying value as type list. Returns true if the value was set +successfully. This object keeps a reference to |value| and ownership of +the underlying data remains unchanged. + + + + +Sets the underlying value as type dict. Returns true if the value was set +successfully. This object keeps a reference to |value| and ownership of +the underlying data remains unchanged. + + + + +Sets the underlying value as type binary. Returns true if the value was +set successfully. This object keeps a reference to |value| and ownership +of the underlying data remains unchanged. + + + + +Sets the underlying value as type string. Returns true if the value was +set successfully. + + + + +Sets the underlying value as type double. Returns true if the value was +set successfully. + + + + +Sets the underlying value as type int. Returns true if the value was set +successfully. + + + + +Sets the underlying value as type bool. Returns true if the value was set +successfully. + + + + +Sets the underlying value as type null. Returns true if the value was set +successfully. + + + + +Returns the underlying value as type list. The returned reference may +become invalid if the value is owned by another object or if ownership is +transferred to another object in the future. To maintain a reference to +the value after assigning ownership to a dictionary or list pass this +object to the SetValue() method instead of passing the returned reference +to SetList(). + + + + +Returns the underlying value as type dictionary. The returned reference +may become invalid if the value is owned by another object or if ownership +is transferred to another object in the future. To maintain a reference to +the value after assigning ownership to a dictionary or list pass this +object to the SetValue() method instead of passing the returned reference +to SetDictionary(). + + + + +Returns the underlying value as type binary. The returned reference may +become invalid if the value is owned by another object or if ownership is +transferred to another object in the future. To maintain a reference to +the value after assigning ownership to a dictionary or list pass this +object to the SetValue() method instead of passing the returned reference +to SetBinary(). + + + + +Returns the underlying value as type string. + + + + +Returns the underlying value as type double. + + + + +Returns the underlying value as type int. + + + + +Returns the underlying value as type bool. + + + + +Returns the underlying value type. + + + + +Returns a copy of this object. The underlying data will also be copied. + + + + +Returns true if this object and |that| object have an equivalent +underlying value but are not necessarily the same object. + + + + +Returns true if this object and |that| object have the same underlying +data. If true modifications to this object will also affect |that| object +and vice-versa. + + + + +Returns true if the underlying data is read-only. Some APIs may expose +read-only objects. + + + + +Returns true if the underlying data is owned by another object. + + + + +Returns true if the underlying data is valid. This will always be true for +simple types. For complex types (binary, dictionary and list) the +underlying data may become invalid if owned by another object (e.g. list +or dictionary) and that other object is then modified or destroyed. This +value object can be re-used by calling Set*() even if the underlying data +is invalid. + + + + +Creates a new object. + + + + +Class that wraps other data value types. Complex types (binary, dictionary +and list) will be referenced but not owned by this object. Can be used on +any process and thread. + + + + +Method that will be called when the DevTools agent has detached. |browser| +is the originating browser instance. Any method results that were pending +before the agent became detached will not be delivered, and any active +event subscriptions will be canceled. + + + + +Method that will be called when the DevTools agent has attached. |browser| +is the originating browser instance. This will generally occur in response +to the first message sent while the agent is detached. + + + + +Method that will be called on receipt of a DevTools protocol event. +|browser| is the originating browser instance. |method| is the "method" +value. |params| is the UTF8-encoded JSON "params" dictionary value (which +may be empty). |params| is only valid for the scope of this callback and +should be copied if necessary. See the OnDevToolsMessage documentation for +additional details on |params| contents. + + + + +Method that will be called after attempted execution of a DevTools +protocol method. |browser| is the originating browser instance. +|message_id| is the "id" value that identifies the originating method call +message. If the method succeeded |success| will be true and |result| will +be the UTF8-encoded JSON "result" dictionary value (which may be empty). +If the method failed |success| will be false and |result| will be the +UTF8-encoded JSON "error" dictionary value. |result| is only valid for the +scope of this callback and should be copied if necessary. See the +OnDevToolsMessage documentation for additional details on |result| +contents. + + + + +Method that will be called on receipt of a DevTools protocol message. +|browser| is the originating browser instance. |message| is a UTF8-encoded +JSON dictionary representing either a method result or an event. |message| +is only valid for the scope of this callback and should be copied if +necessary. Return true if the message was handled or false if the message +should be further processed and passed to the OnDevToolsMethodResult or +OnDevToolsEvent methods as appropriate. + +Method result dictionaries include an "id" (int) value that identifies the +orginating method call sent from CefBrowserHost::SendDevToolsMessage, and +optionally either a "result" (dictionary) or "error" (dictionary) value. +The "error" dictionary will contain "code" (int) and "message" (string) +values. Event dictionaries include a "method" (string) value and +optionally a "params" (dictionary) value. See the DevTools protocol +documentation at https://chromedevtools.github.io/devtools-protocol/ for +details of supported method calls and the expected "result" or "params" +dictionary contents. JSON dictionaries can be parsed using the +CefParseJSON function if desired, however be aware of performance +considerations when parsing large messages (some of which may exceed 1MB +in size). + + + + +Callback interface for CefBrowserHost::AddDevToolsMessageObserver. The +methods of this class will be called on the browser process UI thread. + + + + +Set to true before calling Windows APIs like TrackPopupMenu that enter a +modal message loop. Set to false after exiting the modal message loop. + + + + +Run the main thread on 32-bit Windows using a fiber with the preferred 4MiB +stack size. This function must be called at the top of the executable entry +point function (`main()` or `wWinMain()`). It is used in combination with +the initial stack size of 0.5MiB configured via the `/STACK:0x80000` linker +flag on executable targets. This saves significant memory on threads (like +those in the Windows thread pool, and others) whose stack size can only be +controlled via the linker flag. + +CEF's main thread needs at least a 1.5 MiB stack size in order to avoid +stack overflow crashes. However, if this is set in the PE file then other +threads get this size as well, leading to address-space exhaustion in 32-bit +CEF. This function uses fibers to switch the main thread to a 4 MiB stack +(roughly the same effective size as the 64-bit build's 8 MiB stack) before +running any other code. + +Choose the function variant that matches the entry point function type used +by the executable. Reusing the entry point minimizes confusion when +examining call stacks in crash reports. + +If this function is already running on the fiber it will return -1 +immediately, meaning that execution should proceed with the remainder of the +entry point function. Otherwise, this function will block until the entry +point function has completed execution on the fiber and then return a result +>= 0, meaning that the entry point function should return the result +immediately without proceeding with execution. + + + + +Create the browser using windowless (off-screen) rendering. No window +will be created for the browser and all rendering will occur via the +CefRenderHandler interface. The |parent| value will be used to identify +monitor info and to act as the parent window for dialogs, context menus, +etc. If |parent| is not provided then the main screen monitor will be used +and some functionality that requires a parent window may not function +correctly. In order to create windowless browsers the +CefSettings.windowless_rendering_enabled value must be set to true. +Transparent painting is enabled by default but can be disabled by setting +CefBrowserSettings.background_color to an opaque value. + + + + +Create the browser as a popup window. + + + + +Create the browser as a child window. + + + + +Class representing window information. + + + + +Class representing CefExecuteProcess arguments. + + + + +Set to true (1) before calling Windows APIs like TrackPopupMenu that enter a +modal message loop. Set to false (0) after exiting the modal message loop. + + + + +Run the main thread on 32-bit Windows using a fiber with the preferred 4MiB +stack size. This function must be called at the top of the executable entry +point function (`main()` or `wWinMain()`). It is used in combination with +the initial stack size of 0.5MiB configured via the `/STACK:0x80000` linker +flag on executable targets. This saves significant memory on threads (like +those in the Windows thread pool, and others) whose stack size can only be +controlled via the linker flag. + +CEF's main thread needs at least a 1.5 MiB stack size in order to avoid +stack overflow crashes. However, if this is set in the PE file then other +threads get this size as well, leading to address-space exhaustion in 32-bit +CEF. This function uses fibers to switch the main thread to a 4 MiB stack +(roughly the same effective size as the 64-bit build's 8 MiB stack) before +running any other code. + +Choose the function variant that matches the entry point function type used +by the executable. Reusing the entry point minimizes confusion when +examining call stacks in crash reports. + +If this function is already running on the fiber it will return -1 +immediately, meaning that execution should proceed with the remainder of the +entry point function. Otherwise, this function will block until the entry +point function has completed execution on the fiber and then return a result +>= 0, meaning that the entry point function should return the result +immediately without proceeding with execution. + + + + +Class representing CefAudioParameters settings + + + + +Class representing IME composition underline. + + + + +Class representing CefBoxLayout settings. + + + + +Class representing cursor information. + + + + +Class representing the state of a touch handle. + + + + +Class representing popup window features. + + + + +Class representing a touch event. + + + + +Class representing a mouse event. + + + + +Class representing a a keyboard event. + + + + +Class representing the virtual screen information for use when window +rendering is disabled. + + + + +Class representing a draggable region. + + + + +Class representing insets. + + + + +Class representing a range. + + + + +Class representing a size. + + + + +Returns true if the point identified by point_x and point_y falls inside +this rectangle. The point (x, y) is inside the rectangle, but the +point (x + width, y + height) is not. + + + + +Class representing a rectangle. + + + + +Class representing a point. + + + +Request context preferences registered each time a new CefRequestContext +is created. + + +Global preferences registered a single time at application startup. + + +Expired certificate. Loads the "expired_cert.pem" file. + + +Valid certificate using the domain ("localhost"). Loads the +"localhost_cert.pem" file. + + +Valid certificate using the IP (127.0.0.1). Loads the "ok_cert.pem" file. + + + +Ignore the permission request. If the prompt remains unhandled (e.g. +OnShowPermissionPrompt returns false and there is no default permissions +UI) then any related promises may remain unresolved. + + + + +Dismiss the permission request as an explicit user action. + + + + +Deny the permission request as an explicit user action. + + + + +Accept the permission request as an explicit user action. + + + + +Desktop video capture permission. + + + + +Desktop audio capture permission. + + + + +Device video capture permission. + + + + +Device audio capture permission. + + + + +No permission. + + + + +Alpha state. Only set if |flags| contains CEF_THS_FLAG_ALPHA. + + + + +Origin state. Only set if |flags| contains CEF_THS_FLAG_ORIGIN. + + + + +Orientation state. Only set if |flags| contains CEF_THS_FLAG_ORIENTATION. + + + + +Enabled state. Only set if |flags| contains CEF_THS_FLAG_ENABLED. + + + + +Combination of cef_touch_handle_state_flags_t values indicating what state +is set. + + + + +Touch handle id. Increments for each new touch handle. + + + + +Device information for a MediaSink object. + + + + +Number of frames per buffer + + + + +Sample rate + + + +Layout of the audio channels + + + + +Structure representing the audio parameters for setting up the audio +handler. + + + +Max value, must always equal the largest entry ever logged. + + +Front L, Front R, Front C, LFE, Side L, Side R, +Front Height L, Front Height R, Rear Height L, Rear Height R +Will be represented as six channels (5.1) due to eight channel limit +kMaxConcurrentChannels + + +Actual channel layout is specified in the bitstream and the actual channel +count is unknown at Chromium media pipeline level (useful for audio +pass-through mode). + + +Front L, Front R, Side L, Side R, LFE + + +Front L, Front R, Front C. Front C contains the keyboard mic audio. This +layout is only intended for input for WebRTC. The Front C channel +is stripped away in the WebRTC audio input pipeline and never seen outside +of that. + + +Channels are not explicitly mapped to speakers. + + +Front L, Front R, Front C, Side L, Side R, Rear L, Back R, Back C. + + +Front L, Front R, Front C, LFE, Back L, Back R, Front LofC, Front RofC + + +Front L, Front R, Front C, Side L, Side R, Front LofC, Front RofC + + +Stereo L, Stereo R, Side L, Side R, Front LofC, Front RofC, LFE + + +Stereo L, Stereo R, Front C, LFE, Back L, Back R, Rear Center + + +Stereo L, Stereo R, Front C, LFE, Side L, Side R, Rear Center + + +Stereo L, Stereo R, Front C, Rear L, Rear R, Rear C + + +Stereo L, Stereo R, Side L, Side R, Front LofC, Front RofC + + +Stereo L, Stereo R, Front C, Side L, Side R, Back C + + +Stereo L, Stereo R, Front C, Rear C, LFE + + +Stereo L, Stereo R, Front C, LFE + + +Stereo L, Stereo R, LFE + + +Stereo L, Stereo R + + +Front L, Front R, Front C, LFE, Side L, Side R, Front LofC, Front RofC + + +Front L, Front R, Front C, LFE, Side L, Side R, Back L, Back R + + +Front L, Front R, Front C, Side L, Side R, Back L, Back R + + +Front L, Front R, Front C, LFE, Back L, Back R + + +Front L, Front R, Front C, Back L, Back R + + +Front L, Front R, Front C, LFE, Side L, Side R + + +Front L, Front R, Front C, Side L, Side R + + +Front L, Front R, Back L, Back R + + +Front L, Front R, Side L, Side R + + +Front L, Front R, Front C, Back C + + +Front L, Front R, Front C + + +Front L, Front R, Back C + + +Front L, Front R + + +Front C + + + +Style. + + + + +Set to true (1) for thick underline. + + + + +Background color. + + + + +Text color. + + + + +Underline character range. + + + + +Structure representing IME composition underline information. This is a thin +wrapper around Blink's WebCompositionUnderline class and should be kept in +sync with that. + + + + +Structure representing a range. + + + + +If CEF_SCHEME_OPTION_FETCH_ENABLED is set the scheme can perform Fetch API +requests. + + + + +If CEF_SCHEME_OPTION_CSP_BYPASSING is set the scheme can bypass Content- +Security-Policy (CSP) checks. This value should not be set in most cases +where CEF_SCHEME_OPTION_STANDARD is set. + + + + +If CEF_SCHEME_OPTION_CORS_ENABLED is set the scheme can be sent CORS +requests. This value should be set in most cases where +CEF_SCHEME_OPTION_STANDARD is set. + + + + +If CEF_SCHEME_OPTION_SECURE is set the scheme will be treated with the +same security rules as those applied to "https" URLs. For example, loading +this scheme from other secure schemes will not trigger mixed content +warnings. + + + + +If CEF_SCHEME_OPTION_DISPLAY_ISOLATED is set the scheme can only be +displayed from other content hosted with the same scheme. For example, +pages in other origins cannot create iframes or hyperlinks to URLs with +the scheme. For schemes that must be accessible from other schemes don't +set this, set CEF_SCHEME_OPTION_CORS_ENABLED, and use CORS +"Access-Control-Allow-Origin" headers to further restrict access. + + + + +If CEF_SCHEME_OPTION_LOCAL is set the scheme will be treated with the same +security rules as those applied to "file" URLs. Normal pages cannot link +to or access local URLs. Also, by default, local URLs can only perform +XMLHttpRequest calls to the same URL (origin + path) that originated the +request. To allow XMLHttpRequest calls from a local URL to other URLs with +the same origin set the CefSettings.file_access_from_file_urls_allowed +value to true (1). To allow XMLHttpRequest calls from a local URL to all +origins set the CefSettings.universal_access_from_file_urls_allowed value +to true (1). + + + + +If CEF_SCHEME_OPTION_STANDARD is set the scheme will be treated as a +standard scheme. Standard schemes are subject to URL canonicalization and +parsing rules as defined in the Common Internet Scheme Syntax RFC 1738 +Section 3.1 available at http://www.ietf.org/rfc/rfc1738.txt +In particular, the syntax for standard scheme URLs must be of the form: +
+ [scheme]://[username]:[password]@[host]:[port]/[url-path]
+
Standard scheme URLs must have a host component that is a fully +qualified domain name as defined in Section 3.5 of RFC 1034 [13] and +Section 2.1 of RFC 1123. These URLs will be canonicalized to +"scheme://host/path" in the simplest case and +"scheme://username:password@host:port/path" in the most explicit case. For +example, "scheme:host/path" and "scheme:///host/path" will both be +canonicalized to "scheme://host/path". The origin of a standard scheme URL +is the combination of scheme, host and port (i.e., "scheme://host:port" in +the most explicit case). +For non-standard scheme URLs only the "scheme:" component is parsed and +canonicalized. The remainder of the URL will be passed to the handler as- +is. For example, "scheme:///some%20text" will remain the same. +Non-standard scheme URLs cannot be used as a target for form submission. + +
+ + +Align the text's right edge with that of its display area. + + + + +Align the text's center with that of its display area. + + + + +Align the text's left edge with that of its display area. + + + + +Default flex for views when none is specified via CefBoxLayout methods. +Using the preferred size as the basis, free space along the main axis is +distributed to views in the ratio of their flex weights. Similarly, if the +views will overflow the parent, space is subtracted in these ratios. A +flex of 0 means this view is not resized. Flex values must not be +negative. + + + + +Minimum cross axis size. + + + + +Specifies where along the cross axis the child views should be laid out. + + + + +Specifies where along the main axis the child views should be laid out. + + + + +Adds additional space between child views. + + + + +Adds additional space around the child view area. + + + + +Adds additional vertical space between the child view area and the host +view border. + + + + +Adds additional horizontal space between the child view area and the host +view border. + + + + +If true (1) the layout will be horizontal, otherwise the layout will be +vertical. + + + + +Settings used when initializing a CefBoxLayout. + + + + +Child views will be right-aligned. + + + + +Child views will be center-aligned. + + + + +Child views will be left-aligned. + + + + +Child views will be stretched to fit. + + + + +Child views will be right-aligned. + + + + +Child views will be center-aligned. + + + + +Child views will be left-aligned. + + + + +Transparency with post-multiplied alpha component. + + + + +Transparency with pre-multiplied alpha component. + + + + +No transparency. The alpha component is ignored. + + + + +BGRA with 8 bits per pixel (32bits total). + + + + +RGBA with 8 bits per pixel (32bits total). + + + + +An error occurred during filtering. + + + + +Some or all of the pre-filter data was read successfully and all available +filtered output has been written. + + + + +Some or all of the pre-filter data was read successfully but more data is +needed in order to continue filtering (filtered output is pending). + + + +Always the last value in this enumeration. + + + +Always clear the referrer regardless of the request destination. + + + + +Strip the referrer down to the origin, but clear it entirely if the +referrer value is HTTPS and the destination is HTTP. + + + + +Clear the referrer when the request's referrer is cross-origin with the +request's destination. + + + + +Strip the referrer down to the origin regardless of the redirect location. + + + + +Never change the referrer. + + + + +Strip the referrer down to an origin when the origin of the referrer is +different from the destination's origin. + + + + +A slight variant on CLEAR_REFERRER_ON_TRANSITION_FROM_SECURE_TO_INSECURE: +If the request destination is HTTP, an HTTPS referrer will be cleared. If +the request's destination is cross-origin with the referrer (but does not +downgrade), the referrer's granularity will be stripped down to an origin +rather than a full URL. Same-origin requests will send the full referrer. + + + + +Clear the referrer header if the header value is HTTPS but the request +destination is HTTP. This is the default behavior. + + + + +HTML template for the print footer. Only displayed if +|display_header_footer| is true (1). Uses the same format as +|header_template|. + + + + +Set to true (1) to display the header and/or footer. Modify +|header_template| and/or |footer_template| to customize the display. + + + + +Paper ranges to print, one based, e.g., '1-5, 8, 11-13'. Pages are printed +in the document order, not in the order specified, and no more than once. +Defaults to empty string, which implies the entire document is printed. +The page numbers are quietly capped to actual page count of the document, +and ranges beyond the end of the document are ignored. If this results in +no pages to print, an error is reported. It is an error to specify a range +with start greater than end. + + + + +Margins in inches. Only used if |margin_type| is set to +PDF_PRINT_MARGIN_CUSTOM. + + + + +Margin type. + + + + +Set to true (1) to prefer page size as defined by css. Defaults to false +(0), in which case the content will be scaled to fit the paper size. + + + + +Output paper size in inches. If either of these values is less than or +equal to zero then the default paper size (letter, 8.5 x 11 inches) will +be used. + + + + +The percentage to scale the PDF by before printing (e.g. .5 is 50%). +If this value is less than or equal to zero the default value of 1.0 +will be used. + + + + +Set to true (1) to print background graphics. + + + + +Set to true (1) for landscape mode or false (0) for portrait mode. + + + + +Structure representing PDF print settings. These values match the parameters +supported by the DevTools Page.printToPDF function. See +https://chromedevtools.github.io/devtools-protocol/tot/Page/#method-printToPDF + + + + +Custom margins using the |margin_*| values from cef_pdf_print_settings_t. + + + + +No margins. + + + + +Default margins of 1cm (~0.4 inches). + + + + +Return a slightly nicer formatted json string (pads with whitespace to +help with readability). + + + + +This option instructs the writer to write doubles that have no fractional +part as a normal integer (i.e., without using exponential notation +or appending a '.0') as long as the value is within the range of a +64-bit int. + + + + +This option instructs the writer that if a Binary value is encountered, +the value (and key if within a dictionary) will be omitted from the +output, and success will be returned. Otherwise, if a binary value is +encountered, failure will be returned. + + + + +Default behavior. + + + + +Allows commas to exist after the last element in structures. + + + + +Parses the input strictly according to RFC 4627. See comments in +Chromium's base/json/json_reader.h file for known limitations/ +deviations from the RFC. + + + + +URL queries use "+" for space. This flag controls that replacement. + + + + +Unescapes '/' and '\\'. If these characters were unescaped, the resulting +URL won't be the same as the source one. Moreover, they are dangerous to +unescape in strings that will be used as file paths or names. This value +should only be used when slashes don't have special meaning, like data +URLs. + + + + +Convert %20 to spaces. In some places where we're showing URLs, we may +want this. In places where the URL may be copied and pasted out, then +you wouldn't want this since it might not be interpreted in one piece +by other applications. + + + + +Don't unescape anything special, but all normal unescaping will happen. +This is a placeholder and can't be combined with other flags (since it's +just the absence of them). All other unescape rules imply "normal" in +addition to their special meaning. Things like escaped letters, digits, +and most symbols will get unescaped with this mode. + + + + +Don't unescape anything at all. + + + + +Structure representing cursor information. |buffer| will be +|size.width|*|size.height|*4 bytes in size and represents a BGRA image with +an upper-left origin. + + + + +Allows picking a nonexistent file, and prompts to overwrite if the file +already exists. + + + + +Like Open, but selects a folder to open. + + + + +Like Open, but allows picking multiple files to open. + + + + +Requires that the file exists before allowing the user to pick it. + + + +True (1) if browser interface elements should be hidden. + + + +Popup window features. + + + + +The source is a system-generated focus event. + + + + +The source is explicit navigation via the API (LoadURL(), etc). + + + + +True if the focus is currently on an editable field on the page. This is +useful for determining if standard key events should be intercepted. + + + + +Same as |character| but unmodified by any concurrently-held modifiers +(except shift). This is useful for working out shortcut keys. + + + + +The character generated by the keystroke. + + + + +Indicates whether the event is considered a "system key" event (see +http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). +This value will always be false on non-Windows platforms. + + + + +The actual key code genenerated by the platform. + + + + +The Windows key code for the key event. This value is used by the DOM +specification. Sometimes it comes directly from the event (i.e. on +Windows) and sometimes it's determined using a mapping function. See +WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + + + +Bit flags describing any pressed modifier keys. See +cef_event_flags_t for values. + + + + +The type of keyboard event. + + + + +Structure representing keyboard event information. + + + + +Notification that a character was typed. Use this for text input. Key +down events may generate 0, 1, or more than one character event depending +on the key, locale, and operating system. + + + + +Notification that a key was released. + + + + +Notification that a key was pressed. This does not necessarily correspond +to a character depending on the key and language. Use KEYEVENT_CHAR for +character input. + + + + +Notification that a key transitioned from "up" to "down". + + + + +A plugin node is selected. + + + + +A file node is selected. + + + + +An canvas node is selected. + + + + +An audio node is selected. + + + + +A video node is selected. + + + + +An image node is selected. + + + + +No special node is in context. + + + + +An editable element is selected. + + + + +There is a textual or mixed selection that is selected. + + + + +A media node is selected. + + + + +A link is selected. + + + + +A subframe page is selected. + + + + +The top page is selected. + + + + +No node is selected. + + + +Mac OS-X command key. + + + +The device type that caused the event. + + + + +Bit flags describing any pressed modifier keys. See +cef_event_flags_t for values. + + + + +The state of the touch point. Touches begin with one CEF_TET_PRESSED event +followed by zero or more CEF_TET_MOVED events and finally one +CEF_TET_RELEASED or CEF_TET_CANCELLED event. Events not respecting this +order will be ignored. + + + + +The normalized pressure of the pointer input in the range of [0,1]. +Set to 0 if not applicable. + + + + +Rotation angle in radians. Set to 0 if not applicable. + + + + +Y radius in pixels. Set to 0 if not applicable. + + + + +X radius in pixels. Set to 0 if not applicable. + + + + +Y coordinate relative to the top side of the view. + + + + +X coordinate relative to the left side of the view. + + + + +Id of a touch point. Must be unique per touch, can be any number except +-1. Note that a maximum of 16 concurrent touches will be tracked; touches +beyond that will be ignored. + + + + +Structure representing touch event information. + + + + +Bit flags describing any pressed modifier keys. See +cef_event_flags_t for values. + + + + +Y coordinate relative to the top side of the view. + + + + +X coordinate relative to the left side of the view. + + + + +Structure representing mouse event information. + + + + +This is set from the rcWork member of MONITORINFOEX, to whit: + "A RECT structure that specifies the work area rectangle of the + display monitor that can be used by applications, expressed in + virtual-screen coordinates. Windows uses this rectangle to + maximize an application on the monitor. The rest of the area in + rcMonitor contains system windows such as the task bar and side + bars. Note that if the monitor is not the primary display monitor, + some of the rectangle's coordinates may be negative values". +The |rect| and |available_rect| properties are used to determine the +available surface for rendering popup views. + + + + +This is set from the rcMonitor member of MONITORINFOEX, to whit: + "A RECT structure that specifies the display monitor rectangle, + expressed in virtual-screen coordinates. Note that if the monitor + is not the primary display monitor, some of the rectangle's + coordinates may be negative values." +The |rect| and |available_rect| properties are used to determine the +available surface for rendering popup views. + + + + +This can be true for black and white printers. + + + + +The bits per color component. This assumes that the colors are balanced +equally. + + + + +The screen depth in bits per pixel. + + + + +Device scale factor. Specifies the ratio between physical and logical +pixels. + + + + +Screen information used when window rendering is disabled. This structure is +passed as a parameter to CefRenderHandler::GetScreenInfo and should be +filled in by the client. + + + + +Initialize COM using multi-threaded apartments. + + + + +Initialize COM using single-threaded apartments. + + + + +No COM initialization. + + + + +Supports tasks, timers and asynchronous IO events. + + + + +Supports tasks, timers and native UI events (e.g. Windows messages). + + + + +Supports tasks and timers. + + + + +Suitable for low-latency, glitch-resistant audio. + + + + +Suitable for threads which generate data for the display (at ~60Hz). + + + + +Default priority level. + + + + +Suitable for threads that shouldn't disrupt high priority work. + + + + +The main thread in the renderer. Used for all WebKit and V8 interaction. +Tasks may be posted to this thread after +CefRenderProcessHandler::OnWebKitInitialized but are not guaranteed to +run before sub-process termination (sub-processes may be killed at any +time without warning). + + + + +Used to process IPC and network messages. Do not perform blocking tasks on +this thread. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. + + + + +Used to launch and terminate browser processes. + + + + +Used for blocking tasks like file system access that affect UI +immediately after a user interaction. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. +Example: Generating data shown in the UI immediately after a click. + + + + +Used for blocking tasks like file system access that affect UI or +responsiveness of future user interactions. Do not use if an immediate +response to a user interaction is expected. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. +Examples: +- Updating the UI to reflect progress on a long task. +- Loading data that might be shown in the UI after a future user + interaction. + + + + +Used for blocking tasks like file system access where the user won't +notice if the task takes an arbitrarily long time to complete. All tasks +posted after CefBrowserProcessHandler::OnContextInitialized() and before +CefShutdown() are guaranteed to run. + + + + +The main thread in the browser. This will be the same as the main +application thread if CefInitialize() is called with a +CefSettings.multi_threaded_message_loop value of false. Do not perform +blocking tasks on this thread. All tasks posted after +CefBrowserProcessHandler::OnContextInitialized() and before CefShutdown() +are guaranteed to run. This thread will outlive all other CEF threads. + + + + +Renderer process. + + + + +Browser process. + + + + +True (1) this this region is draggable and false (0) otherwise. + + + + +Bounds of the region. + + + +Structure representing a draggable region. + + + + +Request failed for some reason. + + + + +Request was canceled programatically. + + + + +An IO request is pending, and the caller will be informed when it is +completed. + + + + +Request succeeded. + + + + +Unknown status. + + + + +If set 3XX responses will cause the fetch to halt immediately rather than +continue through the redirect. + + + + +If set 5XX redirect errors will be propagated to the observer instead of +automatically re-tried. This currently only applies for requests +originated in the browser process. + + + + +If set the CefURLRequestClient::OnDownloadData method will not be called. + + + + +If set upload progress events will be generated when a request has a body. + + + + +If set user name, password, and cookies may be sent with the request, and +cookies may be saved from the response. + + + + +If set the cache will not be used at all. Setting this value is equivalent +to specifying the "Cache-Control: no-store" request header. Setting this +value in combination with UR_FLAG_ONLY_FROM_CACHE will cause the request +to fail. + + + + +If set the request will fail if it cannot be served from the cache (or +some equivalent local store). Setting this value is equivalent to +specifying the "Cache-Control: only-if-cached" request header. Setting +this value in combination with UR_FLAG_SKIP_CACHE or UR_FLAG_DISABLE_CACHE +will cause the request to fail. + + + + +If set the cache will be skipped when handling the request. Setting this +value is equivalent to specifying the "Cache-Control: no-cache" request +header. Setting this value in combination with UR_FLAG_ONLY_FROM_CACHE +will cause the request to fail. + + + + +Default behavior. + + + + +General mask defining the bits used for the qualifiers. + + + + +Used to test whether a transition involves a redirect. + + + + +Redirects sent from the server by HTTP headers. + + + + +Redirects caused by JavaScript or a meta refresh tag on the page. + + + + +The last transition in a redirect chain. + + + + +The beginning of a navigation chain. + + + + +The transition originated from an external application; the exact +definition of this is embedder dependent. Chrome runtime and +extension system only. + + + + +User is navigating to the home page. Chrome runtime only. + + + + +Loaded a URL directly via CreateBrowser, LoadURL or LoadRequest. + + + + +Used the Forward or Back function to navigate among browsing history. +Will be ORed to the transition type for the original load. + + + +Qualifiers. +Any of the core values above can be augmented by one or more qualifiers. +These qualifiers further define the transition. + +Attempted to visit a URL but was blocked. + + + + +General mask defining the bits used for the source values. + + + + +Corresponds to a visit generated for a keyword. See description of +TT_KEYWORD for more details. Chrome runtime only. + + + + +The url was generated from a replaceable keyword other than the default +search provider. If the user types a keyword (which also applies to +tab-to-search) in the omnibox this qualifier is applied to the transition +type of the generated url. TemplateURLModel then may generate an +additional visit with a transition type of TT_KEYWORD_GENERATED against +the url 'http://' + keyword. For example, if you do a tab-to-search +against wikipedia the generated url has a transition qualifer of +TT_KEYWORD, and TemplateURLModel generates a visit for 'wikipedia.org' +with a transition type of TT_KEYWORD_GENERATED. Chrome runtime only. + + + + +Source is a "reload" of the page via the Reload function or by re-visiting +the same URL. NOTE: This is distinct from the concept of whether a +particular load uses "reload semantics" (i.e. bypasses cached data). + + + + +Source is a form submission by the user. NOTE: In some situations +submitting a form does not result in this transition type. This can happen +if the form uses a script to submit the contents. + + + + +This is a toplevel navigation. This is any content that is automatically +loaded in a toplevel frame. For example, opening a tab to show the ASH +screen saver, opening the devtools window, opening the NTP after the safe +browsing warning, opening web-based dialog boxes are examples of +AUTO_TOPLEVEL navigations. Chrome runtime only. + + + + +User got to this page by typing in the URL bar and selecting an entry +that did not look like a URL. For example, a match might have the URL +of a Google search result page, but appear like "Search Google for ...". +These are not quite the same as EXPLICIT navigations because the user +didn't type or see the destination URL. Chrome runtime only. +See also TT_KEYWORD. + + + + +Source is a subframe navigation explicitly requested by the user that will +generate new navigation entries in the back/forward list. These are +probably more important than frames that were automatically loaded in +the background because the user probably cares about the fact that this +link was loaded. + + + + +Source is a subframe navigation. This is any content that is automatically +loaded in a non-toplevel frame. For example, if a page consists of several +frames containing ads, those ad URLs will have this transition type. +The user may not even realize the content in these pages is a separate +frame, so may not care about the URL. + + + + +User got to this page through a suggestion in the UI (for example, via the +destinations page). Chrome runtime only. + + + + +Source is some other "explicit" navigation. This is the default value for +navigations where the actual type is unknown. See also +TT_DIRECT_LOAD_FLAG. + + + + +Source is a link click or the JavaScript window.open function. This is +also the default value for requests like sub-resource loads that are not +navigations. + + + + +A sub-frame service worker navigation preload request. + + + + +A main-frame service worker navigation preload request. + + + + +A resource that a plugin requested. + + + + +A report of Content Security Policy violations. + + + + +Main resource of a service worker. + + + + +XMLHttpRequest. + + + + +Favicon. + + + + +Explicitly requested prefetch. + + + + +Main resource of a shared worker. + + + + +Main resource of a dedicated worker. + + + + +Media resource. + + + + +Object (or embed) tag for a plugin, or a resource that a plugin requested. + + + + +Some other subresource. This is the default type if the actual type is +unknown. + + + + +Font. + + + + +Image (jpg/gif/png/etc). + + + + +External script. + + + + +CSS stylesheet. + + + + +Frame or iframe. + + + + +Top level page. + + + + +Not configurable + + + + +Not enumerable + + + + +Not writeable + + + + +Writeable, Enumerable, Configurable + + + + +Creates a new document picture-in-picture window showing a child WebView. + + + + +Activates an existing tab containing the url, rather than navigating. +This is similar to SINGLETON_TAB, but searches across all windows from +the current profile and anonymity (instead of just the current one); +closes the current tab on switching if the current tab was the NTP with +no session history; and behaves like CURRENT_TAB instead of +NEW_FOREGROUND_TAB when no existing tab is found. + + + + +Special case error condition from the renderer. + + + + +New off-the-record (incognito) window. + + + + +Alt key while clicking. + + + + +Shift key while clicking. + + + + +New popup window. + + + + +Middle mouse button or meta/ctrl key while clicking. + + + + +Shift key + Middle mouse button or meta/ctrl key while clicking. + + + + +Indicates that only one tab with the url should exist in the same window. + + + + +Current tab. This is the default in most cases. + + + + +Directory containing application resources. Can be configured via +CefSettings.resources_dir_path. + + + + +"Application Data" directory under the user profile directory on Windows +and "~/Library/Application Support" directory on MacOS. + + + + +"Local Settings\Application Data" directory under the user profile +directory on Windows. + + + + +Path and filename of the module containing the CEF code (usually the +libcef module). + + + + +Path and filename of the current executable. + + + + +Temporary directory. + + + + +Directory containing PK_FILE_MODULE. + + + + +Directory containing PK_FILE_EXE. + + + + +Current directory. + + + + +Out of memory. Some platforms may use TS_PROCESS_CRASHED instead. + + + + +Segmentation fault. + + + + +SIGKILL or task manager kill. + + + + +Non-zero exit status. + + + + +Priority. + + + + +Same site. + + + + +The cookie expiration date is only valid if |has_expires| is true. + + + + +The cookie last access date. This is automatically populated by the system +on access. + + + + +The cookie creation date. This is automatically populated by the system on +cookie creation. + + + + +If |httponly| is true the cookie will only be sent for HTTP requests. + + + + +If |secure| is true the cookie will only be sent for HTTPS requests. + + + + +If |path| is non-empty only URLs at or below the path will get the cookie +value. + + + + +If |domain| is empty a host cookie will be created instead of a domain +cookie. Domain cookies are stored with a leading "." and are visible to +sub-domains whereas host cookies are not. + + + + +The cookie value. + + + + +The cookie name. + + + + +Cookie information. + + + + +Fragment (hash) identifier component (i.e., the string following the '#'). + + + + +Query string component (i.e., everything following the '?'). + + + + +Path component including the first slash following the host. + + + + +Origin contains just the scheme, host, and port from a URL. Equivalent to +clearing any username and password, replacing the path with a slash, and +clearing everything after that. This value will be empty for non-standard +URLs. + + + + +Port number component. + + + + +Host component. This may be a hostname, an IPv4 address or an IPv6 literal +surrounded by square brackets (e.g., "[2001:db8::1]"). + + + + +Password component. + + + + +User name component. + + + + +Scheme component not including the colon (e.g., "http"). + + + + +The complete URL specification. + + + + +URL component parts. + + + + +Continue asynchronously (usually via a callback). + + + + +Continue immediately. + + + + +Cancel immediately. + + + + +Controls whether the Chrome status bubble will be used. Only supported +with the Chrome runtime. For details about the status bubble see +https://www.chromium.org/user-experience/status-bubble/ + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. May be set globally +using the CefSettings.accept_language_list value. If both values are +empty then "en-US,en" will be used. + + + +END values that map to WebPreferences settings. + +Background color used for the browser before a document is loaded and when +no document color is specified. The alpha component must be either fully +opaque (0xFF) or fully transparent (0x00). If the alpha component is fully +opaque then the RGB components will be used as the background color. If +the alpha component is fully transparent for a windowed browser then the +CefSettings.background_color value will be used. If the alpha component is +fully transparent for a windowless (off-screen) browser then transparent +painting will be enabled. + + + + +Controls whether WebGL can be used. Note that WebGL requires hardware +support and may not work on all systems even when enabled. Also +configurable using the "disable-webgl" command-line switch. + + + + +Controls whether databases can be used. Also configurable using the +"disable-databases" command-line switch. + + + + +Controls whether local storage can be used. Also configurable using the +"disable-local-storage" command-line switch. + + + + +Controls whether the tab key can advance focus to links. Also configurable +using the "disable-tab-to-links" command-line switch. + + + + +Controls whether text areas can be resized. Also configurable using the +"disable-text-area-resize" command-line switch. + + + + +Controls whether standalone images will be shrunk to fit the page. Also +configurable using the "image-shrink-standalone-to-fit" command-line +switch. + + + + +Controls whether image URLs will be loaded from the network. A cached +image will still be rendered if requested. Also configurable using the +"disable-image-loading" command-line switch. + + + + +Controls whether DOM pasting is supported in the editor via +execCommand("paste"). The |javascript_access_clipboard| setting must also +be enabled. Also configurable using the "disable-javascript-dom-paste" +command-line switch. + + + + +Controls whether JavaScript can access the clipboard. Also configurable +using the "disable-javascript-access-clipboard" command-line switch. + + + + +Controls whether JavaScript can be used to close windows that were not +opened via JavaScript. JavaScript can still be used to close windows that +were opened via JavaScript or that have no back/forward history. Also +configurable using the "disable-javascript-close-windows" command-line +switch. + + + + +Controls whether JavaScript can be executed. Also configurable using the +"disable-javascript" command-line switch. + + + + +Controls the loading of fonts from remote sources. Also configurable using +the "disable-remote-fonts" command-line switch. + + + + +Default encoding for Web content. If empty "ISO-8859-1" will be used. Also +configurable using the "default-encoding" command-line switch. + + + +BEGIN values that map to WebPreferences settings. + +Font settings. + + + + +The maximum rate in frames per second (fps) that CefRenderHandler::OnPaint +will be called for a windowless browser. The actual fps may be lower if +the browser cannot generate frames at the requested rate. The minimum +value is 1 and the maximum value is 60 (default 30). This value can also +be changed dynamically via CefBrowserHost::SetWindowlessFrameRate. + + + + +Size of this structure. + + + + +Browser initialization settings. Specify NULL or 0 to get the recommended +default values. The consequences of using custom values may not be well +tested. Many of these and other settings can also configured using command- +line switches. + + + + +Comma delimited list of schemes supported by the associated +CefCookieManager. If |cookieable_schemes_exclude_defaults| is false (0) +the default schemes ("http", "https", "ws" and "wss") will also be +supported. Not specifying a |cookieable_schemes_list| value and setting +|cookieable_schemes_exclude_defaults| to true (1) will disable all loading +and saving of cookies. These values will be ignored if |cache_path| +matches the CefSettings.cache_path value. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. Can be set globally +using the CefSettings.accept_language_list value or overridden on a per- +browser basis using the CefBrowserSettings.accept_language_list value. If +all values are empty then "en-US,en" will be used. This value will be +ignored if |cache_path| matches the CefSettings.cache_path value. + + + + +To persist user preferences as a JSON file in the cache path directory set +this value to true (1). Can be set globally using the +CefSettings.persist_user_preferences value. This value will be ignored if +|cache_path| is empty or if it matches the CefSettings.cache_path value. + + + + +To persist session cookies (cookies without an expiry date or validity +interval) by default when using the global cookie manager set this value +to true (1). Session cookies are generally intended to be transient and +most Web browsers do not persist them. Can be set globally using the +CefSettings.persist_session_cookies value. This value will be ignored if +|cache_path| is empty or if it matches the CefSettings.cache_path value. + + + + +The location where cache data for this request context will be stored on +disk. If this value is non-empty then it must be an absolute path that is +either equal to or a child directory of CefSettings.root_cache_path. If +this value is empty then browsers will be created in "incognito mode" +where in-memory caches are used for storage and no data is persisted to +disk. HTML5 databases such as localStorage will only persist across +sessions if a cache path is specified. To share the global browser cache +and related configuration set this value to match the +CefSettings.cache_path value. + + + + +Size of this structure. + + + + +Request context initialization settings. Specify NULL or 0 to get the +recommended default values. + + + + +Comma delimited list of schemes supported by the associated +CefCookieManager. If |cookieable_schemes_exclude_defaults| is false (0) +the default schemes ("http", "https", "ws" and "wss") will also be +supported. Not specifying a |cookieable_schemes_list| value and setting +|cookieable_schemes_exclude_defaults| to true (1) will disable all loading +and saving of cookies. These settings will only impact the global +CefRequestContext. Individual CefRequestContext instances can be +configured via the CefRequestContextSettings.cookieable_schemes_list and +CefRequestContextSettings.cookieable_schemes_exclude_defaults values. + + + + +Comma delimited ordered list of language codes without any whitespace that +will be used in the "Accept-Language" HTTP header. May be overridden on a +per-browser basis using the CefBrowserSettings.accept_language_list value. +If both values are empty then "en-US,en" will be used. Can be overridden +for individual CefRequestContext instances via the +CefRequestContextSettings.accept_language_list value. + + + + +Background color used for the browser before a document is loaded and when +no document color is specified. The alpha component must be either fully +opaque (0xFF) or fully transparent (0x00). If the alpha component is fully +opaque then the RGB components will be used as the background color. If +the alpha component is fully transparent for a windowed browser then the +default value of opaque white be used. If the alpha component is fully +transparent for a windowless (off-screen) browser then transparent +painting will be enabled. + + + + +The number of stack trace frames to capture for uncaught exceptions. +Specify a positive value to enable the +CefRenderProcessHandler::OnUncaughtException() callback. Specify 0 +(default value) and OnUncaughtException() will not be called. Also +configurable using the "uncaught-exception-stack-size" command-line +switch. + + + + +Set to a value between 1024 and 65535 to enable remote debugging on the +specified port. Also configurable using the "remote-debugging-port" +command-line switch. Remote debugging can be accessed by loading the +chrome://inspect page in Google Chrome. Port numbers 9222 and 9229 are +discoverable by default. Other port numbers may need to be configured via +"Discover network targets" on the Devices tab. + + + + +Set to true (1) to disable loading of pack files for resources and +locales. A resource bundle handler must be provided for the browser and +render processes via CefApp::GetResourceBundleHandler() if loading of pack +files is disabled. Also configurable using the "disable-pack-loading" +command- line switch. + + + + +The fully qualified path for the locales directory. If this value is empty +the locales directory must be located in the module directory. If this +value is non-empty then it must be an absolute path. This value is ignored +on MacOS where pack files are always loaded from the app bundle Resources +directory. Also configurable using the "locales-dir-path" command-line +switch. + + + + +The fully qualified path for the resources directory. If this value is +empty the *.pak files must be located in the module directory on +Windows/Linux or the app bundle Resources directory on MacOS. If this +value is non-empty then it must be an absolute path. Also configurable +using the "resources-dir-path" command-line switch. + + + + +Custom flags that will be used when initializing the V8 JavaScript engine. +The consequences of using custom flags may not be well tested. Also +configurable using the "js-flags" command-line switch. + + + + +The log severity. Only messages of this severity level or higher will be +logged. When set to DISABLE no messages will be written to the log file, +but FATAL messages will still be output to stderr. Also configurable using +the "log-severity" command-line switch with a value of "verbose", "info", +"warning", "error", "fatal" or "disable". + + + + +The directory and file name to use for the debug log. If empty a default +log file name and location will be used. On Windows and Linux a +"debug.log" file will be written in the main executable directory. On +MacOS a "~/Library/Logs/[app name]_debug.log" file will be written where +[app name] is the name of the main app executable. Also configurable using +the "log-file" command-line switch. + + + + +The locale string that will be passed to WebKit. If empty the default +locale of "en-US" will be used. This value is ignored on Linux where +locale is determined using environment variable parsing with the +precedence order: LANGUAGE, LC_ALL, LC_MESSAGES and LANG. Also +configurable using the "lang" command-line switch. + + + + +Value that will be inserted as the product portion of the default +User-Agent string. If empty the Chromium product version will be used. If +|userAgent| is specified this value will be ignored. Also configurable +using the "user-agent-product" command-line switch. + + + + +Value that will be returned as the User-Agent HTTP header. If empty the +default User-Agent string will be used. Also configurable using the +"user-agent" command-line switch. + + + + +To persist user preferences as a JSON file in the cache path directory set +this value to true (1). A |cache_path| value must also be specified +to enable this feature. Also configurable using the +"persist-user-preferences" command-line switch. Can be overridden for +individual CefRequestContext instances via the +CefRequestContextSettings.persist_user_preferences value. + + + + +To persist session cookies (cookies without an expiry date or validity +interval) by default when using the global cookie manager set this value +to true (1). Session cookies are generally intended to be transient and +most Web browsers do not persist them. A |cache_path| value must also be +specified to enable this feature. Also configurable using the +"persist-session-cookies" command-line switch. Can be overridden for +individual CefRequestContext instances via the +CefRequestContextSettings.persist_session_cookies value. + + + + +The location where user data such as the Widevine CDM module and spell +checking dictionary files will be stored on disk. If this value is empty +then the default platform-specific user data directory will be used +("~/.config/cef_user_data" directory on Linux, "~/Library/Application +Support/CEF/User Data" directory on MacOS, "AppData\Local\CEF\User Data" +directory under the user profile directory on Windows). If this value is +non-empty then it must be an absolute path. When using the Chrome runtime +this value will be ignored in favor of the |root_cache_path| value. + + + + +The root directory that all CefSettings.cache_path and +CefRequestContextSettings.cache_path values must have in common. If this +value is empty and CefSettings.cache_path is non-empty then it will +default to the CefSettings.cache_path value. If this value is non-empty +then it must be an absolute path. Failure to set this value correctly may +result in the sandbox blocking read/write access to the cache_path +directory. + + + + +The location where data for the global browser cache will be stored on +disk. If this value is non-empty then it must be an absolute path that is +either equal to or a child directory of CefSettings.root_cache_path. If +this value is empty then browsers will be created in "incognito mode" +where in-memory caches are used for storage and no data is persisted to +disk. HTML5 databases such as localStorage will only persist across +sessions if a cache path is specified. Can be overridden for individual +CefRequestContext instances via the CefRequestContextSettings.cache_path +value. When using the Chrome runtime the "default" profile will be used if +|cache_path| and |root_cache_path| have the same value. + + + + +Set to true (1) to disable configuration of browser process features using +standard CEF and Chromium command-line arguments. Configuration can still +be specified using CEF data structures or via the +CefApp::OnBeforeCommandLineProcessing() method. + + + + +Set to true (1) to enable windowless (off-screen) rendering support. Do +not enable this value if the application does not use windowless rendering +as it may reduce rendering performance on some systems. + + + + +Set to true (1) to control browser process main (UI) thread message pump +scheduling via the CefBrowserProcessHandler::OnScheduleMessagePumpWork() +callback. This option is recommended for use in combination with the +CefDoMessageLoopWork() function in cases where the CEF message loop must +be integrated into an existing application message loop (see additional +comments and warnings on CefDoMessageLoopWork). Enabling this option is +not recommended for most users; leave this option disabled and use either +the CefRunMessageLoop() function or multi_threaded_message_loop if +possible. + + + + +Set to true (1) to have the browser process message loop run in a separate +thread. If false (0) then the CefDoMessageLoopWork() function must be +called from your application message loop. This option is only supported +on Windows and Linux. + + + + +Set to true (1) to enable use of the Chrome runtime in CEF. This feature +is considered experimental and is not recommended for most users at this +time. See issue #2969 for details. + + + + +The path to the main bundle on macOS. If this value is empty then it +defaults to the top-level app bundle. If this value is non-empty then it +must be an absolute path. Also configurable using the "main-bundle-path" +command-line switch. + + + + +The path to the CEF framework directory on macOS. If this value is empty +then the framework must exist at "Contents/Frameworks/Chromium Embedded +Framework.framework" in the top-level app bundle. If this value is +non-empty then it must be an absolute path. Also configurable using the +"framework-dir-path" command-line switch. + + + + +Set to true (1) to disable the sandbox for sub-processes. See +cef_sandbox_win.h for requirements to enable the sandbox on Windows. Also +configurable using the "no-sandbox" command-line switch. + + + + +Size of this structure. + + + + +Initialization settings. Specify NULL or 0 to get the recommended default +values. Many of these and other settings can also configured using command- +line switches. + + + + +Disable or disallow the setting. + + + + +Enable or allow the setting. + + + + +Use the default state for the setting. + + + + +Disable logging to file for all messages, and to stderr for messages with +severity less than FATAL. + + + + +FATAL logging. + + + + +ERROR logging. + + + + +WARNING logging. + + + + +INFO logging. + + + + +DEBUG logging. + + + + +Verbose logging. + + + + +Default logging (currently INFO logging). + + + + +Handle for the new browser window. Only used with windowed rendering. + + + + +Set to true (1) to enable the ability to issue BeginFrame requests from +the client application by calling CefBrowserHost::SendExternalBeginFrame. + + + + +Set to true (1) to enable shared textures for windowless rendering. Only +valid if windowless_rendering_enabled above is also set to true. Currently +only supported on Windows (D3D11). + + + + +Set to true (1) to create the browser using windowless (off-screen) +rendering. No window will be created for the browser and all rendering +will occur via the CefRenderHandler interface. The |parent_window| value +will be used to identify monitor info and to act as the parent window for +dialogs, context menus, etc. If |parent_window| is not provided then the +main screen monitor will be used and some functionality that requires a +parent window may not function correctly. In order to create windowless +browsers the CefSettings.windowless_rendering_enabled value must be set to +true. Transparent painting is enabled by default but can be disabled by +setting CefBrowserSettings.background_color to an opaque value. + + + + +Structure representing window information. + + + + +Structure representing CefExecuteProcess arguments. + + + + +Structure representing insets. + + + + +Structure representing a size. + + + + +Structure representing a rectangle. + + + + +Structure representing a point. + + + + +Creates a copy of an existing string list. + + + + +Free the string list. + + + + +Clear the string list. + + + + +Append a new value at the end of the string list. + + + + +Retrieve the value at the specified zero-based string list index. Returns +true (1) if the value was successfully retrieved. + + + + +Return the number of elements in the string list. + + + + +Allocate a new string map. + + + + +CEF string maps are a set of key/value string pairs. + + + + +Traits implementation for utf16 character strings. + + + + +Traits implementation for utf8 character strings. + + + + +Traits implementation for wide character strings. + + + + +These functions convert utf16 string case using the current ICU locale. This +may change the length of the string in some cases. + + + + +These functions free the string structure allocated by the associated +alloc function. Any string contents will first be cleared. + + + + +These functions allocate a new string structure. They must be freed by +calling the associated free function. + + + + +It is sometimes necessary for the system to allocate string structures with +the expectation that the user will free them. The userfree types act as a +hint that the user is responsible for freeing the structure. + + + + +These functions convert an ASCII string, typically a hardcoded constant, to +a Wide/UTF16 string. Use instead of the UTF8 conversion routines if you know +the string is ASCII. + + + + +These functions convert between UTF-8, -16, and -32 strings. They are +potentially slow so unnecessary conversions should be avoided. The best +possible result will always be written to |output| with the boolean return +value indicating whether the conversion is 100% valid. + + + + +These functions compare two string values with the same results as strcmp(). + + + + +Convenience macros for copying values. + + +These functions clear string values. The structure itself is not freed. + + + + +These functions set string values. If |copy| is true (1) the value will be +copied instead of referenced. It is up to the user to properly manage +the lifespan of references. + + + + +\file +CEF provides functions for converting between UTF-8, -16 and -32 strings. +CEF string types are safe for reading from multiple threads but not for +modification. It is the user's responsibility to provide synchronization if +modifying CEF strings from multiple threads. + + +CEF string type definitions. Whomever allocates |str| is responsible for +providing an appropriate |dtor| implementation that will free the string in +the same memory space. When reusing an existing string structure make sure +to call |dtor| for the old value before assigning new |str| and |dtor| +values. Static strings will have a NULL |dtor| value. Using the below +functions if you want this managed for you. + + + + +Return the delta between this object and |other| in milliseconds. + + + + +Set this object to now. + + + + +Converts to/from a double which is the number of seconds since epoch +(Jan 1, 1970). Webkit uses this format to represent time. A value of 0 +means "not initialized". + + + + +Converts to/from time_t. + + + + +Class representing a time. + + + + +Represents a wall clock time in UTC. Values are not guaranteed to be +monotonically non-decreasing and are subject to large amounts of skew. +Time is stored internally as microseconds since the Windows epoch (1601). + +This is equivalent of Chromium `base::Time` (see base/time/time.h). + + + + +Converts cef_basetime_t to cef_time_t. Returns true (1) on success and +false (0) on failure. + + + + +Converts cef_time_t to cef_basetime_t. Returns true (1) on success and +false (0) on failure. + + + + +Retrieve the delta in milliseconds between two time values. Returns true (1) +on success and false (0) on failure. + + + +Retrieve the current system time. + + + + +Retrieve the current system time. Returns true (1) on success and false (0) +on failure. + + + + +Converts cef_time_t to/from a double which is the number of seconds since +epoch (Jan 1, 1970). Webkit uses this format to represent time. A value of 0 +means "not initialized". Returns true (1) on success and false (0) on +failure. + + + + +Converts cef_time_t to/from time_t. Returns true (1) on success and false +(0) on failure. + + + + +Milliseconds within the current second (0-999) + + + + +Second within the current minute (0-59 plus leap seconds which may take +it up to 60). + + + + +Minute within the current hour (0-59) + + + + +Hour within the current day (0-23) + + + + +1-based day of month (1-31) + + + + +0-based day of week (0 = Sunday, etc.) + + + + +1-based month (values 1 = January, etc.) + + + + +Four or five digit year "2007" (1601 to 30827 on Windows, 1970 to 2038 on +32-bit POSIX) + + + + +Time information. Values should always be in UTC. + + + + +ThreadChecker is a helper class used to help verify that some methods of a +class are called from the same thread. It provides identical functionality +to base::NonThreadSafe, but it is meant to be held as a member variable, +rather than inherited from base::NonThreadSafe. + +While inheriting from base::NonThreadSafe may give a clear indication about +the thread-safety of a class, it may also lead to violations of the style +guide with regard to multiple inheritance. The choice between having a +ThreadChecker member and inheriting from base::NonThreadSafe should be based +on whether: + - Derived classes need to know the thread they belong to, as opposed to + having that functionality fully encapsulated in the base class. + - Derived classes should be able to reassign the base class to another + thread, via DetachFromThread. + +If neither of these are true, then having a ThreadChecker member and calling +CalledOnValidThread is the preferable solution. + +Example: + +
+  class MyClass {
+   public:
+    void Foo() {
+      DCHECK(thread_checker_.CalledOnValidThread());
+      ... (do stuff) ...
+    }
+
+   private:
+    ThreadChecker thread_checker_;
+  }
+
+ +In Release mode, CalledOnValidThread will always return true. + +
+ + +Do nothing implementation, for use in release mode. + +Note: You should almost always use the ThreadChecker class to get the +right version for your build configuration. + + + + +AutoUnlock is a helper that will Release() the |lock| argument in the +constructor, and re-Acquire() it in the destructor. + + + + +A helper class that acquires the given Lock while the AutoLock is in scope. + + + + +A convenient wrapper for an OS specific critical section. The only real +intelligence in this class is in debug mode for the support for the +AssertAcquired() method. + + + + +Gets the current thread reference, which can be used to check if +we're on the right thread quickly. + + + + +Gets the current thread id, which may be useful for logging purposes. + + + + +Used for thread checking and debugging. +Meant to be as fast as possible. +These are produced by PlatformThread::CurrentRef(), and used to later +check if we are on the same thread or not by using ==. These are safe +to copy between threads, but can't be copied to another process as they +have no meaning there. Also, the internal identifier can be re-used +after a thread dies, so a PlatformThreadRef cannot be reliably used +to distinguish a new thread from an old, dead thread. + + + + +Used for logging. Always an integer value. + + + + +Returns the current platform thread handle. + + + + +Returns the current platform thread ID. + + + + +Add a log message. See the LogSeverity defines for supported |severity| +values. + + + + +Gets the current vlog level for the given file (usually taken from +__FILE__). Note that |N| is the size *with* the null terminator. + + + + +Gets the current log level. + + + + +Returns the current reference count (with no barriers). This is subtle, +and should be used only for debugging. + + + + +Return whether the reference count is zero. With conventional object +referencing counting, the object will be destroyed, so the reference count +should never be zero. Hence this is generally used for a debug check. + + + + +Return whether the reference count is one. If the reference count is used +in the conventional way, a refrerence count of 1 implies that the current +thread owns the reference and no other thread shares it. This call +performs the test for a reference count of one, and performs the memory +barrier needed for the owning thread to act on the object, knowing that it +has exclusive access to the object. + + + + +Decrement a reference count, and return whether the result is non-zero. +Insert barriers to ensure that state written before the reference count +became zero will be visible to a thread that has just made the count zero. + + + + +Increment a reference count by "increment", which must exceed 0. +Returns the previous value of the count. + + + + +Increment a reference count. +Returns the previous value of the count. + + + + +Set the resolved URL after redirects or changed as a result of HSTS. + + + +Set the resolved URL after redirects or changed as a result of HSTS. + + + +Set the resolved URL after redirects or changed as a result of HSTS. + + + + +Get the resolved URL after redirects or changed as a result of HSTS. + + + +Get the resolved URL after redirects or changed as a result of HSTS. + + + +Get the resolved URL after redirects or changed as a result of HSTS. + + + + +Set all response header fields. + + + +Set all response header fields. + + + +Set all response header fields. + + + + +Get all response header fields. + + + +Get all response header fields. + + + +Get all response header fields. + + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. + + + +Set the header |name| to |value|. If |overwrite| is true any existing +values will be replaced with the new value. If |overwrite| is false any +existing values will not be overwritten. + + + + +Get the value for the specified response header field. + + + +Get the value for the specified response header field. + + + +Get the value for the specified response header field. + + + + +Set the response charset. + + + +Set the response charset. + + + +Set the response charset. + + + + +Get the response charset. + + + +Get the response charset. + + + +Get the response charset. + + + + +Set the response mime type. + + + +Set the response mime type. + + + +Set the response mime type. + + + + +Get the response mime type. + + + +Get the response mime type. + + + +Get the response mime type. + + + + +Set the response status text. + + + +Set the response status text. + + + +Set the response status text. + + + + +Get the response status text. + + + +Get the response status text. + + + +Get the response status text. + + + + +Set the response status code. + + + +Set the response status code. + + + +Set the response status code. + + + + +Get the response status code. + + + +Get the response status code. + + + +Get the response status code. + + + + +Set the response error code. This can be used by custom scheme handlers +to return errors during initial request processing. + + + +Set the response error code. This can be used by custom scheme handlers +to return errors during initial request processing. + + + +Set the response error code. This can be used by custom scheme handlers +to return errors during initial request processing. + + + + +Get the response error code. Returns ERR_NONE if there was no error. + + + +Get the response error code. Returns ERR_NONE if there was no error. + + + +Get the response error code. Returns ERR_NONE if there was no error. + + + + +Returns true if this object is read-only. + + + +Returns true if this object is read-only. + + + +Returns true if this object is read-only. + + + + +Create a new CefResponse object. + + + +Create a new CefResponse object. + + + +Create a new CefResponse object. + + + + +Class used to represent a web response. The methods of this class may be +called on any thread. + + + +Class used to represent a web response. The methods of this class may be +called on any thread. + + + +Class used to represent a web response. The methods of this class may be +called on any thread. + + + + +Returns the mime type. + + + +Returns the mime type. + + + + +Returns the content disposition. + + + +Returns the content disposition. + + + + +Returns the suggested file name. + + + +Returns the suggested file name. + + + + +Returns the original URL before any redirections. + + + +Returns the original URL before any redirections. + + + + +Returns the URL. + + + +Returns the URL. + + + + +Returns the unique identifier for this download. + + + +Returns the unique identifier for this download. + + + + +Returns the full path to the downloaded or downloading file. + + + +Returns the full path to the downloaded or downloading file. + + + + +Returns the time that the download ended. + + + +Returns the time that the download ended. + + + + +Returns the time that the download started. + + + +Returns the time that the download started. + + + + +Returns the number of received bytes. + + + +Returns the number of received bytes. + + + + +Returns the total number of bytes. + + + +Returns the total number of bytes. + + + + +Returns the rough percent complete or -1 if the receive total size is +unknown. + + + +Returns the rough percent complete or -1 if the receive total size is +unknown. + + + + +Returns a simple speed estimate in bytes/s. + + + +Returns a simple speed estimate in bytes/s. + + + + +Returns true if the download has been canceled or interrupted. + + + +Returns true if the download has been canceled or interrupted. + + + + +Returns true if the download is complete. + + + +Returns true if the download is complete. + + + + +Returns true if the download is in progress. + + + +Returns true if the download is in progress. + + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + +Returns true if this object is valid. Do not call any other methods if +this function returns false. + + + + +Class used to represent a download item. + + + +Class used to represent a download item. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
\ No newline at end of file diff --git a/packages/CefSharp.Common.113.1.40/build/CefSharp.Common.props b/packages/CefSharp.Common.113.1.40/build/CefSharp.Common.props new file mode 100644 index 0000000..22767c9 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/build/CefSharp.Common.props @@ -0,0 +1,5 @@ + + + + + diff --git a/packages/CefSharp.Common.113.1.40/build/CefSharp.Common.targets b/packages/CefSharp.Common.113.1.40/build/CefSharp.Common.targets new file mode 100644 index 0000000..17fe27d --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/build/CefSharp.Common.targets @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/packages/CefSharp.Common.113.1.40/build/app.config.x64.transform b/packages/CefSharp.Common.113.1.40/build/app.config.x64.transform new file mode 100644 index 0000000..1c4b0b5 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/build/app.config.x64.transform @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/CefSharp.Common.113.1.40/build/app.config.x86.transform b/packages/CefSharp.Common.113.1.40/build/app.config.x86.transform new file mode 100644 index 0000000..6aae62a --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/build/app.config.x86.transform @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/CefSharp.Common.113.1.40/buildTransitive/CefSharp.Common.props b/packages/CefSharp.Common.113.1.40/buildTransitive/CefSharp.Common.props new file mode 100644 index 0000000..5806058 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/buildTransitive/CefSharp.Common.props @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + + + diff --git a/packages/CefSharp.Common.113.1.40/buildTransitive/CefSharp.Common.targets b/packages/CefSharp.Common.113.1.40/buildTransitive/CefSharp.Common.targets new file mode 100644 index 0000000..7347aa7 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/buildTransitive/CefSharp.Common.targets @@ -0,0 +1,444 @@ + + + + + + <_CefSharpCoreRuntimeFiltered Include="@(ReferenceCopyLocalPaths)" Condition="'%(Filename)%(Extension)' == 'CefSharp.Core.Runtime.dll'" /> + <_CefSharpCoreRuntimeFiltered Include="@(ReferenceCopyLocalPaths)" Condition="'%(Filename)%(Extension)' == 'CefSharp.Core.Runtime.pdb'" /> + <_CefSharpCoreRuntimeFiltered Include="@(ReferenceCopyLocalPaths)" Condition="'%(Filename)%(Extension)' == 'CefSharp.Core.Runtime.xml'" /> + + + + + + + + <_DeploymentManifestFiles Remove="$(MSBuildThisFileDirectory)..\CefSharp\$(PlatformTarget)\CefSharp.Core.Runtime.dll" /> + <_DeploymentManifestFiles Remove="$(MSBuildThisFileDirectory)..\CefSharp\$(PlatformTarget)\CefSharp.Core.Runtime.pdb" /> + <_DeploymentManifestFiles Remove="$(MSBuildThisFileDirectory)..\CefSharp\$(PlatformTarget)\CefSharp.Core.Runtime.xml" /> + + + + + + + <_CefSharpCoreRuntimeFilteredManifest Include="@(_DeploymentManifestDependencies)" Condition="'%(Filename)%(Extension)' == 'CefSharp.Core.Runtime.dll'" /> + <_CefSharpCoreRuntimeFilteredManifest Include="@(_DeploymentManifestDependencies)" Condition="'%(Filename)%(Extension)' == 'CefSharp.Core.Runtime.pdb'" /> + <_CefSharpCoreRuntimeFilteredManifest Include="@(_DeploymentManifestDependencies)" Condition="'%(Filename)%(Extension)' == 'CefSharp.Core.Runtime.xml'" /> + <_DeploymentManifestDependencies Remove="@(_CefSharpCoreRuntimeFilteredManifest)" /> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + $(MSBuildExtensionsPath)\Microsoft\VisualStudio\v$(VisualStudioVersion)\Web\Microsoft.Web.Publishing.Tasks.dll + $(VSToolsPath)\Web\Microsoft.Web.Publishing.Tasks.dll + $(CefSharpTransformXmlDllPathOverride) + + + + + Content + None + + + + $(CefSharpTargetDir)\ + $(CefSharpTargetDir)x86\ + $(CefSharpTargetDir)x64\ + + $(PlatformTarget) + $(Platform) + x86 + x86 + $(CefSharpPlatformTargetOverride) + + + true + + + true + + + + + + + + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + + + + + + + + + + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + $(CefSharpTargetDirAnyCpu32)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu64)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu32)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu64)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + $(CefSharpTargetDirAnyCpu32)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDirAnyCpu64)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + + + + + + + + + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + + + + + $(CefSharpTargetDirAnyCpu32)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + $(CefSharpTargetDirAnyCpu64)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + $(CefSharpTargetDirAnyCpu32)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + $(CefSharpTargetDirAnyCpu64)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + + $(CefSharpTargetDirAnyCpu32)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + $(CefSharpTargetDirAnyCpu64)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + + + + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + $(CefSharpTargetDir)%(RecursiveDir)%(FileName)%(Extension) + PreserveNewest + Included + false + true + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + <_CefSharpPlatformTarget>$(PlatformTarget) + <_CefSharpPlatformTarget Condition="'$(_CefSharpPlatformTarget)' == ''">$(Platform) + <_CefSharpPlatformTarget Condition="'$(_CefSharpPlatformTarget)' == 'Win32'">x86 + <_CefSharpPlatformTarget Condition="'$(_CefSharpPlatformTarget)' == 'AnyCPU' AND '$(Prefer32Bit)' == 'true' AND '$(CefSharpAnyCpuSupport)' == ''">x86 + <_CefSharpPlatformTarget Condition="'$(CefSharpPlatformTargetOverride)' != ''">$(CefSharpPlatformTargetOverride) + + $(TargetDir)$(CefSharpTargetDir) + $(TargetDir)$(CefSharpTargetDir) + $(CefRedist32TargetDir)x86\ + $(CefRedist64TargetDir)x64\ + + + <_CefSharpCommonManagedDll Include="$(MSBuildThisFileDirectory)..\lib\net452\CefSharp.dll" /> + <_CefSharpCommonBinaries32 Include="$(MSBuildThisFileDirectory)..\CefSharp\x86\*.*" /> + <_CefSharpCommonBinaries64 Include="$(MSBuildThisFileDirectory)..\CefSharp\x64\*.*" /> + + + + + + + + diff --git a/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.XML b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.XML new file mode 100644 index 0000000..f71f00a --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.XML @@ -0,0 +1,30925 @@ + + + + CefSharp.Core + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Create a new instance of + + set to false if you plan to reuse the instance, otherwise true + BrowserSettings + + + + SelfHost allows your application executable to be used as the BrowserSubProcess + with minimal effort. + https://github.com/cefsharp/CefSharp/wiki/SelfHost-BrowserSubProcess + + + //WinForms Example + public class Program + { + [STAThread] + public static int Main(string[] args) + { + var exitCode = CefSharp.BrowserSubprocess.SelfHost.Main(args); + + if (exitCode >= 0) + { + return exitCode; + } + + var settings = new CefSettings(); + //Absolute path to your applications executable + settings.BrowserSubprocessPath = System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName; + + Cef.Initialize(settings); + + var browser = new BrowserForm(true); + Application.Run(browser); + + return 0; + } + } + + + + + This function should be called from the application entry point function (typically Program.Main) + to execute a secondary process e.g. gpu, renderer, utility + This overload is specifically used for .Net Core. For hosting your own BrowserSubProcess + it's preferable to use the Main method provided by this class. + - Pass in command line args + + command line args + + If called for the browser process (identified by no "type" command-line value) it will return immediately + with a value of -1. If called for a recognized secondary process it will block until the process should exit + and then return the process exit code. + + + + + Global CEF methods are exposed through this class. e.g. CefInitalize maps to Cef.Initialize + CEF API Doc https://magpcss.org/ceforum/apidocs3/projects/(default)/(_globals).html + This class cannot be inherited. + + + + + Event is raised when is called, + before the shutdown logic is executed. + + + Will be called on the same thread as + + + + Gets a value that indicates whether CefSharp is initialized. + true if CefSharp is initialized; otherwise, false. + + + Gets a value that indicates whether CefSharp was shutdown. + true if CefSharp was shutdown; otherwise, false. + + + Gets a value that indicates the version of CefSharp currently being used. + The CefSharp version. + + + Gets a value that indicates the CEF version currently being used. + The CEF Version + + + Gets a value that indicates the Chromium version currently being used. + The Chromium version. + + + + Gets a value that indicates the Git Hash for CEF version currently being used. + + The Git Commit Hash + + + + Parse the specified url into its component parts. + Uses a GURL to parse the Url. GURL is Google's URL parsing library. + + url + Returns null if the URL is empty or invalid. + + + + Initializes CefSharp with user-provided settings. + It's important to note that Initialize and Shutdown MUST be called on your main + application thread (typically the UI thread). If you call them on different + threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + true if successful; otherwise, false. + + + + Initializes CefSharp with user-provided settings. + It's important to note that Initialize/Shutdown MUST be called on your main + application thread (typically the UI thread). If you call them on different + threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies available, throws exception if any are missing + true if successful; otherwise, false. + + + + Initializes CefSharp with user-provided settings. + It's important to note that Initialize/Shutdown MUST be called on your main + application thread (typically the UI thread). If you call them on different + threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies available, throws exception if any are missing + The handler for functionality specific to the browser process. Null if you don't wish to handle these events + true if successful; otherwise, false. + + + + Initializes CefSharp with user-provided settings. + It's important to note that Initialize/Shutdown MUST be called on your main + application thread (typically the UI thread). If you call them on different + threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies available, throws exception if any are missing + Implement this interface to provide handler implementations. Null if you don't wish to handle these events + true if successful; otherwise, false. + + + + Initializes CefSharp with user-provided settings. This method allows you to wait for + to be called before continuing. + It's important to note that Initialize and Shutdown MUST be called on your main + application thread (typically the UI thread). If you call them on different + threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + + CefSharp configuration settings. + Check that all relevant dependencies available, throws exception if any are missing + The handler for functionality specific to the browser process. Null if you don't wish to handle these events + returns a Task that can be awaited. true if successful; otherwise, false. If false check the log file for possible errors + + If successful then the Task will be completed successfully when is called. + If successful then the continuation will happen syncrionously on the CEF UI thread. + + + + + Run the CEF message loop. Use this function instead of an application- + provided message loop to get the best balance between performance and CPU + usage. This function should only be called on the main application thread and + only if Cef.Initialize() is called with a + CefSettings.MultiThreadedMessageLoop value of false. This function will + block until a quit message is received by the system. + + + + + Quit the CEF message loop that was started by calling Cef.RunMessageLoop(). + This function should only be called on the main application thread and only + if Cef.RunMessageLoop() was used. + + + + + Perform a single iteration of CEF message loop processing.This function is + provided for cases where the CEF message loop must be integrated into an + existing application message loop. Use of this function is not recommended + for most users; use CefSettings.MultiThreadedMessageLoop if possible (the default). + When using this function care must be taken to balance performance + against excessive CPU usage. It is recommended to enable the + CefSettings.ExternalMessagePump option when using + this function so that IBrowserProcessHandler.OnScheduleMessagePumpWork() + callbacks can facilitate the scheduling process. This function should only be + called on the main application thread and only if Cef.Initialize() is called + with a CefSettings.MultiThreadedMessageLoop value of false. This function + will not block. + + + + + This function should be called from the application entry point function to execute a secondary process. + It can be used to run secondary processes from the browser client executable (default behavior) or + from a separate executable specified by the CefSettings.browser_subprocess_path value. + If called for the browser process (identified by no "type" command-line value) it will return immediately with a value of -1. + If called for a recognized secondary process it will block until the process should exit and then return the process exit code. + The |application| parameter may be empty. The |windows_sandbox_info| parameter is only used on Windows and may be NULL (see cef_sandbox_win.h for details). + + + + Add an entry to the cross-origin whitelist. + The origin allowed to be accessed by the target protocol/domain. + The target protocol allowed to access the source origin. + The optional target domain allowed to access the source origin. + If set to true would allow a blah.example.com if the + was set to example.com + + Returns false if is invalid or the whitelist cannot be accessed. + + The same-origin policy restricts how scripts hosted from different origins + (scheme + domain + port) can communicate. By default, scripts can only access + resources with the same origin. Scripts hosted on the HTTP and HTTPS schemes + (but no other schemes) can use the "Access-Control-Allow-Origin" header to + allow cross-origin requests. For example, https://source.example.com can make + XMLHttpRequest requests on http://target.example.com if the + http://target.example.com request returns an "Access-Control-Allow-Origin: + https://source.example.com" response header. + + Scripts in separate frames or iframes and hosted from the same protocol and + domain suffix can execute cross-origin JavaScript if both pages set the + document.domain value to the same domain suffix. For example, + scheme://foo.example.com and scheme://bar.example.com can communicate using + JavaScript if both domains set document.domain="example.com". + + This method is used to allow access to origins that would otherwise violate + the same-origin policy. Scripts hosted underneath the fully qualified + URL (like http://www.example.com) will be allowed access to + all resources hosted on the specified and . + If is non-empty and if false only + exact domain matches will be allowed. If contains a top- + level domain component (like "example.com") and is + true sub-domain matches will be allowed. If is empty and + if true all domains and IP addresses will be + allowed. + + This method cannot be used to bypass the restrictions on local or display + isolated schemes. See the comments on for more + information. + + This function may be called on any thread. Returns false if + is invalid or the whitelist cannot be accessed. + + + + Remove entry from cross-origin whitelist + The origin allowed to be accessed by the target protocol/domain. + The target protocol allowed to access the source origin. + The optional target domain allowed to access the source origin. + If set to true would allow a blah.example.com if the + was set to example.com + + + Remove an entry from the cross-origin access whitelist. Returns false if + is invalid or the whitelist cannot be accessed. + + + + Remove all entries from the cross-origin access whitelist. + + Remove all entries from the cross-origin access whitelist. Returns false if + the whitelist cannot be accessed. + + + + + Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. + Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() + The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, + there may be a short delay before you can Get/Write cookies. + To be sure the cookie manager has been initialized use one of the following + - Access the ICookieManager after ICompletionCallback.OnComplete has been called + - Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. + - Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + If non-NULL it will be executed asynchronously on the CEF UI thread after the manager's storage has been initialized. + A the global cookie manager or null if the RequestContext has not yet been initialized. + + + + Called prior to calling Cef.Shutdown, this disposes of any remaining + ChromiumWebBrowser instances. In WPF this is used from Dispatcher.ShutdownStarted + to release the unmanaged resources held by the ChromiumWebBrowser instances. + Generally speaking you don't need to call this yourself. + + + + + Shuts down CefSharp and the underlying CEF infrastructure. This method is safe to call multiple times; it will only + shut down CEF on the first call (all subsequent calls will be ignored). + This method should be called on the main application thread to shut down the CEF browser process before the application exits. + If you are Using CefSharp.OffScreen then you must call this explicitly before your application exits or it will hang. + This method must be called on the same thread as Initialize. If you don't call Shutdown explicitly then CefSharp.Wpf and CefSharp.WinForms + versions will do their best to call Shutdown for you, if your application is having trouble closing then call thus explicitly. + + + + + This method should only be used by advanced users, if you're unsure then use Cef.Shutdown(). + This function should be called on the main application thread to shut down + the CEF browser process before the application exits. This method simply obtains a lock + and calls the native CefShutdown method, only IsInitialized is checked. All ChromiumWebBrowser + instances MUST be Disposed of before calling this method. If calling this method results in a crash + or hangs then you're likely hanging on to some unmanaged resources or haven't closed all of your browser + instances + + + + + Clear all scheme handler factories registered with the global request context. + Returns false on error. This function may be called on any thread in the browser process. + Using this function is equivalent to calling Cef.GetGlobalRequestContext().ClearSchemeHandlerFactories(). + + Returns false on error. + + + + Returns true if called on the specified CEF thread. + + Returns true if called on the specified thread. + + + + Gets the Global Request Context. Make sure to Dispose of this object when finished. + The earlier possible place to access the IRequestContext is in IBrowserProcessHandler.OnContextInitialized. + Alternative use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + + Returns the global request context or null if the RequestContext has not been initialized yet. + + + + Helper function (wrapper around the CefColorSetARGB macro) which combines + the 4 color components into an uint32 for use with BackgroundColor property + + Alpha + Red + Green + Blue + Returns the color. + + + + Crash reporting is configured using an INI-style config file named + crash_reporter.cfg. This file must be placed next to + the main application executable. File contents are as follows: + + # Comments start with a hash character and must be on their own line. + + [Config] + ProductName=<Value of the "prod" crash key; defaults to "cef"> + ProductVersion=<Value of the "ver" crash key; defaults to the CEF version> + AppName=<Windows only; App-specific folder name component for storing crash + information; default to "CEF"> + ExternalHandler=<Windows only; Name of the external handler exe to use + instead of re-launching the main exe; default to empty> + ServerURL=<crash server URL; default to empty> + RateLimitEnabled=<True if uploads should be rate limited; default to true> + MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; + default to 5> + MaxDatabaseSizeInMb=<Total crash report disk usage greater than this value + will cause older reports to be deleted; default to 20> + MaxDatabaseAgeInDays=<Crash reports older than this value will be deleted; + default to 5> + + [CrashKeys] + my_key1=<small|medium|large> + my_key2=<small|medium|large> + + Config section: + + If "ProductName" and/or "ProductVersion" are set then the specified values + will be included in the crash dump metadata. + + If "AppName" is set on Windows then crash report information (metrics, + database and dumps) will be stored locally on disk under the + "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. + + If "ExternalHandler" is set on Windows then the specified exe will be + launched as the crashpad-handler instead of re-launching the main process + exe. The value can be an absolute path or a path relative to the main exe + directory. + + If "ServerURL" is set then crashes will be uploaded as a multi-part POST + request to the specified URL. Otherwise, reports will only be stored locally + on disk. + + If "RateLimitEnabled" is set to true then crash report uploads will be rate + limited as follows: + 1. If "MaxUploadsPerDay" is set to a positive value then at most the + specified number of crashes will be uploaded in each 24 hour period. + 2. If crash upload fails due to a network or server error then an + incremental backoff delay up to a maximum of 24 hours will be applied for + retries. + 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the + "MaxUploadsPerDay" value will be reduced to 1 until the client is + restarted. This helps to avoid an upload flood when the network or + server error is resolved. + + If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage + on disk will be limited to that size in megabytes. For example, on Windows + each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to + about 34 crash reports stored on disk. + + If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older + than the specified age in days will be deleted. + + CrashKeys section: + + Any number of crash keys can be specified for use by the application. Crash + key values will be truncated based on the specified size (small = 63 bytes, + medium = 252 bytes, large = 1008 bytes). The value of crash keys can be set + from any thread or process using the Cef.SetCrashKeyValue function. These + key/value pairs will be sent to the crash server along with the crash dump + file. Medium and large values will be chunked for submission. For example, + if your key is named "mykey" then the value will be broken into ordered + chunks and submitted using keys named "mykey-1", "mykey-2", etc. + + Returns true if crash reporting is enabled. + + + + Sets or clears a specific key-value pair from the crash metadata. + + key + value + + + + Gets the current log level. + When is set to then + no messages will be written to the log file, but FATAL messages will still be output to stderr. + When logging is disabled this method will return . + + Current Log Level + + + + Returns the mime type for the specified file extension or an empty string if unknown. + + file extension + Returns the mime type for the specified file extension or an empty string if unknown. + + + + WaitForBrowsersToClose is not enabled by default, call this method + before Cef.Initialize to enable. If you aren't calling Cef.Initialize + explicitly then this should be called before creating your first + ChromiumWebBrowser instance. + + + + + Helper method to ensure all ChromiumWebBrowser instances have been + closed/disposed, should be called before Cef.Shutdown. + Disposes all remaining ChromiumWebBrowser instances + then waits for CEF to release its remaining CefBrowser instances. + Finally a small delay of 50ms to allow for CEF to finish it's cleanup. + Should only be called when MultiThreadedMessageLoop = true; + (Hasn't been tested when when CEF integrates into main message loop). + + + + + Helper method to ensure all ChromiumWebBrowser instances have been + closed/disposed, should be called before Cef.Shutdown. + Disposes all remaining ChromiumWebBrowser instances + then waits for CEF to release its remaining CefBrowser instances. + Finally a small delay of 50ms to allow for CEF to finish it's cleanup. + Should only be called when MultiThreadedMessageLoop = true; + (Hasn't been tested when when CEF integrates into main message loop). + + The timeout in miliseconds. + + + + Post an action for delayed execution on the specified thread. + + thread id + action to execute + delay in ms + bool + + + + Post an action for execution on the specified thread. + + thread id + action to execute + bool + + + + Initialization settings. Many of these and other settings can also configured using command-line switches. + WPF/WinForms/OffScreen each have their own CefSettings implementation that sets + relevant settings e.g. OffScreen starts with audio muted. + + + + + Free the unmanaged CefSettingsBase instance. + Under normal circumstances you shouldn't need to call this + The unmanaged resource will be freed after (or one of the overloads) is called. + + + + + Gets a value indicating if the CefSettings has been disposed. + + + + + Add Customs schemes to this collection. + + + + + Add custom command line argumens to this collection, they will be added in OnBeforeCommandLineProcessing. The + CefSettings.CommandLineArgsDisabled value can be used to start with an empty command-line object. Any values specified in + CefSettings that equate to command-line arguments will be set before this method is called. + + + + + **Experimental** + Set to true to enable use of the Chrome runtime in CEF. This feature is + considered experimental and is not recommended for most users at this time. + See issue https://github.com/chromiumembedded/cef/issues/2969 + + + + + Set to true to disable configuration of browser process features using standard CEF and Chromium command-line arguments. + Configuration can still be specified using CEF data structures or by adding to CefCommandLineArgs. + + + + + Set to true to control browser process main (UI) thread message pump scheduling via the + IBrowserProcessHandler.OnScheduleMessagePumpWork callback. This option is recommended for use in combination with the + Cef.DoMessageLoopWork() function in cases where the CEF message loop must be integrated into an existing application message + loop (see additional comments and warnings on Cef.DoMessageLoopWork). Enabling this option is not recommended for most users; + leave this option disabled and use either MultiThreadedMessageLoop (the default) if possible. + + + + + Set to true to have the browser process message loop run in a separate thread. If false then the CefDoMessageLoopWork() + function must be called from your application message loop. This option is only supported on Windows. The default value is + true. + + + + + The path to a separate executable that will be launched for sub-processes. By default the browser process executable is used. + See the comments on Cef.ExecuteProcess() for details. If this value is non-empty then it must be an absolute path. + Also configurable using the "browser-subprocess-path" command-line switch. + Defaults to using the provided CefSharp.BrowserSubprocess.exe instance + + + + + The location where data for the global browser cache will be stored on disk. In this value is non-empty then it must be + an absolute path that is must be either equal to or a child directory of CefSettings.RootCachePath (if RootCachePath is + empty it will default to this value). If the value is empty then browsers will be created in "incognito mode" where + in-memory caches are used for storage and no data is persisted to disk. HTML5 databases such as localStorage will only + persist across sessions if a cache path is specified. Can be overridden for individual RequestContext instances via the + RequestContextSettings.CachePath value. + + + + + The root directory that all CefSettings.CachePath and RequestContextSettings.CachePath values must have in common. If this + value is empty and CefSettings.CachePath is non-empty then it will default to the CefSettings.CachePath value. + If this value is non-empty then it must be an absolute path. Failure to set this value correctly may result in the sandbox + blocking read/write access to the CachePath directory. NOTE: CefSharp does not implement the CHROMIUM SANDBOX. A non-empty + RootCachePath can be used in conjuncation with an empty CefSettings.CachePath in instances where you would like browsers + attached to the Global RequestContext (the default) created in "incognito mode" and instances created with a custom + RequestContext using a disk based cache. + + + + + The location where user data such as the Widevine CDM module and spell checking dictionary files will be stored on disk. + If this value is empty then "Local Settings\Application Data\CEF\User Data" directory under the user profile directory + will be used. If this value is non-empty then it must be an absolute path. + + + + + Set to true in order to completely ignore SSL certificate errors. This is NOT recommended. + + + + + The locale string that will be passed to WebKit. If empty the default locale of "en-US" will be used. Also configurable using + the "lang" command-line switch. + + + + + The fully qualified path for the locales directory. If this value is empty the locales directory must be located in the + module directory. If this value is non-empty then it must be an absolute path. Also configurable using the "locales-dir-path" + command-line switch. + + + + + The fully qualified path for the resources directory. If this value is empty the cef.pak and/or devtools_resources.pak files + must be located in the module directory. Also configurable using the "resources-dir-path" command-line switch. + + + + + The directory and file name to use for the debug log. If empty a default log file name and location will be used. On Windows + a "debug.log" file will be written in the main executable directory. Also configurable using the"log-file" command- line + switch. + + + + + The log severity. Only messages of this severity level or higher will be logged. When set to + no messages will be written to the log file, but Fatal messages will still be + output to stderr. Also configurable using the "log-severity" command-line switch with a value of "verbose", "info", "warning", + "error", "fatal", "error-report" or "disable". + + + + + Custom flags that will be used when initializing the V8 JavaScript engine. The consequences of using custom flags may not be + well tested. Also configurable using the "js-flags" command-line switch. + + + + + Set to true to disable loading of pack files for resources and locales. A resource bundle handler must be provided for the + browser and render processes via CefApp.GetResourceBundleHandler() if loading of pack files is disabled. Also configurable + using the "disable-pack-loading" command- line switch. + + + + + Value that will be inserted as the product portion of the default User-Agent string. If empty the Chromium product version + will be used. If UserAgent is specified this value will be ignored. Also configurable using the "user-agent-product" command- + line switch. + + + + + Set to a value between 1024 and 65535 to enable remote debugging on the specified port. For example, if 8080 is specified the + remote debugging URL will be http://localhost:8080. CEF can be remotely debugged from any CEF or Chrome browser window. Also + configurable using the "remote-debugging-port" command-line switch. + + + + + The number of stack trace frames to capture for uncaught exceptions. Specify a positive value to enable the + CefRenderProcessHandler. OnUncaughtException() callback. Specify 0 (default value) and OnUncaughtException() will not be + called. Also configurable using the "uncaught-exception-stack-size" command-line switch. + + + + + Value that will be returned as the User-Agent HTTP header. If empty the default User-Agent string will be used. Also + configurable using the "user-agent" command-line switch. + + + + + Set to true (1) to enable windowless (off-screen) rendering support. Do not enable this value if the application does not use + windowless rendering as it may reduce rendering performance on some systems. + + + + + To persist session cookies (cookies without an expiry date or validity interval) by default when using the global cookie + manager set this value to true. Session cookies are generally intended to be transient and most Web browsers do not persist + them. A CachePath value must also be specified to enable this feature. Also configurable using the "persist-session-cookies" + command-line switch. Can be overridden for individual RequestContext instances via the + RequestContextSettings.PersistSessionCookies value. + + + + + To persist user preferences as a JSON file in the cache path directory set this value to true. A CachePath value must also be + specified to enable this feature. Also configurable using the "persist-user-preferences" command-line switch. Can be + overridden for individual RequestContext instances via the RequestContextSettings.PersistUserPreferences value. + + + + + Comma delimited ordered list of language codes without any whitespace that will be used in the "Accept-Language" HTTP header. + May be set globally using the CefSettings.AcceptLanguageList value. If both values are empty then "en-US,en" will be used. + + + + + + Background color used for the browser before a document is loaded and when no document color is specified. The alpha + component must be either fully opaque (0xFF) or fully transparent (0x00). If the alpha component is fully opaque then the RGB + components will be used as the background color. If the alpha component is fully transparent for a WinForms browser then the + default value of opaque white be used. If the alpha component is fully transparent for a windowless (WPF/OffScreen) browser + then transparent painting will be enabled. + + + + + Comma delimited list of schemes supported by the associated + ICookieManager. If CookieableSchemesExcludeDefaults is false the + default schemes ("http", "https", "ws" and "wss") will also be supported. + Specifying a CookieableSchemesList value and setting + CookieableSchemesExcludeDefaults to true will disable all loading + and saving of cookies for this manager. Can be overridden + for individual RequestContext instances via the + RequestContextSettings.CookieableSchemesList and + RequestContextSettings.CookieableSchemesExcludeDefaults values. + + + + + If CookieableSchemesExcludeDefaults is false the + default schemes ("http", "https", "ws" and "wss") will also be supported. + Specifying a CookieableSchemesList value and setting + CookieableSchemesExcludeDefaults to true will disable all loading + and saving of cookies for this manager. Can be overridden + for individual RequestContext instances via the + RequestContextSettings.CookieableSchemesList and + RequestContextSettings.CookieableSchemesExcludeDefaults values. + + + + + Registers a custom scheme using the provided settings. + + The CefCustomScheme which provides the details about the scheme. + + + + Set command line argument to disable GPU Acceleration. WebGL will use + software rendering + + + + + Set command line argument to enable Print Preview See + https://github.com/chromiumembedded/cef/issues/123/add-support-for-print-preview for details. + + + + + Set command line arguments for best OSR (Offscreen and WPF) Rendering performance Software Rendering will be used for WebGL, look at the source + to determine which flags best suite your requirements. + + + + + Extensions for accessing DevTools through + + + + + Execute a method call over the DevTools protocol. This is a more structured + version of SendDevToolsMessage. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected JSON message format. + See the SendDevToolsMessage documentation for additional usage information. + + browser host + is an incremental number that uniquely identifies the message (pass 0 to have the next number assigned + automatically based on previous values) + is the method name + are the method parameters represented as a , + which may be empty. + return the assigned message Id if called on the CEF UI thread and the message was + successfully submitted for validation, otherwise 0 + + + + Execute a method call over the DevTools protocol. This is a more structured + version of SendDevToolsMessage. can only be called on the + CEF UI Thread, this method can be called on any thread. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + See the SendDevToolsMessage documentation for additional usage information. + + the browser instance + is an incremental number that uniquely identifies the message (pass 0 to have the next number assigned + automatically based on previous values) + is the method name + are the method parameters represented as a dictionary, + which may be empty. + return a Task that can be awaited to obtain the assigned message Id. If the message was + unsuccessfully submitted for validation, this value will be 0. + + + + Execute a method call over the DevTools protocol. This is a more structured + version of SendDevToolsMessage. can only be called on the + CEF UI Thread, this method can be called on any thread. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + See the SendDevToolsMessage documentation for additional usage information. + + the ChromiumWebBrowser instance + is an incremental number that uniquely identifies the message (pass 0 to have the next number assigned + automatically based on previous values) + is the method name + are the method parameters represented as a dictionary, + which may be empty. + return a Task that can be awaited to obtain the assigned message Id. If the message was + unsuccessfully submitted for validation, this value will be 0. + + + + Gets a new Instance of the DevTools client for the chromiumWebBrowser + instance. + + the chromiumWebBrowser instance + DevToolsClient + + + + Gets a new Instance of the DevTools client + + the IBrowser instance + DevToolsClient + + + + Set the Document Content for the Main Frame using DevTools Protocol. + + ChromiumWebBrowser instance + html + Task that can be awaited to determine if the content was successfully updated. + + + + Set the Document Content for the Main Frame using DevTools Protocol. + + the browser instance + html + Task that can be awaited to determine if the content was successfully updated. + + + + DevTool Client + + + Generated DevToolsClient methods + + + + + + + + + + + Capture the current so + continuation executes on the original calling thread. If + is null for + + then the continuation will be run on the CEF UI Thread (by default + this is not the same as the WPF/WinForms UI Thread). + + + + + When not null provided + will be used to run the contination. Defaults to null + Setting this property will change + to false. + + + + + DevToolsClient + + Browser associated with this DevTools client + + + + Store a reference to the IRegistration that's returned when + you register an observer. + + registration + + + + + + + + + + Execute a method call over the DevTools protocol. This method can be called on any thread. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + + is the method name + are the method parameters represented as a dictionary, + which may be empty. + return a Task that can be awaited to obtain the method result + + + + Execute a method call over the DevTools protocol. This method can be called on any thread. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + + The type into which the result will be deserialzed. + is the method name + are the method parameters represented as a dictionary, + which may be empty. + return a Task that can be awaited to obtain the method result + + + + + + + + + + + + + + + + + + + + + + Deserialize the JSON stream into a .Net object. + For .Net Core/.Net 5.0 uses System.Text.Json + for .Net 4.5.2 uses System.Runtime.Serialization.Json + + Object type + event Name + JSON stream + object of type + + + + Deserialize the JSON stream into a .Net object. + For .Net Core/.Net 5.0 uses System.Text.Json + for .Net 4.5.2 uses System.Runtime.Serialization.Json + + Object type + JSON stream + object of type + + + + Deserialize the JSON stream into a .Net object. + For .Net Core/.Net 5.0 uses System.Text.Json + for .Net 4.5.2 uses System.Runtime.Serialization.Json + + Object type + JSON stream + object of type + + + + Accessibility + + + + + Animation + + + + + Audits domain allows investigation of page violations and possible improvements. + + + + + Defines events for background web platform features. + + + + + The Browser domain defines methods and events for browser managing. + + + + + This domain exposes CSS read/write operations. All CSS objects (stylesheets, rules, and styles) + have an associated `id` used in subsequent operations on the related object. Each object type has + a specific `id` structure, and those are not interchangeable between objects of different kinds. + CSS objects can be loaded using the `get*ForNode()` calls (which accept a DOM node id). A client + can also keep track of stylesheets via the `styleSheetAdded`/`styleSheetRemoved` events and + subsequently load the required stylesheet contents using the `getStyleSheet[Text]()` methods. + + + + + CacheStorage + + + + + A domain for interacting with Cast, Presentation API, and Remote Playback API + functionalities. + + + + + This domain exposes DOM read/write operations. Each DOM Node is represented with its mirror object + that has an `id`. This `id` can be used to get additional information on the Node, resolve it into + the JavaScript object wrapper, etc. It is important that client receives DOM events only for the + nodes that are known to the client. Backend keeps track of the nodes that were sent to the client + and never sends the same node twice. It is client's responsibility to collect information about + the nodes that were sent to the client.<p>Note that `iframe` owner elements will return + corresponding document elements as their child nodes.</p> + + + + + DOM debugging allows setting breakpoints on particular DOM operations and events. JavaScript + execution will stop on these operations as if there was a regular breakpoint set. + + + + + EventBreakpoints permits setting breakpoints on particular operations and + events in targets that run JavaScript but do not have a DOM. + JavaScript execution will stop on these operations as if there was a regular + breakpoint set. + + + + + This domain facilitates obtaining document snapshots with DOM, layout, and style information. + + + + + Query and modify DOM storage. + + + + + Database + + + + + DeviceOrientation + + + + + This domain emulates different environments for the page. + + + + + This domain provides experimental commands only supported in headless mode. + + + + + Input/Output operations for streams produced by DevTools. + + + + + IndexedDB + + + + + Input + + + + + Inspector + + + + + LayerTree + + + + + Provides access to log entries. + + + + + Memory + + + + + Network domain allows tracking network activities of the page. It exposes information about http, + file, data and other requests and responses, their headers, bodies, timing, etc. + + + + + This domain provides various functionality related to drawing atop the inspected page. + + + + + Actions and events related to the inspected page belong to the page domain. + + + + + Performance + + + + + Reporting of performance timeline events, as specified in + https://w3c.github.io/performance-timeline/#dom-performanceobserver. + + + + + Security + + + + + ServiceWorker + + + + + Storage + + + + + The SystemInfo domain defines methods and events for querying low-level system information. + + + + + Supports additional targets discovery and allows to attach to them. + + + + + The Tethering domain defines methods and events for browser port binding. + + + + + Tracing + + + + + A domain for letting clients substitute browser's network layer with client code. + + + + + This domain allows inspection of Web Audio API. + https://webaudio.github.io/web-audio-api/ + + + + + This domain allows configuring virtual authenticators to test the WebAuthn + API. + + + + + This domain allows detailed inspection of media elements + + + + + DeviceAccess + + + + + Preload + + + + + This domain allows interacting with the FedCM dialog. + + + + + Debugger domain exposes JavaScript debugging capabilities. It allows setting and removing + breakpoints, stepping through execution, exploring stack traces, etc. + + + + + HeapProfiler + + + + + Profiler + + + + + Runtime domain exposes JavaScript runtime by means of remote evaluation and mirror objects. + Evaluation results are returned as mirror object that expose object type, string representation + and unique identifier that can be used for further object reference. Original objects are + maintained in memory unless they are either explicitly released or are released along with the + other objects in their object group. + + + + + Enum of possible property types. + + + + + boolean + + + + + tristate + + + + + booleanOrUndefined + + + + + idref + + + + + idrefList + + + + + integer + + + + + node + + + + + nodeList + + + + + number + + + + + string + + + + + computedString + + + + + token + + + + + tokenList + + + + + domRelation + + + + + role + + + + + internalRole + + + + + valueUndefined + + + + + Enum of possible property sources. + + + + + attribute + + + + + implicit + + + + + style + + + + + contents + + + + + placeholder + + + + + relatedElement + + + + + Enum of possible native property sources (as a subtype of a particular AXValueSourceType). + + + + + description + + + + + figcaption + + + + + label + + + + + labelfor + + + + + labelwrapped + + + + + legend + + + + + rubyannotation + + + + + tablecaption + + + + + title + + + + + other + + + + + A single source for a computed AX property. + + + + + What type of source this is. + + + + + What type of source this is. + + + + + The value of this property source. + + + + + The name of the relevant attribute, if any. + + + + + The value of the relevant attribute, if any. + + + + + Whether this source is superseded by a higher priority source. + + + + + The native markup source for this value, e.g. a <label> element. + + + + + The native markup source for this value, e.g. a <label> element. + + + + + The value, such as a node or node list, of the native source. + + + + + Whether the value for this property is invalid. + + + + + Reason for the value being invalid, if it is. + + + + + AXRelatedNode + + + + + The BackendNodeId of the related DOM node. + + + + + The IDRef value provided, if any. + + + + + The text alternative of this node in the current context. + + + + + AXProperty + + + + + The name of this property. + + + + + The name of this property. + + + + + The value of this property. + + + + + A single computed AX property. + + + + + The type of this value. + + + + + The type of this value. + + + + + The computed value of this property. + + + + + One or more related nodes, if applicable. + + + + + The sources which contributed to the computation of this property. + + + + + Values of AXProperty name: + - from 'busy' to 'roledescription': states which apply to every AX node + - from 'live' to 'root': attributes which apply to nodes in live regions + - from 'autocomplete' to 'valuetext': attributes which apply to widgets + - from 'checked' to 'selected': states which apply to widgets + - from 'activedescendant' to 'owns' - relationships between elements other than parent/child/sibling. + + + + + busy + + + + + disabled + + + + + editable + + + + + focusable + + + + + focused + + + + + hidden + + + + + hiddenRoot + + + + + invalid + + + + + keyshortcuts + + + + + settable + + + + + roledescription + + + + + live + + + + + atomic + + + + + relevant + + + + + root + + + + + autocomplete + + + + + hasPopup + + + + + level + + + + + multiselectable + + + + + orientation + + + + + multiline + + + + + readonly + + + + + required + + + + + valuemin + + + + + valuemax + + + + + valuetext + + + + + checked + + + + + expanded + + + + + modal + + + + + pressed + + + + + selected + + + + + activedescendant + + + + + controls + + + + + describedby + + + + + details + + + + + errormessage + + + + + flowto + + + + + labelledby + + + + + owns + + + + + A node in the accessibility tree. + + + + + Unique identifier for this node. + + + + + Whether this node is ignored for accessibility + + + + + Collection of reasons why this node is hidden. + + + + + This `Node`'s role, whether explicit or implicit. + + + + + This `Node`'s Chrome raw role. + + + + + The accessible name for this `Node`. + + + + + The accessible description for this `Node`. + + + + + The value for this `Node`. + + + + + All other properties + + + + + ID for this node's parent. + + + + + IDs for each of this node's child nodes. + + + + + The backend ID for the associated DOM node, if any. + + + + + The frame ID for the frame associated with this nodes document. + + + + + The loadComplete event mirrors the load complete event sent by the browser to assistive + technology when the web page has finished loading. + + + + + New document root node. + + + + + The nodesUpdated event is sent every time a previously requested node has changed the in tree. + + + + + Updated node data. + + + + + GetPartialAXTreeResponse + + + + + nodes + + + + + GetFullAXTreeResponse + + + + + nodes + + + + + GetRootAXNodeResponse + + + + + node + + + + + GetAXNodeAndAncestorsResponse + + + + + nodes + + + + + GetChildAXNodesResponse + + + + + nodes + + + + + QueryAXTreeResponse + + + + + nodes + + + + + Accessibility + + + + + Accessibility + + DevToolsClient + + + + The loadComplete event mirrors the load complete event sent by the browser to assistive + technology when the web page has finished loading. + + + + + The nodesUpdated event is sent every time a previously requested node has changed the in tree. + + + + + Disables the accessibility domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables the accessibility domain which causes `AXNodeId`s to remain consistent between method calls. + This turns on accessibility for the page, which can impact performance until accessibility is disabled. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Fetches the accessibility node and partial accessibility tree for this DOM node, if it exists. + + Identifier of the node to get the partial accessibility tree for. + Identifier of the backend node to get the partial accessibility tree for. + JavaScript object id of the node wrapper to get the partial accessibility tree for. + Whether to fetch this node's ancestors, siblings and children. Defaults to true. + returns System.Threading.Tasks.Task<GetPartialAXTreeResponse> + + + + Fetches the entire accessibility tree for the root Document + + The maximum depth at which descendants of the root node should be retrieved.If omitted, the full tree is returned. + The frame for whose document the AX tree should be retrieved.If omited, the root frame is used. + returns System.Threading.Tasks.Task<GetFullAXTreeResponse> + + + + Fetches the root node. + Requires `enable()` to have been called previously. + + The frame in whose document the node resides.If omitted, the root frame is used. + returns System.Threading.Tasks.Task<GetRootAXNodeResponse> + + + + Fetches a node and all ancestors up to and including the root. + Requires `enable()` to have been called previously. + + Identifier of the node to get. + Identifier of the backend node to get. + JavaScript object id of the node wrapper to get. + returns System.Threading.Tasks.Task<GetAXNodeAndAncestorsResponse> + + + + Fetches a particular accessibility node by AXNodeId. + Requires `enable()` to have been called previously. + + id + The frame in whose document the node resides.If omitted, the root frame is used. + returns System.Threading.Tasks.Task<GetChildAXNodesResponse> + + + + Query a DOM node's accessibility subtree for accessible name and role. + This command computes the name and role for all nodes in the subtree, including those that are + ignored for accessibility, and returns those that mactch the specified name and role. If no DOM + node is specified, or the DOM node does not exist, the command returns an error. If neither + `accessibleName` or `role` is specified, it returns all the accessibility nodes in the subtree. + + Identifier of the node for the root to query. + Identifier of the backend node for the root to query. + JavaScript object id of the node wrapper for the root to query. + Find nodes with this computed name. + Find nodes with this computed role. + returns System.Threading.Tasks.Task<QueryAXTreeResponse> + + + + Animation type of `Animation`. + + + + + CSSTransition + + + + + CSSAnimation + + + + + WebAnimation + + + + + Animation instance. + + + + + `Animation`'s id. + + + + + `Animation`'s name. + + + + + `Animation`'s internal paused state. + + + + + `Animation`'s play state. + + + + + `Animation`'s playback rate. + + + + + `Animation`'s start time. + + + + + `Animation`'s current time. + + + + + Animation type of `Animation`. + + + + + Animation type of `Animation`. + + + + + `Animation`'s source animation node. + + + + + A unique ID for `Animation` representing the sources that triggered this CSS + animation/transition. + + + + + AnimationEffect instance + + + + + `AnimationEffect`'s delay. + + + + + `AnimationEffect`'s end delay. + + + + + `AnimationEffect`'s iteration start. + + + + + `AnimationEffect`'s iterations. + + + + + `AnimationEffect`'s iteration duration. + + + + + `AnimationEffect`'s playback direction. + + + + + `AnimationEffect`'s fill mode. + + + + + `AnimationEffect`'s target node. + + + + + `AnimationEffect`'s keyframes. + + + + + `AnimationEffect`'s timing function. + + + + + Keyframes Rule + + + + + CSS keyframed animation's name. + + + + + List of animation keyframes. + + + + + Keyframe Style + + + + + Keyframe's time offset. + + + + + `AnimationEffect`'s timing function. + + + + + Event for when an animation has been cancelled. + + + + + Id of the animation that was cancelled. + + + + + Event for each animation that has been created. + + + + + Id of the animation that was created. + + + + + Event for animation that has been started. + + + + + Animation that was started. + + + + + GetCurrentTimeResponse + + + + + currentTime + + + + + GetPlaybackRateResponse + + + + + playbackRate + + + + + ResolveAnimationResponse + + + + + remoteObject + + + + + Animation + + + + + Animation + + DevToolsClient + + + + Event for when an animation has been cancelled. + + + + + Event for each animation that has been created. + + + + + Event for animation that has been started. + + + + + Disables animation domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables animation domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns the current time of the an animation. + + Id of animation. + returns System.Threading.Tasks.Task<GetCurrentTimeResponse> + + + + Gets the playback rate of the document timeline. + + returns System.Threading.Tasks.Task<GetPlaybackRateResponse> + + + + Releases a set of animations to no longer be manipulated. + + List of animation ids to seek. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Gets the remote object of the Animation. + + Animation id. + returns System.Threading.Tasks.Task<ResolveAnimationResponse> + + + + Seek a set of animations to a particular time within each animation. + + List of animation ids to seek. + Set the current time of each animation. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets the paused state of a set of animations. + + Animations to set the pause state of. + Paused state to set to. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets the playback rate of the document timeline. + + Playback rate for animations on page + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets the timing of an animation node. + + Animation id. + Duration of the animation. + Delay of the animation. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Information about a cookie that is affected by an inspector issue. + + + + + The following three properties uniquely identify a cookie + + + + + Path + + + + + Domain + + + + + Information about a request that is affected by an inspector issue. + + + + + The unique request id. + + + + + Url + + + + + Information about the frame affected by an inspector issue. + + + + + FrameId + + + + + CookieExclusionReason + + + + + ExcludeSameSiteUnspecifiedTreatedAsLax + + + + + ExcludeSameSiteNoneInsecure + + + + + ExcludeSameSiteLax + + + + + ExcludeSameSiteStrict + + + + + ExcludeInvalidSameParty + + + + + ExcludeSamePartyCrossPartyContext + + + + + ExcludeDomainNonASCII + + + + + ExcludeThirdPartyCookieBlockedInFirstPartySet + + + + + CookieWarningReason + + + + + WarnSameSiteUnspecifiedCrossSiteContext + + + + + WarnSameSiteNoneInsecure + + + + + WarnSameSiteUnspecifiedLaxAllowUnsafe + + + + + WarnSameSiteStrictLaxDowngradeStrict + + + + + WarnSameSiteStrictCrossDowngradeStrict + + + + + WarnSameSiteStrictCrossDowngradeLax + + + + + WarnSameSiteLaxCrossDowngradeStrict + + + + + WarnSameSiteLaxCrossDowngradeLax + + + + + WarnAttributeValueExceedsMaxSize + + + + + WarnDomainNonASCII + + + + + CookieOperation + + + + + SetCookie + + + + + ReadCookie + + + + + This information is currently necessary, as the front-end has a difficult + time finding a specific cookie. With this, we can convey specific error + information without the cookie. + + + + + If AffectedCookie is not set then rawCookieLine contains the raw + Set-Cookie header string. This hints at a problem where the + cookie line is syntactically or semantically malformed in a way + that no valid cookie could be created. + + + + + RawCookieLine + + + + + CookieWarningReasons + + + + + CookieWarningReasons + + + + + CookieExclusionReasons + + + + + CookieExclusionReasons + + + + + Optionally identifies the site-for-cookies and the cookie url, which + may be used by the front-end as additional context. + + + + + Optionally identifies the site-for-cookies and the cookie url, which + may be used by the front-end as additional context. + + + + + SiteForCookies + + + + + CookieUrl + + + + + Request + + + + + MixedContentResolutionStatus + + + + + MixedContentBlocked + + + + + MixedContentAutomaticallyUpgraded + + + + + MixedContentWarning + + + + + MixedContentResourceType + + + + + AttributionSrc + + + + + Audio + + + + + Beacon + + + + + CSPReport + + + + + Download + + + + + EventSource + + + + + Favicon + + + + + Font + + + + + Form + + + + + Frame + + + + + Image + + + + + Import + + + + + Manifest + + + + + Ping + + + + + PluginData + + + + + PluginResource + + + + + Prefetch + + + + + Resource + + + + + Script + + + + + ServiceWorker + + + + + SharedWorker + + + + + Stylesheet + + + + + Track + + + + + Video + + + + + Worker + + + + + XMLHttpRequest + + + + + XSLT + + + + + MixedContentIssueDetails + + + + + The type of resource causing the mixed content issue (css, js, iframe, + form,...). Marked as optional because it is mapped to from + blink::mojom::RequestContextType, which will be replaced + by network::mojom::RequestDestination + + + + + The type of resource causing the mixed content issue (css, js, iframe, + form,...). Marked as optional because it is mapped to from + blink::mojom::RequestContextType, which will be replaced + by network::mojom::RequestDestination + + + + + The way the mixed content issue is being resolved. + + + + + The way the mixed content issue is being resolved. + + + + + The unsafe http url causing the mixed content issue. + + + + + The url responsible for the call to an unsafe url. + + + + + The mixed content request. + Does not always exist (e.g. for unsafe form submission urls). + + + + + Optional because not every mixed content issue is necessarily linked to a frame. + + + + + Enum indicating the reason a response has been blocked. These reasons are + refinements of the net error BLOCKED_BY_RESPONSE. + + + + + CoepFrameResourceNeedsCoepHeader + + + + + CoopSandboxedIFrameCannotNavigateToCoopPage + + + + + CorpNotSameOrigin + + + + + CorpNotSameOriginAfterDefaultedToSameOriginByCoep + + + + + CorpNotSameSite + + + + + Details for a request that has been blocked with the BLOCKED_BY_RESPONSE + code. Currently only used for COEP/COOP, but may be extended to include + some CSP errors in the future. + + + + + Request + + + + + ParentFrame + + + + + BlockedFrame + + + + + Reason + + + + + Reason + + + + + HeavyAdResolutionStatus + + + + + HeavyAdBlocked + + + + + HeavyAdWarning + + + + + HeavyAdReason + + + + + NetworkTotalLimit + + + + + CpuTotalLimit + + + + + CpuPeakLimit + + + + + HeavyAdIssueDetails + + + + + The resolution status, either blocking the content or warning. + + + + + The resolution status, either blocking the content or warning. + + + + + The reason the ad was blocked, total network or cpu or peak cpu. + + + + + The reason the ad was blocked, total network or cpu or peak cpu. + + + + + The frame that was blocked. + + + + + ContentSecurityPolicyViolationType + + + + + kInlineViolation + + + + + kEvalViolation + + + + + kURLViolation + + + + + kTrustedTypesSinkViolation + + + + + kTrustedTypesPolicyViolation + + + + + kWasmEvalViolation + + + + + SourceCodeLocation + + + + + ScriptId + + + + + Url + + + + + LineNumber + + + + + ColumnNumber + + + + + ContentSecurityPolicyIssueDetails + + + + + The url not included in allowed sources. + + + + + Specific directive that is violated, causing the CSP issue. + + + + + IsReportOnly + + + + + ContentSecurityPolicyViolationType + + + + + ContentSecurityPolicyViolationType + + + + + FrameAncestor + + + + + SourceCodeLocation + + + + + ViolatingNodeId + + + + + SharedArrayBufferIssueType + + + + + TransferIssue + + + + + CreationIssue + + + + + Details for a issue arising from an SAB being instantiated in, or + transferred to a context that is not cross-origin isolated. + + + + + SourceCodeLocation + + + + + IsWarning + + + + + Type + + + + + Type + + + + + TwaQualityEnforcementViolationType + + + + + kHttpError + + + + + kUnavailableOffline + + + + + kDigitalAssetLinks + + + + + TrustedWebActivityIssueDetails + + + + + The url that triggers the violation. + + + + + ViolationType + + + + + ViolationType + + + + + HttpStatusCode + + + + + The package name of the Trusted Web Activity client app. This field is + only used when violation type is kDigitalAssetLinks. + + + + + The signature of the Trusted Web Activity client app. This field is only + used when violation type is kDigitalAssetLinks. + + + + + LowTextContrastIssueDetails + + + + + ViolatingNodeId + + + + + ViolatingNodeSelector + + + + + ContrastRatio + + + + + ThresholdAA + + + + + ThresholdAAA + + + + + FontSize + + + + + FontWeight + + + + + Details for a CORS related issue, e.g. a warning or error related to + CORS RFC1918 enforcement. + + + + + CorsErrorStatus + + + + + IsWarning + + + + + Request + + + + + Location + + + + + InitiatorOrigin + + + + + ResourceIPAddressSpace + + + + + ResourceIPAddressSpace + + + + + ClientSecurityState + + + + + AttributionReportingIssueType + + + + + PermissionPolicyDisabled + + + + + UntrustworthyReportingOrigin + + + + + InsecureContext + + + + + InvalidHeader + + + + + InvalidRegisterTriggerHeader + + + + + InvalidEligibleHeader + + + + + TooManyConcurrentRequests + + + + + SourceAndTriggerHeaders + + + + + SourceIgnored + + + + + TriggerIgnored + + + + + OsSourceIgnored + + + + + OsTriggerIgnored + + + + + InvalidRegisterOsSourceHeader + + + + + InvalidRegisterOsTriggerHeader + + + + + WebAndOsHeaders + + + + + Details for issues around "Attribution Reporting API" usage. + Explainer: https://github.com/WICG/attribution-reporting-api + + + + + ViolationType + + + + + ViolationType + + + + + Request + + + + + ViolatingNodeId + + + + + InvalidParameter + + + + + Details for issues about documents in Quirks Mode + or Limited Quirks Mode that affects page layouting. + + + + + If false, it means the document's mode is "quirks" + instead of "limited-quirks". + + + + + DocumentNodeId + + + + + Url + + + + + FrameId + + + + + LoaderId + + + + + NavigatorUserAgentIssueDetails + + + + + Url + + + + + Location + + + + + GenericIssueErrorType + + + + + CrossOriginPortalPostMessageError + + + + + FormLabelForNameError + + + + + FormDuplicateIdForInputError + + + + + FormInputWithNoLabelError + + + + + FormAutocompleteAttributeEmptyError + + + + + FormEmptyIdAndNameAttributesForInputError + + + + + FormAriaLabelledByToNonExistingId + + + + + FormInputAssignedAutocompleteValueToIdOrNameAttributeError + + + + + FormLabelHasNeitherForNorNestedInput + + + + + FormLabelForMatchesNonExistingIdError + + + + + FormInputHasWrongButWellIntendedAutocompleteValueError + + + + + Depending on the concrete errorType, different properties are set. + + + + + Issues with the same errorType are aggregated in the frontend. + + + + + Issues with the same errorType are aggregated in the frontend. + + + + + FrameId + + + + + ViolatingNodeId + + + + + This issue tracks information needed to print a deprecation message. + https://source.chromium.org/chromium/chromium/src/+/main:third_party/blink/renderer/core/frame/third_party/blink/renderer/core/frame/deprecation/README.md + + + + + AffectedFrame + + + + + SourceCodeLocation + + + + + One of the deprecation names from third_party/blink/renderer/core/frame/deprecation/deprecation.json5 + + + + + ClientHintIssueReason + + + + + MetaTagAllowListInvalidOrigin + + + + + MetaTagModifiedHTML + + + + + FederatedAuthRequestIssueDetails + + + + + FederatedAuthRequestIssueReason + + + + + FederatedAuthRequestIssueReason + + + + + Represents the failure reason when a federated authentication reason fails. + Should be updated alongside RequestIdTokenStatus in + third_party/blink/public/mojom/devtools/inspector_issue.mojom to include + all cases except for success. + + + + + ShouldEmbargo + + + + + TooManyRequests + + + + + WellKnownHttpNotFound + + + + + WellKnownNoResponse + + + + + WellKnownInvalidResponse + + + + + WellKnownListEmpty + + + + + ConfigNotInWellKnown + + + + + WellKnownTooBig + + + + + ConfigHttpNotFound + + + + + ConfigNoResponse + + + + + ConfigInvalidResponse + + + + + ClientMetadataHttpNotFound + + + + + ClientMetadataNoResponse + + + + + ClientMetadataInvalidResponse + + + + + DisabledInSettings + + + + + ErrorFetchingSignin + + + + + InvalidSigninResponse + + + + + AccountsHttpNotFound + + + + + AccountsNoResponse + + + + + AccountsInvalidResponse + + + + + AccountsListEmpty + + + + + IdTokenHttpNotFound + + + + + IdTokenNoResponse + + + + + IdTokenInvalidResponse + + + + + IdTokenInvalidRequest + + + + + ErrorIdToken + + + + + Canceled + + + + + RpPageNotVisible + + + + + This issue tracks client hints related issues. It's used to deprecate old + features, encourage the use of new ones, and provide general guidance. + + + + + SourceCodeLocation + + + + + ClientHintIssueReason + + + + + ClientHintIssueReason + + + + + A unique identifier for the type of issue. Each type may use one of the + optional fields in InspectorIssueDetails to convey more specific + information about the kind of issue. + + + + + CookieIssue + + + + + MixedContentIssue + + + + + BlockedByResponseIssue + + + + + HeavyAdIssue + + + + + ContentSecurityPolicyIssue + + + + + SharedArrayBufferIssue + + + + + TrustedWebActivityIssue + + + + + LowTextContrastIssue + + + + + CorsIssue + + + + + AttributionReportingIssue + + + + + QuirksModeIssue + + + + + NavigatorUserAgentIssue + + + + + GenericIssue + + + + + DeprecationIssue + + + + + ClientHintIssue + + + + + FederatedAuthRequestIssue + + + + + This struct holds a list of optional fields with additional information + specific to the kind of issue. When adding a new issue code, please also + add a new optional field to this type. + + + + + CookieIssueDetails + + + + + MixedContentIssueDetails + + + + + BlockedByResponseIssueDetails + + + + + HeavyAdIssueDetails + + + + + ContentSecurityPolicyIssueDetails + + + + + SharedArrayBufferIssueDetails + + + + + TwaQualityEnforcementDetails + + + + + LowTextContrastIssueDetails + + + + + CorsIssueDetails + + + + + AttributionReportingIssueDetails + + + + + QuirksModeIssueDetails + + + + + NavigatorUserAgentIssueDetails + + + + + GenericIssueDetails + + + + + DeprecationIssueDetails + + + + + ClientHintIssueDetails + + + + + FederatedAuthRequestIssueDetails + + + + + An inspector issue reported from the back-end. + + + + + Code + + + + + Code + + + + + Details + + + + + A unique id for this issue. May be omitted if no other entity (e.g. + exception, CDP message, etc.) is referencing this issue. + + + + + issueAdded + + + + + Issue + + + + + GetEncodedResponseResponse + + + + + body + + + + + originalSize + + + + + encodedSize + + + + + The encoding to use. + + + + + webp + + + + + jpeg + + + + + png + + + + + Audits domain allows investigation of page violations and possible improvements. + + + + + Audits + + DevToolsClient + + + + IssueAdded + + + + + Returns the response body and size if it were re-encoded with the specified settings. Only + applies to images. + + Identifier of the network request to get content for. + The encoding to use. + The quality of the encoding (0-1). (defaults to 1) + Whether to only return the size information (defaults to false). + returns System.Threading.Tasks.Task<GetEncodedResponseResponse> + + + + Disables issues domain, prevents further issues from being reported to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables issues domain, sends the issues collected so far to the client by means of the + `issueAdded` event. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Runs the contrast check for the target page. Found issues are reported + using Audits.issueAdded event. + + Whether to report WCAG AAA level issues. Default is false. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + The Background Service that will be associated with the commands/events. + Every Background Service operates independently, but they share the same + API. + + + + + backgroundFetch + + + + + backgroundSync + + + + + pushMessaging + + + + + notifications + + + + + paymentHandler + + + + + periodicBackgroundSync + + + + + A key-value pair for additional event information to pass along. + + + + + Key + + + + + Value + + + + + BackgroundServiceEvent + + + + + Timestamp of the event (in seconds). + + + + + The origin this event belongs to. + + + + + The Service Worker ID that initiated the event. + + + + + The Background Service this event belongs to. + + + + + The Background Service this event belongs to. + + + + + A description of the event. + + + + + An identifier that groups related events together. + + + + + A list of event-specific information. + + + + + Storage key this event belongs to. + + + + + Called when the recording state for the service has been updated. + + + + + IsRecording + + + + + Service + + + + + Service + + + + + Called with all existing backgroundServiceEvents when enabled, and all new + events afterwards if enabled and recording. + + + + + BackgroundServiceEvent + + + + + Defines events for background web platform features. + + + + + BackgroundService + + DevToolsClient + + + + Called when the recording state for the service has been updated. + + + + + Called with all existing backgroundServiceEvents when enabled, and all new + events afterwards if enabled and recording. + + + + + Enables event updates for the service. + + service + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables event updates for the service. + + service + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Set the recording state for the service. + + shouldRecord + service + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears all stored data for the service. + + service + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + The state of the browser window. + + + + + normal + + + + + minimized + + + + + maximized + + + + + fullscreen + + + + + Browser window bounds information + + + + + The offset from the left edge of the screen to the window in pixels. + + + + + The offset from the top edge of the screen to the window in pixels. + + + + + The window width in pixels. + + + + + The window height in pixels. + + + + + The window state. Default to normal. + + + + + The window state. Default to normal. + + + + + PermissionType + + + + + accessibilityEvents + + + + + audioCapture + + + + + backgroundSync + + + + + backgroundFetch + + + + + clipboardReadWrite + + + + + clipboardSanitizedWrite + + + + + displayCapture + + + + + durableStorage + + + + + flash + + + + + geolocation + + + + + idleDetection + + + + + localFonts + + + + + midi + + + + + midiSysex + + + + + nfc + + + + + notifications + + + + + paymentHandler + + + + + periodicBackgroundSync + + + + + protectedMediaIdentifier + + + + + sensors + + + + + storageAccess + + + + + topLevelStorageAccess + + + + + videoCapture + + + + + videoCapturePanTiltZoom + + + + + wakeLockScreen + + + + + wakeLockSystem + + + + + windowManagement + + + + + PermissionSetting + + + + + granted + + + + + denied + + + + + prompt + + + + + Definition of PermissionDescriptor defined in the Permissions API: + https://w3c.github.io/permissions/#dictdef-permissiondescriptor. + + + + + Name of permission. + See https://cs.chromium.org/chromium/src/third_party/blink/renderer/modules/permissions/permission_descriptor.idl for valid permission names. + + + + + For "midi" permission, may also specify sysex control. + + + + + For "push" permission, may specify userVisibleOnly. + Note that userVisibleOnly = true is the only currently supported type. + + + + + For "clipboard" permission, may specify allowWithoutSanitization. + + + + + For "camera" permission, may specify panTiltZoom. + + + + + Browser command ids used by executeBrowserCommand. + + + + + openTabSearch + + + + + closeTabSearch + + + + + Chrome histogram bucket. + + + + + Minimum value (inclusive). + + + + + Maximum value (exclusive). + + + + + Number of samples. + + + + + Chrome histogram. + + + + + Name. + + + + + Sum of sample values. + + + + + Total number of samples. + + + + + Buckets. + + + + + Fired when page is about to start a download. + + + + + Id of the frame that caused the download to begin. + + + + + Global unique identifier of the download. + + + + + URL of the resource being downloaded. + + + + + Suggested file name of the resource (the actual name of the file saved on disk may differ). + + + + + Download status. + + + + + inProgress + + + + + completed + + + + + canceled + + + + + Fired when download makes progress. Last call has |done| == true. + + + + + Global unique identifier of the download. + + + + + Total expected bytes to download. + + + + + Total bytes received. + + + + + Download status. + + + + + Download status. + + + + + GetVersionResponse + + + + + protocolVersion + + + + + product + + + + + revision + + + + + userAgent + + + + + jsVersion + + + + + GetBrowserCommandLineResponse + + + + + arguments + + + + + GetHistogramsResponse + + + + + histograms + + + + + GetHistogramResponse + + + + + histogram + + + + + GetWindowBoundsResponse + + + + + bounds + + + + + GetWindowForTargetResponse + + + + + windowId + + + + + bounds + + + + + Whether to allow all or deny all download requests, or use default Chrome behavior if + available (otherwise deny). |allowAndName| allows download and names files according to + their dowmload guids. + + + + + deny + + + + + allow + + + + + allowAndName + + + + + default + + + + + The Browser domain defines methods and events for browser managing. + + + + + Browser + + DevToolsClient + + + + Fired when page is about to start a download. + + + + + Fired when download makes progress. Last call has |done| == true. + + + + + Set permission settings for given origin. + + Descriptor of permission to override. + Setting of the permission. + Origin the permission applies to, all origins if not specified. + Context to override. When omitted, default browser context is used. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Grant specific permissions to the given origin and reject all others. + + permissions + Origin the permission applies to, all origins if not specified. + BrowserContext to override permissions. When omitted, default browser context is used. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Reset all permission management for all origins. + + BrowserContext to reset permissions. When omitted, default browser context is used. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Set the behavior when downloading a file. + + Whether to allow all or deny all download requests, or use default Chrome behavior ifavailable (otherwise deny). |allowAndName| allows download and names files according totheir dowmload guids. + BrowserContext to set download behavior. When omitted, default browser context is used. + The default path to save downloaded files to. This is required if behavior is set to 'allow'or 'allowAndName'. + Whether to emit download events (defaults to false). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Cancel a download if in progress + + Global unique identifier of the download. + BrowserContext to perform the action in. When omitted, default browser context is used. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Close browser gracefully. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Crashes browser on the main thread. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Crashes GPU process. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns version information. + + returns System.Threading.Tasks.Task<GetVersionResponse> + + + + Returns the command line switches for the browser process if, and only if + --enable-automation is on the commandline. + + returns System.Threading.Tasks.Task<GetBrowserCommandLineResponse> + + + + Get Chrome histograms. + + Requested substring in name. Only histograms which have query as asubstring in their name are extracted. An empty or absent query returnsall histograms. + If true, retrieve delta since last delta call. + returns System.Threading.Tasks.Task<GetHistogramsResponse> + + + + Get a Chrome histogram by name. + + Requested histogram name. + If true, retrieve delta since last delta call. + returns System.Threading.Tasks.Task<GetHistogramResponse> + + + + Get position and size of the browser window. + + Browser window id. + returns System.Threading.Tasks.Task<GetWindowBoundsResponse> + + + + Get the browser window that contains the devtools target. + + Devtools agent host id. If called as a part of the session, associated targetId is used. + returns System.Threading.Tasks.Task<GetWindowForTargetResponse> + + + + Set position and/or size of the browser window. + + Browser window id. + New window bounds. The 'minimized', 'maximized' and 'fullscreen' states cannot be combinedwith 'left', 'top', 'width' or 'height'. Leaves unspecified fields unchanged. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Set dock tile details, platform-specific. + + badgeLabel + Png encoded image. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Invoke custom browser commands used by telemetry. + + commandId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stylesheet type: "injected" for stylesheets injected via extension, "user-agent" for user-agent + stylesheets, "inspector" for stylesheets created by the inspector (i.e. those holding the "via + inspector" rules), "regular" for regular stylesheets. + + + + + injected + + + + + user-agent + + + + + inspector + + + + + regular + + + + + CSS rule collection for a single pseudo style. + + + + + Pseudo element type. + + + + + Pseudo element type. + + + + + Pseudo element custom ident. + + + + + Matches of CSS rules applicable to the pseudo style. + + + + + Inherited CSS rule collection from ancestor node. + + + + + The ancestor node's inline style, if any, in the style inheritance chain. + + + + + Matches of CSS rules matching the ancestor node in the style inheritance chain. + + + + + Inherited pseudo element matches from pseudos of an ancestor node. + + + + + Matches of pseudo styles from the pseudos of an ancestor node. + + + + + Match data for a CSS rule. + + + + + CSS rule in the match. + + + + + Matching selector indices in the rule's selectorList selectors (0-based). + + + + + Data for a simple selector (these are delimited by commas in a selector list). + + + + + Value text. + + + + + Value range in the underlying resource (if available). + + + + + Selector list data. + + + + + Selectors in the list. + + + + + Rule selector text. + + + + + CSS stylesheet metainformation. + + + + + The stylesheet identifier. + + + + + Owner frame identifier. + + + + + Stylesheet resource URL. Empty if this is a constructed stylesheet created using + new CSSStyleSheet() (but non-empty if this is a constructed sylesheet imported + as a CSS module script). + + + + + URL of source map associated with the stylesheet (if any). + + + + + Stylesheet origin. + + + + + Stylesheet origin. + + + + + Stylesheet title. + + + + + The backend id for the owner node of the stylesheet. + + + + + Denotes whether the stylesheet is disabled. + + + + + Whether the sourceURL field value comes from the sourceURL comment. + + + + + Whether this stylesheet is created for STYLE tag by parser. This flag is not set for + document.written STYLE tags. + + + + + Whether this stylesheet is mutable. Inline stylesheets become mutable + after they have been modified via CSSOM API. + <link> element's stylesheets become mutable only if DevTools modifies them. + Constructed stylesheets (new CSSStyleSheet()) are mutable immediately after creation. + + + + + True if this stylesheet is created through new CSSStyleSheet() or imported as a + CSS module script. + + + + + Line offset of the stylesheet within the resource (zero based). + + + + + Column offset of the stylesheet within the resource (zero based). + + + + + Size of the content (in characters). + + + + + Line offset of the end of the stylesheet within the resource (zero based). + + + + + Column offset of the end of the stylesheet within the resource (zero based). + + + + + CSS rule representation. + + + + + The css style sheet identifier (absent for user agent stylesheet and user-specified + stylesheet rules) this rule came from. + + + + + Rule selector data. + + + + + Array of selectors from ancestor style rules, sorted by distance from the current rule. + + + + + Parent stylesheet's origin. + + + + + Parent stylesheet's origin. + + + + + Associated style declaration. + + + + + Media list array (for rules involving media queries). The array enumerates media queries + starting with the innermost one, going outwards. + + + + + Container query list array (for rules involving container queries). + The array enumerates container queries starting with the innermost one, going outwards. + + + + + @supports CSS at-rule array. + The array enumerates @supports at-rules starting with the innermost one, going outwards. + + + + + Cascade layer array. Contains the layer hierarchy that this rule belongs to starting + with the innermost layer and going outwards. + + + + + @scope CSS at-rule array. + The array enumerates @scope at-rules starting with the innermost one, going outwards. + + + + + CSS coverage information. + + + + + The css style sheet identifier (absent for user agent stylesheet and user-specified + stylesheet rules) this rule came from. + + + + + Offset of the start of the rule (including selector) from the beginning of the stylesheet. + + + + + Offset of the end of the rule body from the beginning of the stylesheet. + + + + + Indicates whether the rule was actually used by some element in the page. + + + + + Text range within a resource. All numbers are zero-based. + + + + + Start line of range. + + + + + Start column of range (inclusive). + + + + + End line of range + + + + + End column of range (exclusive). + + + + + ShorthandEntry + + + + + Shorthand name. + + + + + Shorthand value. + + + + + Whether the property has "!important" annotation (implies `false` if absent). + + + + + CSSComputedStyleProperty + + + + + Computed style property name. + + + + + Computed style property value. + + + + + CSS style representation. + + + + + The css style sheet identifier (absent for user agent stylesheet and user-specified + stylesheet rules) this rule came from. + + + + + CSS properties in the style. + + + + + Computed values for all shorthands found in the style. + + + + + Style declaration text (if available). + + + + + Style declaration range in the enclosing stylesheet (if available). + + + + + CSS property declaration data. + + + + + The property name. + + + + + The property value. + + + + + Whether the property has "!important" annotation (implies `false` if absent). + + + + + Whether the property is implicit (implies `false` if absent). + + + + + The full property text as specified in the style. + + + + + Whether the property is understood by the browser (implies `true` if absent). + + + + + Whether the property is disabled by the user (present for source-based properties only). + + + + + The entire property range in the enclosing style declaration (if available). + + + + + Parsed longhand components of this property if it is a shorthand. + This field will be empty if the given property is not a shorthand. + + + + + Source of the media query: "mediaRule" if specified by a @media rule, "importRule" if + specified by an @import rule, "linkedSheet" if specified by a "media" attribute in a linked + stylesheet's LINK tag, "inlineSheet" if specified by a "media" attribute in an inline + stylesheet's STYLE tag. + + + + + mediaRule + + + + + importRule + + + + + linkedSheet + + + + + inlineSheet + + + + + CSS media rule descriptor. + + + + + Media query text. + + + + + Source of the media query: "mediaRule" if specified by a @media rule, "importRule" if + specified by an @import rule, "linkedSheet" if specified by a "media" attribute in a linked + stylesheet's LINK tag, "inlineSheet" if specified by a "media" attribute in an inline + stylesheet's STYLE tag. + + + + + Source of the media query: "mediaRule" if specified by a @media rule, "importRule" if + specified by an @import rule, "linkedSheet" if specified by a "media" attribute in a linked + stylesheet's LINK tag, "inlineSheet" if specified by a "media" attribute in an inline + stylesheet's STYLE tag. + + + + + URL of the document containing the media query description. + + + + + The associated rule (@media or @import) header range in the enclosing stylesheet (if + available). + + + + + Identifier of the stylesheet containing this object (if exists). + + + + + Array of media queries. + + + + + Media query descriptor. + + + + + Array of media query expressions. + + + + + Whether the media query condition is satisfied. + + + + + Media query expression descriptor. + + + + + Media query expression value. + + + + + Media query expression units. + + + + + Media query expression feature. + + + + + The associated range of the value text in the enclosing stylesheet (if available). + + + + + Computed length of media query expression (if applicable). + + + + + CSS container query rule descriptor. + + + + + Container query text. + + + + + The associated rule header range in the enclosing stylesheet (if + available). + + + + + Identifier of the stylesheet containing this object (if exists). + + + + + Optional name for the container. + + + + + Optional physical axes queried for the container. + + + + + Optional physical axes queried for the container. + + + + + Optional logical axes queried for the container. + + + + + Optional logical axes queried for the container. + + + + + CSS Supports at-rule descriptor. + + + + + Supports rule text. + + + + + Whether the supports condition is satisfied. + + + + + The associated rule header range in the enclosing stylesheet (if + available). + + + + + Identifier of the stylesheet containing this object (if exists). + + + + + CSS Scope at-rule descriptor. + + + + + Scope rule text. + + + + + The associated rule header range in the enclosing stylesheet (if + available). + + + + + Identifier of the stylesheet containing this object (if exists). + + + + + CSS Layer at-rule descriptor. + + + + + Layer name. + + + + + The associated rule header range in the enclosing stylesheet (if + available). + + + + + Identifier of the stylesheet containing this object (if exists). + + + + + CSS Layer data. + + + + + Layer name. + + + + + Direct sub-layers + + + + + Layer order. The order determines the order of the layer in the cascade order. + A higher number has higher priority in the cascade order. + + + + + Information about amount of glyphs that were rendered with given font. + + + + + Font's family name reported by platform. + + + + + Indicates if the font was downloaded or resolved locally. + + + + + Amount of glyphs that were rendered with this font. + + + + + Information about font variation axes for variable fonts + + + + + The font-variation-setting tag (a.k.a. "axis tag"). + + + + + Human-readable variation name in the default language (normally, "en"). + + + + + The minimum value (inclusive) the font supports for this tag. + + + + + The maximum value (inclusive) the font supports for this tag. + + + + + The default value. + + + + + Properties of a web font: https://www.w3.org/TR/2008/REC-CSS2-20080411/fonts.html#font-descriptions + and additional information such as platformFontFamily and fontVariationAxes. + + + + + The font-family. + + + + + The font-style. + + + + + The font-variant. + + + + + The font-weight. + + + + + The font-stretch. + + + + + The font-display. + + + + + The unicode-range. + + + + + The src. + + + + + The resolved platform font family + + + + + Available variation settings (a.k.a. "axes"). + + + + + CSS keyframes rule representation. + + + + + Animation name. + + + + + List of keyframes. + + + + + CSS keyframe rule representation. + + + + + The css style sheet identifier (absent for user agent stylesheet and user-specified + stylesheet rules) this rule came from. + + + + + Parent stylesheet's origin. + + + + + Parent stylesheet's origin. + + + + + Associated key text. + + + + + Associated style declaration. + + + + + A descriptor of operation to mutate style declaration text. + + + + + The css style sheet identifier. + + + + + The range of the style text in the enclosing stylesheet. + + + + + New style text. + + + + + Fires whenever a web font is updated. A non-empty font parameter indicates a successfully loaded + web font. + + + + + The web font that has loaded. + + + + + Fired whenever an active document stylesheet is added. + + + + + Added stylesheet metainfo. + + + + + Fired whenever a stylesheet is changed as a result of the client operation. + + + + + StyleSheetId + + + + + Fired whenever an active document stylesheet is removed. + + + + + Identifier of the removed stylesheet. + + + + + AddRuleResponse + + + + + rule + + + + + CollectClassNamesResponse + + + + + classNames + + + + + CreateStyleSheetResponse + + + + + styleSheetId + + + + + GetBackgroundColorsResponse + + + + + backgroundColors + + + + + computedFontSize + + + + + computedFontWeight + + + + + GetComputedStyleForNodeResponse + + + + + computedStyle + + + + + GetInlineStylesForNodeResponse + + + + + inlineStyle + + + + + attributesStyle + + + + + GetMatchedStylesForNodeResponse + + + + + inlineStyle + + + + + attributesStyle + + + + + matchedCSSRules + + + + + pseudoElements + + + + + inherited + + + + + inheritedPseudoElements + + + + + cssKeyframesRules + + + + + parentLayoutNodeId + + + + + GetMediaQueriesResponse + + + + + medias + + + + + GetPlatformFontsForNodeResponse + + + + + fonts + + + + + GetStyleSheetTextResponse + + + + + text + + + + + GetLayersForNodeResponse + + + + + rootLayer + + + + + TakeComputedStyleUpdatesResponse + + + + + nodeIds + + + + + SetKeyframeKeyResponse + + + + + keyText + + + + + SetMediaTextResponse + + + + + media + + + + + SetContainerQueryTextResponse + + + + + containerQuery + + + + + SetSupportsTextResponse + + + + + supports + + + + + SetScopeTextResponse + + + + + scope + + + + + SetRuleSelectorResponse + + + + + selectorList + + + + + SetStyleSheetTextResponse + + + + + sourceMapURL + + + + + SetStyleTextsResponse + + + + + styles + + + + + StopRuleUsageTrackingResponse + + + + + ruleUsage + + + + + TakeCoverageDeltaResponse + + + + + coverage + + + + + timestamp + + + + + This domain exposes CSS read/write operations. All CSS objects (stylesheets, rules, and styles) + have an associated `id` used in subsequent operations on the related object. Each object type has + a specific `id` structure, and those are not interchangeable between objects of different kinds. + CSS objects can be loaded using the `get*ForNode()` calls (which accept a DOM node id). A client + can also keep track of stylesheets via the `styleSheetAdded`/`styleSheetRemoved` events and + subsequently load the required stylesheet contents using the `getStyleSheet[Text]()` methods. + + + + + CSS + + DevToolsClient + + + + Fires whenever a web font is updated. A non-empty font parameter indicates a successfully loaded + web font. + + + + + Fires whenever a MediaQuery result changes (for example, after a browser window has been + resized.) The current implementation considers only viewport-dependent media features. + + + + + Fired whenever an active document stylesheet is added. + + + + + Fired whenever a stylesheet is changed as a result of the client operation. + + + + + Fired whenever an active document stylesheet is removed. + + + + + Inserts a new rule with the given `ruleText` in a stylesheet with given `styleSheetId`, at the + position specified by `location`. + + The css style sheet identifier where a new rule should be inserted. + The text of a new rule. + Text position of a new rule in the target style sheet. + returns System.Threading.Tasks.Task<AddRuleResponse> + + + + Returns all class names from specified stylesheet. + + styleSheetId + returns System.Threading.Tasks.Task<CollectClassNamesResponse> + + + + Creates a new special "via-inspector" stylesheet in the frame with given `frameId`. + + Identifier of the frame where "via-inspector" stylesheet should be created. + returns System.Threading.Tasks.Task<CreateStyleSheetResponse> + + + + Disables the CSS agent for the given page. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables the CSS agent for the given page. Clients should not assume that the CSS agent has been + enabled until the result of this command is received. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Ensures that the given node will have specified pseudo-classes whenever its style is computed by + the browser. + + The element id for which to force the pseudo state. + Element pseudo classes to force when computing the element's style. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + GetBackgroundColors + + Id of the node to get background colors for. + returns System.Threading.Tasks.Task<GetBackgroundColorsResponse> + + + + Returns the computed style for a DOM node identified by `nodeId`. + + nodeId + returns System.Threading.Tasks.Task<GetComputedStyleForNodeResponse> + + + + Returns the styles defined inline (explicitly in the "style" attribute and implicitly, using DOM + attributes) for a DOM node identified by `nodeId`. + + nodeId + returns System.Threading.Tasks.Task<GetInlineStylesForNodeResponse> + + + + Returns requested styles for a DOM node identified by `nodeId`. + + nodeId + returns System.Threading.Tasks.Task<GetMatchedStylesForNodeResponse> + + + + Returns all media queries parsed by the rendering engine. + + returns System.Threading.Tasks.Task<GetMediaQueriesResponse> + + + + Requests information about platform fonts which we used to render child TextNodes in the given + node. + + nodeId + returns System.Threading.Tasks.Task<GetPlatformFontsForNodeResponse> + + + + Returns the current textual content for a stylesheet. + + styleSheetId + returns System.Threading.Tasks.Task<GetStyleSheetTextResponse> + + + + Returns all layers parsed by the rendering engine for the tree scope of a node. + Given a DOM element identified by nodeId, getLayersForNode returns the root + layer for the nearest ancestor document or shadow root. The layer root contains + the full layer tree for the tree scope and their ordering. + + nodeId + returns System.Threading.Tasks.Task<GetLayersForNodeResponse> + + + + Starts tracking the given computed styles for updates. The specified array of properties + replaces the one previously specified. Pass empty array to disable tracking. + Use takeComputedStyleUpdates to retrieve the list of nodes that had properties modified. + The changes to computed style properties are only tracked for nodes pushed to the front-end + by the DOM agent. If no changes to the tracked properties occur after the node has been pushed + to the front-end, no updates will be issued for the node. + + propertiesToTrack + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Polls the next batch of computed style updates. + + returns System.Threading.Tasks.Task<TakeComputedStyleUpdatesResponse> + + + + Find a rule with the given active property for the given node and set the new value for this + property + + The element id for which to set property. + propertyName + value + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Modifies the keyframe rule key text. + + styleSheetId + range + keyText + returns System.Threading.Tasks.Task<SetKeyframeKeyResponse> + + + + Modifies the rule selector. + + styleSheetId + range + text + returns System.Threading.Tasks.Task<SetMediaTextResponse> + + + + Modifies the expression of a container query. + + styleSheetId + range + text + returns System.Threading.Tasks.Task<SetContainerQueryTextResponse> + + + + Modifies the expression of a supports at-rule. + + styleSheetId + range + text + returns System.Threading.Tasks.Task<SetSupportsTextResponse> + + + + Modifies the expression of a scope at-rule. + + styleSheetId + range + text + returns System.Threading.Tasks.Task<SetScopeTextResponse> + + + + Modifies the rule selector. + + styleSheetId + range + selector + returns System.Threading.Tasks.Task<SetRuleSelectorResponse> + + + + Sets the new stylesheet text. + + styleSheetId + text + returns System.Threading.Tasks.Task<SetStyleSheetTextResponse> + + + + Applies specified style edits one after another in the given order. + + edits + returns System.Threading.Tasks.Task<SetStyleTextsResponse> + + + + Enables the selector recording. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stop tracking rule usage and return the list of rules that were used since last call to + `takeCoverageDelta` (or since start of coverage instrumentation). + + returns System.Threading.Tasks.Task<StopRuleUsageTrackingResponse> + + + + Obtain list of rules that became used since last call to this method (or since start of coverage + instrumentation). + + returns System.Threading.Tasks.Task<TakeCoverageDeltaResponse> + + + + Enables/disables rendering of local CSS fonts (enabled by default). + + Whether rendering of local fonts is enabled. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + type of HTTP response cached + + + + + basic + + + + + cors + + + + + default + + + + + error + + + + + opaqueResponse + + + + + opaqueRedirect + + + + + Data entry. + + + + + Request URL. + + + + + Request method. + + + + + Request headers + + + + + Number of seconds since epoch. + + + + + HTTP response status code. + + + + + HTTP response status text. + + + + + HTTP response type + + + + + HTTP response type + + + + + Response headers + + + + + Cache identifier. + + + + + An opaque unique id of the cache. + + + + + Security origin of the cache. + + + + + Storage key of the cache. + + + + + The name of the cache. + + + + + Header + + + + + Name + + + + + Value + + + + + Cached response + + + + + Entry content, base64-encoded. + + + + + RequestCacheNamesResponse + + + + + caches + + + + + RequestCachedResponseResponse + + + + + response + + + + + RequestEntriesResponse + + + + + cacheDataEntries + + + + + returnCount + + + + + CacheStorage + + + + + CacheStorage + + DevToolsClient + + + + Deletes a cache. + + Id of cache for deletion. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Deletes a cache entry. + + Id of cache where the entry will be deleted. + URL spec of the request. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests cache names. + + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<RequestCacheNamesResponse> + + + + Fetches cache entry. + + Id of cache that contains the entry. + URL spec of the request. + headers of the request. + returns System.Threading.Tasks.Task<RequestCachedResponseResponse> + + + + Requests data from cache. + + ID of cache to get entries from. + Number of records to skip. + Number of records to fetch. + If present, only return the entries containing this substring in the path + returns System.Threading.Tasks.Task<RequestEntriesResponse> + + + + Sink + + + + + Name + + + + + Id + + + + + Text describing the current session. Present only if there is an active + session on the sink. + + + + + This is fired whenever the list of available sinks changes. A sink is a + device or a software surface that you can cast to. + + + + + Sinks + + + + + This is fired whenever the outstanding issue/error message changes. + |issueMessage| is empty if there is no issue. + + + + + IssueMessage + + + + + A domain for interacting with Cast, Presentation API, and Remote Playback API + functionalities. + + + + + Cast + + DevToolsClient + + + + This is fired whenever the list of available sinks changes. A sink is a + device or a software surface that you can cast to. + + + + + This is fired whenever the outstanding issue/error message changes. + |issueMessage| is empty if there is no issue. + + + + + Starts observing for sinks that can be used for tab mirroring, and if set, + sinks compatible with |presentationUrl| as well. When sinks are found, a + |sinksUpdated| event is fired. + Also starts observing for issue messages. When an issue is added or removed, + an |issueUpdated| event is fired. + + presentationUrl + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stops observing for sinks and issues. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets a sink to be used when the web page requests the browser to choose a + sink via Presentation API, Remote Playback API, or Cast SDK. + + sinkName + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Starts mirroring the desktop to the sink. + + sinkName + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Starts mirroring the tab to the sink. + + sinkName + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stops the active Cast session on the sink. + + sinkName + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Backend node with a friendly name. + + + + + `Node`'s nodeType. + + + + + `Node`'s nodeName. + + + + + BackendNodeId + + + + + Pseudo element type. + + + + + first-line + + + + + first-letter + + + + + before + + + + + after + + + + + marker + + + + + backdrop + + + + + selection + + + + + target-text + + + + + spelling-error + + + + + grammar-error + + + + + highlight + + + + + first-line-inherited + + + + + scrollbar + + + + + scrollbar-thumb + + + + + scrollbar-button + + + + + scrollbar-track + + + + + scrollbar-track-piece + + + + + scrollbar-corner + + + + + resizer + + + + + input-list-button + + + + + view-transition + + + + + view-transition-group + + + + + view-transition-image-pair + + + + + view-transition-old + + + + + view-transition-new + + + + + Shadow root type. + + + + + user-agent + + + + + open + + + + + closed + + + + + Document compatibility mode. + + + + + QuirksMode + + + + + LimitedQuirksMode + + + + + NoQuirksMode + + + + + ContainerSelector physical axes + + + + + Horizontal + + + + + Vertical + + + + + Both + + + + + ContainerSelector logical axes + + + + + Inline + + + + + Block + + + + + Both + + + + + DOM interaction is implemented in terms of mirror objects that represent the actual DOM nodes. + DOMNode is a base node mirror type. + + + + + Node identifier that is passed into the rest of the DOM messages as the `nodeId`. Backend + will only push node with given `id` once. It is aware of all requested nodes and will only + fire DOM events for nodes known to the client. + + + + + The id of the parent node if any. + + + + + The BackendNodeId for this node. + + + + + `Node`'s nodeType. + + + + + `Node`'s nodeName. + + + + + `Node`'s localName. + + + + + `Node`'s nodeValue. + + + + + Child count for `Container` nodes. + + + + + Child nodes of this node when requested with children. + + + + + Attributes of the `Element` node in the form of flat array `[name1, value1, name2, value2]`. + + + + + Document URL that `Document` or `FrameOwner` node points to. + + + + + Base URL that `Document` or `FrameOwner` node uses for URL completion. + + + + + `DocumentType`'s publicId. + + + + + `DocumentType`'s systemId. + + + + + `DocumentType`'s internalSubset. + + + + + `Document`'s XML version in case of XML documents. + + + + + `Attr`'s name. + + + + + `Attr`'s value. + + + + + Pseudo element type for this node. + + + + + Pseudo element type for this node. + + + + + Pseudo element identifier for this node. Only present if there is a + valid pseudoType. + + + + + Shadow root type. + + + + + Shadow root type. + + + + + Frame ID for frame owner elements. + + + + + Content document for frame owner elements. + + + + + Shadow root list for given element host. + + + + + Content document fragment for template elements. + + + + + Pseudo elements associated with this node. + + + + + Deprecated, as the HTML Imports API has been removed (crbug.com/937746). + This property used to return the imported document for the HTMLImport links. + The property is always undefined now. + + + + + Distributed nodes for given insertion point. + + + + + Whether the node is SVG. + + + + + CompatibilityMode + + + + + CompatibilityMode + + + + + AssignedSlot + + + + + A structure holding an RGBA color. + + + + + The red component, in the [0-255] range. + + + + + The green component, in the [0-255] range. + + + + + The blue component, in the [0-255] range. + + + + + The alpha component, in the [0-1] range (default: 1). + + + + + Box model. + + + + + Content box + + + + + Padding box + + + + + Border box + + + + + Margin box + + + + + Node width + + + + + Node height + + + + + Shape outside coordinates + + + + + CSS Shape Outside details. + + + + + Shape bounds + + + + + Shape coordinate details + + + + + Margin shape bounds + + + + + Rectangle. + + + + + X coordinate + + + + + Y coordinate + + + + + Rectangle width + + + + + Rectangle height + + + + + CSSComputedStyleProperty + + + + + Computed style property name. + + + + + Computed style property value. + + + + + Fired when `Element`'s attribute is modified. + + + + + Id of the node that has changed. + + + + + Attribute name. + + + + + Attribute value. + + + + + Fired when `Element`'s attribute is removed. + + + + + Id of the node that has changed. + + + + + A ttribute name. + + + + + Mirrors `DOMCharacterDataModified` event. + + + + + Id of the node that has changed. + + + + + New text value. + + + + + Fired when `Container`'s child node count has changed. + + + + + Id of the node that has changed. + + + + + New node count. + + + + + Mirrors `DOMNodeInserted` event. + + + + + Id of the node that has changed. + + + + + Id of the previous sibling. + + + + + Inserted node data. + + + + + Mirrors `DOMNodeRemoved` event. + + + + + Parent id. + + + + + Id of the node that has been removed. + + + + + Called when distribution is changed. + + + + + Insertion point where distributed nodes were updated. + + + + + Distributed nodes for given insertion point. + + + + + Fired when `Element`'s inline style is modified via a CSS property modification. + + + + + Ids of the nodes for which the inline styles have been invalidated. + + + + + Called when a pseudo element is added to an element. + + + + + Pseudo element's parent element id. + + + + + The added pseudo element. + + + + + Called when a pseudo element is removed from an element. + + + + + Pseudo element's parent element id. + + + + + The removed pseudo element id. + + + + + Fired when backend wants to provide client with the missing DOM structure. This happens upon + most of the calls requesting node ids. + + + + + Parent node id to populate with children. + + + + + Child nodes array. + + + + + Called when shadow root is popped from the element. + + + + + Host element id. + + + + + Shadow root id. + + + + + Called when shadow root is pushed into the element. + + + + + Host element id. + + + + + Shadow root. + + + + + CollectClassNamesFromSubtreeResponse + + + + + classNames + + + + + CopyToResponse + + + + + nodeId + + + + + DescribeNodeResponse + + + + + node + + + + + GetAttributesResponse + + + + + attributes + + + + + GetBoxModelResponse + + + + + model + + + + + GetContentQuadsResponse + + + + + quads + + + + + GetDocumentResponse + + + + + root + + + + + GetNodesForSubtreeByStyleResponse + + + + + nodeIds + + + + + GetNodeForLocationResponse + + + + + backendNodeId + + + + + frameId + + + + + nodeId + + + + + GetOuterHTMLResponse + + + + + outerHTML + + + + + GetRelayoutBoundaryResponse + + + + + nodeId + + + + + GetSearchResultsResponse + + + + + nodeIds + + + + + MoveToResponse + + + + + nodeId + + + + + PerformSearchResponse + + + + + searchId + + + + + resultCount + + + + + PushNodeByPathToFrontendResponse + + + + + nodeId + + + + + PushNodesByBackendIdsToFrontendResponse + + + + + nodeIds + + + + + QuerySelectorResponse + + + + + nodeId + + + + + QuerySelectorAllResponse + + + + + nodeIds + + + + + GetTopLayerElementsResponse + + + + + nodeIds + + + + + RequestNodeResponse + + + + + nodeId + + + + + ResolveNodeResponse + + + + + object + + + + + GetNodeStackTracesResponse + + + + + creation + + + + + GetFileInfoResponse + + + + + path + + + + + SetNodeNameResponse + + + + + nodeId + + + + + GetFrameOwnerResponse + + + + + backendNodeId + + + + + nodeId + + + + + GetContainerForNodeResponse + + + + + nodeId + + + + + GetQueryingDescendantsForContainerResponse + + + + + nodeIds + + + + + Whether to include whitespaces in the children array of returned Nodes. + + + + + none + + + + + all + + + + + This domain exposes DOM read/write operations. Each DOM Node is represented with its mirror object + that has an `id`. This `id` can be used to get additional information on the Node, resolve it into + the JavaScript object wrapper, etc. It is important that client receives DOM events only for the + nodes that are known to the client. Backend keeps track of the nodes that were sent to the client + and never sends the same node twice. It is client's responsibility to collect information about + the nodes that were sent to the client.<p>Note that `iframe` owner elements will return + corresponding document elements as their child nodes.</p> + + + + + DOM + + DevToolsClient + + + + Fired when `Element`'s attribute is modified. + + + + + Fired when `Element`'s attribute is removed. + + + + + Mirrors `DOMCharacterDataModified` event. + + + + + Fired when `Container`'s child node count has changed. + + + + + Mirrors `DOMNodeInserted` event. + + + + + Mirrors `DOMNodeRemoved` event. + + + + + Called when distribution is changed. + + + + + Fired when `Document` has been totally updated. Node ids are no longer valid. + + + + + Fired when `Element`'s inline style is modified via a CSS property modification. + + + + + Called when a pseudo element is added to an element. + + + + + Called when top layer elements are changed. + + + + + Called when a pseudo element is removed from an element. + + + + + Fired when backend wants to provide client with the missing DOM structure. This happens upon + most of the calls requesting node ids. + + + + + Called when shadow root is popped from the element. + + + + + Called when shadow root is pushed into the element. + + + + + Collects class names for the node with given id and all of it's child nodes. + + Id of the node to collect class names. + returns System.Threading.Tasks.Task<CollectClassNamesFromSubtreeResponse> + + + + Creates a deep copy of the specified node and places it into the target container before the + given anchor. + + Id of the node to copy. + Id of the element to drop the copy into. + Drop the copy before this node (if absent, the copy becomes the last child of`targetNodeId`). + returns System.Threading.Tasks.Task<CopyToResponse> + + + + Describes node given its id, does not require domain to be enabled. Does not start tracking any + objects, can be used for automation. + + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + The maximum depth at which children should be retrieved, defaults to 1. Use -1 for theentire subtree or provide an integer larger than 0. + Whether or not iframes and shadow roots should be traversed when returning the subtree(default is false). + returns System.Threading.Tasks.Task<DescribeNodeResponse> + + + + Scrolls the specified rect of the given node into view if not already visible. + Note: exactly one between nodeId, backendNodeId and objectId should be passed + to identify the node. + + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + The rect to be scrolled into view, relative to the node's border box, in CSS pixels.When omitted, center of the node will be used, similar to Element.scrollIntoView. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables DOM agent for the given page. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Discards search results from the session with the given id. `getSearchResults` should no longer + be called for that search. + + Unique search session identifier. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables DOM agent for the given page. + + Whether to include whitespaces in the children array of returned Nodes. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Focuses the given element. + + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns attributes for the specified node. + + Id of the node to retrieve attibutes for. + returns System.Threading.Tasks.Task<GetAttributesResponse> + + + + Returns boxes for the given node. + + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + returns System.Threading.Tasks.Task<GetBoxModelResponse> + + + + Returns quads that describe node position on the page. This method + might return multiple quads for inline nodes. + + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + returns System.Threading.Tasks.Task<GetContentQuadsResponse> + + + + Returns the root DOM node (and optionally the subtree) to the caller. + Implicitly enables the DOM domain events for the current target. + + The maximum depth at which children should be retrieved, defaults to 1. Use -1 for theentire subtree or provide an integer larger than 0. + Whether or not iframes and shadow roots should be traversed when returning the subtree(default is false). + returns System.Threading.Tasks.Task<GetDocumentResponse> + + + + Finds nodes with a given computed style in a subtree. + + Node ID pointing to the root of a subtree. + The style to filter nodes by (includes nodes if any of properties matches). + Whether or not iframes and shadow roots in the same target should be traversed when returning theresults (default is false). + returns System.Threading.Tasks.Task<GetNodesForSubtreeByStyleResponse> + + + + Returns node id at given location. Depending on whether DOM domain is enabled, nodeId is + either returned or not. + + X coordinate. + Y coordinate. + False to skip to the nearest non-UA shadow root ancestor (default: false). + Whether to ignore pointer-events: none on elements and hit test them. + returns System.Threading.Tasks.Task<GetNodeForLocationResponse> + + + + Returns node's HTML markup. + + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + returns System.Threading.Tasks.Task<GetOuterHTMLResponse> + + + + Returns the id of the nearest ancestor that is a relayout boundary. + + Id of the node. + returns System.Threading.Tasks.Task<GetRelayoutBoundaryResponse> + + + + Returns search results from given `fromIndex` to given `toIndex` from the search with the given + identifier. + + Unique search session identifier. + Start index of the search result to be returned. + End index of the search result to be returned. + returns System.Threading.Tasks.Task<GetSearchResultsResponse> + + + + Hides any highlight. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights DOM node. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights given rectangle. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Marks last undoable state. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Moves node into the new container, places it before the given anchor. + + Id of the node to move. + Id of the element to drop the moved node into. + Drop node before this one (if absent, the moved node becomes the last child of`targetNodeId`). + returns System.Threading.Tasks.Task<MoveToResponse> + + + + Searches for a given string in the DOM tree. Use `getSearchResults` to access search results or + `cancelSearch` to end this search session. + + Plain text or query selector or XPath search query. + True to search in user agent shadow DOM. + returns System.Threading.Tasks.Task<PerformSearchResponse> + + + + Requests that the node is sent to the caller given its path. // FIXME, use XPath + + Path to node in the proprietary format. + returns System.Threading.Tasks.Task<PushNodeByPathToFrontendResponse> + + + + Requests that a batch of nodes is sent to the caller given their backend node ids. + + The array of backend node ids. + returns System.Threading.Tasks.Task<PushNodesByBackendIdsToFrontendResponse> + + + + Executes `querySelector` on a given node. + + Id of the node to query upon. + Selector string. + returns System.Threading.Tasks.Task<QuerySelectorResponse> + + + + Executes `querySelectorAll` on a given node. + + Id of the node to query upon. + Selector string. + returns System.Threading.Tasks.Task<QuerySelectorAllResponse> + + + + Returns NodeIds of current top layer elements. + Top layer is rendered closest to the user within a viewport, therefore its elements always + appear on top of all other content. + + returns System.Threading.Tasks.Task<GetTopLayerElementsResponse> + + + + Re-does the last undone action. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes attribute with given name from an element with given id. + + Id of the element to remove attribute from. + Name of the attribute to remove. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes node with given id. + + Id of the node to remove. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that children of the node with given id are returned to the caller in form of + `setChildNodes` events where not only immediate children are retrieved, but all children down to + the specified depth. + + Id of the node to get children for. + The maximum depth at which children should be retrieved, defaults to 1. Use -1 for theentire subtree or provide an integer larger than 0. + Whether or not iframes and shadow roots should be traversed when returning the sub-tree(default is false). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that the node is sent to the caller given the JavaScript node object reference. All + nodes that form the path from the node to the root are also sent to the client as a series of + `setChildNodes` notifications. + + JavaScript object id to convert into node. + returns System.Threading.Tasks.Task<RequestNodeResponse> + + + + Resolves the JavaScript node object for a given NodeId or BackendNodeId. + + Id of the node to resolve. + Backend identifier of the node to resolve. + Symbolic group name that can be used to release multiple objects. + Execution context in which to resolve the node. + returns System.Threading.Tasks.Task<ResolveNodeResponse> + + + + Sets attribute for an element with given id. + + Id of the element to set attribute for. + Attribute name. + Attribute value. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets attributes on element with given id. This method is useful when user edits some existing + attribute value and types in several attribute name/value pairs. + + Id of the element to set attributes for. + Text with a number of attributes. Will parse this text using HTML parser. + Attribute name to replace with new attributes derived from text in case text parsedsuccessfully. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets files for the given file input element. + + Array of file paths to set. + Identifier of the node. + Identifier of the backend node. + JavaScript object id of the node wrapper. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets if stack traces should be captured for Nodes. See `Node.getNodeStackTraces`. Default is disabled. + + Enable or disable. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Gets stack traces associated with a Node. As of now, only provides stack trace for Node creation. + + Id of the node to get stack traces for. + returns System.Threading.Tasks.Task<GetNodeStackTracesResponse> + + + + Returns file information for the given + File wrapper. + + JavaScript object id of the node wrapper. + returns System.Threading.Tasks.Task<GetFileInfoResponse> + + + + Enables console to refer to the node with given id via $x (see Command Line API for more details + $x functions). + + DOM node id to be accessible by means of $x command line API. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets node name for a node with given id. + + Id of the node to set name for. + New node's name. + returns System.Threading.Tasks.Task<SetNodeNameResponse> + + + + Sets node value for a node with given id. + + Id of the node to set value for. + New node's value. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets node HTML markup, returns new node id. + + Id of the node to set markup for. + Outer HTML markup to set. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Undoes the last performed action. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns iframe node that owns iframe with the given domain. + + frameId + returns System.Threading.Tasks.Task<GetFrameOwnerResponse> + + + + Returns the query container of the given node based on container query + conditions: containerName, physical, and logical axes. If no axes are + provided, the style container is returned, which is the direct parent or the + closest element with a matching container-name. + + nodeId + containerName + physicalAxes + logicalAxes + returns System.Threading.Tasks.Task<GetContainerForNodeResponse> + + + + Returns the descendants of a container query container that have + container queries against this container. + + Id of the container node to find querying descendants from. + returns System.Threading.Tasks.Task<GetQueryingDescendantsForContainerResponse> + + + + DOM breakpoint type. + + + + + subtree-modified + + + + + attribute-modified + + + + + node-removed + + + + + CSP Violation type. + + + + + trustedtype-sink-violation + + + + + trustedtype-policy-violation + + + + + Object event listener. + + + + + `EventListener`'s type. + + + + + `EventListener`'s useCapture. + + + + + `EventListener`'s passive flag. + + + + + `EventListener`'s once flag. + + + + + Script id of the handler code. + + + + + Line number in the script (0-based). + + + + + Column number in the script (0-based). + + + + + Event handler function value. + + + + + Event original handler function value. + + + + + Node the listener is added to (if any). + + + + + GetEventListenersResponse + + + + + listeners + + + + + DOM debugging allows setting breakpoints on particular DOM operations and events. JavaScript + execution will stop on these operations as if there was a regular breakpoint set. + + + + + DOMDebugger + + DevToolsClient + + + + Returns event listeners of the given object. + + Identifier of the object to return listeners for. + The maximum depth at which Node children should be retrieved, defaults to 1. Use -1 for theentire subtree or provide an integer larger than 0. + Whether or not iframes and shadow roots should be traversed when returning the subtree(default is false). Reports listeners for all contexts if pierce is enabled. + returns System.Threading.Tasks.Task<GetEventListenersResponse> + + + + Removes DOM breakpoint that was set using `setDOMBreakpoint`. + + Identifier of the node to remove breakpoint from. + Type of the breakpoint to remove. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes breakpoint on particular DOM event. + + Event name. + EventTarget interface name. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes breakpoint on particular native event. + + Instrumentation name to stop on. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes breakpoint from XMLHttpRequest. + + Resource URL substring. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets breakpoint on particular CSP violations. + + CSP Violations to stop upon. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets breakpoint on particular operation with DOM. + + Identifier of the node to set breakpoint on. + Type of the operation to stop upon. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets breakpoint on particular DOM event. + + DOM Event name to stop on (any DOM event will do). + EventTarget interface name to stop on. If equal to `"*"` or not provided, will stop on anyEventTarget. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets breakpoint on particular native event. + + Instrumentation name to stop on. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets breakpoint on XMLHttpRequest. + + Resource URL substring. All XHRs having this substring in the URL will get stopped upon. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + A Node in the DOM tree. + + + + + `Node`'s nodeType. + + + + + `Node`'s nodeName. + + + + + `Node`'s nodeValue. + + + + + Only set for textarea elements, contains the text value. + + + + + Only set for input elements, contains the input's associated text value. + + + + + Only set for radio and checkbox input elements, indicates if the element has been checked + + + + + Only set for option elements, indicates if the element has been selected + + + + + `Node`'s id, corresponds to DOM.Node.backendNodeId. + + + + + The indexes of the node's child nodes in the `domNodes` array returned by `getSnapshot`, if + any. + + + + + Attributes of an `Element` node. + + + + + Indexes of pseudo elements associated with this node in the `domNodes` array returned by + `getSnapshot`, if any. + + + + + The index of the node's related layout tree node in the `layoutTreeNodes` array returned by + `getSnapshot`, if any. + + + + + Document URL that `Document` or `FrameOwner` node points to. + + + + + Base URL that `Document` or `FrameOwner` node uses for URL completion. + + + + + Only set for documents, contains the document's content language. + + + + + Only set for documents, contains the document's character set encoding. + + + + + `DocumentType` node's publicId. + + + + + `DocumentType` node's systemId. + + + + + Frame ID for frame owner elements and also for the document node. + + + + + The index of a frame owner element's content document in the `domNodes` array returned by + `getSnapshot`, if any. + + + + + Type of a pseudo element node. + + + + + Type of a pseudo element node. + + + + + Shadow root type. + + + + + Shadow root type. + + + + + Whether this DOM node responds to mouse clicks. This includes nodes that have had click + event listeners attached via JavaScript as well as anchor tags that naturally navigate when + clicked. + + + + + Details of the node's event listeners, if any. + + + + + The selected url for nodes with a srcset attribute. + + + + + The url of the script (if any) that generates this node. + + + + + Scroll offsets, set when this node is a Document. + + + + + ScrollOffsetY + + + + + Details of post layout rendered text positions. The exact layout should not be regarded as + stable and may change between versions. + + + + + The bounding box in document coordinates. Note that scroll offset of the document is ignored. + + + + + The starting index in characters, for this post layout textbox substring. Characters that + would be represented as a surrogate pair in UTF-16 have length 2. + + + + + The number of characters in this post layout textbox substring. Characters that would be + represented as a surrogate pair in UTF-16 have length 2. + + + + + Details of an element in the DOM tree with a LayoutObject. + + + + + The index of the related DOM node in the `domNodes` array returned by `getSnapshot`. + + + + + The bounding box in document coordinates. Note that scroll offset of the document is ignored. + + + + + Contents of the LayoutText, if any. + + + + + The post-layout inline text nodes, if any. + + + + + Index into the `computedStyles` array returned by `getSnapshot`. + + + + + Global paint order index, which is determined by the stacking order of the nodes. Nodes + that are painted together will have the same index. Only provided if includePaintOrder in + getSnapshot was true. + + + + + Set to true to indicate the element begins a new stacking context. + + + + + A subset of the full ComputedStyle as defined by the request whitelist. + + + + + Name/value pairs of computed style properties. + + + + + A name/value pair. + + + + + Attribute/property name. + + + + + Attribute/property value. + + + + + Data that is only present on rare nodes. + + + + + Index + + + + + Value + + + + + RareBooleanData + + + + + Index + + + + + RareIntegerData + + + + + Index + + + + + Value + + + + + Document snapshot. + + + + + Document URL that `Document` or `FrameOwner` node points to. + + + + + Document title. + + + + + Base URL that `Document` or `FrameOwner` node uses for URL completion. + + + + + Contains the document's content language. + + + + + Contains the document's character set encoding. + + + + + `DocumentType` node's publicId. + + + + + `DocumentType` node's systemId. + + + + + Frame ID for frame owner elements and also for the document node. + + + + + A table with dom nodes. + + + + + The nodes in the layout tree. + + + + + The post-layout inline text nodes. + + + + + Horizontal scroll offset. + + + + + Vertical scroll offset. + + + + + Document content width. + + + + + Document content height. + + + + + Table containing nodes. + + + + + Parent node index. + + + + + `Node`'s nodeType. + + + + + Type of the shadow root the `Node` is in. String values are equal to the `ShadowRootType` enum. + + + + + `Node`'s nodeName. + + + + + `Node`'s nodeValue. + + + + + `Node`'s id, corresponds to DOM.Node.backendNodeId. + + + + + Attributes of an `Element` node. Flatten name, value pairs. + + + + + Only set for textarea elements, contains the text value. + + + + + Only set for input elements, contains the input's associated text value. + + + + + Only set for radio and checkbox input elements, indicates if the element has been checked + + + + + Only set for option elements, indicates if the element has been selected + + + + + The index of the document in the list of the snapshot documents. + + + + + Type of a pseudo element node. + + + + + Pseudo element identifier for this node. Only present if there is a + valid pseudoType. + + + + + Whether this DOM node responds to mouse clicks. This includes nodes that have had click + event listeners attached via JavaScript as well as anchor tags that naturally navigate when + clicked. + + + + + The selected url for nodes with a srcset attribute. + + + + + The url of the script (if any) that generates this node. + + + + + Table of details of an element in the DOM tree with a LayoutObject. + + + + + Index of the corresponding node in the `NodeTreeSnapshot` array returned by `captureSnapshot`. + + + + + Array of indexes specifying computed style strings, filtered according to the `computedStyles` parameter passed to `captureSnapshot`. + + + + + The absolute position bounding box. + + + + + Contents of the LayoutText, if any. + + + + + Stacking context information. + + + + + Global paint order index, which is determined by the stacking order of the nodes. Nodes + that are painted together will have the same index. Only provided if includePaintOrder in + captureSnapshot was true. + + + + + The offset rect of nodes. Only available when includeDOMRects is set to true + + + + + The scroll rect of nodes. Only available when includeDOMRects is set to true + + + + + The client rect of nodes. Only available when includeDOMRects is set to true + + + + + The list of background colors that are blended with colors of overlapping elements. + + + + + The list of computed text opacities. + + + + + Table of details of the post layout rendered text positions. The exact layout should not be regarded as + stable and may change between versions. + + + + + Index of the layout tree node that owns this box collection. + + + + + The absolute position bounding box. + + + + + The starting index in characters, for this post layout textbox substring. Characters that + would be represented as a surrogate pair in UTF-16 have length 2. + + + + + The number of characters in this post layout textbox substring. Characters that would be + represented as a surrogate pair in UTF-16 have length 2. + + + + + CaptureSnapshotResponse + + + + + documents + + + + + strings + + + + + This domain facilitates obtaining document snapshots with DOM, layout, and style information. + + + + + DOMSnapshot + + DevToolsClient + + + + Disables DOM snapshot agent for the given page. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables DOM snapshot agent for the given page. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns a document snapshot, including the full DOM tree of the root node (including iframes, + template contents, and imported documents) in a flattened array, as well as layout and + white-listed computed style information for the nodes. Shadow DOM in the returned DOM tree is + flattened. + + Whitelist of computed styles to return. + Whether to include layout object paint orders into the snapshot. + Whether to include DOM rectangles (offsetRects, clientRects, scrollRects) into the snapshot + Whether to include blended background colors in the snapshot (default: false).Blended background color is achieved by blending background colors of all elementsthat overlap with the current element. + Whether to include text color opacity in the snapshot (default: false).An element might have the opacity property set that affects the text color of the element.The final text color opacity is computed based on the opacity of all overlapping elements. + returns System.Threading.Tasks.Task<CaptureSnapshotResponse> + + + + DOM Storage identifier. + + + + + Security origin for the storage. + + + + + Represents a key by which DOM Storage keys its CachedStorageAreas + + + + + Whether the storage is local storage (not session storage). + + + + + domStorageItemAdded + + + + + StorageId + + + + + Key + + + + + NewValue + + + + + domStorageItemRemoved + + + + + StorageId + + + + + Key + + + + + domStorageItemUpdated + + + + + StorageId + + + + + Key + + + + + OldValue + + + + + NewValue + + + + + domStorageItemsCleared + + + + + StorageId + + + + + GetDOMStorageItemsResponse + + + + + entries + + + + + Query and modify DOM storage. + + + + + DOMStorage + + DevToolsClient + + + + DomStorageItemAdded + + + + + DomStorageItemRemoved + + + + + DomStorageItemUpdated + + + + + DomStorageItemsCleared + + + + + Clear + + storageId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables storage tracking, prevents storage events from being sent to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables storage tracking, storage events will now be delivered to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + GetDOMStorageItems + + storageId + returns System.Threading.Tasks.Task<GetDOMStorageItemsResponse> + + + + RemoveDOMStorageItem + + storageId + key + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetDOMStorageItem + + storageId + key + value + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Database object. + + + + + Database ID. + + + + + Database domain. + + + + + Database name. + + + + + Database version. + + + + + Database error. + + + + + Error message. + + + + + Error code. + + + + + addDatabase + + + + + Database + + + + + ExecuteSQLResponse + + + + + columnNames + + + + + values + + + + + sqlError + + + + + GetDatabaseTableNamesResponse + + + + + tableNames + + + + + Database + + + + + Database + + DevToolsClient + + + + AddDatabase + + + + + Disables database tracking, prevents database events from being sent to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables database tracking, database events will now be delivered to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + ExecuteSQL + + databaseId + query + returns System.Threading.Tasks.Task<ExecuteSQLResponse> + + + + GetDatabaseTableNames + + databaseId + returns System.Threading.Tasks.Task<GetDatabaseTableNamesResponse> + + + + Orientation type. + + + + + portraitPrimary + + + + + portraitSecondary + + + + + landscapePrimary + + + + + landscapeSecondary + + + + + Screen orientation. + + + + + Orientation type. + + + + + Orientation type. + + + + + Orientation angle. + + + + + Orientation of a display feature in relation to screen + + + + + vertical + + + + + horizontal + + + + + DisplayFeature + + + + + Orientation of a display feature in relation to screen + + + + + Orientation of a display feature in relation to screen + + + + + The offset from the screen origin in either the x (for vertical + orientation) or y (for horizontal orientation) direction. + + + + + A display feature may mask content such that it is not physically + displayed - this length along with the offset describes this area. + A display feature that only splits content will have a 0 mask_length. + + + + + MediaFeature + + + + + Name + + + + + Value + + + + + advance: If the scheduler runs out of immediate work, the virtual time base may fast forward to + allow the next delayed task (if any) to run; pause: The virtual time base may not advance; + pauseIfNetworkFetchesPending: The virtual time base may not advance if there are any pending + resource fetches. + + + + + advance + + + + + pause + + + + + pauseIfNetworkFetchesPending + + + + + Used to specify User Agent Cient Hints to emulate. See https://wicg.github.io/ua-client-hints + + + + + Brand + + + + + Version + + + + + Used to specify User Agent Cient Hints to emulate. See https://wicg.github.io/ua-client-hints + Missing optional values will be filled in by the target with what it would normally use. + + + + + Brands appearing in Sec-CH-UA. + + + + + Brands appearing in Sec-CH-UA-Full-Version-List. + + + + + FullVersion + + + + + Platform + + + + + PlatformVersion + + + + + Architecture + + + + + Model + + + + + Mobile + + + + + Bitness + + + + + Wow64 + + + + + Enum of image types that can be disabled. + + + + + avif + + + + + webp + + + + + CanEmulateResponse + + + + + result + + + + + SetVirtualTimePolicyResponse + + + + + virtualTimeTicksBase + + + + + Touch/gesture events configuration. Default: current platform. + + + + + mobile + + + + + desktop + + + + + Vision deficiency to emulate. Order: best-effort emulations come first, followed by any + physiologically accurate emulations for medically recognized color vision deficiencies. + + + + + none + + + + + blurredVision + + + + + reducedContrast + + + + + achromatopsia + + + + + deuteranopia + + + + + protanopia + + + + + tritanopia + + + + + This domain emulates different environments for the page. + + + + + Emulation + + DevToolsClient + + + + Notification sent after the virtual time budget for the current VirtualTimePolicy has run out. + + + + + Tells whether emulation is supported. + + returns System.Threading.Tasks.Task<CanEmulateResponse> + + + + Clears the overridden device metrics. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears the overridden Geolocation Position and Error. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that page scale factor is reset to initial values. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables or disables simulating a focused and active page. + + Whether to enable to disable focus emulation. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Automatically render all web contents using a dark theme. + + Whether to enable or disable automatic dark mode.If not specified, any existing override will be cleared. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables CPU throttling to emulate slow CPUs. + + Throttling rate as a slowdown factor (1 is no throttle, 2 is 2x slowdown, etc). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets or clears an override of the default background color of the frame. This override is used + if the content does not specify one. + + RGBA of the default background color. If not specified, any existing override will becleared. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Overrides the values of device screen dimensions (window.screen.width, window.screen.height, + window.innerWidth, window.innerHeight, and "device-width"/"device-height"-related CSS media + query results). + + Overriding width value in pixels (minimum 0, maximum 10000000). 0 disables the override. + Overriding height value in pixels (minimum 0, maximum 10000000). 0 disables the override. + Overriding device scale factor value. 0 disables the override. + Whether to emulate mobile device. This includes viewport meta tag, overlay scrollbars, textautosizing and more. + Scale to apply to resulting view image. + Overriding screen width value in pixels (minimum 0, maximum 10000000). + Overriding screen height value in pixels (minimum 0, maximum 10000000). + Overriding view X position on screen in pixels (minimum 0, maximum 10000000). + Overriding view Y position on screen in pixels (minimum 0, maximum 10000000). + Do not set visible view size, rely upon explicit setVisibleSize call. + Screen orientation override. + If set, the visible area of the page will be overridden to this viewport. This viewportchange is not observed by the page, e.g. viewport-relative elements do not change positions. + If set, the display feature of a multi-segment screen. If not set, multi-segment supportis turned-off. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetScrollbarsHidden + + Whether scrollbars should be always hidden. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetDocumentCookieDisabled + + Whether document.coookie API should be disabled. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetEmitTouchEventsForMouse + + Whether touch emulation based on mouse input should be enabled. + Touch/gesture events configuration. Default: current platform. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Emulates the given media type or media feature for CSS media queries. + + Media type to emulate. Empty string disables the override. + Media features to emulate. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Emulates the given vision deficiency. + + Vision deficiency to emulate. Order: best-effort emulations come first, followed by anyphysiologically accurate emulations for medically recognized color vision deficiencies. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Overrides the Geolocation Position or Error. Omitting any of the parameters emulates position + unavailable. + + Mock latitude + Mock longitude + Mock accuracy + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Overrides the Idle state. + + Mock isUserActive + Mock isScreenUnlocked + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears Idle state overrides. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets a specified page scale factor. + + Page scale factor. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Switches script execution in the page. + + Whether script execution should be disabled in the page. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables touch on platforms which do not support them. + + Whether the touch event emulation should be enabled. + Maximum touch points supported. Defaults to one. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Turns on virtual time for all frames (replacing real-time with a synthetic time source) and sets + the current virtual time policy. Note this supersedes any previous time budget. + + policy + If set, after this many virtual milliseconds have elapsed virtual time will be paused and avirtualTimeBudgetExpired event is sent. + If set this specifies the maximum number of tasks that can be run before virtual is forcedforwards to prevent deadlock. + If set, base::Time::Now will be overridden to initially return this value. + returns System.Threading.Tasks.Task<SetVirtualTimePolicyResponse> + + + + Overrides default host system locale with the specified one. + + ICU style C locale (e.g. "en_US"). If not specified or empty, disables the override andrestores default host system locale. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Overrides default host system timezone with the specified one. + + The timezone identifier. If empty, disables the override andrestores default host system timezone. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetDisabledImageTypes + + Image types to disable. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetHardwareConcurrencyOverride + + Hardware concurrency to report + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Allows overriding user agent with the given string. + + User agent to use. + Browser langugage to emulate. + The platform navigator.platform should return. + To be sent in Sec-CH-UA-* headers and returned in navigator.userAgentData + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Allows overriding the automation flag. + + Whether the override should be enabled. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Image compression format (defaults to png). + + + + + jpeg + + + + + png + + + + + webp + + + + + Encoding options for a screenshot. + + + + + Image compression format (defaults to png). + + + + + Image compression format (defaults to png). + + + + + Compression quality from range [0..100] (jpeg only). + + + + + Optimize image encoding for speed, not for resulting size (defaults to false) + + + + + BeginFrameResponse + + + + + hasDamage + + + + + screenshotData + + + + + This domain provides experimental commands only supported in headless mode. + + + + + HeadlessExperimental + + DevToolsClient + + + + Sends a BeginFrame to the target and returns when the frame was completed. Optionally captures a + screenshot from the resulting frame. Requires that the target was created with enabled + BeginFrameControl. Designed for use with --run-all-compositor-stages-before-draw, see also + https://goo.gle/chrome-headless-rendering for more background. + + Timestamp of this BeginFrame in Renderer TimeTicks (milliseconds of uptime). If not set,the current time will be used. + The interval between BeginFrames that is reported to the compositor, in milliseconds.Defaults to a 60 frames/second interval, i.e. about 16.666 milliseconds. + Whether updates should not be committed and drawn onto the display. False by default. Iftrue, only side effects of the BeginFrame will be run, such as layout and animations, butany visual updates may not be visible on the display or in screenshots. + If set, a screenshot of the frame will be captured and returned in the response. Otherwise,no screenshot will be captured. Note that capturing a screenshot can fail, for example,during renderer initialization. In such a case, no screenshot data will be returned. + returns System.Threading.Tasks.Task<BeginFrameResponse> + + + + Database with an array of object stores. + + + + + Database name. + + + + + Database version (type is not 'integer', as the standard + requires the version number to be 'unsigned long long') + + + + + Object stores in this database. + + + + + Object store. + + + + + Object store name. + + + + + Object store key path. + + + + + If true, object store has auto increment flag set. + + + + + Indexes in this object store. + + + + + Object store index. + + + + + Index name. + + + + + Index key path. + + + + + If true, index is unique. + + + + + If true, index allows multiple entries for a key. + + + + + Key type. + + + + + number + + + + + string + + + + + date + + + + + array + + + + + Key. + + + + + Key type. + + + + + Key type. + + + + + Number value. + + + + + String value. + + + + + Date value. + + + + + Array value. + + + + + Key range. + + + + + Lower bound. + + + + + Upper bound. + + + + + If true lower bound is open. + + + + + If true upper bound is open. + + + + + Data entry. + + + + + Key object. + + + + + Primary key object. + + + + + Value object. + + + + + Key path type. + + + + + null + + + + + string + + + + + array + + + + + Key path. + + + + + Key path type. + + + + + Key path type. + + + + + String value. + + + + + Array value. + + + + + RequestDataResponse + + + + + objectStoreDataEntries + + + + + hasMore + + + + + GetMetadataResponse + + + + + entriesCount + + + + + keyGeneratorValue + + + + + RequestDatabaseResponse + + + + + databaseWithObjectStores + + + + + RequestDatabaseNamesResponse + + + + + databaseNames + + + + + IndexedDB + + + + + IndexedDB + + DevToolsClient + + + + Clears all entries from an object store. + + Database name. + Object store name. + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Deletes a database. + + Database name. + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Delete a range of entries from an object store + + databaseName + objectStoreName + Range of entry keys to delete + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables events from backend. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables events from backend. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests data from object store or index. + + Database name. + Object store name. + Index name, empty string for object store data requests. + Number of records to skip. + Number of records to fetch. + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + Key range. + returns System.Threading.Tasks.Task<RequestDataResponse> + + + + Gets metadata of an object store. + + Database name. + Object store name. + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<GetMetadataResponse> + + + + Requests database with given name in given frame. + + Database name. + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<RequestDatabaseResponse> + + + + Requests database names for given security origin. + + At least and at most one of securityOrigin, storageKey must be specified.Security origin. + Storage key. + returns System.Threading.Tasks.Task<RequestDatabaseNamesResponse> + + + + TouchPoint + + + + + X coordinate of the event relative to the main frame's viewport in CSS pixels. + + + + + Y coordinate of the event relative to the main frame's viewport in CSS pixels. 0 refers to + the top of the viewport and Y increases as it proceeds towards the bottom of the viewport. + + + + + X radius of the touch area (default: 1.0). + + + + + Y radius of the touch area (default: 1.0). + + + + + Rotation angle (default: 0.0). + + + + + Force (default: 1.0). + + + + + The normalized tangential pressure, which has a range of [-1,1] (default: 0). + + + + + The plane angle between the Y-Z plane and the plane containing both the stylus axis and the Y axis, in degrees of the range [-90,90], a positive tiltX is to the right (default: 0) + + + + + The plane angle between the X-Z plane and the plane containing both the stylus axis and the X axis, in degrees of the range [-90,90], a positive tiltY is towards the user (default: 0). + + + + + The clockwise rotation of a pen stylus around its own major axis, in degrees in the range [0,359] (default: 0). + + + + + Identifier used to track touch sources between events, must be unique within an event. + + + + + GestureSourceType + + + + + default + + + + + touch + + + + + mouse + + + + + MouseButton + + + + + none + + + + + left + + + + + middle + + + + + right + + + + + back + + + + + forward + + + + + DragDataItem + + + + + Mime type of the dragged data. + + + + + Depending of the value of `mimeType`, it contains the dragged link, + text, HTML markup or any other data. + + + + + Title associated with a link. Only valid when `mimeType` == "text/uri-list". + + + + + Stores the base URL for the contained markup. Only valid when `mimeType` + == "text/html". + + + + + DragData + + + + + Items + + + + + List of filenames that should be included when dropping + + + + + Bit field representing allowed drag operations. Copy = 1, Link = 2, Move = 16 + + + + + Emitted only when `Input.setInterceptDrags` is enabled. Use this data with `Input.dispatchDragEvent` to + restore normal drag and drop behavior. + + + + + Data + + + + + Type of the drag event. + + + + + dragEnter + + + + + dragOver + + + + + drop + + + + + dragCancel + + + + + Type of the key event. + + + + + keyDown + + + + + keyUp + + + + + rawKeyDown + + + + + char + + + + + Type of the mouse event. + + + + + mousePressed + + + + + mouseReleased + + + + + mouseMoved + + + + + mouseWheel + + + + + Pointer type (default: "mouse"). + + + + + mouse + + + + + pen + + + + + Type of the touch event. TouchEnd and TouchCancel must not contain any touch points, while + TouchStart and TouchMove must contains at least one. + + + + + touchStart + + + + + touchEnd + + + + + touchMove + + + + + touchCancel + + + + + Type of the mouse event. + + + + + mousePressed + + + + + mouseReleased + + + + + mouseMoved + + + + + mouseWheel + + + + + Input + + + + + Input + + DevToolsClient + + + + Emitted only when `Input.setInterceptDrags` is enabled. Use this data with `Input.dispatchDragEvent` to + restore normal drag and drop behavior. + + + + + Dispatches a drag event into the page. + + Type of the drag event. + X coordinate of the event relative to the main frame's viewport in CSS pixels. + Y coordinate of the event relative to the main frame's viewport in CSS pixels. 0 refers tothe top of the viewport and Y increases as it proceeds towards the bottom of the viewport. + data + Bit field representing pressed modifier keys. Alt=1, Ctrl=2, Meta/Command=4, Shift=8(default: 0). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Dispatches a key event to the page. + + Type of the key event. + Bit field representing pressed modifier keys. Alt=1, Ctrl=2, Meta/Command=4, Shift=8(default: 0). + Time at which the event occurred. + Text as generated by processing a virtual key code with a keyboard layout. Not needed forfor `keyUp` and `rawKeyDown` events (default: "") + Text that would have been generated by the keyboard if no modifiers were pressed (except forshift). Useful for shortcut (accelerator) key handling (default: ""). + Unique key identifier (e.g., 'U+0041') (default: ""). + Unique DOM defined string value for each physical key (e.g., 'KeyA') (default: ""). + Unique DOM defined string value describing the meaning of the key in the context of activemodifiers, keyboard layout, etc (e.g., 'AltGr') (default: ""). + Windows virtual key code (default: 0). + Native virtual key code (default: 0). + Whether the event was generated from auto repeat (default: false). + Whether the event was generated from the keypad (default: false). + Whether the event was a system key event (default: false). + Whether the event was from the left or right side of the keyboard. 1=Left, 2=Right (default:0). + Editing commands to send with the key event (e.g., 'selectAll') (default: []).These are related to but not equal the command names used in `document.execCommand` and NSStandardKeyBindingResponding.See https://source.chromium.org/chromium/chromium/src/+/main:third_party/blink/renderer/core/editing/commands/editor_command_names.h for valid command names. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + This method emulates inserting text that doesn't come from a key press, + for example an emoji keyboard or an IME. + + The text to insert. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + This method sets the current candidate text for ime. + Use imeCommitComposition to commit the final text. + Use imeSetComposition with empty string as text to cancel composition. + + The text to insert + selection start + selection end + replacement start + replacement end + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Dispatches a mouse event to the page. + + Type of the mouse event. + X coordinate of the event relative to the main frame's viewport in CSS pixels. + Y coordinate of the event relative to the main frame's viewport in CSS pixels. 0 refers tothe top of the viewport and Y increases as it proceeds towards the bottom of the viewport. + Bit field representing pressed modifier keys. Alt=1, Ctrl=2, Meta/Command=4, Shift=8(default: 0). + Time at which the event occurred. + Mouse button (default: "none"). + A number indicating which buttons are pressed on the mouse when a mouse event is triggered.Left=1, Right=2, Middle=4, Back=8, Forward=16, None=0. + Number of times the mouse button was clicked (default: 0). + The normalized pressure, which has a range of [0,1] (default: 0). + The normalized tangential pressure, which has a range of [-1,1] (default: 0). + The plane angle between the Y-Z plane and the plane containing both the stylus axis and the Y axis, in degrees of the range [-90,90], a positive tiltX is to the right (default: 0). + The plane angle between the X-Z plane and the plane containing both the stylus axis and the X axis, in degrees of the range [-90,90], a positive tiltY is towards the user (default: 0). + The clockwise rotation of a pen stylus around its own major axis, in degrees in the range [0,359] (default: 0). + X delta in CSS pixels for mouse wheel event (default: 0). + Y delta in CSS pixels for mouse wheel event (default: 0). + Pointer type (default: "mouse"). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Dispatches a touch event to the page. + + Type of the touch event. TouchEnd and TouchCancel must not contain any touch points, whileTouchStart and TouchMove must contains at least one. + Active touch points on the touch device. One event per any changed point (compared toprevious touch event in a sequence) is generated, emulating pressing/moving/releasing pointsone by one. + Bit field representing pressed modifier keys. Alt=1, Ctrl=2, Meta/Command=4, Shift=8(default: 0). + Time at which the event occurred. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Emulates touch event from the mouse event parameters. + + Type of the mouse event. + X coordinate of the mouse pointer in DIP. + Y coordinate of the mouse pointer in DIP. + Mouse button. Only "none", "left", "right" are supported. + Time at which the event occurred (default: current time). + X delta in DIP for mouse wheel event (default: 0). + Y delta in DIP for mouse wheel event (default: 0). + Bit field representing pressed modifier keys. Alt=1, Ctrl=2, Meta/Command=4, Shift=8(default: 0). + Number of times the mouse button was clicked (default: 0). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Ignores input events (useful while auditing page). + + Ignores input events processing when set to true. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Prevents default drag and drop behavior and instead emits `Input.dragIntercepted` events. + Drag and drop behavior can be directly controlled via `Input.dispatchDragEvent`. + + enabled + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Synthesizes a pinch gesture over a time period by issuing appropriate touch events. + + X coordinate of the start of the gesture in CSS pixels. + Y coordinate of the start of the gesture in CSS pixels. + Relative scale factor after zooming (>1.0 zooms in, <1.0 zooms out). + Relative pointer speed in pixels per second (default: 800). + Which type of input events to be generated (default: 'default', which queries the platformfor the preferred input type). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Synthesizes a scroll gesture over a time period by issuing appropriate touch events. + + X coordinate of the start of the gesture in CSS pixels. + Y coordinate of the start of the gesture in CSS pixels. + The distance to scroll along the X axis (positive to scroll left). + The distance to scroll along the Y axis (positive to scroll up). + The number of additional pixels to scroll back along the X axis, in addition to the givendistance. + The number of additional pixels to scroll back along the Y axis, in addition to the givendistance. + Prevent fling (default: true). + Swipe speed in pixels per second (default: 800). + Which type of input events to be generated (default: 'default', which queries the platformfor the preferred input type). + The number of times to repeat the gesture (default: 0). + The number of milliseconds delay between each repeat. (default: 250). + The name of the interaction markers to generate, if not empty (default: ""). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Synthesizes a tap gesture over a time period by issuing appropriate touch events. + + X coordinate of the start of the gesture in CSS pixels. + Y coordinate of the start of the gesture in CSS pixels. + Duration between touchdown and touchup events in ms (default: 50). + Number of times to perform the tap (e.g. 2 for double tap, default: 1). + Which type of input events to be generated (default: 'default', which queries the platformfor the preferred input type). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Fired when remote debugging connection is about to be terminated. Contains detach reason. + + + + + The reason why connection has been terminated. + + + + + Inspector + + + + + Inspector + + DevToolsClient + + + + Fired when remote debugging connection is about to be terminated. Contains detach reason. + + + + + Fired when debugging target has crashed + + + + + Fired when debugging target has reloaded after crash + + + + + Disables inspector domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables inspector domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Reason for rectangle to force scrolling on the main thread + + + + + RepaintsOnScroll + + + + + TouchEventHandler + + + + + WheelEventHandler + + + + + Rectangle where scrolling happens on the main thread. + + + + + Rectangle itself. + + + + + Reason for rectangle to force scrolling on the main thread + + + + + Reason for rectangle to force scrolling on the main thread + + + + + Sticky position constraints. + + + + + Layout rectangle of the sticky element before being shifted + + + + + Layout rectangle of the containing block of the sticky element + + + + + The nearest sticky layer that shifts the sticky box + + + + + The nearest sticky layer that shifts the containing block + + + + + Serialized fragment of layer picture along with its offset within the layer. + + + + + Offset from owning layer left boundary + + + + + Offset from owning layer top boundary + + + + + Base64-encoded snapshot data. + + + + + Information about a compositing layer. + + + + + The unique id for this layer. + + + + + The id of parent (not present for root). + + + + + The backend id for the node associated with this layer. + + + + + Offset from parent layer, X coordinate. + + + + + Offset from parent layer, Y coordinate. + + + + + Layer width. + + + + + Layer height. + + + + + Transformation matrix for layer, default is identity matrix + + + + + Transform anchor point X, absent if no transform specified + + + + + Transform anchor point Y, absent if no transform specified + + + + + Transform anchor point Z, absent if no transform specified + + + + + Indicates how many time this layer has painted. + + + + + Indicates whether this layer hosts any content, rather than being used for + transform/scrolling purposes only. + + + + + Set if layer is not visible. + + + + + Rectangles scrolling on main thread only. + + + + + Sticky position constraint information + + + + + layerPainted + + + + + The id of the painted layer. + + + + + Clip rectangle. + + + + + layerTreeDidChange + + + + + Layer tree, absent if not in the comspositing mode. + + + + + CompositingReasonsResponse + + + + + compositingReasons + + + + + compositingReasonIds + + + + + LoadSnapshotResponse + + + + + snapshotId + + + + + MakeSnapshotResponse + + + + + snapshotId + + + + + ProfileSnapshotResponse + + + + + timings + + + + + ReplaySnapshotResponse + + + + + dataURL + + + + + SnapshotCommandLogResponse + + + + + commandLog + + + + + LayerTree + + + + + LayerTree + + DevToolsClient + + + + LayerPainted + + + + + LayerTreeDidChange + + + + + Provides the reasons why the given layer was composited. + + The id of the layer for which we want to get the reasons it was composited. + returns System.Threading.Tasks.Task<CompositingReasonsResponse> + + + + Disables compositing tree inspection. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables compositing tree inspection. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns the snapshot identifier. + + An array of tiles composing the snapshot. + returns System.Threading.Tasks.Task<LoadSnapshotResponse> + + + + Returns the layer snapshot identifier. + + The id of the layer. + returns System.Threading.Tasks.Task<MakeSnapshotResponse> + + + + ProfileSnapshot + + The id of the layer snapshot. + The maximum number of times to replay the snapshot (1, if not specified). + The minimum duration (in seconds) to replay the snapshot. + The clip rectangle to apply when replaying the snapshot. + returns System.Threading.Tasks.Task<ProfileSnapshotResponse> + + + + Releases layer snapshot captured by the back-end. + + The id of the layer snapshot. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Replays the layer snapshot and returns the resulting bitmap. + + The id of the layer snapshot. + The first step to replay from (replay from the very start if not specified). + The last step to replay to (replay till the end if not specified). + The scale to apply while replaying (defaults to 1). + returns System.Threading.Tasks.Task<ReplaySnapshotResponse> + + + + Replays the layer snapshot and returns canvas log. + + The id of the layer snapshot. + returns System.Threading.Tasks.Task<SnapshotCommandLogResponse> + + + + Log entry source. + + + + + xml + + + + + javascript + + + + + network + + + + + storage + + + + + appcache + + + + + rendering + + + + + security + + + + + deprecation + + + + + worker + + + + + violation + + + + + intervention + + + + + recommendation + + + + + other + + + + + Log entry severity. + + + + + verbose + + + + + info + + + + + warning + + + + + error + + + + + LogEntryCategory + + + + + cors + + + + + Log entry. + + + + + Log entry source. + + + + + Log entry source. + + + + + Log entry severity. + + + + + Log entry severity. + + + + + Logged text. + + + + + Category + + + + + Category + + + + + Timestamp when this entry was added. + + + + + URL of the resource if known. + + + + + Line number in the resource. + + + + + JavaScript stack trace. + + + + + Identifier of the network request associated with this entry. + + + + + Identifier of the worker associated with this entry. + + + + + Call arguments. + + + + + Violation type. + + + + + longTask + + + + + longLayout + + + + + blockedEvent + + + + + blockedParser + + + + + discouragedAPIUse + + + + + handler + + + + + recurringHandler + + + + + Violation configuration setting. + + + + + Violation type. + + + + + Violation type. + + + + + Time threshold to trigger upon. + + + + + Issued when new message was logged. + + + + + The entry. + + + + + Provides access to log entries. + + + + + Log + + DevToolsClient + + + + Issued when new message was logged. + + + + + Clears the log. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables log domain, prevents further log entries from being reported to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables log domain, sends the entries collected so far to the client by means of the + `entryAdded` notification. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + start violation reporting. + + Configuration for violations. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stop violation reporting. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Memory pressure level. + + + + + moderate + + + + + critical + + + + + Heap profile sample. + + + + + Size of the sampled allocation. + + + + + Total bytes attributed to this sample. + + + + + Execution stack at the point of allocation. + + + + + Array of heap profile samples. + + + + + Samples + + + + + Modules + + + + + Executable module information + + + + + Name of the module. + + + + + UUID of the module. + + + + + Base address where the module is loaded into memory. Encoded as a decimal + or hexadecimal (0x prefixed) string. + + + + + Size of the module in bytes. + + + + + GetDOMCountersResponse + + + + + documents + + + + + nodes + + + + + jsEventListeners + + + + + GetAllTimeSamplingProfileResponse + + + + + profile + + + + + GetBrowserSamplingProfileResponse + + + + + profile + + + + + GetSamplingProfileResponse + + + + + profile + + + + + Memory + + + + + Memory + + DevToolsClient + + + + GetDOMCounters + + returns System.Threading.Tasks.Task<GetDOMCountersResponse> + + + + PrepareForLeakDetection + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Simulate OomIntervention by purging V8 memory. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable/disable suppressing memory pressure notifications in all processes. + + If true, memory pressure notifications will be suppressed. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Simulate a memory pressure notification in all processes. + + Memory pressure level of the notification. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Start collecting native memory profile. + + Average number of bytes between samples. + Do not randomize intervals between samples. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stop collecting native memory profile. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Retrieve native memory allocations profile + collected since renderer process startup. + + returns System.Threading.Tasks.Task<GetAllTimeSamplingProfileResponse> + + + + Retrieve native memory allocations profile + collected since browser process startup. + + returns System.Threading.Tasks.Task<GetBrowserSamplingProfileResponse> + + + + Retrieve native memory allocations profile collected since last + `startSampling` call. + + returns System.Threading.Tasks.Task<GetSamplingProfileResponse> + + + + Resource type as it was perceived by the rendering engine. + + + + + Document + + + + + Stylesheet + + + + + Image + + + + + Media + + + + + Font + + + + + Script + + + + + TextTrack + + + + + XHR + + + + + Fetch + + + + + Prefetch + + + + + EventSource + + + + + WebSocket + + + + + Manifest + + + + + SignedExchange + + + + + Ping + + + + + CSPViolationReport + + + + + Preflight + + + + + Other + + + + + Network level fetch failure reason. + + + + + Failed + + + + + Aborted + + + + + TimedOut + + + + + AccessDenied + + + + + ConnectionClosed + + + + + ConnectionReset + + + + + ConnectionRefused + + + + + ConnectionAborted + + + + + ConnectionFailed + + + + + NameNotResolved + + + + + InternetDisconnected + + + + + AddressUnreachable + + + + + BlockedByClient + + + + + BlockedByResponse + + + + + The underlying connection technology that the browser is supposedly using. + + + + + none + + + + + cellular2g + + + + + cellular3g + + + + + cellular4g + + + + + bluetooth + + + + + ethernet + + + + + wifi + + + + + wimax + + + + + other + + + + + Represents the cookie's 'SameSite' status: + https://tools.ietf.org/html/draft-west-first-party-cookies + + + + + Strict + + + + + Lax + + + + + None + + + + + Represents the cookie's 'Priority' status: + https://tools.ietf.org/html/draft-west-cookie-priority-00 + + + + + Low + + + + + Medium + + + + + High + + + + + Represents the source scheme of the origin that originally set the cookie. + A value of "Unset" allows protocol clients to emulate legacy cookie scope for the scheme. + This is a temporary ability and it will be removed in the future. + + + + + Unset + + + + + NonSecure + + + + + Secure + + + + + Timing information for the request. + + + + + Timing's requestTime is a baseline in seconds, while the other numbers are ticks in + milliseconds relatively to this requestTime. + + + + + Started resolving proxy. + + + + + Finished resolving proxy. + + + + + Started DNS address resolve. + + + + + Finished DNS address resolve. + + + + + Started connecting to the remote host. + + + + + Connected to the remote host. + + + + + Started SSL handshake. + + + + + Finished SSL handshake. + + + + + Started running ServiceWorker. + + + + + Finished Starting ServiceWorker. + + + + + Started fetch event. + + + + + Settled fetch event respondWith promise. + + + + + Started sending request. + + + + + Finished sending request. + + + + + Time the server started pushing request. + + + + + Time the server finished pushing request. + + + + + Finished receiving response headers. + + + + + Loading priority of a resource request. + + + + + VeryLow + + + + + Low + + + + + Medium + + + + + High + + + + + VeryHigh + + + + + Post data entry for HTTP request + + + + + Bytes + + + + + The referrer policy of the request, as defined in https://www.w3.org/TR/referrer-policy/ + + + + + unsafe-url + + + + + no-referrer-when-downgrade + + + + + no-referrer + + + + + origin + + + + + origin-when-cross-origin + + + + + same-origin + + + + + strict-origin + + + + + strict-origin-when-cross-origin + + + + + HTTP request data. + + + + + Request URL (without fragment). + + + + + Fragment of the requested URL starting with hash, if present. + + + + + HTTP request method. + + + + + HTTP request headers. + + + + + HTTP POST request data. + + + + + True when the request has POST data. Note that postData might still be omitted when this flag is true when the data is too long. + + + + + Request body elements. This will be converted from base64 to binary + + + + + The mixed content type of the request. + + + + + The mixed content type of the request. + + + + + Priority of the resource request at the time request is sent. + + + + + Priority of the resource request at the time request is sent. + + + + + The referrer policy of the request, as defined in https://www.w3.org/TR/referrer-policy/ + + + + + The referrer policy of the request, as defined in https://www.w3.org/TR/referrer-policy/ + + + + + Whether is loaded via link preload. + + + + + Set for requests when the TrustToken API is used. Contains the parameters + passed by the developer (e.g. via "fetch") as understood by the backend. + + + + + True if this resource request is considered to be the 'same site' as the + request correspondinfg to the main frame. + + + + + Details of a signed certificate timestamp (SCT). + + + + + Validation status. + + + + + Origin. + + + + + Log name / description. + + + + + Log ID. + + + + + Issuance date. Unlike TimeSinceEpoch, this contains the number of + milliseconds since January 1, 1970, UTC, not the number of seconds. + + + + + Hash algorithm. + + + + + Signature algorithm. + + + + + Signature data. + + + + + Security details about a request. + + + + + Protocol name (e.g. "TLS 1.2" or "QUIC"). + + + + + Key Exchange used by the connection, or the empty string if not applicable. + + + + + (EC)DH group used by the connection, if applicable. + + + + + Cipher name. + + + + + TLS MAC. Note that AEAD ciphers do not have separate MACs. + + + + + Certificate ID value. + + + + + Certificate subject name. + + + + + Subject Alternative Name (SAN) DNS names and IP addresses. + + + + + Name of the issuing CA. + + + + + Certificate valid from date. + + + + + Certificate valid to (expiration) date + + + + + List of signed certificate timestamps (SCTs). + + + + + Whether the request complied with Certificate Transparency policy + + + + + Whether the request complied with Certificate Transparency policy + + + + + The signature algorithm used by the server in the TLS server signature, + represented as a TLS SignatureScheme code point. Omitted if not + applicable or not known. + + + + + Whether the connection used Encrypted ClientHello + + + + + Whether the request complied with Certificate Transparency policy. + + + + + unknown + + + + + not-compliant + + + + + compliant + + + + + The reason why request was blocked. + + + + + other + + + + + csp + + + + + mixed-content + + + + + origin + + + + + inspector + + + + + subresource-filter + + + + + content-type + + + + + coep-frame-resource-needs-coep-header + + + + + coop-sandboxed-iframe-cannot-navigate-to-coop-page + + + + + corp-not-same-origin + + + + + corp-not-same-origin-after-defaulted-to-same-origin-by-coep + + + + + corp-not-same-site + + + + + The reason why request was blocked. + + + + + DisallowedByMode + + + + + InvalidResponse + + + + + WildcardOriginNotAllowed + + + + + MissingAllowOriginHeader + + + + + MultipleAllowOriginValues + + + + + InvalidAllowOriginValue + + + + + AllowOriginMismatch + + + + + InvalidAllowCredentials + + + + + CorsDisabledScheme + + + + + PreflightInvalidStatus + + + + + PreflightDisallowedRedirect + + + + + PreflightWildcardOriginNotAllowed + + + + + PreflightMissingAllowOriginHeader + + + + + PreflightMultipleAllowOriginValues + + + + + PreflightInvalidAllowOriginValue + + + + + PreflightAllowOriginMismatch + + + + + PreflightInvalidAllowCredentials + + + + + PreflightMissingAllowExternal + + + + + PreflightInvalidAllowExternal + + + + + PreflightMissingAllowPrivateNetwork + + + + + PreflightInvalidAllowPrivateNetwork + + + + + InvalidAllowMethodsPreflightResponse + + + + + InvalidAllowHeadersPreflightResponse + + + + + MethodDisallowedByPreflightResponse + + + + + HeaderDisallowedByPreflightResponse + + + + + RedirectContainsCredentials + + + + + InsecurePrivateNetwork + + + + + InvalidPrivateNetworkAccess + + + + + UnexpectedPrivateNetworkAccess + + + + + NoCorsRedirectModeNotFollow + + + + + CorsErrorStatus + + + + + CorsError + + + + + CorsError + + + + + FailedParameter + + + + + Source of serviceworker response. + + + + + cache-storage + + + + + http-cache + + + + + fallback-code + + + + + network + + + + + Only set for "token-redemption" operation and determine whether + to request a fresh SRR or use a still valid cached SRR. + + + + + UseCached + + + + + Refresh + + + + + Determines what type of Trust Token operation is executed and + depending on the type, some additional parameters. The values + are specified in third_party/blink/renderer/core/fetch/trust_token.idl. + + + + + Operation + + + + + Operation + + + + + Only set for "token-redemption" operation and determine whether + to request a fresh SRR or use a still valid cached SRR. + + + + + Only set for "token-redemption" operation and determine whether + to request a fresh SRR or use a still valid cached SRR. + + + + + Origins of issuers from whom to request tokens or redemption + records. + + + + + TrustTokenOperationType + + + + + Issuance + + + + + Redemption + + + + + Signing + + + + + The reason why Chrome uses a specific transport protocol for HTTP semantics. + + + + + alternativeJobWonWithoutRace + + + + + alternativeJobWonRace + + + + + mainJobWonRace + + + + + mappingMissing + + + + + broken + + + + + dnsAlpnH3JobWonWithoutRace + + + + + dnsAlpnH3JobWonRace + + + + + unspecifiedReason + + + + + HTTP response data. + + + + + Response URL. This URL can be different from CachedResource.url in case of redirect. + + + + + HTTP response status code. + + + + + HTTP response status text. + + + + + HTTP response headers. + + + + + HTTP response headers text. This has been replaced by the headers in Network.responseReceivedExtraInfo. + + + + + Resource mimeType as determined by the browser. + + + + + Refined HTTP request headers that were actually transmitted over the network. + + + + + HTTP request headers text. This has been replaced by the headers in Network.requestWillBeSentExtraInfo. + + + + + Specifies whether physical connection was actually reused for this request. + + + + + Physical connection id that was actually used for this request. + + + + + Remote IP address. + + + + + Remote port. + + + + + Specifies that the request was served from the disk cache. + + + + + Specifies that the request was served from the ServiceWorker. + + + + + Specifies that the request was served from the prefetch cache. + + + + + Total number of bytes received for this request so far. + + + + + Timing information for the given request. + + + + + Response source of response from ServiceWorker. + + + + + Response source of response from ServiceWorker. + + + + + The time at which the returned response was generated. + + + + + Cache Storage Cache Name. + + + + + Protocol used to fetch this request. + + + + + The reason why Chrome uses a specific transport protocol for HTTP semantics. + + + + + The reason why Chrome uses a specific transport protocol for HTTP semantics. + + + + + Security state of the request resource. + + + + + Security state of the request resource. + + + + + Security details for the request. + + + + + WebSocket request data. + + + + + HTTP request headers. + + + + + WebSocket response data. + + + + + HTTP response status code. + + + + + HTTP response status text. + + + + + HTTP response headers. + + + + + HTTP response headers text. + + + + + HTTP request headers. + + + + + HTTP request headers text. + + + + + WebSocket message data. This represents an entire WebSocket message, not just a fragmented frame as the name suggests. + + + + + WebSocket message opcode. + + + + + WebSocket message mask. + + + + + WebSocket message payload data. + If the opcode is 1, this is a text message and payloadData is a UTF-8 string. + If the opcode isn't 1, then payloadData is a base64 encoded string representing binary data. + + + + + Information about the cached resource. + + + + + Resource URL. This is the url of the original network request. + + + + + Type of this resource. + + + + + Type of this resource. + + + + + Cached response data. + + + + + Cached response body size. + + + + + Type of this initiator. + + + + + parser + + + + + script + + + + + preload + + + + + SignedExchange + + + + + preflight + + + + + other + + + + + Information about the request initiator. + + + + + Type of this initiator. + + + + + Type of this initiator. + + + + + Initiator JavaScript stack trace, set for Script only. + + + + + Initiator URL, set for Parser type or for Script type (when script is importing module) or for SignedExchange type. + + + + + Initiator line number, set for Parser type or for Script type (when script is importing + module) (0-based). + + + + + Initiator column number, set for Parser type or for Script type (when script is importing + module) (0-based). + + + + + Set if another request triggered this request (e.g. preflight). + + + + + Cookie object + + + + + Cookie name. + + + + + Cookie value. + + + + + Cookie domain. + + + + + Cookie path. + + + + + Cookie expiration date as the number of seconds since the UNIX epoch. + + + + + Cookie size. + + + + + True if cookie is http-only. + + + + + True if cookie is secure. + + + + + True in case of session cookie. + + + + + Cookie SameSite type. + + + + + Cookie SameSite type. + + + + + Cookie Priority + + + + + Cookie Priority + + + + + True if cookie is SameParty. + + + + + Cookie source scheme type. + + + + + Cookie source scheme type. + + + + + Cookie source port. Valid values are {-1, [1, 65535]}, -1 indicates an unspecified port. + An unspecified port value allows protocol clients to emulate legacy cookie scope for the port. + This is a temporary ability and it will be removed in the future. + + + + + Cookie partition key. The site of the top-level URL the browser was visiting at the start + of the request to the endpoint that set the cookie. + + + + + True if cookie partition key is opaque. + + + + + Types of reasons why a cookie may not be stored from a response. + + + + + SecureOnly + + + + + SameSiteStrict + + + + + SameSiteLax + + + + + SameSiteUnspecifiedTreatedAsLax + + + + + SameSiteNoneInsecure + + + + + UserPreferences + + + + + ThirdPartyBlockedInFirstPartySet + + + + + SyntaxError + + + + + SchemeNotSupported + + + + + OverwriteSecure + + + + + InvalidDomain + + + + + InvalidPrefix + + + + + UnknownError + + + + + SchemefulSameSiteStrict + + + + + SchemefulSameSiteLax + + + + + SchemefulSameSiteUnspecifiedTreatedAsLax + + + + + SamePartyFromCrossPartyContext + + + + + SamePartyConflictsWithOtherAttributes + + + + + NameValuePairExceedsMaxSize + + + + + Types of reasons why a cookie may not be sent with a request. + + + + + SecureOnly + + + + + NotOnPath + + + + + DomainMismatch + + + + + SameSiteStrict + + + + + SameSiteLax + + + + + SameSiteUnspecifiedTreatedAsLax + + + + + SameSiteNoneInsecure + + + + + UserPreferences + + + + + ThirdPartyBlockedInFirstPartySet + + + + + UnknownError + + + + + SchemefulSameSiteStrict + + + + + SchemefulSameSiteLax + + + + + SchemefulSameSiteUnspecifiedTreatedAsLax + + + + + SamePartyFromCrossPartyContext + + + + + NameValuePairExceedsMaxSize + + + + + A cookie which was not stored from a response with the corresponding reason. + + + + + The reason(s) this cookie was blocked. + + + + + The reason(s) this cookie was blocked. + + + + + The string representing this individual cookie as it would appear in the header. + This is not the entire "cookie" or "set-cookie" header which could have multiple cookies. + + + + + The cookie object which represents the cookie which was not stored. It is optional because + sometimes complete cookie information is not available, such as in the case of parsing + errors. + + + + + A cookie with was not sent with a request with the corresponding reason. + + + + + The reason(s) the cookie was blocked. + + + + + The reason(s) the cookie was blocked. + + + + + The cookie object representing the cookie which was not sent. + + + + + Cookie parameter object + + + + + Cookie name. + + + + + Cookie value. + + + + + The request-URI to associate with the setting of the cookie. This value can affect the + default domain, path, source port, and source scheme values of the created cookie. + + + + + Cookie domain. + + + + + Cookie path. + + + + + True if cookie is secure. + + + + + True if cookie is http-only. + + + + + Cookie SameSite type. + + + + + Cookie SameSite type. + + + + + Cookie expiration date, session cookie if not set + + + + + Cookie Priority. + + + + + Cookie Priority. + + + + + True if cookie is SameParty. + + + + + Cookie source scheme type. + + + + + Cookie source scheme type. + + + + + Cookie source port. Valid values are {-1, [1, 65535]}, -1 indicates an unspecified port. + An unspecified port value allows protocol clients to emulate legacy cookie scope for the port. + This is a temporary ability and it will be removed in the future. + + + + + Cookie partition key. The site of the top-level URL the browser was visiting at the start + of the request to the endpoint that set the cookie. + If not set, the cookie will be set as not partitioned. + + + + + Source of the authentication challenge. + + + + + Server + + + + + Proxy + + + + + Authorization challenge for HTTP status code 401 or 407. + + + + + Source of the authentication challenge. + + + + + Source of the authentication challenge. + + + + + Origin of the challenger. + + + + + The authentication scheme used, such as basic or digest + + + + + The realm of the challenge. May be empty. + + + + + The decision on what to do in response to the authorization challenge. Default means + deferring to the default behavior of the net stack, which will likely either the Cancel + authentication or display a popup dialog box. + + + + + Default + + + + + CancelAuth + + + + + ProvideCredentials + + + + + Response to an AuthChallenge. + + + + + The decision on what to do in response to the authorization challenge. Default means + deferring to the default behavior of the net stack, which will likely either the Cancel + authentication or display a popup dialog box. + + + + + The decision on what to do in response to the authorization challenge. Default means + deferring to the default behavior of the net stack, which will likely either the Cancel + authentication or display a popup dialog box. + + + + + The username to provide, possibly empty. Should only be set if response is + ProvideCredentials. + + + + + The password to provide, possibly empty. Should only be set if response is + ProvideCredentials. + + + + + Stages of the interception to begin intercepting. Request will intercept before the request is + sent. Response will intercept after the response is received. + + + + + Request + + + + + HeadersReceived + + + + + Request pattern for interception. + + + + + Wildcards (`'*'` -> zero or more, `'?'` -> exactly one) are allowed. Escape character is + backslash. Omitting is equivalent to `"*"`. + + + + + If set, only requests for matching resource types will be intercepted. + + + + + If set, only requests for matching resource types will be intercepted. + + + + + Stage at which to begin intercepting requests. Default is Request. + + + + + Stage at which to begin intercepting requests. Default is Request. + + + + + Information about a signed exchange signature. + https://wicg.github.io/webpackage/draft-yasskin-httpbis-origin-signed-exchanges-impl.html#rfc.section.3.1 + + + + + Signed exchange signature label. + + + + + The hex string of signed exchange signature. + + + + + Signed exchange signature integrity. + + + + + Signed exchange signature cert Url. + + + + + The hex string of signed exchange signature cert sha256. + + + + + Signed exchange signature validity Url. + + + + + Signed exchange signature date. + + + + + Signed exchange signature expires. + + + + + The encoded certificates. + + + + + Information about a signed exchange header. + https://wicg.github.io/webpackage/draft-yasskin-httpbis-origin-signed-exchanges-impl.html#cbor-representation + + + + + Signed exchange request URL. + + + + + Signed exchange response code. + + + + + Signed exchange response headers. + + + + + Signed exchange response signature. + + + + + Signed exchange header integrity hash in the form of "sha256-<base64-hash-value> ". + + + + + Field type for a signed exchange related error. + + + + + signatureSig + + + + + signatureIntegrity + + + + + signatureCertUrl + + + + + signatureCertSha256 + + + + + signatureValidityUrl + + + + + signatureTimestamps + + + + + Information about a signed exchange response. + + + + + Error message. + + + + + The index of the signature which caused the error. + + + + + The field which caused the error. + + + + + The field which caused the error. + + + + + Information about a signed exchange response. + + + + + The outer response of signed HTTP exchange which was received from network. + + + + + Information about the signed exchange header. + + + + + Security details for the signed exchange header. + + + + + Errors occurred while handling the signed exchagne. + + + + + List of content encodings supported by the backend. + + + + + deflate + + + + + gzip + + + + + br + + + + + PrivateNetworkRequestPolicy + + + + + Allow + + + + + BlockFromInsecureToMorePrivate + + + + + WarnFromInsecureToMorePrivate + + + + + PreflightBlock + + + + + PreflightWarn + + + + + IPAddressSpace + + + + + Local + + + + + Private + + + + + Public + + + + + Unknown + + + + + ConnectTiming + + + + + Timing's requestTime is a baseline in seconds, while the other numbers are ticks in + milliseconds relatively to this requestTime. Matches ResourceTiming's requestTime for + the same request (but not for redirected requests). + + + + + ClientSecurityState + + + + + InitiatorIsSecureContext + + + + + InitiatorIPAddressSpace + + + + + InitiatorIPAddressSpace + + + + + PrivateNetworkRequestPolicy + + + + + PrivateNetworkRequestPolicy + + + + + CrossOriginOpenerPolicyValue + + + + + SameOrigin + + + + + SameOriginAllowPopups + + + + + RestrictProperties + + + + + UnsafeNone + + + + + SameOriginPlusCoep + + + + + RestrictPropertiesPlusCoep + + + + + CrossOriginOpenerPolicyStatus + + + + + Value + + + + + Value + + + + + ReportOnlyValue + + + + + ReportOnlyValue + + + + + ReportingEndpoint + + + + + ReportOnlyReportingEndpoint + + + + + CrossOriginEmbedderPolicyValue + + + + + None + + + + + Credentialless + + + + + RequireCorp + + + + + CrossOriginEmbedderPolicyStatus + + + + + Value + + + + + Value + + + + + ReportOnlyValue + + + + + ReportOnlyValue + + + + + ReportingEndpoint + + + + + ReportOnlyReportingEndpoint + + + + + SecurityIsolationStatus + + + + + Coop + + + + + Coep + + + + + The status of a Reporting API report. + + + + + Queued + + + + + Pending + + + + + MarkedForRemoval + + + + + Success + + + + + An object representing a report generated by the Reporting API. + + + + + Id + + + + + The URL of the document that triggered the report. + + + + + The name of the endpoint group that should be used to deliver the report. + + + + + The type of the report (specifies the set of data that is contained in the report body). + + + + + When the report was generated. + + + + + How many uploads deep the related request was. + + + + + The number of delivery attempts made so far, not including an active attempt. + + + + + Body + + + + + Status + + + + + Status + + + + + ReportingApiEndpoint + + + + + The URL of the endpoint to which reports may be delivered. + + + + + Name of the endpoint group. + + + + + An object providing the result of a network resource load. + + + + + Success + + + + + Optional values used for error reporting. + + + + + NetErrorName + + + + + HttpStatusCode + + + + + If successful, one of the following two fields holds the result. + + + + + Response headers. + + + + + An options object that may be extended later to better support CORS, + CORB and streaming. + + + + + DisableCache + + + + + IncludeCredentials + + + + + Fired when data chunk was received over the network. + + + + + Request identifier. + + + + + Timestamp. + + + + + Data chunk length. + + + + + Actual bytes received (might be less than dataLength for compressed encodings). + + + + + Fired when EventSource message is received. + + + + + Request identifier. + + + + + Timestamp. + + + + + Message type. + + + + + Message identifier. + + + + + Message content. + + + + + Fired when HTTP request has failed to load. + + + + + Request identifier. + + + + + Timestamp. + + + + + Resource type. + + + + + Resource type. + + + + + User friendly error message. + + + + + True if loading was canceled. + + + + + The reason why loading was blocked, if any. + + + + + The reason why loading was blocked, if any. + + + + + The reason why loading was blocked by CORS, if any. + + + + + Fired when HTTP request has finished loading. + + + + + Request identifier. + + + + + Timestamp. + + + + + Total number of bytes received for this request. + + + + + Set when 1) response was blocked by Cross-Origin Read Blocking and also + 2) this needs to be reported to the DevTools console. + + + + + Details of an intercepted HTTP request, which must be either allowed, blocked, modified or + mocked. + Deprecated, use Fetch.requestPaused instead. + + + + + Each request the page makes will have a unique id, however if any redirects are encountered + while processing that fetch, they will be reported with the same id as the original fetch. + Likewise if HTTP authentication is needed then the same fetch id will be used. + + + + + Request + + + + + The id of the frame that initiated the request. + + + + + How the requested resource will be used. + + + + + How the requested resource will be used. + + + + + Whether this is a navigation request, which can abort the navigation completely. + + + + + Set if the request is a navigation that will result in a download. + Only present after response is received from the server (i.e. HeadersReceived stage). + + + + + Redirect location, only sent if a redirect was intercepted. + + + + + Details of the Authorization Challenge encountered. If this is set then + continueInterceptedRequest must contain an authChallengeResponse. + + + + + Response error if intercepted at response stage or if redirect occurred while intercepting + request. + + + + + Response error if intercepted at response stage or if redirect occurred while intercepting + request. + + + + + Response code if intercepted at response stage or if redirect occurred while intercepting + request or auth retry occurred. + + + + + Response headers if intercepted at the response stage or if redirect occurred while + intercepting request or auth retry occurred. + + + + + If the intercepted request had a corresponding requestWillBeSent event fired for it, then + this requestId will be the same as the requestId present in the requestWillBeSent event. + + + + + Fired if request ended up loading from cache. + + + + + Request identifier. + + + + + Fired when page is about to send HTTP request. + + + + + Request identifier. + + + + + Loader identifier. Empty string if the request is fetched from worker. + + + + + URL of the document this request is loaded for. + + + + + Request data. + + + + + Timestamp. + + + + + Timestamp. + + + + + Request initiator. + + + + + In the case that redirectResponse is populated, this flag indicates whether + requestWillBeSentExtraInfo and responseReceivedExtraInfo events will be or were emitted + for the request which was just redirected. + + + + + Redirect response data. + + + + + Type of this resource. + + + + + Type of this resource. + + + + + Frame identifier. + + + + + Whether the request is initiated by a user gesture. Defaults to false. + + + + + Fired when resource loading priority is changed + + + + + Request identifier. + + + + + New priority + + + + + New priority + + + + + Timestamp. + + + + + Fired when a signed exchange was received over the network + + + + + Request identifier. + + + + + Information about the signed exchange response. + + + + + Fired when HTTP response is available. + + + + + Request identifier. + + + + + Loader identifier. Empty string if the request is fetched from worker. + + + + + Timestamp. + + + + + Resource type. + + + + + Resource type. + + + + + Response data. + + + + + Indicates whether requestWillBeSentExtraInfo and responseReceivedExtraInfo events will be + or were emitted for this request. + + + + + Frame identifier. + + + + + Fired when WebSocket is closed. + + + + + Request identifier. + + + + + Timestamp. + + + + + Fired upon WebSocket creation. + + + + + Request identifier. + + + + + WebSocket request URL. + + + + + Request initiator. + + + + + Fired when WebSocket message error occurs. + + + + + Request identifier. + + + + + Timestamp. + + + + + WebSocket error message. + + + + + Fired when WebSocket message is received. + + + + + Request identifier. + + + + + Timestamp. + + + + + WebSocket response data. + + + + + Fired when WebSocket message is sent. + + + + + Request identifier. + + + + + Timestamp. + + + + + WebSocket response data. + + + + + Fired when WebSocket handshake response becomes available. + + + + + Request identifier. + + + + + Timestamp. + + + + + WebSocket response data. + + + + + Fired when WebSocket is about to initiate handshake. + + + + + Request identifier. + + + + + Timestamp. + + + + + UTC Timestamp. + + + + + WebSocket request data. + + + + + Fired upon WebTransport creation. + + + + + WebTransport identifier. + + + + + WebTransport request URL. + + + + + Timestamp. + + + + + Request initiator. + + + + + Fired when WebTransport handshake is finished. + + + + + WebTransport identifier. + + + + + Timestamp. + + + + + Fired when WebTransport is disposed. + + + + + WebTransport identifier. + + + + + Timestamp. + + + + + Fired when additional information about a requestWillBeSent event is available from the + network stack. Not every requestWillBeSent event will have an additional + requestWillBeSentExtraInfo fired for it, and there is no guarantee whether requestWillBeSent + or requestWillBeSentExtraInfo will be fired first for the same request. + + + + + Request identifier. Used to match this information to an existing requestWillBeSent event. + + + + + A list of cookies potentially associated to the requested URL. This includes both cookies sent with + the request and the ones not sent; the latter are distinguished by having blockedReason field set. + + + + + Raw request headers as they will be sent over the wire. + + + + + Connection timing information for the request. + + + + + The client security state set for the request. + + + + + Whether the site has partitioned cookies stored in a partition different than the current one. + + + + + Fired when additional information about a responseReceived event is available from the network + stack. Not every responseReceived event will have an additional responseReceivedExtraInfo for + it, and responseReceivedExtraInfo may be fired before or after responseReceived. + + + + + Request identifier. Used to match this information to another responseReceived event. + + + + + A list of cookies which were not stored from the response along with the corresponding + reasons for blocking. The cookies here may not be valid due to syntax errors, which + are represented by the invalid cookie line string instead of a proper cookie. + + + + + Raw response headers as they were received over the wire. + + + + + The IP address space of the resource. The address space can only be determined once the transport + established the connection, so we can't send it in `requestWillBeSentExtraInfo`. + + + + + The IP address space of the resource. The address space can only be determined once the transport + established the connection, so we can't send it in `requestWillBeSentExtraInfo`. + + + + + The status code of the response. This is useful in cases the request failed and no responseReceived + event is triggered, which is the case for, e.g., CORS errors. This is also the correct status code + for cached requests, where the status in responseReceived is a 200 and this will be 304. + + + + + Raw response header text as it was received over the wire. The raw text may not always be + available, such as in the case of HTTP/2 or QUIC. + + + + + The cookie partition key that will be used to store partitioned cookies set in this response. + Only sent when partitioned cookies are enabled. + + + + + True if partitioned cookies are enabled, but the partition key is not serializeable to string. + + + + + Detailed success or error status of the operation. + 'AlreadyExists' also signifies a successful operation, as the result + of the operation already exists und thus, the operation was abort + preemptively (e.g. a cache hit). + + + + + Ok + + + + + InvalidArgument + + + + + FailedPrecondition + + + + + ResourceExhausted + + + + + AlreadyExists + + + + + Unavailable + + + + + Unauthorized + + + + + BadResponse + + + + + InternalError + + + + + UnknownError + + + + + FulfilledLocally + + + + + Fired exactly once for each Trust Token operation. Depending on + the type of the operation and whether the operation succeeded or + failed, the event is fired before the corresponding request was sent + or after the response was received. + + + + + Detailed success or error status of the operation. + 'AlreadyExists' also signifies a successful operation, as the result + of the operation already exists und thus, the operation was abort + preemptively (e.g. a cache hit). + + + + + Detailed success or error status of the operation. + 'AlreadyExists' also signifies a successful operation, as the result + of the operation already exists und thus, the operation was abort + preemptively (e.g. a cache hit). + + + + + Type + + + + + Type + + + + + RequestId + + + + + Top level origin. The context in which the operation was attempted. + + + + + Origin of the issuer in case of a "Issuance" or "Redemption" operation. + + + + + The number of obtained Trust Tokens on a successful "Issuance" operation. + + + + + Fired once when parsing the .wbn file has succeeded. + The event contains the information about the web bundle contents. + + + + + Request identifier. Used to match this information to another event. + + + + + A list of URLs of resources in the subresource Web Bundle. + + + + + Fired once when parsing the .wbn file has failed. + + + + + Request identifier. Used to match this information to another event. + + + + + Error message + + + + + Fired when handling requests for resources within a .wbn file. + Note: this will only be fired for resources that are requested by the webpage. + + + + + Request identifier of the subresource request + + + + + URL of the subresource resource. + + + + + Bundle request identifier. Used to match this information to another event. + This made be absent in case when the instrumentation was enabled only + after webbundle was parsed. + + + + + Fired when request for resources within a .wbn file failed. + + + + + Request identifier of the subresource request + + + + + URL of the subresource resource. + + + + + Error message + + + + + Bundle request identifier. Used to match this information to another event. + This made be absent in case when the instrumentation was enabled only + after webbundle was parsed. + + + + + Is sent whenever a new report is added. + And after 'enableReportingApi' for all existing reports. + + + + + Report + + + + + reportingApiReportUpdated + + + + + Report + + + + + reportingApiEndpointsChangedForOrigin + + + + + Origin of the document(s) which configured the endpoints. + + + + + Endpoints + + + + + GetCertificateResponse + + + + + tableNames + + + + + GetCookiesResponse + + + + + cookies + + + + + GetResponseBodyResponse + + + + + body + + + + + base64Encoded + + + + + GetRequestPostDataResponse + + + + + postData + + + + + GetResponseBodyForInterceptionResponse + + + + + body + + + + + base64Encoded + + + + + TakeResponseBodyForInterceptionAsStreamResponse + + + + + stream + + + + + SearchInResponseBodyResponse + + + + + result + + + + + SetCookieResponse + + + + + success + + + + + GetSecurityIsolationStatusResponse + + + + + status + + + + + LoadNetworkResourceResponse + + + + + resource + + + + + Network domain allows tracking network activities of the page. It exposes information about http, + file, data and other requests and responses, their headers, bodies, timing, etc. + + + + + Network + + DevToolsClient + + + + Fired when data chunk was received over the network. + + + + + Fired when EventSource message is received. + + + + + Fired when HTTP request has failed to load. + + + + + Fired when HTTP request has finished loading. + + + + + Fired if request ended up loading from cache. + + + + + Fired when page is about to send HTTP request. + + + + + Fired when resource loading priority is changed + + + + + Fired when a signed exchange was received over the network + + + + + Fired when HTTP response is available. + + + + + Fired when WebSocket is closed. + + + + + Fired upon WebSocket creation. + + + + + Fired when WebSocket message error occurs. + + + + + Fired when WebSocket message is received. + + + + + Fired when WebSocket message is sent. + + + + + Fired when WebSocket handshake response becomes available. + + + + + Fired when WebSocket is about to initiate handshake. + + + + + Fired upon WebTransport creation. + + + + + Fired when WebTransport handshake is finished. + + + + + Fired when WebTransport is disposed. + + + + + Fired when additional information about a requestWillBeSent event is available from the + network stack. Not every requestWillBeSent event will have an additional + requestWillBeSentExtraInfo fired for it, and there is no guarantee whether requestWillBeSent + or requestWillBeSentExtraInfo will be fired first for the same request. + + + + + Fired when additional information about a responseReceived event is available from the network + stack. Not every responseReceived event will have an additional responseReceivedExtraInfo for + it, and responseReceivedExtraInfo may be fired before or after responseReceived. + + + + + Fired exactly once for each Trust Token operation. Depending on + the type of the operation and whether the operation succeeded or + failed, the event is fired before the corresponding request was sent + or after the response was received. + + + + + Fired once when parsing the .wbn file has succeeded. + The event contains the information about the web bundle contents. + + + + + Fired once when parsing the .wbn file has failed. + + + + + Fired when handling requests for resources within a .wbn file. + Note: this will only be fired for resources that are requested by the webpage. + + + + + Fired when request for resources within a .wbn file failed. + + + + + Is sent whenever a new report is added. + And after 'enableReportingApi' for all existing reports. + + + + + ReportingApiReportUpdated + + + + + ReportingApiEndpointsChangedForOrigin + + + + + Sets a list of content encodings that will be accepted. Empty list means no encoding is accepted. + + List of accepted content encodings. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears accepted encodings set by setAcceptedEncodings + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears browser cache. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears browser cookies. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Deletes browser cookies with matching name and url or domain/path pair. + + Name of the cookies to remove. + If specified, deletes all the cookies with the given name where domain and path matchprovided URL. + If specified, deletes only cookies with the exact domain. + If specified, deletes only cookies with the exact path. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables network tracking, prevents network events from being sent to the client. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Activates emulation of network conditions. + + True to emulate internet disconnection. + Minimum latency from request sent to response headers received (ms). + Maximal aggregated download throughput (bytes/sec). -1 disables download throttling. + Maximal aggregated upload throughput (bytes/sec). -1 disables upload throttling. + Connection type if known. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables network tracking, network events will now be delivered to the client. + + Buffer size in bytes to use when preserving network payloads (XHRs, etc). + Per-resource buffer size in bytes to use when preserving network payloads (XHRs, etc). + Longest post body size (in bytes) that would be included in requestWillBeSent notification + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns the DER-encoded certificate. + + Origin to get certificate for. + returns System.Threading.Tasks.Task<GetCertificateResponse> + + + + Returns all browser cookies for the current URL. Depending on the backend support, will return + detailed cookie information in the `cookies` field. + + The list of URLs for which applicable cookies will be fetched.If not specified, it's assumed to be set to the list containingthe URLs of the page and all of its subframes. + returns System.Threading.Tasks.Task<GetCookiesResponse> + + + + Returns content served for the given request. + + Identifier of the network request to get content for. + returns System.Threading.Tasks.Task<GetResponseBodyResponse> + + + + Returns post data sent with the request. Returns an error when no data was sent with the request. + + Identifier of the network request to get content for. + returns System.Threading.Tasks.Task<GetRequestPostDataResponse> + + + + Returns content served for the given currently intercepted request. + + Identifier for the intercepted request to get body for. + returns System.Threading.Tasks.Task<GetResponseBodyForInterceptionResponse> + + + + Returns a handle to the stream representing the response body. Note that after this command, + the intercepted request can't be continued as is -- you either need to cancel it or to provide + the response body. The stream only supports sequential read, IO.read will fail if the position + is specified. + + interceptionId + returns System.Threading.Tasks.Task<TakeResponseBodyForInterceptionAsStreamResponse> + + + + This method sends a new XMLHttpRequest which is identical to the original one. The following + parameters should be identical: method, url, async, request body, extra headers, withCredentials + attribute, user, password. + + Identifier of XHR to replay. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Searches for given string in response content. + + Identifier of the network response to search. + String to search for. + If true, search is case sensitive. + If true, treats string parameter as regex. + returns System.Threading.Tasks.Task<SearchInResponseBodyResponse> + + + + Blocks URLs from loading. + + URL patterns to block. Wildcards ('*') are allowed. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Toggles ignoring of service worker for each request. + + Bypass service worker and load from network. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Toggles ignoring cache for each request. If `true`, cache will not be used. + + Cache disabled state. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets a cookie with the given cookie data; may overwrite equivalent cookies if they exist. + + Cookie name. + Cookie value. + The request-URI to associate with the setting of the cookie. This value can affect thedefault domain, path, source port, and source scheme values of the created cookie. + Cookie domain. + Cookie path. + True if cookie is secure. + True if cookie is http-only. + Cookie SameSite type. + Cookie expiration date, session cookie if not set + Cookie Priority type. + True if cookie is SameParty. + Cookie source scheme type. + Cookie source port. Valid values are {-1, [1, 65535]}, -1 indicates an unspecified port.An unspecified port value allows protocol clients to emulate legacy cookie scope for the port.This is a temporary ability and it will be removed in the future. + Cookie partition key. The site of the top-level URL the browser was visiting at the startof the request to the endpoint that set the cookie.If not set, the cookie will be set as not partitioned. + returns System.Threading.Tasks.Task<SetCookieResponse> + + + + Sets given cookies. + + Cookies to be set. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Specifies whether to always send extra HTTP headers with the requests from this page. + + Map with extra HTTP headers. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Specifies whether to attach a page script stack id in requests + + Whether to attach a page script stack for debugging purpose. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Allows overriding user agent with the given string. + + User agent to use. + Browser langugage to emulate. + The platform navigator.platform should return. + To be sent in Sec-CH-UA-* headers and returned in navigator.userAgentData + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns information about the COEP/COOP isolation status. + + If no frameId is provided, the status of the target is provided. + returns System.Threading.Tasks.Task<GetSecurityIsolationStatusResponse> + + + + Enables tracking for the Reporting API, events generated by the Reporting API will now be delivered to the client. + Enabling triggers 'reportingApiReportAdded' for all existing reports. + + Whether to enable or disable events for the Reporting API + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Fetches the resource and returns the content. + + URL of the resource to get content for. + Options for the request. + Frame id to get the resource for. Mandatory for frame targets, andshould be omitted for worker targets. + returns System.Threading.Tasks.Task<LoadNetworkResourceResponse> + + + + Fetches the resource and returns the content. + + Frame id to get the resource for. Mandatory for frame targets, and should be omitted for worker targets. + URL of the resource to get content for. + Options for the request. + returns System.Threading.Tasks.Task<LoadNetworkResourceResponse> + + This overload of LoadNetworkResourceAsync exists to avoid a breaking change as optional params are now always at the end + where previously they weren't marked as optional when at the beginning. + + + + + Request / response headers as keys / values of JSON object. + + + CDP uses comma seperated values to store multiple header values. + Use or to get a string[] + for headers that have multiple values. + + Helper methods for dealing with comma separated header values based on https://github.com/dotnet/aspnetcore/blob/52eff90fbcfca39b7eb58baad597df6a99a542b0/src/Http/Http.Abstractions/src/Extensions/HeaderDictionaryExtensions.cs + + + + Initializes a new instance of the Headers class. + + + + + Returns itself + + Dictionary of headers + + + + Gets an array of values for the specified key. Values are comma seperated and will be split into a string[]. + Quoted values will not be split, and the quotes will be removed. + + The header name. + the associated values from the dictionary separated into individual values, or null if the key is not present. + true if the Dictionary contains an element with the specified key; otherwise, false. + + + + Get the associated values from the dictionary separated into individual values. + Quoted values will not be split, and the quotes will be removed. + + The header name. + the associated values from the dictionary separated into individual values, or null if the key is not present. + + + + Quotes any values containing commas, and then comma joins all of the values with any existing values. + + The header name. + The header values. + + + + Quotes any values containing commas, and then comma joins all of the values. + + The header name. + The header values. + + + + Configuration data for drawing the source order of an elements children. + + + + + the color to outline the givent element in. + + + + + the color to outline the child elements in. + + + + + Configuration data for the highlighting of Grid elements. + + + + + Whether the extension lines from grid cells to the rulers should be shown (default: false). + + + + + Show Positive line number labels (default: false). + + + + + Show Negative line number labels (default: false). + + + + + Show area name labels (default: false). + + + + + Show line name labels (default: false). + + + + + Show track size labels (default: false). + + + + + The grid container border highlight color (default: transparent). + + + + + The cell border color (default: transparent). Deprecated, please use rowLineColor and columnLineColor instead. + + + + + The row line color (default: transparent). + + + + + The column line color (default: transparent). + + + + + Whether the grid border is dashed (default: false). + + + + + Whether the cell border is dashed (default: false). Deprecated, please us rowLineDash and columnLineDash instead. + + + + + Whether row lines are dashed (default: false). + + + + + Whether column lines are dashed (default: false). + + + + + The row gap highlight fill color (default: transparent). + + + + + The row gap hatching fill color (default: transparent). + + + + + The column gap highlight fill color (default: transparent). + + + + + The column gap hatching fill color (default: transparent). + + + + + The named grid areas border color (Default: transparent). + + + + + The grid container background color (Default: transparent). + + + + + Configuration data for the highlighting of Flex container elements. + + + + + The style of the container border + + + + + The style of the separator between lines + + + + + The style of the separator between items + + + + + Style of content-distribution space on the main axis (justify-content). + + + + + Style of content-distribution space on the cross axis (align-content). + + + + + Style of empty space caused by row gaps (gap/row-gap). + + + + + Style of empty space caused by columns gaps (gap/column-gap). + + + + + Style of the self-alignment line (align-items). + + + + + Configuration data for the highlighting of Flex item elements. + + + + + Style of the box representing the item's base size + + + + + Style of the border around the box representing the item's base size + + + + + Style of the arrow representing if the item grew or shrank + + + + + The line pattern (default: solid) + + + + + dashed + + + + + dotted + + + + + Style information for drawing a line. + + + + + The color of the line (default: transparent) + + + + + The line pattern (default: solid) + + + + + The line pattern (default: solid) + + + + + Style information for drawing a box. + + + + + The background color for the box (default: transparent) + + + + + The hatching color for the box (default: transparent) + + + + + ContrastAlgorithm + + + + + aa + + + + + aaa + + + + + apca + + + + + Configuration data for the highlighting of page elements. + + + + + Whether the node info tooltip should be shown (default: false). + + + + + Whether the node styles in the tooltip (default: false). + + + + + Whether the rulers should be shown (default: false). + + + + + Whether the a11y info should be shown (default: true). + + + + + Whether the extension lines from node to the rulers should be shown (default: false). + + + + + The content box highlight fill color (default: transparent). + + + + + The padding highlight fill color (default: transparent). + + + + + The border highlight fill color (default: transparent). + + + + + The margin highlight fill color (default: transparent). + + + + + The event target element highlight fill color (default: transparent). + + + + + The shape outside fill color (default: transparent). + + + + + The shape margin fill color (default: transparent). + + + + + The grid layout color (default: transparent). + + + + + The color format used to format color styles (default: hex). + + + + + The color format used to format color styles (default: hex). + + + + + The grid layout highlight configuration (default: all transparent). + + + + + The flex container highlight configuration (default: all transparent). + + + + + The flex item highlight configuration (default: all transparent). + + + + + The contrast algorithm to use for the contrast ratio (default: aa). + + + + + The contrast algorithm to use for the contrast ratio (default: aa). + + + + + The container query container highlight configuration (default: all transparent). + + + + + ColorFormat + + + + + rgb + + + + + hsl + + + + + hwb + + + + + hex + + + + + Configurations for Persistent Grid Highlight + + + + + A descriptor for the highlight appearance. + + + + + Identifier of the node to highlight. + + + + + FlexNodeHighlightConfig + + + + + A descriptor for the highlight appearance of flex containers. + + + + + Identifier of the node to highlight. + + + + + ScrollSnapContainerHighlightConfig + + + + + The style of the snapport border (default: transparent) + + + + + The style of the snap area border (default: transparent) + + + + + The margin highlight fill color (default: transparent). + + + + + The padding highlight fill color (default: transparent). + + + + + ScrollSnapHighlightConfig + + + + + A descriptor for the highlight appearance of scroll snap containers. + + + + + Identifier of the node to highlight. + + + + + Configuration for dual screen hinge + + + + + A rectangle represent hinge + + + + + The content box highlight fill color (default: a dark color). + + + + + The content box highlight outline color (default: transparent). + + + + + ContainerQueryHighlightConfig + + + + + A descriptor for the highlight appearance of container query containers. + + + + + Identifier of the container node to highlight. + + + + + ContainerQueryContainerHighlightConfig + + + + + The style of the container border. + + + + + The style of the descendants' borders. + + + + + IsolatedElementHighlightConfig + + + + + A descriptor for the highlight appearance of an element in isolation mode. + + + + + Identifier of the isolated element to highlight. + + + + + IsolationModeHighlightConfig + + + + + The fill color of the resizers (default: transparent). + + + + + The fill color for resizer handles (default: transparent). + + + + + The fill color for the mask covering non-isolated elements (default: transparent). + + + + + InspectMode + + + + + searchForNode + + + + + searchForUAShadowDOM + + + + + captureAreaScreenshot + + + + + showDistances + + + + + none + + + + + Fired when the node should be inspected. This happens after call to `setInspectMode` or when + user manually inspects an element. + + + + + Id of the node to inspect. + + + + + Fired when the node should be highlighted. This happens after call to `setInspectMode`. + + + + + NodeId + + + + + Fired when user asks to capture screenshot of some area on the page. + + + + + Viewport to capture, in device independent pixels (dip). + + + + + GetHighlightObjectForTestResponse + + + + + highlight + + + + + GetGridHighlightObjectsForTestResponse + + + + + highlights + + + + + GetSourceOrderHighlightObjectForTestResponse + + + + + highlight + + + + + This domain provides various functionality related to drawing atop the inspected page. + + + + + Overlay + + DevToolsClient + + + + Fired when the node should be inspected. This happens after call to `setInspectMode` or when + user manually inspects an element. + + + + + Fired when the node should be highlighted. This happens after call to `setInspectMode`. + + + + + Fired when user asks to capture screenshot of some area on the page. + + + + + Fired when user cancels the inspect mode. + + + + + Disables domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + For testing. + + Id of the node to get highlight object for. + Whether to include distance info. + Whether to include style info. + The color format to get config with (default: hex). + Whether to show accessibility info (default: true). + returns System.Threading.Tasks.Task<GetHighlightObjectForTestResponse> + + + + For Persistent Grid testing. + + Ids of the node to get highlight object for. + returns System.Threading.Tasks.Task<GetGridHighlightObjectsForTestResponse> + + + + For Source Order Viewer testing. + + Id of the node to highlight. + returns System.Threading.Tasks.Task<GetSourceOrderHighlightObjectForTestResponse> + + + + Hides any highlight. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights DOM node with given id or with the given JavaScript object wrapper. Either nodeId or + objectId must be specified. + + A descriptor for the highlight appearance. + Identifier of the node to highlight. + Identifier of the backend node to highlight. + JavaScript object id of the node to be highlighted. + Selectors to highlight relevant nodes. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights given quad. Coordinates are absolute with respect to the main frame viewport. + + Quad to highlight + The highlight fill color (default: transparent). + The highlight outline color (default: transparent). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights given rectangle. Coordinates are absolute with respect to the main frame viewport. + + X coordinate + Y coordinate + Rectangle width + Rectangle height + The highlight fill color (default: transparent). + The highlight outline color (default: transparent). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights the source order of the children of the DOM node with given id or with the given + JavaScript object wrapper. Either nodeId or objectId must be specified. + + A descriptor for the appearance of the overlay drawing. + Identifier of the node to highlight. + Identifier of the backend node to highlight. + JavaScript object id of the node to be highlighted. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enters the 'inspect' mode. In this mode, elements that user is hovering over are highlighted. + Backend then generates 'inspectNodeRequested' event upon element selection. + + Set an inspection mode. + A descriptor for the highlight appearance of hovered-over nodes. May be omitted if `enabled== false`. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlights owner element of all frames detected to be ads. + + True for showing ad highlights + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetPausedInDebuggerMessage + + The message to display, also triggers resume and step over controls. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that backend shows debug borders on layers + + True for showing debug borders + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that backend shows the FPS counter + + True for showing the FPS counter + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Highlight multiple elements with the CSS Grid overlay. + + An array of node identifiers and descriptors for the highlight appearance. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetShowFlexOverlays + + An array of node identifiers and descriptors for the highlight appearance. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetShowScrollSnapOverlays + + An array of node identifiers and descriptors for the highlight appearance. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetShowContainerQueryOverlays + + An array of node identifiers and descriptors for the highlight appearance. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that backend shows paint rectangles + + True for showing paint rectangles + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that backend shows layout shift regions + + True for showing layout shift regions + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests that backend shows scroll bottleneck rects + + True for showing scroll bottleneck rects + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Request that backend shows an overlay with web vital metrics. + + show + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Paints viewport size upon main frame resize. + + Whether to paint size or not. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Add a dual screen device hinge + + hinge data, null means hideHinge + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Show elements in isolation mode with overlays. + + An array of node identifiers and descriptors for the highlight appearance. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Indicates whether a frame has been identified as an ad. + + + + + none + + + + + child + + + + + root + + + + + AdFrameExplanation + + + + + ParentIsAd + + + + + CreatedByAdScript + + + + + MatchedBlockingRule + + + + + Indicates whether a frame has been identified as an ad and why. + + + + + AdFrameType + + + + + AdFrameType + + + + + Explanations + + + + + Explanations + + + + + Identifies the bottom-most script which caused the frame to be labelled + as an ad. + + + + + Script Id of the bottom-most script which caused the frame to be labelled + as an ad. + + + + + Id of adScriptId's debugger. + + + + + Indicates whether the frame is a secure context and why it is the case. + + + + + Secure + + + + + SecureLocalhost + + + + + InsecureScheme + + + + + InsecureAncestor + + + + + Indicates whether the frame is cross-origin isolated and why it is the case. + + + + + Isolated + + + + + NotIsolated + + + + + NotIsolatedFeatureDisabled + + + + + GatedAPIFeatures + + + + + SharedArrayBuffers + + + + + SharedArrayBuffersTransferAllowed + + + + + PerformanceMeasureMemory + + + + + PerformanceProfile + + + + + All Permissions Policy features. This enum should match the one defined + in third_party/blink/renderer/core/permissions_policy/permissions_policy_features.json5. + + + + + accelerometer + + + + + ambient-light-sensor + + + + + attribution-reporting + + + + + autoplay + + + + + bluetooth + + + + + browsing-topics + + + + + camera + + + + + ch-dpr + + + + + ch-device-memory + + + + + ch-downlink + + + + + ch-ect + + + + + ch-prefers-color-scheme + + + + + ch-prefers-reduced-motion + + + + + ch-rtt + + + + + ch-save-data + + + + + ch-ua + + + + + ch-ua-arch + + + + + ch-ua-bitness + + + + + ch-ua-platform + + + + + ch-ua-model + + + + + ch-ua-mobile + + + + + ch-ua-full + + + + + ch-ua-full-version + + + + + ch-ua-full-version-list + + + + + ch-ua-platform-version + + + + + ch-ua-reduced + + + + + ch-ua-wow64 + + + + + ch-viewport-height + + + + + ch-viewport-width + + + + + ch-width + + + + + clipboard-read + + + + + clipboard-write + + + + + compute-pressure + + + + + cross-origin-isolated + + + + + direct-sockets + + + + + display-capture + + + + + document-domain + + + + + encrypted-media + + + + + execution-while-out-of-viewport + + + + + execution-while-not-rendered + + + + + focus-without-user-activation + + + + + fullscreen + + + + + frobulate + + + + + gamepad + + + + + geolocation + + + + + gyroscope + + + + + hid + + + + + identity-credentials-get + + + + + idle-detection + + + + + interest-cohort + + + + + join-ad-interest-group + + + + + keyboard-map + + + + + local-fonts + + + + + magnetometer + + + + + microphone + + + + + midi + + + + + otp-credentials + + + + + payment + + + + + picture-in-picture + + + + + private-aggregation + + + + + publickey-credentials-get + + + + + run-ad-auction + + + + + screen-wake-lock + + + + + serial + + + + + shared-autofill + + + + + shared-storage + + + + + shared-storage-select-url + + + + + smart-card + + + + + storage-access + + + + + sync-xhr + + + + + trust-token-redemption + + + + + unload + + + + + usb + + + + + vertical-scroll + + + + + web-share + + + + + window-management + + + + + window-placement + + + + + xr-spatial-tracking + + + + + Reason for a permissions policy feature to be disabled. + + + + + Header + + + + + IframeAttribute + + + + + InFencedFrameTree + + + + + InIsolatedApp + + + + + PermissionsPolicyBlockLocator + + + + + FrameId + + + + + BlockReason + + + + + BlockReason + + + + + PermissionsPolicyFeatureState + + + + + Feature + + + + + Feature + + + + + Allowed + + + + + Locator + + + + + Origin Trial(https://www.chromium.org/blink/origin-trials) support. + Status for an Origin Trial token. + + + + + Success + + + + + NotSupported + + + + + Insecure + + + + + Expired + + + + + WrongOrigin + + + + + InvalidSignature + + + + + Malformed + + + + + WrongVersion + + + + + FeatureDisabled + + + + + TokenDisabled + + + + + FeatureDisabledForUser + + + + + UnknownTrial + + + + + Status for an Origin Trial. + + + + + Enabled + + + + + ValidTokenNotProvided + + + + + OSNotSupported + + + + + TrialNotAllowed + + + + + OriginTrialUsageRestriction + + + + + None + + + + + Subset + + + + + OriginTrialToken + + + + + Origin + + + + + MatchSubDomains + + + + + TrialName + + + + + ExpiryTime + + + + + IsThirdParty + + + + + UsageRestriction + + + + + UsageRestriction + + + + + OriginTrialTokenWithStatus + + + + + RawTokenText + + + + + `parsedToken` is present only when the token is extractable and + parsable. + + + + + Status + + + + + Status + + + + + OriginTrial + + + + + TrialName + + + + + Status + + + + + Status + + + + + TokensWithStatus + + + + + Information about the Frame on the page. + + + + + Frame unique identifier. + + + + + Parent frame identifier. + + + + + Identifier of the loader associated with this frame. + + + + + Frame's name as specified in the tag. + + + + + Frame document's URL without fragment. + + + + + Frame document's URL fragment including the '#'. + + + + + Frame document's registered domain, taking the public suffixes list into account. + Extracted from the Frame's url. + Example URLs: http://www.google.com/file.html -> "google.com" + http://a.b.co.uk/file.html -> "b.co.uk" + + + + + Frame document's security origin. + + + + + Frame document's mimeType as determined by the browser. + + + + + If the frame failed to load, this contains the URL that could not be loaded. Note that unlike url above, this URL may contain a fragment. + + + + + Indicates whether this frame was tagged as an ad and why. + + + + + Indicates whether the main document is a secure context and explains why that is the case. + + + + + Indicates whether the main document is a secure context and explains why that is the case. + + + + + Indicates whether this is a cross origin isolated context. + + + + + Indicates whether this is a cross origin isolated context. + + + + + Indicated which gated APIs / features are available. + + + + + Indicated which gated APIs / features are available. + + + + + Information about the Resource on the page. + + + + + Resource URL. + + + + + Type of this resource. + + + + + Type of this resource. + + + + + Resource mimeType as determined by the browser. + + + + + last-modified timestamp as reported by server. + + + + + Resource content size. + + + + + True if the resource failed to load. + + + + + True if the resource was canceled during loading. + + + + + Information about the Frame hierarchy along with their cached resources. + + + + + Frame information for this tree item. + + + + + Child frames. + + + + + Information about frame resources. + + + + + Information about the Frame hierarchy. + + + + + Frame information for this tree item. + + + + + Child frames. + + + + + Transition type. + + + + + link + + + + + typed + + + + + address_bar + + + + + auto_bookmark + + + + + auto_subframe + + + + + manual_subframe + + + + + generated + + + + + auto_toplevel + + + + + form_submit + + + + + reload + + + + + keyword + + + + + keyword_generated + + + + + other + + + + + Navigation history entry. + + + + + Unique id of the navigation history entry. + + + + + URL of the navigation history entry. + + + + + URL that the user typed in the url bar. + + + + + Title of the navigation history entry. + + + + + Transition type. + + + + + Transition type. + + + + + Screencast frame metadata. + + + + + Top offset in DIP. + + + + + Page scale factor. + + + + + Device screen width in DIP. + + + + + Device screen height in DIP. + + + + + Position of horizontal scroll in CSS pixels. + + + + + Position of vertical scroll in CSS pixels. + + + + + Frame swap timestamp. + + + + + Javascript dialog type. + + + + + alert + + + + + confirm + + + + + prompt + + + + + beforeunload + + + + + Error while paring app manifest. + + + + + Error message. + + + + + If criticial, this is a non-recoverable parse error. + + + + + Error line. + + + + + Error column. + + + + + Parsed app manifest properties. + + + + + Computed scope value + + + + + Layout viewport position and dimensions. + + + + + Horizontal offset relative to the document (CSS pixels). + + + + + Vertical offset relative to the document (CSS pixels). + + + + + Width (CSS pixels), excludes scrollbar if present. + + + + + Height (CSS pixels), excludes scrollbar if present. + + + + + Visual viewport position, dimensions, and scale. + + + + + Horizontal offset relative to the layout viewport (CSS pixels). + + + + + Vertical offset relative to the layout viewport (CSS pixels). + + + + + Horizontal offset relative to the document (CSS pixels). + + + + + Vertical offset relative to the document (CSS pixels). + + + + + Width (CSS pixels), excludes scrollbar if present. + + + + + Height (CSS pixels), excludes scrollbar if present. + + + + + Scale relative to the ideal viewport (size at width=device-width). + + + + + Page zoom factor (CSS to device independent pixels ratio). + + + + + Viewport for capturing screenshot. + + + + + X offset in device independent pixels (dip). + + + + + Y offset in device independent pixels (dip). + + + + + Rectangle width in device independent pixels (dip). + + + + + Rectangle height in device independent pixels (dip). + + + + + Page scale factor. + + + + + Default Constructor + + + + + Generic font families collection. + + + + + The standard font-family. + + + + + The fixed font-family. + + + + + The serif font-family. + + + + + The sansSerif font-family. + + + + + The cursive font-family. + + + + + The fantasy font-family. + + + + + The math font-family. + + + + + Font families collection for a script. + + + + + Name of the script which these font families are defined for. + + + + + Generic font families collection for the script. + + + + + Default font sizes. + + + + + Default standard font size. + + + + + Default fixed font size. + + + + + ClientNavigationReason + + + + + formSubmissionGet + + + + + formSubmissionPost + + + + + httpHeaderRefresh + + + + + scriptInitiated + + + + + metaTagRefresh + + + + + pageBlockInterstitial + + + + + reload + + + + + anchorClick + + + + + ClientNavigationDisposition + + + + + currentTab + + + + + newTab + + + + + newWindow + + + + + download + + + + + InstallabilityErrorArgument + + + + + Argument name (e.g. name:'minimum-icon-size-in-pixels'). + + + + + Argument value (e.g. value:'64'). + + + + + The installability error + + + + + The error id (e.g. 'manifest-missing-suitable-icon'). + + + + + The list of error arguments (e.g. {name:'minimum-icon-size-in-pixels', value:'64'}). + + + + + The referring-policy used for the navigation. + + + + + noReferrer + + + + + noReferrerWhenDowngrade + + + + + origin + + + + + originWhenCrossOrigin + + + + + sameOrigin + + + + + strictOrigin + + + + + strictOriginWhenCrossOrigin + + + + + unsafeUrl + + + + + Per-script compilation cache parameters for `Page.produceCompilationCache` + + + + + The URL of the script to produce a compilation cache entry for. + + + + + A hint to the backend whether eager compilation is recommended. + (the actual compilation mode used is upon backend discretion). + + + + + Enum of possible auto-reponse for permisison / prompt dialogs. + + + + + none + + + + + autoAccept + + + + + autoReject + + + + + autoOptOut + + + + + The type of a frameNavigated event. + + + + + Navigation + + + + + BackForwardCacheRestore + + + + + List of not restored reasons for back-forward cache. + + + + + NotPrimaryMainFrame + + + + + BackForwardCacheDisabled + + + + + RelatedActiveContentsExist + + + + + HTTPStatusNotOK + + + + + SchemeNotHTTPOrHTTPS + + + + + Loading + + + + + WasGrantedMediaAccess + + + + + DisableForRenderFrameHostCalled + + + + + DomainNotAllowed + + + + + HTTPMethodNotGET + + + + + SubframeIsNavigating + + + + + Timeout + + + + + CacheLimit + + + + + JavaScriptExecution + + + + + RendererProcessKilled + + + + + RendererProcessCrashed + + + + + SchedulerTrackedFeatureUsed + + + + + ConflictingBrowsingInstance + + + + + CacheFlushed + + + + + ServiceWorkerVersionActivation + + + + + SessionRestored + + + + + ServiceWorkerPostMessage + + + + + EnteredBackForwardCacheBeforeServiceWorkerHostAdded + + + + + RenderFrameHostReused_SameSite + + + + + RenderFrameHostReused_CrossSite + + + + + ServiceWorkerClaim + + + + + IgnoreEventAndEvict + + + + + HaveInnerContents + + + + + TimeoutPuttingInCache + + + + + BackForwardCacheDisabledByLowMemory + + + + + BackForwardCacheDisabledByCommandLine + + + + + NetworkRequestDatapipeDrainedAsBytesConsumer + + + + + NetworkRequestRedirected + + + + + NetworkRequestTimeout + + + + + NetworkExceedsBufferLimit + + + + + NavigationCancelledWhileRestoring + + + + + NotMostRecentNavigationEntry + + + + + BackForwardCacheDisabledForPrerender + + + + + UserAgentOverrideDiffers + + + + + ForegroundCacheLimit + + + + + BrowsingInstanceNotSwapped + + + + + BackForwardCacheDisabledForDelegate + + + + + UnloadHandlerExistsInMainFrame + + + + + UnloadHandlerExistsInSubFrame + + + + + ServiceWorkerUnregistration + + + + + CacheControlNoStore + + + + + CacheControlNoStoreCookieModified + + + + + CacheControlNoStoreHTTPOnlyCookieModified + + + + + NoResponseHead + + + + + Unknown + + + + + ActivationNavigationsDisallowedForBug1234857 + + + + + ErrorDocument + + + + + FencedFramesEmbedder + + + + + WebSocket + + + + + WebTransport + + + + + WebRTC + + + + + MainResourceHasCacheControlNoStore + + + + + MainResourceHasCacheControlNoCache + + + + + SubresourceHasCacheControlNoStore + + + + + SubresourceHasCacheControlNoCache + + + + + ContainsPlugins + + + + + DocumentLoaded + + + + + DedicatedWorkerOrWorklet + + + + + OutstandingNetworkRequestOthers + + + + + OutstandingIndexedDBTransaction + + + + + RequestedMIDIPermission + + + + + RequestedAudioCapturePermission + + + + + RequestedVideoCapturePermission + + + + + RequestedBackForwardCacheBlockedSensors + + + + + RequestedBackgroundWorkPermission + + + + + BroadcastChannel + + + + + IndexedDBConnection + + + + + WebXR + + + + + SharedWorker + + + + + WebLocks + + + + + WebHID + + + + + WebShare + + + + + RequestedStorageAccessGrant + + + + + WebNfc + + + + + OutstandingNetworkRequestFetch + + + + + OutstandingNetworkRequestXHR + + + + + AppBanner + + + + + Printing + + + + + WebDatabase + + + + + PictureInPicture + + + + + Portal + + + + + SpeechRecognizer + + + + + IdleManager + + + + + PaymentManager + + + + + SpeechSynthesis + + + + + KeyboardLock + + + + + WebOTPService + + + + + OutstandingNetworkRequestDirectSocket + + + + + InjectedJavascript + + + + + InjectedStyleSheet + + + + + KeepaliveRequest + + + + + IndexedDBEvent + + + + + Dummy + + + + + AuthorizationHeader + + + + + ContentSecurityHandler + + + + + ContentWebAuthenticationAPI + + + + + ContentFileChooser + + + + + ContentSerial + + + + + ContentFileSystemAccess + + + + + ContentMediaDevicesDispatcherHost + + + + + ContentWebBluetooth + + + + + ContentWebUSB + + + + + ContentMediaSessionService + + + + + ContentScreenReader + + + + + EmbedderPopupBlockerTabHelper + + + + + EmbedderSafeBrowsingTriggeredPopupBlocker + + + + + EmbedderSafeBrowsingThreatDetails + + + + + EmbedderAppBannerManager + + + + + EmbedderDomDistillerViewerSource + + + + + EmbedderDomDistillerSelfDeletingRequestDelegate + + + + + EmbedderOomInterventionTabHelper + + + + + EmbedderOfflinePage + + + + + EmbedderChromePasswordManagerClientBindCredentialManager + + + + + EmbedderPermissionRequestManager + + + + + EmbedderModalDialog + + + + + EmbedderExtensions + + + + + EmbedderExtensionMessaging + + + + + EmbedderExtensionMessagingForOpenPort + + + + + EmbedderExtensionSentMessageToCachedFrame + + + + + Types of not restored reasons for back-forward cache. + + + + + SupportPending + + + + + PageSupportNeeded + + + + + Circumstantial + + + + + BackForwardCacheNotRestoredExplanation + + + + + Type of the reason + + + + + Type of the reason + + + + + Not restored reason + + + + + Not restored reason + + + + + Context associated with the reason. The meaning of this context is + dependent on the reason: + - EmbedderExtensionSentMessageToCachedFrame: the extension ID. + + + + + BackForwardCacheNotRestoredExplanationTree + + + + + URL of each frame + + + + + Not restored reasons of each frame + + + + + Array of children frame + + + + + domContentEventFired + + + + + Timestamp + + + + + Input mode. + + + + + selectSingle + + + + + selectMultiple + + + + + Emitted only when `page.interceptFileChooser` is enabled. + + + + + Id of the frame containing input node. + + + + + Input mode. + + + + + Input mode. + + + + + Input node id. Only present for file choosers opened via an <input type="file" > element. + + + + + Fired when frame has been attached to its parent. + + + + + Id of the frame that has been attached. + + + + + Parent frame identifier. + + + + + JavaScript stack trace of when frame was attached, only set if frame initiated from script. + + + + + Fired when frame no longer has a scheduled navigation. + + + + + Id of the frame that has cleared its scheduled navigation. + + + + + FrameDetachedReason + + + + + remove + + + + + swap + + + + + Fired when frame has been detached from its parent. + + + + + Id of the frame that has been detached. + + + + + Reason + + + + + Reason + + + + + Fired once navigation of the frame has completed. Frame is now associated with the new loader. + + + + + Frame object. + + + + + Type + + + + + Type + + + + + Fired when opening document to write to. + + + + + Frame object. + + + + + Fired when a renderer-initiated navigation is requested. + Navigation may still be cancelled after the event is issued. + + + + + Id of the frame that is being navigated. + + + + + The reason for the navigation. + + + + + The reason for the navigation. + + + + + The destination URL for the requested navigation. + + + + + The disposition for the navigation. + + + + + The disposition for the navigation. + + + + + Fired when frame schedules a potential navigation. + + + + + Id of the frame that has scheduled a navigation. + + + + + Delay (in seconds) until the navigation is scheduled to begin. The navigation is not + guaranteed to start. + + + + + The reason for the navigation. + + + + + The reason for the navigation. + + + + + The destination URL for the scheduled navigation. + + + + + Fired when frame has started loading. + + + + + Id of the frame that has started loading. + + + + + Fired when frame has stopped loading. + + + + + Id of the frame that has stopped loading. + + + + + Fired when page is about to start a download. + Deprecated. Use Browser.downloadWillBegin instead. + + + + + Id of the frame that caused download to begin. + + + + + Global unique identifier of the download. + + + + + URL of the resource being downloaded. + + + + + Suggested file name of the resource (the actual name of the file saved on disk may differ). + + + + + Download status. + + + + + inProgress + + + + + completed + + + + + canceled + + + + + Fired when download makes progress. Last call has |done| == true. + Deprecated. Use Browser.downloadProgress instead. + + + + + Global unique identifier of the download. + + + + + Total expected bytes to download. + + + + + Total bytes received. + + + + + Download status. + + + + + Download status. + + + + + Fired when a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload) has been + closed. + + + + + Whether dialog was confirmed. + + + + + User input in case of prompt. + + + + + Fired when a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload) is about to + open. + + + + + Frame url. + + + + + Message that will be displayed by the dialog. + + + + + Dialog type. + + + + + Dialog type. + + + + + True iff browser is capable showing or acting on the given dialog. When browser has no + dialog handler for given target, calling alert while Page domain is engaged will stall + the page execution. Execution can be resumed via calling Page.handleJavaScriptDialog. + + + + + Default dialog prompt. + + + + + Fired for top level page lifecycle events such as navigation, load, paint, etc. + + + + + Id of the frame. + + + + + Loader identifier. Empty string if the request is fetched from worker. + + + + + Name + + + + + Timestamp + + + + + Fired for failed bfcache history navigations if BackForwardCache feature is enabled. Do + not assume any ordering with the Page.frameNavigated event. This event is fired only for + main-frame history navigation where the document changes (non-same-document navigations), + when bfcache navigation fails. + + + + + The loader id for the associated navgation. + + + + + The frame id of the associated frame. + + + + + Array of reasons why the page could not be cached. This must not be empty. + + + + + Tree structure of reasons why the page could not be cached for each frame. + + + + + loadEventFired + + + + + Timestamp + + + + + Fired when same-document navigation happens, e.g. due to history API usage or anchor navigation. + + + + + Id of the frame. + + + + + Frame's new url. + + + + + Compressed image data requested by the `startScreencast`. + + + + + Base64-encoded compressed image. + + + + + Screencast frame metadata. + + + + + Frame number. + + + + + Fired when the page with currently enabled screencast was shown or hidden `. + + + + + True if the page is visible. + + + + + Fired when a new window is going to be opened, via window.open(), link click, form submission, + etc. + + + + + The URL for the new window. + + + + + Window name. + + + + + An array of enabled window features. + + + + + Whether or not it was triggered by user gesture. + + + + + Issued for every compilation cache generated. Is only available + if Page.setGenerateCompilationCache is enabled. + + + + + Url + + + + + Base64-encoded data + + + + + AddScriptToEvaluateOnNewDocumentResponse + + + + + identifier + + + + + CaptureScreenshotResponse + + + + + data + + + + + CaptureSnapshotResponse + + + + + data + + + + + CreateIsolatedWorldResponse + + + + + executionContextId + + + + + GetAppManifestResponse + + + + + url + + + + + errors + + + + + data + + + + + parsed + + + + + GetInstallabilityErrorsResponse + + + + + installabilityErrors + + + + + GetAppIdResponse + + + + + appId + + + + + recommendedId + + + + + GetAdScriptIdResponse + + + + + adScriptId + + + + + GetFrameTreeResponse + + + + + frameTree + + + + + GetLayoutMetricsResponse + + + + + layoutViewport + + + + + visualViewport + + + + + contentSize + + + + + cssLayoutViewport + + + + + cssVisualViewport + + + + + cssContentSize + + + + + GetNavigationHistoryResponse + + + + + currentIndex + + + + + entries + + + + + GetResourceContentResponse + + + + + content + + + + + base64Encoded + + + + + GetResourceTreeResponse + + + + + frameTree + + + + + NavigateResponse + + + + + frameId + + + + + loaderId + + + + + errorText + + + + + PrintToPDFResponse + + + + + data + + + + + stream + + + + + SearchInResourceResponse + + + + + result + + + + + GetPermissionsPolicyStateResponse + + + + + states + + + + + GetOriginTrialsResponse + + + + + originTrials + + + + + Image compression format (defaults to png). + + + + + jpeg + + + + + png + + + + + webp + + + + + Format (defaults to mhtml). + + + + + mhtml + + + + + return as stream + + + + + ReturnAsBase64 + + + + + ReturnAsStream + + + + + Image compression format. + + + + + jpeg + + + + + png + + + + + Target lifecycle state + + + + + frozen + + + + + active + + + + + Actions and events related to the inspected page belong to the page domain. + + + + + Page + + DevToolsClient + + + + DomContentEventFired + + + + + Emitted only when `page.interceptFileChooser` is enabled. + + + + + Fired when frame has been attached to its parent. + + + + + Fired when frame has been detached from its parent. + + + + + Fired once navigation of the frame has completed. Frame is now associated with the new loader. + + + + + Fired when opening document to write to. + + + + + FrameResized + + + + + Fired when a renderer-initiated navigation is requested. + Navigation may still be cancelled after the event is issued. + + + + + Fired when frame has started loading. + + + + + Fired when frame has stopped loading. + + + + + Fired when interstitial page was hidden + + + + + Fired when interstitial page was shown + + + + + Fired when a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload) has been + closed. + + + + + Fired when a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload) is about to + open. + + + + + Fired for top level page lifecycle events such as navigation, load, paint, etc. + + + + + Fired for failed bfcache history navigations if BackForwardCache feature is enabled. Do + not assume any ordering with the Page.frameNavigated event. This event is fired only for + main-frame history navigation where the document changes (non-same-document navigations), + when bfcache navigation fails. + + + + + LoadEventFired + + + + + Fired when same-document navigation happens, e.g. due to history API usage or anchor navigation. + + + + + Compressed image data requested by the `startScreencast`. + + + + + Fired when the page with currently enabled screencast was shown or hidden `. + + + + + Fired when a new window is going to be opened, via window.open(), link click, form submission, + etc. + + + + + Issued for every compilation cache generated. Is only available + if Page.setGenerateCompilationCache is enabled. + + + + + Evaluates given script in every frame upon creation (before loading frame's scripts). + + source + If specified, creates an isolated world with the given name and evaluates given script in it.This world name will be used as the ExecutionContextDescription::name when the correspondingevent is emitted. + Specifies whether command line API should be available to the script, defaultsto false. + returns System.Threading.Tasks.Task<AddScriptToEvaluateOnNewDocumentResponse> + + + + Brings page to front (activates tab). + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Capture page screenshot. + + Image compression format (defaults to png). + Compression quality from range [0..100] (jpeg only). + Capture the screenshot of a given region only. + Capture the screenshot from the surface, rather than the view. Defaults to true. + Capture the screenshot beyond the viewport. Defaults to false. + Optimize image encoding for speed, not for resulting size (defaults to false) + returns System.Threading.Tasks.Task<CaptureScreenshotResponse> + + + + Returns a snapshot of the page as a string. For MHTML format, the serialization includes + iframes, shadow DOM, external resources, and element-inline styles. + + Format (defaults to mhtml). + returns System.Threading.Tasks.Task<CaptureSnapshotResponse> + + + + Creates an isolated world for the given frame. + + Id of the frame in which the isolated world should be created. + An optional name which is reported in the Execution Context. + Whether or not universal access should be granted to the isolated world. This is a powerfuloption, use with caution. + returns System.Threading.Tasks.Task<CreateIsolatedWorldResponse> + + + + Disables page domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables page domain notifications. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + GetAppManifest + + returns System.Threading.Tasks.Task<GetAppManifestResponse> + + + + GetInstallabilityErrors + + returns System.Threading.Tasks.Task<GetInstallabilityErrorsResponse> + + + + Returns the unique (PWA) app id. + Only returns values if the feature flag 'WebAppEnableManifestId' is enabled + + returns System.Threading.Tasks.Task<GetAppIdResponse> + + + + GetAdScriptId + + frameId + returns System.Threading.Tasks.Task<GetAdScriptIdResponse> + + + + Returns present frame tree structure. + + returns System.Threading.Tasks.Task<GetFrameTreeResponse> + + + + Returns metrics relating to the layouting of the page, such as viewport bounds/scale. + + returns System.Threading.Tasks.Task<GetLayoutMetricsResponse> + + + + Returns navigation history for the current page. + + returns System.Threading.Tasks.Task<GetNavigationHistoryResponse> + + + + Resets navigation history for the current page. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns content of the given resource. + + Frame id to get resource for. + URL of the resource to get content for. + returns System.Threading.Tasks.Task<GetResourceContentResponse> + + + + Returns present frame / resource tree structure. + + returns System.Threading.Tasks.Task<GetResourceTreeResponse> + + + + Accepts or dismisses a JavaScript initiated dialog (alert, confirm, prompt, or onbeforeunload). + + Whether to accept or dismiss the dialog. + The text to enter into the dialog prompt before accepting. Used only if this is a promptdialog. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Navigates current page to the given URL. + + URL to navigate the page to. + Referrer URL. + Intended transition type. + Frame id to navigate, if not specified navigates the top frame. + Referrer-policy used for the navigation. + returns System.Threading.Tasks.Task<NavigateResponse> + + + + Navigates current page to the given history entry. + + Unique id of the entry to navigate to. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Print page as PDF. + + Paper orientation. Defaults to false. + Display header and footer. Defaults to false. + Print background graphics. Defaults to false. + Scale of the webpage rendering. Defaults to 1. + Paper width in inches. Defaults to 8.5 inches. + Paper height in inches. Defaults to 11 inches. + Top margin in inches. Defaults to 1cm (~0.4 inches). + Bottom margin in inches. Defaults to 1cm (~0.4 inches). + Left margin in inches. Defaults to 1cm (~0.4 inches). + Right margin in inches. Defaults to 1cm (~0.4 inches). + Paper ranges to print, one based, e.g., '1-5, 8, 11-13'. Pages areprinted in the document order, not in the order specified, and nomore than once.Defaults to empty string, which implies the entire document is printed.The page numbers are quietly capped to actual page count of thedocument, and ranges beyond the end of the document are ignored.If this results in no pages to print, an error is reported.It is an error to specify a range with start greater than end. + HTML template for the print header. Should be valid HTML markup with followingclasses used to inject printing values into them:- `date`: formatted print date- `title`: document title- `url`: document location- `pageNumber`: current page number- `totalPages`: total pages in the documentFor example, `<span class=title> </span>` would generate span containing the title. + HTML template for the print footer. Should use the same format as the `headerTemplate`. + Whether or not to prefer page size as defined by css. Defaults to false,in which case the content will be scaled to fit the paper size. + return as stream + returns System.Threading.Tasks.Task<PrintToPDFResponse> + + + + Reloads given page optionally ignoring the cache. + + If true, browser cache is ignored (as if the user pressed Shift+refresh). + If set, the script will be injected into all frames of the inspected page after reload.Argument will be ignored if reloading dataURL origin. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes given script from the list. + + identifier + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Acknowledges that a screencast frame has been received by the frontend. + + Frame number. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Searches for given string in resource content. + + Frame id for resource to search in. + URL of the resource to search in. + String to search for. + If true, search is case sensitive. + If true, treats string parameter as regex. + returns System.Threading.Tasks.Task<SearchInResourceResponse> + + + + Enable Chrome's experimental ad filter on all sites. + + Whether to block ads. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable page Content Security Policy by-passing. + + Whether to bypass page CSP. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Get Permissions Policy state on given frame. + + frameId + returns System.Threading.Tasks.Task<GetPermissionsPolicyStateResponse> + + + + Get Origin Trials on given frame. + + frameId + returns System.Threading.Tasks.Task<GetOriginTrialsResponse> + + + + Set generic font families. + + Specifies font families to set. If a font family is not specified, it won't be changed. + Specifies font families to set for individual scripts. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Set default font sizes. + + Specifies font sizes to set. If a font size is not specified, it won't be changed. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets given markup as the document's HTML. + + Frame id to set HTML for. + HTML content to set. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Controls whether page will emit lifecycle events. + + If true, starts emitting lifecycle events. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Starts sending each frame using the `screencastFrame` event. + + Image compression format. + Compression quality from range [0..100]. + Maximum screenshot width. + Maximum screenshot height. + Send every n-th frame. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Force the page stop all navigations and pending resource fetches. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Crashes renderer on the IO thread, generates minidumps. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Tries to close page, running its beforeunload hooks, if any. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Tries to update the web lifecycle state of the page. + It will transition the page to the given state according to: + https://github.com/WICG/web-lifecycle/ + + Target lifecycle state + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Stops sending each frame in the `screencastFrame`. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Requests backend to produce compilation cache for the specified scripts. + `scripts` are appeneded to the list of scripts for which the cache + would be produced. The list may be reset during page navigation. + When script with a matching URL is encountered, the cache is optionally + produced upon backend discretion, based on internal heuristics. + See also: `Page.compilationCacheProduced`. + + scripts + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Seeds compilation cache for given url. Compilation cache does not survive + cross-process navigation. + + url + Base64-encoded data + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears seeded compilation cache. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets the Secure Payment Confirmation transaction mode. + https://w3c.github.io/secure-payment-confirmation/#sctn-automation-set-spc-transaction-mode + + mode + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Extensions for Custom Handlers API: + https://html.spec.whatwg.org/multipage/system-state.html#rph-automation + + mode + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Generates a report for testing. + + Message to be displayed in the report. + Specifies the endpoint group to deliver the report to. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Pauses page execution. Can be resumed using generic Runtime.runIfWaitingForDebugger. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Intercept file chooser requests and transfer control to protocol clients. + When file chooser interception is enabled, native file chooser dialog is not shown. + Instead, a protocol event `Page.fileChooserOpened` is emitted. + + enabled + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Run-time execution metric. + + + + + Metric name. + + + + + Metric value. + + + + + Current values of the metrics. + + + + + Current values of the metrics. + + + + + Timestamp title. + + + + + GetMetricsResponse + + + + + metrics + + + + + Time domain to use for collecting and reporting duration metrics. + + + + + timeTicks + + + + + threadTicks + + + + + Performance + + + + + Performance + + DevToolsClient + + + + Current values of the metrics. + + + + + Disable collecting and reporting metrics. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable collecting and reporting metrics. + + Time domain to use for collecting and reporting duration metrics. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Retrieve current values of run-time metrics. + + returns System.Threading.Tasks.Task<GetMetricsResponse> + + + + See https://github.com/WICG/LargestContentfulPaint and largest_contentful_paint.idl + + + + + RenderTime + + + + + LoadTime + + + + + The number of pixels being painted. + + + + + The id attribute of the element, if available. + + + + + The URL of the image (may be trimmed). + + + + + NodeId + + + + + LayoutShiftAttribution + + + + + PreviousRect + + + + + CurrentRect + + + + + NodeId + + + + + See https://wicg.github.io/layout-instability/#sec-layout-shift and layout_shift.idl + + + + + Score increment produced by this event. + + + + + HadRecentInput + + + + + LastInputTime + + + + + Sources + + + + + TimelineEvent + + + + + Identifies the frame that this event is related to. Empty for non-frame targets. + + + + + The event type, as specified in https://w3c.github.io/performance-timeline/#dom-performanceentry-entrytype + This determines which of the optional "details" fiedls is present. + + + + + Name may be empty depending on the type. + + + + + Time in seconds since Epoch, monotonically increasing within document lifetime. + + + + + Event duration, if applicable. + + + + + LcpDetails + + + + + LayoutShiftDetails + + + + + Sent when a performance timeline event is added. See reportPerformanceTimeline method. + + + + + Event + + + + + Reporting of performance timeline events, as specified in + https://w3c.github.io/performance-timeline/#dom-performanceobserver. + + + + + PerformanceTimeline + + DevToolsClient + + + + Sent when a performance timeline event is added. See reportPerformanceTimeline method. + + + + + Previously buffered events would be reported before method returns. + See also: timelineEventAdded + + The types of event to report, as specified inhttps://w3c.github.io/performance-timeline/#dom-performanceentry-entrytypeThe specified filter overrides any previous filters, passing emptyfilter disables recording.Note that not all types exposed to the web platform are currently supported. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + A description of mixed content (HTTP resources on HTTPS pages), as defined by + https://www.w3.org/TR/mixed-content/#categories + + + + + blockable + + + + + optionally-blockable + + + + + none + + + + + The security level of a page or resource. + + + + + unknown + + + + + neutral + + + + + insecure + + + + + secure + + + + + info + + + + + insecure-broken + + + + + Details about the security state of the page certificate. + + + + + Protocol name (e.g. "TLS 1.2" or "QUIC"). + + + + + Key Exchange used by the connection, or the empty string if not applicable. + + + + + (EC)DH group used by the connection, if applicable. + + + + + Cipher name. + + + + + TLS MAC. Note that AEAD ciphers do not have separate MACs. + + + + + Page certificate. + + + + + Certificate subject name. + + + + + Name of the issuing CA. + + + + + Certificate valid from date. + + + + + Certificate valid to (expiration) date + + + + + The highest priority network error code, if the certificate has an error. + + + + + True if the certificate uses a weak signature aglorithm. + + + + + True if the certificate has a SHA1 signature in the chain. + + + + + True if modern SSL + + + + + True if the connection is using an obsolete SSL protocol. + + + + + True if the connection is using an obsolete SSL key exchange. + + + + + True if the connection is using an obsolete SSL cipher. + + + + + True if the connection is using an obsolete SSL signature. + + + + + SafetyTipStatus + + + + + badReputation + + + + + lookalike + + + + + SafetyTipInfo + + + + + Describes whether the page triggers any safety tips or reputation warnings. Default is unknown. + + + + + Describes whether the page triggers any safety tips or reputation warnings. Default is unknown. + + + + + The URL the safety tip suggested ("Did you mean?"). Only filled in for lookalike matches. + + + + + Security state information about the page. + + + + + The security level of the page. + + + + + The security level of the page. + + + + + Security state details about the page certificate. + + + + + The type of Safety Tip triggered on the page. Note that this field will be set even if the Safety Tip UI was not actually shown. + + + + + Array of security state issues ids. + + + + + An explanation of an factor contributing to the security state. + + + + + Security state representing the severity of the factor being explained. + + + + + Security state representing the severity of the factor being explained. + + + + + Title describing the type of factor. + + + + + Short phrase describing the type of factor. + + + + + Full text explanation of the factor. + + + + + The type of mixed content described by the explanation. + + + + + The type of mixed content described by the explanation. + + + + + Page certificate. + + + + + Recommendations to fix any issues. + + + + + Information about insecure content on the page. + + + + + Always false. + + + + + Always false. + + + + + Always false. + + + + + Always false. + + + + + Always false. + + + + + Always set to unknown. + + + + + Always set to unknown. + + + + + Always set to unknown. + + + + + Always set to unknown. + + + + + The action to take when a certificate error occurs. continue will continue processing the + request and cancel will cancel the request. + + + + + continue + + + + + cancel + + + + + There is a certificate error. If overriding certificate errors is enabled, then it should be + handled with the `handleCertificateError` command. Note: this event does not fire if the + certificate error has been allowed internally. Only one client per target should override + certificate errors at the same time. + + + + + The ID of the event. + + + + + The type of the error. + + + + + The url that was requested. + + + + + The security state of the page changed. + + + + + Security state information about the page. + + + + + The security state of the page changed. No longer being sent. + + + + + Security state. + + + + + Security state. + + + + + True if the page was loaded over cryptographic transport such as HTTPS. + + + + + Previously a list of explanations for the security state. Now always + empty. + + + + + Information about insecure content on the page. + + + + + Overrides user-visible description of the state. Always omitted. + + + + + Security + + + + + Security + + DevToolsClient + + + + The security state of the page changed. + + + + + Disables tracking security state changes. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables tracking security state changes. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable/disable whether all certificate errors should be ignored. + + If true, all certificate errors will be ignored. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + ServiceWorker registration. + + + + + RegistrationId + + + + + ScopeURL + + + + + IsDeleted + + + + + ServiceWorkerVersionRunningStatus + + + + + stopped + + + + + starting + + + + + running + + + + + stopping + + + + + ServiceWorkerVersionStatus + + + + + new + + + + + installing + + + + + installed + + + + + activating + + + + + activated + + + + + redundant + + + + + ServiceWorker version. + + + + + VersionId + + + + + RegistrationId + + + + + ScriptURL + + + + + RunningStatus + + + + + RunningStatus + + + + + Status + + + + + Status + + + + + The Last-Modified header value of the main script. + + + + + The time at which the response headers of the main script were received from the server. + For cached script it is the last time the cache entry was validated. + + + + + ControlledClients + + + + + TargetId + + + + + ServiceWorker error message. + + + + + ErrorMessage + + + + + RegistrationId + + + + + VersionId + + + + + SourceURL + + + + + LineNumber + + + + + ColumnNumber + + + + + workerErrorReported + + + + + ErrorMessage + + + + + workerRegistrationUpdated + + + + + Registrations + + + + + workerVersionUpdated + + + + + Versions + + + + + ServiceWorker + + + + + ServiceWorker + + DevToolsClient + + + + WorkerErrorReported + + + + + WorkerRegistrationUpdated + + + + + WorkerVersionUpdated + + + + + DeliverPushMessage + + origin + registrationId + data + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + DispatchSyncEvent + + origin + registrationId + tag + lastChance + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + DispatchPeriodicSyncEvent + + origin + registrationId + tag + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + InspectWorker + + versionId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetForceUpdateOnPageLoad + + forceUpdateOnPageLoad + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SkipWaiting + + scopeURL + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + StartWorker + + scopeURL + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + StopAllWorkers + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + StopWorker + + versionId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Unregister + + scopeURL + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + UpdateRegistration + + scopeURL + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enum of possible storage types. + + + + + appcache + + + + + cookies + + + + + file_systems + + + + + indexeddb + + + + + local_storage + + + + + shader_cache + + + + + websql + + + + + service_workers + + + + + cache_storage + + + + + interest_groups + + + + + shared_storage + + + + + storage_buckets + + + + + all + + + + + other + + + + + Usage for a storage type. + + + + + Name of storage type. + + + + + Name of storage type. + + + + + Storage usage (bytes). + + + + + Pair of issuer origin and number of available (signed, but not used) Trust + Tokens from that issuer. + + + + + IssuerOrigin + + + + + Count + + + + + Enum of interest group access types. + + + + + join + + + + + leave + + + + + update + + + + + loaded + + + + + bid + + + + + win + + + + + Ad advertising element inside an interest group. + + + + + RenderUrl + + + + + Metadata + + + + + The full details of an interest group. + + + + + OwnerOrigin + + + + + Name + + + + + ExpirationTime + + + + + JoiningOrigin + + + + + BiddingUrl + + + + + BiddingWasmHelperUrl + + + + + UpdateUrl + + + + + TrustedBiddingSignalsUrl + + + + + TrustedBiddingSignalsKeys + + + + + UserBiddingSignals + + + + + Ads + + + + + AdComponents + + + + + Enum of shared storage access types. + + + + + documentAddModule + + + + + documentSelectURL + + + + + documentRun + + + + + documentSet + + + + + documentAppend + + + + + documentDelete + + + + + documentClear + + + + + workletSet + + + + + workletAppend + + + + + workletDelete + + + + + workletClear + + + + + workletGet + + + + + workletKeys + + + + + workletEntries + + + + + workletLength + + + + + workletRemainingBudget + + + + + Struct for a single key-value pair in an origin's shared storage. + + + + + Key + + + + + Value + + + + + Details for an origin's shared storage. + + + + + CreationTime + + + + + Length + + + + + RemainingBudget + + + + + Pair of reporting metadata details for a candidate URL for `selectURL()`. + + + + + EventType + + + + + ReportingUrl + + + + + Bundles a candidate URL with its reporting metadata. + + + + + Spec of candidate URL. + + + + + Any associated reporting metadata. + + + + + Bundles the parameters for shared storage access events whose + presence/absence can vary according to SharedStorageAccessType. + + + + + Spec of the module script URL. + Present only for SharedStorageAccessType.documentAddModule. + + + + + Name of the registered operation to be run. + Present only for SharedStorageAccessType.documentRun and + SharedStorageAccessType.documentSelectURL. + + + + + The operation's serialized data in bytes (converted to a string). + Present only for SharedStorageAccessType.documentRun and + SharedStorageAccessType.documentSelectURL. + + + + + Array of candidate URLs' specs, along with any associated metadata. + Present only for SharedStorageAccessType.documentSelectURL. + + + + + Key for a specific entry in an origin's shared storage. + Present only for SharedStorageAccessType.documentSet, + SharedStorageAccessType.documentAppend, + SharedStorageAccessType.documentDelete, + SharedStorageAccessType.workletSet, + SharedStorageAccessType.workletAppend, + SharedStorageAccessType.workletDelete, and + SharedStorageAccessType.workletGet. + + + + + Value for a specific entry in an origin's shared storage. + Present only for SharedStorageAccessType.documentSet, + SharedStorageAccessType.documentAppend, + SharedStorageAccessType.workletSet, and + SharedStorageAccessType.workletAppend. + + + + + Whether or not to set an entry for a key if that key is already present. + Present only for SharedStorageAccessType.documentSet and + SharedStorageAccessType.workletSet. + + + + + StorageBucketsDurability + + + + + relaxed + + + + + strict + + + + + StorageBucketInfo + + + + + StorageKey + + + + + Id + + + + + Name + + + + + IsDefault + + + + + Expiration + + + + + Storage quota (bytes). + + + + + Persistent + + + + + Durability + + + + + Durability + + + + + A cache's contents have been modified. + + + + + Origin to update. + + + + + Storage key to update. + + + + + Name of cache in origin. + + + + + A cache has been added/deleted. + + + + + Origin to update. + + + + + Storage key to update. + + + + + The origin's IndexedDB object store has been modified. + + + + + Origin to update. + + + + + Storage key to update. + + + + + Database to update. + + + + + ObjectStore to update. + + + + + The origin's IndexedDB database list has been modified. + + + + + Origin to update. + + + + + Storage key to update. + + + + + One of the interest groups was accessed by the associated page. + + + + + AccessTime + + + + + Type + + + + + Type + + + + + OwnerOrigin + + + + + Name + + + + + Shared storage was accessed by the associated page. + The following parameters are included in all events. + + + + + Time of the access. + + + + + Enum value indicating the Shared Storage API method invoked. + + + + + Enum value indicating the Shared Storage API method invoked. + + + + + DevTools Frame Token for the primary frame tree's root. + + + + + Serialized origin for the context that invoked the Shared Storage API. + + + + + The sub-parameters warapped by `params` are all optional and their + presence/absence depends on `type`. + + + + + storageBucketCreatedOrUpdated + + + + + Bucket + + + + + storageBucketDeleted + + + + + BucketId + + + + + GetStorageKeyForFrameResponse + + + + + storageKey + + + + + GetCookiesResponse + + + + + cookies + + + + + GetUsageAndQuotaResponse + + + + + usage + + + + + quota + + + + + overrideActive + + + + + usageBreakdown + + + + + GetTrustTokensResponse + + + + + tokens + + + + + ClearTrustTokensResponse + + + + + didDeleteTokens + + + + + GetInterestGroupDetailsResponse + + + + + details + + + + + GetSharedStorageMetadataResponse + + + + + metadata + + + + + GetSharedStorageEntriesResponse + + + + + entries + + + + + Storage + + + + + Storage + + DevToolsClient + + + + A cache's contents have been modified. + + + + + A cache has been added/deleted. + + + + + The origin's IndexedDB object store has been modified. + + + + + The origin's IndexedDB database list has been modified. + + + + + One of the interest groups was accessed by the associated page. + + + + + Shared storage was accessed by the associated page. + The following parameters are included in all events. + + + + + StorageBucketCreatedOrUpdated + + + + + StorageBucketDeleted + + + + + Returns a storage key given a frame id. + + frameId + returns System.Threading.Tasks.Task<GetStorageKeyForFrameResponse> + + + + Clears storage for origin. + + Security origin. + Comma separated list of StorageType to clear. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears storage for storage key. + + Storage key. + Comma separated list of StorageType to clear. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns all browser cookies. + + Browser context to use when called on the browser endpoint. + returns System.Threading.Tasks.Task<GetCookiesResponse> + + + + Sets given cookies. + + Cookies to be set. + Browser context to use when called on the browser endpoint. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears cookies. + + Browser context to use when called on the browser endpoint. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns usage and quota in bytes. + + Security origin. + returns System.Threading.Tasks.Task<GetUsageAndQuotaResponse> + + + + Override quota for the specified origin + + Security origin. + The quota size (in bytes) to override the original quota with.If this is called multiple times, the overridden quota will be equal tothe quotaSize provided in the final call. If this is called withoutspecifying a quotaSize, the quota will be reset to the default value forthe specified origin. If this is called multiple times with differentorigins, the override will be maintained for each origin until it isdisabled (called without a quotaSize). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Registers origin to be notified when an update occurs to its cache storage list. + + Security origin. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Registers storage key to be notified when an update occurs to its cache storage list. + + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Registers origin to be notified when an update occurs to its IndexedDB. + + Security origin. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Registers storage key to be notified when an update occurs to its IndexedDB. + + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Unregisters origin from receiving notifications for cache storage. + + Security origin. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Unregisters storage key from receiving notifications for cache storage. + + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Unregisters origin from receiving notifications for IndexedDB. + + Security origin. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Unregisters storage key from receiving notifications for IndexedDB. + + Storage key. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns the number of stored Trust Tokens per issuer for the + current browsing context. + + returns System.Threading.Tasks.Task<GetTrustTokensResponse> + + + + Removes all Trust Tokens issued by the provided issuerOrigin. + Leaves other stored data, including the issuer's Redemption Records, intact. + + issuerOrigin + returns System.Threading.Tasks.Task<ClearTrustTokensResponse> + + + + Gets details for a named interest group. + + ownerOrigin + name + returns System.Threading.Tasks.Task<GetInterestGroupDetailsResponse> + + + + Enables/Disables issuing of interestGroupAccessed events. + + enable + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Gets metadata for an origin's shared storage. + + ownerOrigin + returns System.Threading.Tasks.Task<GetSharedStorageMetadataResponse> + + + + Gets the entries in an given origin's shared storage. + + ownerOrigin + returns System.Threading.Tasks.Task<GetSharedStorageEntriesResponse> + + + + Sets entry with `key` and `value` for a given origin's shared storage. + + ownerOrigin + key + value + If `ignoreIfPresent` is included and true, then only sets the entry if`key` doesn't already exist. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Deletes entry for `key` (if it exists) for a given origin's shared storage. + + ownerOrigin + key + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears all entries for a given origin's shared storage. + + ownerOrigin + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Resets the budget for `ownerOrigin` by clearing all budget withdrawals. + + ownerOrigin + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables/disables issuing of sharedStorageAccessed events. + + enable + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Set tracking for a storage key's buckets. + + storageKey + enable + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Deletes the Storage Bucket with the given storage key and bucket name. + + storageKey + bucketName + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Describes a single graphics processor (GPU). + + + + + PCI ID of the GPU vendor, if available; 0 otherwise. + + + + + PCI ID of the GPU device, if available; 0 otherwise. + + + + + Sub sys ID of the GPU, only available on Windows. + + + + + Revision of the GPU, only available on Windows. + + + + + String description of the GPU vendor, if the PCI ID is not available. + + + + + String description of the GPU device, if the PCI ID is not available. + + + + + String description of the GPU driver vendor. + + + + + String description of the GPU driver version. + + + + + Describes the width and height dimensions of an entity. + + + + + Width in pixels. + + + + + Height in pixels. + + + + + Describes a supported video decoding profile with its associated minimum and + maximum resolutions. + + + + + Video codec profile that is supported, e.g. VP9 Profile 2. + + + + + Maximum video dimensions in pixels supported for this |profile|. + + + + + Minimum video dimensions in pixels supported for this |profile|. + + + + + Describes a supported video encoding profile with its associated maximum + resolution and maximum framerate. + + + + + Video codec profile that is supported, e.g H264 Main. + + + + + Maximum video dimensions in pixels supported for this |profile|. + + + + + Maximum encoding framerate in frames per second supported for this + |profile|, as fraction's numerator and denominator, e.g. 24/1 fps, + 24000/1001 fps, etc. + + + + + MaxFramerateDenominator + + + + + YUV subsampling type of the pixels of a given image. + + + + + yuv420 + + + + + yuv422 + + + + + yuv444 + + + + + Image format of a given image. + + + + + jpeg + + + + + webp + + + + + unknown + + + + + Describes a supported image decoding profile with its associated minimum and + maximum resolutions and subsampling. + + + + + Image coded, e.g. Jpeg. + + + + + Image coded, e.g. Jpeg. + + + + + Maximum supported dimensions of the image in pixels. + + + + + Minimum supported dimensions of the image in pixels. + + + + + Optional array of supported subsampling formats, e.g. 4:2:0, if known. + + + + + Optional array of supported subsampling formats, e.g. 4:2:0, if known. + + + + + Provides information about the GPU(s) on the system. + + + + + The graphics devices on the system. Element 0 is the primary GPU. + + + + + An optional dictionary of additional GPU related attributes. + + + + + An optional dictionary of graphics features and their status. + + + + + An optional array of GPU driver bug workarounds. + + + + + Supported accelerated video decoding capabilities. + + + + + Supported accelerated video encoding capabilities. + + + + + Supported accelerated image decoding capabilities. + + + + + Represents process info. + + + + + Specifies process type. + + + + + Specifies process id. + + + + + Specifies cumulative CPU usage in seconds across all threads of the + process since the process start. + + + + + GetInfoResponse + + + + + gpu + + + + + modelName + + + + + modelVersion + + + + + commandLine + + + + + GetFeatureStateResponse + + + + + featureEnabled + + + + + GetProcessInfoResponse + + + + + processInfo + + + + + The SystemInfo domain defines methods and events for querying low-level system information. + + + + + SystemInfo + + DevToolsClient + + + + Returns information about the system. + + returns System.Threading.Tasks.Task<GetInfoResponse> + + + + Returns information about the feature state. + + featureState + returns System.Threading.Tasks.Task<GetFeatureStateResponse> + + + + Returns information about all running processes. + + returns System.Threading.Tasks.Task<GetProcessInfoResponse> + + + + TargetInfo + + + + + TargetId + + + + + Type + + + + + Title + + + + + Url + + + + + Whether the target has an attached client. + + + + + Opener target Id + + + + + Whether the target has access to the originating window. + + + + + Frame id of originating window (is only set if target has an opener). + + + + + BrowserContextId + + + + + Provides additional details for specific target types. For example, for + the type of "page", this may be set to "portal" or "prerender". + + + + + A filter used by target query/discovery/auto-attach operations. + + + + + If set, causes exclusion of mathcing targets from the list. + + + + + If not present, matches any type. + + + + + RemoteLocation + + + + + Host + + + + + Port + + + + + Issued when attached to target because of auto-attach or `attachToTarget` command. + + + + + Identifier assigned to the session used to send/receive messages. + + + + + TargetInfo + + + + + WaitingForDebugger + + + + + Issued when detached from target for any reason (including `detachFromTarget` command). Can be + issued multiple times per target if multiple sessions have been attached to it. + + + + + Detached session identifier. + + + + + Deprecated. + + + + + Notifies about a new protocol message received from the session (as reported in + `attachedToTarget` event). + + + + + Identifier of a session which sends a message. + + + + + Message + + + + + Deprecated. + + + + + Issued when a possible inspection target is created. + + + + + TargetInfo + + + + + Issued when a target is destroyed. + + + + + TargetId + + + + + Issued when a target has crashed. + + + + + TargetId + + + + + Termination status type. + + + + + Termination error code. + + + + + Issued when some information about a target has changed. This only happens between + `targetCreated` and `targetDestroyed`. + + + + + TargetInfo + + + + + AttachToTargetResponse + + + + + sessionId + + + + + AttachToBrowserTargetResponse + + + + + sessionId + + + + + CloseTargetResponse + + + + + success + + + + + CreateBrowserContextResponse + + + + + browserContextId + + + + + GetBrowserContextsResponse + + + + + browserContextIds + + + + + CreateTargetResponse + + + + + targetId + + + + + GetTargetInfoResponse + + + + + targetInfo + + + + + GetTargetsResponse + + + + + targetInfos + + + + + Supports additional targets discovery and allows to attach to them. + + + + + Target + + DevToolsClient + + + + Issued when attached to target because of auto-attach or `attachToTarget` command. + + + + + Issued when detached from target for any reason (including `detachFromTarget` command). Can be + issued multiple times per target if multiple sessions have been attached to it. + + + + + Notifies about a new protocol message received from the session (as reported in + `attachedToTarget` event). + + + + + Issued when a possible inspection target is created. + + + + + Issued when a target is destroyed. + + + + + Issued when a target has crashed. + + + + + Issued when some information about a target has changed. This only happens between + `targetCreated` and `targetDestroyed`. + + + + + Activates (focuses) the target. + + targetId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Attaches to the target with given id. + + targetId + Enables "flat" access to the session via specifying sessionId attribute in the commands.We plan to make this the default, deprecate non-flattened mode,and eventually retire it. See crbug.com/991325. + returns System.Threading.Tasks.Task<AttachToTargetResponse> + + + + Attaches to the browser target, only uses flat sessionId mode. + + returns System.Threading.Tasks.Task<AttachToBrowserTargetResponse> + + + + Closes the target. If the target is a page that gets closed too. + + targetId + returns System.Threading.Tasks.Task<CloseTargetResponse> + + + + Inject object to the target's main frame that provides a communication + channel with browser target. + + Injected object will be available as `window[bindingName]`. + + The object has the follwing API: + - `binding.send(json)` - a method to send messages over the remote debugging protocol + - `binding.onmessage = json => handleMessage(json)` - a callback that will be called for the protocol notifications and command responses. + + targetId + Binding name, 'cdp' if not specified. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Creates a new empty BrowserContext. Similar to an incognito profile but you can have more than + one. + + If specified, disposes this context when debugging session disconnects. + Proxy server, similar to the one passed to --proxy-server + Proxy bypass list, similar to the one passed to --proxy-bypass-list + An optional list of origins to grant unlimited cross-origin access to.Parts of the URL other than those constituting origin are ignored. + returns System.Threading.Tasks.Task<CreateBrowserContextResponse> + + + + Returns all browser contexts created with `Target.createBrowserContext` method. + + returns System.Threading.Tasks.Task<GetBrowserContextsResponse> + + + + Creates a new page. + + The initial URL the page will be navigated to. An empty string indicates about:blank. + Frame width in DIP (headless chrome only). + Frame height in DIP (headless chrome only). + The browser context to create the page in. + Whether BeginFrames for this target will be controlled via DevTools (headless chrome only,not supported on MacOS yet, false by default). + Whether to create a new Window or Tab (chrome-only, false by default). + Whether to create the target in background or foreground (chrome-only,false by default). + Whether to create the target of type "tab". + returns System.Threading.Tasks.Task<CreateTargetResponse> + + + + Detaches session with given id. + + Session to detach. + Deprecated. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Deletes a BrowserContext. All the belonging pages will be closed without calling their + beforeunload hooks. + + browserContextId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns information about a target. + + targetId + returns System.Threading.Tasks.Task<GetTargetInfoResponse> + + + + Retrieves a list of available targets. + + Only targets matching filter will be reported. If filter is not specifiedand target discovery is currently enabled, a filter used for target discoveryis used for consistency. + returns System.Threading.Tasks.Task<GetTargetsResponse> + + + + Controls whether to automatically attach to new targets which are considered to be related to + this one. When turned on, attaches to all existing related targets as well. When turned off, + automatically detaches from all currently attached targets. + This also clears all targets added by `autoAttachRelated` from the list of targets to watch + for creation of related targets. + + Whether to auto-attach to related targets. + Whether to pause new targets when attaching to them. Use `Runtime.runIfWaitingForDebugger`to run paused targets. + Enables "flat" access to the session via specifying sessionId attribute in the commands.We plan to make this the default, deprecate non-flattened mode,and eventually retire it. See crbug.com/991325. + Only targets matching filter will be attached. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Adds the specified target to the list of targets that will be monitored for any related target + creation (such as child frames, child workers and new versions of service worker) and reported + through `attachedToTarget`. The specified target is also auto-attached. + This cancels the effect of any previous `setAutoAttach` and is also cancelled by subsequent + `setAutoAttach`. Only available at the Browser target. + + targetId + Whether to pause new targets when attaching to them. Use `Runtime.runIfWaitingForDebugger`to run paused targets. + Only targets matching filter will be attached. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Controls whether to discover available targets and notify via + `targetCreated/targetInfoChanged/targetDestroyed` events. + + Whether to discover available targets. + Only targets matching filter will be attached. If `discover` is false,`filter` must be omitted or empty. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables target discovery for the specified locations, when `setDiscoverTargets` was set to + `true`. + + List of remote locations. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + The entries in TargetFilter are matched sequentially against targets and the first entry that matches + determines if the target is included or not, depending on the value of exclude field in the entry. + If filter is not specified, the one assumed is [{type: "browser", exclude: true}, {type: "tab", exclude: true}, {}] (i.e. include everything but browser and tab). + + + + + Type + + + + + Exclude + + + + + Informs that port was successfully bound and got a specified connection id. + + + + + Port number that was successfully bound. + + + + + Connection id to be used. + + + + + The Tethering domain defines methods and events for browser port binding. + + + + + Tethering + + DevToolsClient + + + + Informs that port was successfully bound and got a specified connection id. + + + + + Request browser port binding. + + Port number to bind. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Request browser port unbinding. + + Port number to unbind. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Controls how the trace buffer stores data. + + + + + recordUntilFull + + + + + recordContinuously + + + + + recordAsMuchAsPossible + + + + + echoToConsole + + + + + TraceConfig + + + + + Controls how the trace buffer stores data. + + + + + Controls how the trace buffer stores data. + + + + + Size of the trace buffer in kilobytes. If not specified or zero is passed, a default value + of 200 MB would be used. + + + + + Turns on JavaScript stack sampling. + + + + + Turns on system tracing. + + + + + Turns on argument filter. + + + + + Included category filters. + + + + + Excluded category filters. + + + + + Configuration to synthesize the delays in tracing. + + + + + Configuration for memory dump triggers. Used only when "memory-infra" category is enabled. + + + + + Data format of a trace. Can be either the legacy JSON format or the + protocol buffer format. Note that the JSON format will be deprecated soon. + + + + + json + + + + + proto + + + + + Compression type to use for traces returned via streams. + + + + + none + + + + + gzip + + + + + Details exposed when memory request explicitly declared. + Keep consistent with memory_dump_request_args.h and + memory_instrumentation.mojom + + + + + background + + + + + light + + + + + detailed + + + + + Backend type to use for tracing. `chrome` uses the Chrome-integrated + tracing service and is supported on all platforms. `system` is only + supported on Chrome OS and uses the Perfetto system tracing service. + `auto` chooses `system` when the perfettoConfig provided to Tracing.start + specifies at least one non-Chrome data source; otherwise uses `chrome`. + + + + + auto + + + + + chrome + + + + + system + + + + + bufferUsage + + + + + A number in range [0..1] that indicates the used size of event buffer as a fraction of its + total size. + + + + + An approximate number of events in the trace log. + + + + + A number in range [0..1] that indicates the used size of event buffer as a fraction of its + total size. + + + + + Contains a bucket of collected trace events. When tracing is stopped collected events will be + sent as a sequence of dataCollected events followed by tracingComplete event. + + + + + Value + + + + + Signals that tracing is stopped and there is no trace buffers pending flush, all data were + delivered via dataCollected events. + + + + + Indicates whether some trace data is known to have been lost, e.g. because the trace ring + buffer wrapped around. + + + + + A handle of the stream that holds resulting trace data. + + + + + Trace data format of returned stream. + + + + + Trace data format of returned stream. + + + + + Compression format of returned stream. + + + + + Compression format of returned stream. + + + + + GetCategoriesResponse + + + + + categories + + + + + RequestMemoryDumpResponse + + + + + dumpGuid + + + + + success + + + + + Whether to report trace events as series of dataCollected events or to save trace to a + stream (defaults to `ReportEvents`). + + + + + ReportEvents + + + + + ReturnAsStream + + + + + Tracing + + + + + Tracing + + DevToolsClient + + + + BufferUsage + + + + + Contains a bucket of collected trace events. When tracing is stopped collected events will be + sent as a sequence of dataCollected events followed by tracingComplete event. + + + + + Signals that tracing is stopped and there is no trace buffers pending flush, all data were + delivered via dataCollected events. + + + + + Stop trace events collection. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Gets supported tracing categories. + + returns System.Threading.Tasks.Task<GetCategoriesResponse> + + + + Record a clock sync marker in the trace. + + The ID of this clock sync marker + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Request a global memory dump. + + Enables more deterministic results by forcing garbage collection + Specifies level of details in memory dump. Defaults to "detailed". + returns System.Threading.Tasks.Task<RequestMemoryDumpResponse> + + + + Start trace events collection. + + Category/tag filter + Tracing options + If set, the agent will issue bufferUsage events at this interval, specified in milliseconds + Whether to report trace events as series of dataCollected events or to save trace to astream (defaults to `ReportEvents`). + Trace data format to use. This only applies when using `ReturnAsStream`transfer mode (defaults to `json`). + Compression format to use. This only applies when using `ReturnAsStream`transfer mode (defaults to `none`) + traceConfig + Base64-encoded serialized perfetto.protos.TraceConfig protobuf messageWhen specified, the parameters `categories`, `options`, `traceConfig`are ignored. + Backend type (defaults to `auto`) + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + MemoryDumpConfig + + + + + Stages of the request to handle. Request will intercept before the request is + sent. Response will intercept after the response is received (but before response + body is received). + + + + + Request + + + + + Response + + + + + RequestPattern + + + + + Wildcards (`'*'` -> zero or more, `'?'` -> exactly one) are allowed. Escape character is + backslash. Omitting is equivalent to `"*"`. + + + + + If set, only requests for matching resource types will be intercepted. + + + + + If set, only requests for matching resource types will be intercepted. + + + + + Stage at which to begin intercepting requests. Default is Request. + + + + + Stage at which to begin intercepting requests. Default is Request. + + + + + Response HTTP header entry + + + + + Name + + + + + Value + + + + + Source of the authentication challenge. + + + + + Server + + + + + Proxy + + + + + Authorization challenge for HTTP status code 401 or 407. + + + + + Source of the authentication challenge. + + + + + Source of the authentication challenge. + + + + + Origin of the challenger. + + + + + The authentication scheme used, such as basic or digest + + + + + The realm of the challenge. May be empty. + + + + + The decision on what to do in response to the authorization challenge. Default means + deferring to the default behavior of the net stack, which will likely either the Cancel + authentication or display a popup dialog box. + + + + + Default + + + + + CancelAuth + + + + + ProvideCredentials + + + + + Response to an AuthChallenge. + + + + + The decision on what to do in response to the authorization challenge. Default means + deferring to the default behavior of the net stack, which will likely either the Cancel + authentication or display a popup dialog box. + + + + + The decision on what to do in response to the authorization challenge. Default means + deferring to the default behavior of the net stack, which will likely either the Cancel + authentication or display a popup dialog box. + + + + + The username to provide, possibly empty. Should only be set if response is + ProvideCredentials. + + + + + The password to provide, possibly empty. Should only be set if response is + ProvideCredentials. + + + + + Issued when the domain is enabled and the request URL matches the + specified filter. The request is paused until the client responds + with one of continueRequest, failRequest or fulfillRequest. + The stage of the request can be determined by presence of responseErrorReason + and responseStatusCode -- the request is at the response stage if either + of these fields is present and in the request stage otherwise. + + + + + Each request the page makes will have a unique id. + + + + + The details of the request. + + + + + The id of the frame that initiated the request. + + + + + How the requested resource will be used. + + + + + How the requested resource will be used. + + + + + Response error if intercepted at response stage. + + + + + Response error if intercepted at response stage. + + + + + Response code if intercepted at response stage. + + + + + Response status text if intercepted at response stage. + + + + + Response headers if intercepted at the response stage. + + + + + If the intercepted request had a corresponding Network.requestWillBeSent event fired for it, + then this networkId will be the same as the requestId present in the requestWillBeSent event. + + + + + If the request is due to a redirect response from the server, the id of the request that + has caused the redirect. + + + + + Issued when the domain is enabled with handleAuthRequests set to true. + The request is paused until client responds with continueWithAuth. + + + + + Each request the page makes will have a unique id. + + + + + The details of the request. + + + + + The id of the frame that initiated the request. + + + + + How the requested resource will be used. + + + + + How the requested resource will be used. + + + + + Details of the Authorization Challenge encountered. + If this is set, client should respond with continueRequest that + contains AuthChallengeResponse. + + + + + GetResponseBodyResponse + + + + + body + + + + + base64Encoded + + + + + TakeResponseBodyAsStreamResponse + + + + + stream + + + + + A domain for letting clients substitute browser's network layer with client code. + + + + + Fetch + + DevToolsClient + + + + Issued when the domain is enabled and the request URL matches the + specified filter. The request is paused until the client responds + with one of continueRequest, failRequest or fulfillRequest. + The stage of the request can be determined by presence of responseErrorReason + and responseStatusCode -- the request is at the response stage if either + of these fields is present and in the request stage otherwise. + + + + + Issued when the domain is enabled with handleAuthRequests set to true. + The request is paused until client responds with continueWithAuth. + + + + + Disables the fetch domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables issuing of requestPaused events. A request will be paused until client + calls one of failRequest, fulfillRequest or continueRequest/continueWithAuth. + + If specified, only requests matching any of these patterns will producefetchRequested event and will be paused until clients response. If not set,all requests will be affected. + If true, authRequired events will be issued and requests will be pausedexpecting a call to continueWithAuth. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Causes the request to fail with specified reason. + + An id the client received in requestPaused event. + Causes the request to fail with the given reason. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Provides response to the request. + + An id the client received in requestPaused event. + An HTTP response code. + Response headers. + Alternative way of specifying response headers as a \0-separatedseries of name: value pairs. Prefer the above method unless youneed to represent some non-UTF8 values that can't be transmittedover the protocol as text. + A response body. If absent, original response body will be used ifthe request is intercepted at the response stage and empty bodywill be used if the request is intercepted at the request stage. + A textual representation of responseCode.If absent, a standard phrase matching responseCode is used. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Continues the request, optionally modifying some of its parameters. + + An id the client received in requestPaused event. + If set, the request url will be modified in a way that's not observable by page. + If set, the request method is overridden. + If set, overrides the post data in the request. + If set, overrides the request headers. Note that the overrides do notextend to subsequent redirect hops, if a redirect happens. Another overridemay be applied to a different request produced by a redirect. + If set, overrides response interception behavior for this request. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Continues a request supplying authChallengeResponse following authRequired event. + + An id the client received in authRequired event. + Response to with an authChallenge. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Continues loading of the paused response, optionally modifying the + response headers. If either responseCode or headers are modified, all of them + must be present. + + An id the client received in requestPaused event. + An HTTP response code. If absent, original response code will be used. + A textual representation of responseCode.If absent, a standard phrase matching responseCode is used. + Response headers. If absent, original response headers will be used. + Alternative way of specifying response headers as a \0-separatedseries of name: value pairs. Prefer the above method unless youneed to represent some non-UTF8 values that can't be transmittedover the protocol as text. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Causes the body of the response to be received from the server and + returned as a single string. May only be issued for a request that + is paused in the Response stage and is mutually exclusive with + takeResponseBodyForInterceptionAsStream. Calling other methods that + affect the request or disabling fetch domain before body is received + results in an undefined behavior. + + Identifier for the intercepted request to get body for. + returns System.Threading.Tasks.Task<GetResponseBodyResponse> + + + + Returns a handle to the stream representing the response body. + The request must be paused in the HeadersReceived stage. + Note that after this command the request can't be continued + as is -- client either needs to cancel it or to provide the + response body. + The stream only supports sequential read, IO.read will fail if the position + is specified. + This method is mutually exclusive with getResponseBody. + Calling other methods that affect the request or disabling fetch + domain before body is received results in an undefined behavior. + + requestId + returns System.Threading.Tasks.Task<TakeResponseBodyAsStreamResponse> + + + + Enum of BaseAudioContext types + + + + + realtime + + + + + offline + + + + + Enum of AudioContextState from the spec + + + + + suspended + + + + + running + + + + + closed + + + + + Enum of AudioNode::ChannelCountMode from the spec + + + + + clamped-max + + + + + explicit + + + + + max + + + + + Enum of AudioNode::ChannelInterpretation from the spec + + + + + discrete + + + + + speakers + + + + + Enum of AudioParam::AutomationRate from the spec + + + + + a-rate + + + + + k-rate + + + + + Fields in AudioContext that change in real-time. + + + + + The current context time in second in BaseAudioContext. + + + + + The time spent on rendering graph divided by render quantum duration, + and multiplied by 100. 100 means the audio renderer reached the full + capacity and glitch may occur. + + + + + A running mean of callback interval. + + + + + A running variance of callback interval. + + + + + Protocol object for BaseAudioContext + + + + + ContextId + + + + + ContextType + + + + + ContextType + + + + + ContextState + + + + + ContextState + + + + + RealtimeData + + + + + Platform-dependent callback buffer size. + + + + + Number of output channels supported by audio hardware in use. + + + + + Context sample rate. + + + + + Protocol object for AudioListener + + + + + ListenerId + + + + + ContextId + + + + + Protocol object for AudioNode + + + + + NodeId + + + + + ContextId + + + + + NodeType + + + + + NumberOfInputs + + + + + NumberOfOutputs + + + + + ChannelCount + + + + + ChannelCountMode + + + + + ChannelCountMode + + + + + ChannelInterpretation + + + + + ChannelInterpretation + + + + + Protocol object for AudioParam + + + + + ParamId + + + + + NodeId + + + + + ContextId + + + + + ParamType + + + + + Rate + + + + + Rate + + + + + DefaultValue + + + + + MinValue + + + + + MaxValue + + + + + Notifies that a new BaseAudioContext has been created. + + + + + Context + + + + + Notifies that an existing BaseAudioContext will be destroyed. + + + + + ContextId + + + + + Notifies that existing BaseAudioContext has changed some properties (id stays the same).. + + + + + Context + + + + + Notifies that the construction of an AudioListener has finished. + + + + + Listener + + + + + Notifies that a new AudioListener has been created. + + + + + ContextId + + + + + ListenerId + + + + + Notifies that a new AudioNode has been created. + + + + + Node + + + + + Notifies that an existing AudioNode has been destroyed. + + + + + ContextId + + + + + NodeId + + + + + Notifies that a new AudioParam has been created. + + + + + Param + + + + + Notifies that an existing AudioParam has been destroyed. + + + + + ContextId + + + + + NodeId + + + + + ParamId + + + + + Notifies that two AudioNodes are connected. + + + + + ContextId + + + + + SourceId + + + + + DestinationId + + + + + SourceOutputIndex + + + + + DestinationInputIndex + + + + + Notifies that AudioNodes are disconnected. The destination can be null, and it means all the outgoing connections from the source are disconnected. + + + + + ContextId + + + + + SourceId + + + + + DestinationId + + + + + SourceOutputIndex + + + + + DestinationInputIndex + + + + + Notifies that an AudioNode is connected to an AudioParam. + + + + + ContextId + + + + + SourceId + + + + + DestinationId + + + + + SourceOutputIndex + + + + + Notifies that an AudioNode is disconnected to an AudioParam. + + + + + ContextId + + + + + SourceId + + + + + DestinationId + + + + + SourceOutputIndex + + + + + GetRealtimeDataResponse + + + + + realtimeData + + + + + This domain allows inspection of Web Audio API. + https://webaudio.github.io/web-audio-api/ + + + + + WebAudio + + DevToolsClient + + + + Notifies that a new BaseAudioContext has been created. + + + + + Notifies that an existing BaseAudioContext will be destroyed. + + + + + Notifies that existing BaseAudioContext has changed some properties (id stays the same).. + + + + + Notifies that the construction of an AudioListener has finished. + + + + + Notifies that a new AudioListener has been created. + + + + + Notifies that a new AudioNode has been created. + + + + + Notifies that an existing AudioNode has been destroyed. + + + + + Notifies that a new AudioParam has been created. + + + + + Notifies that an existing AudioParam has been destroyed. + + + + + Notifies that two AudioNodes are connected. + + + + + Notifies that AudioNodes are disconnected. The destination can be null, and it means all the outgoing connections from the source are disconnected. + + + + + Notifies that an AudioNode is connected to an AudioParam. + + + + + Notifies that an AudioNode is disconnected to an AudioParam. + + + + + Enables the WebAudio domain and starts sending context lifetime events. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables the WebAudio domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Fetch the realtime data from the registered contexts. + + contextId + returns System.Threading.Tasks.Task<GetRealtimeDataResponse> + + + + AuthenticatorProtocol + + + + + u2f + + + + + ctap2 + + + + + Ctap2Version + + + + + ctap2_0 + + + + + ctap2_1 + + + + + AuthenticatorTransport + + + + + usb + + + + + nfc + + + + + ble + + + + + cable + + + + + internal + + + + + VirtualAuthenticatorOptions + + + + + Protocol + + + + + Protocol + + + + + Defaults to ctap2_0. Ignored if |protocol| == u2f. + + + + + Defaults to ctap2_0. Ignored if |protocol| == u2f. + + + + + Transport + + + + + Transport + + + + + Defaults to false. + + + + + Defaults to false. + + + + + If set to true, the authenticator will support the largeBlob extension. + https://w3c.github.io/webauthn#largeBlob + Defaults to false. + + + + + If set to true, the authenticator will support the credBlob extension. + https://fidoalliance.org/specs/fido-v2.1-rd-20201208/fido-client-to-authenticator-protocol-v2.1-rd-20201208.html#sctn-credBlob-extension + Defaults to false. + + + + + If set to true, the authenticator will support the minPinLength extension. + https://fidoalliance.org/specs/fido-v2.1-ps-20210615/fido-client-to-authenticator-protocol-v2.1-ps-20210615.html#sctn-minpinlength-extension + Defaults to false. + + + + + If set to true, the authenticator will support the prf extension. + https://w3c.github.io/webauthn/#prf-extension + Defaults to false. + + + + + If set to true, tests of user presence will succeed immediately. + Otherwise, they will not be resolved. Defaults to true. + + + + + Sets whether User Verification succeeds or fails for an authenticator. + Defaults to false. + + + + + Credential + + + + + CredentialId + + + + + IsResidentCredential + + + + + Relying Party ID the credential is scoped to. Must be set when adding a + credential. + + + + + The ECDSA P-256 private key in PKCS#8 format. + + + + + An opaque byte sequence with a maximum size of 64 bytes mapping the + credential to a specific user. + + + + + Signature counter. This is incremented by one for each successful + assertion. + See https://w3c.github.io/webauthn/#signature-counter + + + + + The large blob associated with the credential. + See https://w3c.github.io/webauthn/#sctn-large-blob-extension + + + + + Triggered when a credential is added to an authenticator. + + + + + AuthenticatorId + + + + + Credential + + + + + Triggered when a credential is used in a webauthn assertion. + + + + + AuthenticatorId + + + + + Credential + + + + + AddVirtualAuthenticatorResponse + + + + + authenticatorId + + + + + GetCredentialResponse + + + + + credential + + + + + GetCredentialsResponse + + + + + credentials + + + + + This domain allows configuring virtual authenticators to test the WebAuthn + API. + + + + + WebAuthn + + DevToolsClient + + + + Triggered when a credential is added to an authenticator. + + + + + Triggered when a credential is used in a webauthn assertion. + + + + + Enable the WebAuthn domain and start intercepting credential storage and + retrieval with a virtual authenticator. + + Whether to enable the WebAuthn user interface. Enabling the UI isrecommended for debugging and demo purposes, as it is closer to the realexperience. Disabling the UI is recommended for automated testing.Supported at the embedder's discretion if UI is available.Defaults to false. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disable the WebAuthn domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Creates and adds a virtual authenticator. + + options + returns System.Threading.Tasks.Task<AddVirtualAuthenticatorResponse> + + + + Resets parameters isBogusSignature, isBadUV, isBadUP to false if they are not present. + + authenticatorId + If isBogusSignature is set, overrides the signature in the authenticator response to be zero.Defaults to false. + If isBadUV is set, overrides the UV bit in the flags in the authenticator response tobe zero. Defaults to false. + If isBadUP is set, overrides the UP bit in the flags in the authenticator response tobe zero. Defaults to false. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes the given authenticator. + + authenticatorId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Adds the credential to the specified authenticator. + + authenticatorId + credential + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Returns a single credential stored in the given virtual authenticator that + matches the credential ID. + + authenticatorId + credentialId + returns System.Threading.Tasks.Task<GetCredentialResponse> + + + + Returns all the credentials stored in the given virtual authenticator. + + authenticatorId + returns System.Threading.Tasks.Task<GetCredentialsResponse> + + + + Removes a credential from the authenticator. + + authenticatorId + credentialId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Clears all the credentials from the specified device. + + authenticatorId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets whether User Verification succeeds or fails for an authenticator. + The default is true. + + authenticatorId + isUserVerified + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets whether tests of user presence will succeed immediately (if true) or fail to resolve (if false) for an authenticator. + The default is true. + + authenticatorId + enabled + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Keep in sync with MediaLogMessageLevel + We are currently keeping the message level 'error' separate from the + PlayerError type because right now they represent different things, + this one being a DVLOG(ERROR) style log message that gets printed + based on what log level is selected in the UI, and the other is a + representation of a media::PipelineStatus object. Soon however we're + going to be moving away from using PipelineStatus for errors and + introducing a new error type which should hopefully let us integrate + the error log level into the PlayerError type. + + + + + error + + + + + warning + + + + + info + + + + + debug + + + + + Have one type per entry in MediaLogRecord::Type + Corresponds to kMessage + + + + + Keep in sync with MediaLogMessageLevel + We are currently keeping the message level 'error' separate from the + PlayerError type because right now they represent different things, + this one being a DVLOG(ERROR) style log message that gets printed + based on what log level is selected in the UI, and the other is a + representation of a media::PipelineStatus object. Soon however we're + going to be moving away from using PipelineStatus for errors and + introducing a new error type which should hopefully let us integrate + the error log level into the PlayerError type. + + + + + Keep in sync with MediaLogMessageLevel + We are currently keeping the message level 'error' separate from the + PlayerError type because right now they represent different things, + this one being a DVLOG(ERROR) style log message that gets printed + based on what log level is selected in the UI, and the other is a + representation of a media::PipelineStatus object. Soon however we're + going to be moving away from using PipelineStatus for errors and + introducing a new error type which should hopefully let us integrate + the error log level into the PlayerError type. + + + + + Message + + + + + Corresponds to kMediaPropertyChange + + + + + Name + + + + + Value + + + + + Corresponds to kMediaEventTriggered + + + + + Timestamp + + + + + Value + + + + + Represents logged source line numbers reported in an error. + NOTE: file and line are from chromium c++ implementation code, not js. + + + + + File + + + + + Line + + + + + Corresponds to kMediaError + + + + + ErrorType + + + + + Code is the numeric enum entry for a specific set of error codes, such + as PipelineStatusCodes in media/base/pipeline_status.h + + + + + A trace of where this error was caused / where it passed through. + + + + + Errors potentially have a root cause error, ie, a DecoderError might be + caused by an WindowsError + + + + + Extra data attached to an error, such as an HRESULT, Video Codec, etc. + + + + + This can be called multiple times, and can be used to set / override / + remove player properties. A null propValue indicates removal. + + + + + PlayerId + + + + + Properties + + + + + Send events as a list, allowing them to be batched on the browser for less + congestion. If batched, events must ALWAYS be in chronological order. + + + + + PlayerId + + + + + Events + + + + + Send a list of any messages that need to be delivered. + + + + + PlayerId + + + + + Messages + + + + + Send a list of any errors that need to be delivered. + + + + + PlayerId + + + + + Errors + + + + + Called whenever a player is created, or when a new agent joins and receives + a list of active players. If an agent is restored, it will receive the full + list of player ids and all events again. + + + + + Players + + + + + This domain allows detailed inspection of media elements + + + + + Media + + DevToolsClient + + + + This can be called multiple times, and can be used to set / override / + remove player properties. A null propValue indicates removal. + + + + + Send events as a list, allowing them to be batched on the browser for less + congestion. If batched, events must ALWAYS be in chronological order. + + + + + Send a list of any messages that need to be delivered. + + + + + Send a list of any errors that need to be delivered. + + + + + Called whenever a player is created, or when a new agent joins and receives + a list of active players. If an agent is restored, it will receive the full + list of player ids and all events again. + + + + + Enables the Media domain + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables the Media domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Device information displayed in a user prompt to select a device. + + + + + Id + + + + + Display name as it appears in a device request user prompt. + + + + + A device request opened a user prompt to select a device. Respond with the + selectPrompt or cancelPrompt command. + + + + + Id + + + + + Devices + + + + + DeviceAccess + + + + + DeviceAccess + + DevToolsClient + + + + A device request opened a user prompt to select a device. Respond with the + selectPrompt or cancelPrompt command. + + + + + Enable events in this domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disable events in this domain. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Select a device in response to a DeviceAccess.deviceRequestPrompted event. + + id + deviceId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Cancel a prompt in response to a DeviceAccess.deviceRequestPrompted event. + + id + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Corresponds to SpeculationRuleSet + + + + + Id + + + + + Identifies a document which the rule set is associated with. + + + + + Source text of JSON representing the rule set. If it comes from + <script> tag, it is the textContent of the node. Note that it is + a JSON for valid case. + + See also: + - https://wicg.github.io/nav-speculation/speculation-rules.html + - https://github.com/WICG/nav-speculation/blob/main/triggers.md + + + + + Error information + `errorMessage` is null iff `errorType` is null. + + + + + Error information + `errorMessage` is null iff `errorType` is null. + + + + + TODO(https://crbug.com/1425354): Replace this property with structured error. + + + + + RuleSetErrorType + + + + + SourceIsNotJsonObject + + + + + InvalidRulesSkipped + + + + + The type of preloading attempted. It corresponds to + mojom::SpeculationAction (although PrefetchWithSubresources is omitted as it + isn't being used by clients). + + + + + Prefetch + + + + + Prerender + + + + + Corresponds to mojom::SpeculationTargetHint. + See https://github.com/WICG/nav-speculation/blob/main/triggers.md#window-name-targeting-hints + + + + + Blank + + + + + Self + + + + + A key that identifies a preloading attempt. + + The url used is the url specified by the trigger (i.e. the initial URL), and + not the final url that is navigated to. For example, prerendering allows + same-origin main frame navigations during the attempt, but the attempt is + still keyed with the initial URL. + + + + + LoaderId + + + + + Action + + + + + Action + + + + + Url + + + + + TargetHint + + + + + TargetHint + + + + + Lists sources for a preloading attempt, specifically the ids of rule sets + that had a speculation rule that triggered the attempt, and the + BackendNodeIds of <a href> or <area href> elements that triggered the + attempt (in the case of attempts triggered by a document rule). It is + possible for mulitple rule sets and links to trigger a single attempt. + + + + + Key + + + + + RuleSetIds + + + + + NodeIds + + + + + List of FinalStatus reasons for Prerender2. + + + + + Activated + + + + + Destroyed + + + + + LowEndDevice + + + + + InvalidSchemeRedirect + + + + + InvalidSchemeNavigation + + + + + InProgressNavigation + + + + + NavigationRequestBlockedByCsp + + + + + MainFrameNavigation + + + + + MojoBinderPolicy + + + + + RendererProcessCrashed + + + + + RendererProcessKilled + + + + + Download + + + + + TriggerDestroyed + + + + + NavigationNotCommitted + + + + + NavigationBadHttpStatus + + + + + ClientCertRequested + + + + + NavigationRequestNetworkError + + + + + MaxNumOfRunningPrerendersExceeded + + + + + CancelAllHostsForTesting + + + + + DidFailLoad + + + + + Stop + + + + + SslCertificateError + + + + + LoginAuthRequested + + + + + UaChangeRequiresReload + + + + + BlockedByClient + + + + + AudioOutputDeviceRequested + + + + + MixedContent + + + + + TriggerBackgrounded + + + + + EmbedderTriggeredAndCrossOriginRedirected + + + + + MemoryLimitExceeded + + + + + FailToGetMemoryUsage + + + + + DataSaverEnabled + + + + + HasEffectiveUrl + + + + + ActivatedBeforeStarted + + + + + InactivePageRestriction + + + + + StartFailed + + + + + TimeoutBackgrounded + + + + + CrossSiteRedirectInInitialNavigation + + + + + CrossSiteNavigationInInitialNavigation + + + + + SameSiteCrossOriginRedirectNotOptInInInitialNavigation + + + + + SameSiteCrossOriginNavigationNotOptInInInitialNavigation + + + + + ActivationNavigationParameterMismatch + + + + + ActivatedInBackground + + + + + EmbedderHostDisallowed + + + + + ActivationNavigationDestroyedBeforeSuccess + + + + + TabClosedByUserGesture + + + + + TabClosedWithoutUserGesture + + + + + PrimaryMainFrameRendererProcessCrashed + + + + + PrimaryMainFrameRendererProcessKilled + + + + + ActivationFramePolicyNotCompatible + + + + + PreloadingDisabled + + + + + BatterySaverEnabled + + + + + ActivatedDuringMainFrameNavigation + + + + + PreloadingUnsupportedByWebContents + + + + + CrossSiteRedirectInMainFrameNavigation + + + + + CrossSiteNavigationInMainFrameNavigation + + + + + SameSiteCrossOriginRedirectNotOptInInMainFrameNavigation + + + + + SameSiteCrossOriginNavigationNotOptInInMainFrameNavigation + + + + + Preloading status values, see also PreloadingTriggeringOutcome. This + status is shared by prefetchStatusUpdated and prerenderStatusUpdated. + + + + + Pending + + + + + Running + + + + + Ready + + + + + Success + + + + + Failure + + + + + NotSupported + + + + + Upsert. Currently, it is only emitted when a rule set added. + + + + + RuleSet + + + + + ruleSetRemoved + + + + + Id + + + + + Fired when a prerender attempt is completed. + + + + + Key + + + + + The frame id of the frame initiating prerendering. + + + + + PrerenderingUrl + + + + + FinalStatus + + + + + FinalStatus + + + + + This is used to give users more information about the name of the API call + that is incompatible with prerender and has caused the cancellation of the attempt + + + + + Fired when a prefetch attempt is updated. + + + + + Key + + + + + The frame id of the frame initiating prefetch. + + + + + PrefetchUrl + + + + + Status + + + + + Status + + + + + Fired when a prerender attempt is updated. + + + + + Key + + + + + The frame id of the frame initiating prerender. + + + + + PrerenderingUrl + + + + + Status + + + + + Status + + + + + Send a list of sources for all preloading attempts in a document. + + + + + LoaderId + + + + + PreloadingAttemptSources + + + + + Preload + + + + + Preload + + DevToolsClient + + + + Upsert. Currently, it is only emitted when a rule set added. + + + + + RuleSetRemoved + + + + + Fired when a prerender attempt is completed. + + + + + Fired when a prefetch attempt is updated. + + + + + Fired when a prerender attempt is updated. + + + + + Send a list of sources for all preloading attempts in a document. + + + + + Enable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Whether this is a sign-up or sign-in action for this account, i.e. + whether this account has ever been used to sign in to this RP before. + + + + + SignIn + + + + + SignUp + + + + + Corresponds to IdentityRequestAccount + + + + + AccountId + + + + + Email + + + + + Name + + + + + GivenName + + + + + PictureUrl + + + + + IdpConfigUrl + + + + + IdpSigninUrl + + + + + LoginState + + + + + LoginState + + + + + These two are only set if the loginState is signUp + + + + + PrivacyPolicyUrl + + + + + dialogShown + + + + + DialogId + + + + + Accounts + + + + + These exist primarily so that the caller can verify the + RP context was used appropriately. + + + + + Subtitle + + + + + This domain allows interacting with the FedCM dialog. + + + + + FedCm + + DevToolsClient + + + + DialogShown + + + + + Enable + + Allows callers to disable the promise rejection delay that wouldnormally happen, if this is unimportant to what's being tested.(step 4 of https://fedidcg.github.io/FedCM/#browser-api-rp-sign-in) + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SelectAccount + + dialogId + accountIndex + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + DismissDialog + + dialogId + triggerCooldown + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Resets the cooldown time, if any, to allow the next FedCM call to show + a dialog even if one was recently dismissed by the user. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Location in the source code. + + + + + Script identifier as reported in the `Debugger.scriptParsed`. + + + + + Line number in the script (0-based). + + + + + Column number in the script (0-based). + + + + + Location in the source code. + + + + + LineNumber + + + + + ColumnNumber + + + + + Location range within one script. + + + + + ScriptId + + + + + Start + + + + + End + + + + + JavaScript call frame. Array of call frames form the call stack. + + + + + Call frame identifier. This identifier is only valid while the virtual machine is paused. + + + + + Name of the JavaScript function called on this call frame. + + + + + Location in the source code. + + + + + Location in the source code. + + + + + JavaScript script name or url. + Deprecated in favor of using the `location.scriptId` to resolve the URL via a previously + sent `Debugger.scriptParsed` event. + + + + + Scope chain for this call frame. + + + + + `this` object for this call frame. + + + + + The value being returned, if the function is at return point. + + + + + Valid only while the VM is paused and indicates whether this frame + can be restarted or not. Note that a `true` value here does not + guarantee that Debugger#restartFrame with this CallFrameId will be + successful, but it is very likely. + + + + + Scope type. + + + + + global + + + + + local + + + + + with + + + + + closure + + + + + catch + + + + + block + + + + + script + + + + + eval + + + + + module + + + + + wasm-expression-stack + + + + + Scope description. + + + + + Scope type. + + + + + Scope type. + + + + + Object representing the scope. For `global` and `with` scopes it represents the actual + object; for the rest of the scopes, it is artificial transient object enumerating scope + variables as its properties. + + + + + Name + + + + + Location in the source code where scope starts + + + + + Location in the source code where scope ends + + + + + Search match for resource. + + + + + Line number in resource content. + + + + + Line with match content. + + + + + BreakLocationType + + + + + debuggerStatement + + + + + call + + + + + return + + + + + BreakLocation + + + + + Script identifier as reported in the `Debugger.scriptParsed`. + + + + + Line number in the script (0-based). + + + + + Column number in the script (0-based). + + + + + Type + + + + + Type + + + + + WasmDisassemblyChunk + + + + + The next chunk of disassembled lines. + + + + + The bytecode offsets describing the start of each line. + + + + + Enum of possible script languages. + + + + + JavaScript + + + + + WebAssembly + + + + + Type of the debug symbols. + + + + + None + + + + + SourceMap + + + + + EmbeddedDWARF + + + + + ExternalDWARF + + + + + Debug symbols available for a wasm script. + + + + + Type of the debug symbols. + + + + + Type of the debug symbols. + + + + + URL of the external symbol source. + + + + + Fired when breakpoint is resolved to an actual script and location. + + + + + Breakpoint unique identifier. + + + + + Actual breakpoint location. + + + + + Pause reason. + + + + + ambiguous + + + + + assert + + + + + CSPViolation + + + + + debugCommand + + + + + DOM + + + + + EventListener + + + + + exception + + + + + instrumentation + + + + + OOM + + + + + other + + + + + promiseRejection + + + + + XHR + + + + + Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + + + + + Call stack the virtual machine stopped on. + + + + + Pause reason. + + + + + Pause reason. + + + + + Object containing break-specific auxiliary properties. + + + + + Hit breakpoints IDs + + + + + Async stack trace, if any. + + + + + Async stack trace, if any. + + + + + Never present, will be removed. + + + + + Fired when virtual machine fails to parse the script. + + + + + Identifier of the script parsed. + + + + + URL or name of the script parsed (if any). + + + + + Line offset of the script within the resource with given URL (for script tags). + + + + + Column offset of the script within the resource with given URL. + + + + + Last line of the script. + + + + + Length of the last line of the script. + + + + + Specifies script creation context. + + + + + Content hash of the script, SHA-256. + + + + + Embedder-specific auxiliary data. + + + + + URL of source map associated with script (if any). + + + + + True, if this script has sourceURL. + + + + + True, if this script is ES6 module. + + + + + This script length. + + + + + JavaScript top stack frame of where the script parsed event was triggered if available. + + + + + If the scriptLanguage is WebAssembly, the code section offset in the module. + + + + + The language of the script. + + + + + The language of the script. + + + + + The name the embedder supplied for this script. + + + + + Fired when virtual machine parses script. This event is also fired for all known and uncollected + scripts upon enabling debugger. + + + + + Identifier of the script parsed. + + + + + URL or name of the script parsed (if any). + + + + + Line offset of the script within the resource with given URL (for script tags). + + + + + Column offset of the script within the resource with given URL. + + + + + Last line of the script. + + + + + Length of the last line of the script. + + + + + Specifies script creation context. + + + + + Content hash of the script, SHA-256. + + + + + Embedder-specific auxiliary data. + + + + + True, if this script is generated as a result of the live edit operation. + + + + + URL of source map associated with script (if any). + + + + + True, if this script has sourceURL. + + + + + True, if this script is ES6 module. + + + + + This script length. + + + + + JavaScript top stack frame of where the script parsed event was triggered if available. + + + + + If the scriptLanguage is WebAssembly, the code section offset in the module. + + + + + The language of the script. + + + + + The language of the script. + + + + + If the scriptLanguage is WebASsembly, the source of debug symbols for the module. + + + + + The name the embedder supplied for this script. + + + + + EnableResponse + + + + + debuggerId + + + + + EvaluateOnCallFrameResponse + + + + + result + + + + + exceptionDetails + + + + + GetPossibleBreakpointsResponse + + + + + locations + + + + + GetScriptSourceResponse + + + + + scriptSource + + + + + bytecode + + + + + DisassembleWasmModuleResponse + + + + + streamId + + + + + totalNumberOfLines + + + + + functionBodyOffsets + + + + + chunk + + + + + NextWasmDisassemblyChunkResponse + + + + + chunk + + + + + GetStackTraceResponse + + + + + stackTrace + + + + + RestartFrameResponse + + + + + callFrames + + + + + asyncStackTrace + + + + + asyncStackTraceId + + + + + SearchInContentResponse + + + + + result + + + + + SetBreakpointResponse + + + + + breakpointId + + + + + actualLocation + + + + + SetInstrumentationBreakpointResponse + + + + + breakpointId + + + + + SetBreakpointByUrlResponse + + + + + breakpointId + + + + + locations + + + + + SetBreakpointOnFunctionCallResponse + + + + + breakpointId + + + + + SetScriptSourceResponse + + + + + callFrames + + + + + stackChanged + + + + + asyncStackTrace + + + + + asyncStackTraceId + + + + + status + + + + + exceptionDetails + + + + + ContinueToLocationTargetCallFrames + + + + + any + + + + + current + + + + + The `mode` parameter must be present and set to 'StepInto', otherwise + `restartFrame` will error out. + + + + + StepInto + + + + + Instrumentation name. + + + + + beforeScriptExecution + + + + + beforeScriptWithSourceMapExecution + + + + + Pause on exceptions mode. + + + + + none + + + + + caught + + + + + uncaught + + + + + all + + + + + Debugger domain exposes JavaScript debugging capabilities. It allows setting and removing + breakpoints, stepping through execution, exploring stack traces, etc. + + + + + Debugger + + DevToolsClient + + + + Fired when breakpoint is resolved to an actual script and location. + + + + + Fired when the virtual machine stopped on breakpoint or exception or any other stop criteria. + + + + + Fired when the virtual machine resumed execution. + + + + + Fired when virtual machine fails to parse the script. + + + + + Fired when virtual machine parses script. This event is also fired for all known and uncollected + scripts upon enabling debugger. + + + + + Continues execution until specific location is reached. + + Location to continue to. + targetCallFrames + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disables debugger for given page. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables debugger for the given page. Clients should not assume that the debugging has been + enabled until the result for this command is received. + + The maximum size in bytes of collected scripts (not referenced by other heap objects)the debugger can hold. Puts no limit if parameter is omitted. + returns System.Threading.Tasks.Task<EnableResponse> + + + + Evaluates expression on a given call frame. + + Call frame identifier to evaluate on. + Expression to evaluate. + String object group name to put result into (allows rapid releasing resulting object handlesusing `releaseObjectGroup`). + Specifies whether command line API should be available to the evaluated expression, defaultsto false. + In silent mode exceptions thrown during evaluation are not reported and do not pauseexecution. Overrides `setPauseOnException` state. + Whether the result is expected to be a JSON object that should be sent by value. + Whether preview should be generated for the result. + Whether to throw an exception if side effect cannot be ruled out during evaluation. + Terminate execution after timing out (number of milliseconds). + returns System.Threading.Tasks.Task<EvaluateOnCallFrameResponse> + + + + Returns possible locations for breakpoint. scriptId in start and end range locations should be + the same. + + Start of range to search possible breakpoint locations in. + End of range to search possible breakpoint locations in (excluding). When not specified, endof scripts is used as end of range. + Only consider locations which are in the same (non-nested) function as start. + returns System.Threading.Tasks.Task<GetPossibleBreakpointsResponse> + + + + Returns source for the script with given id. + + Id of the script to get source for. + returns System.Threading.Tasks.Task<GetScriptSourceResponse> + + + + DisassembleWasmModule + + Id of the script to disassemble + returns System.Threading.Tasks.Task<DisassembleWasmModuleResponse> + + + + Disassemble the next chunk of lines for the module corresponding to the + stream. If disassembly is complete, this API will invalidate the streamId + and return an empty chunk. Any subsequent calls for the now invalid stream + will return errors. + + streamId + returns System.Threading.Tasks.Task<NextWasmDisassemblyChunkResponse> + + + + Returns stack trace with given `stackTraceId`. + + stackTraceId + returns System.Threading.Tasks.Task<GetStackTraceResponse> + + + + Stops on the next JavaScript statement. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes JavaScript breakpoint. + + breakpointId + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Restarts particular call frame from the beginning. The old, deprecated + behavior of `restartFrame` is to stay paused and allow further CDP commands + after a restart was scheduled. This can cause problems with restarting, so + we now continue execution immediatly after it has been scheduled until we + reach the beginning of the restarted frame. + + To stay back-wards compatible, `restartFrame` now expects a `mode` + parameter to be present. If the `mode` parameter is missing, `restartFrame` + errors out. + + The various return values are deprecated and `callFrames` is always empty. + Use the call frames from the `Debugger#paused` events instead, that fires + once V8 pauses at the beginning of the restarted function. + + Call frame identifier to evaluate on. + The `mode` parameter must be present and set to 'StepInto', otherwise`restartFrame` will error out. + returns System.Threading.Tasks.Task<RestartFrameResponse> + + + + Resumes JavaScript execution. + + Set to true to terminate execution upon resuming execution. In contrastto Runtime.terminateExecution, this will allows to execute furtherJavaScript (i.e. via evaluation) until execution of the paused codeis actually resumed, at which point termination is triggered.If execution is currently not paused, this parameter has no effect. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Searches for given string in script content. + + Id of the script to search in. + String to search for. + If true, search is case sensitive. + If true, treats string parameter as regex. + returns System.Threading.Tasks.Task<SearchInContentResponse> + + + + Enables or disables async call stacks tracking. + + Maximum depth of async call stacks. Setting to `0` will effectively disable collecting asynccall stacks (default). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Replace previous blackbox patterns with passed ones. Forces backend to skip stepping/pausing in + scripts with url matching one of the patterns. VM will try to leave blackboxed script by + performing 'step in' several times, finally resorting to 'step out' if unsuccessful. + + Array of regexps that will be used to check script url for blackbox state. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Makes backend skip steps in the script in blackboxed ranges. VM will try leave blacklisted + scripts by performing 'step in' several times, finally resorting to 'step out' if unsuccessful. + Positions array contains positions where blackbox state is changed. First interval isn't + blackboxed. Array should be sorted. + + Id of the script. + positions + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sets JavaScript breakpoint at a given location. + + Location to set breakpoint in. + Expression to use as a breakpoint condition. When specified, debugger will only stop on thebreakpoint if this expression evaluates to true. + returns System.Threading.Tasks.Task<SetBreakpointResponse> + + + + Sets instrumentation breakpoint. + + Instrumentation name. + returns System.Threading.Tasks.Task<SetInstrumentationBreakpointResponse> + + + + Sets JavaScript breakpoint at given location specified either by URL or URL regex. Once this + command is issued, all existing parsed scripts will have breakpoints resolved and returned in + `locations` property. Further matching script parsing will result in subsequent + `breakpointResolved` events issued. This logical breakpoint will survive page reloads. + + Line number to set breakpoint at. + URL of the resources to set breakpoint on. + Regex pattern for the URLs of the resources to set breakpoints on. Either `url` or`urlRegex` must be specified. + Script hash of the resources to set breakpoint on. + Offset in the line to set breakpoint at. + Expression to use as a breakpoint condition. When specified, debugger will only stop on thebreakpoint if this expression evaluates to true. + returns System.Threading.Tasks.Task<SetBreakpointByUrlResponse> + + + + Sets JavaScript breakpoint before each call to the given function. + If another function was created from the same source as a given one, + calling it will also trigger the breakpoint. + + Function object id. + Expression to use as a breakpoint condition. When specified, debugger willstop on the breakpoint if this expression evaluates to true. + returns System.Threading.Tasks.Task<SetBreakpointOnFunctionCallResponse> + + + + Activates / deactivates all breakpoints on the page. + + New value for breakpoints active state. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Defines pause on exceptions state. Can be set to stop on all exceptions, uncaught exceptions, + or caught exceptions, no exceptions. Initial pause on exceptions state is `none`. + + Pause on exceptions mode. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Changes return value in top frame. Available only at return break position. + + New return value. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Edits JavaScript source live. + + In general, functions that are currently on the stack can not be edited with + a single exception: If the edited function is the top-most stack frame and + that is the only activation of that function on the stack. In this case + the live edit will be successful and a `Debugger.restartFrame` for the + top-most function is automatically triggered. + + Id of the script to edit. + New content of the script. + If true the change will not actually be applied. Dry run may be used to get resultdescription without actually modifying the code. + If true, then `scriptSource` is allowed to change the function on top of the stackas long as the top-most stack frame is the only activation of that function. + returns System.Threading.Tasks.Task<SetScriptSourceResponse> + + + + Makes page not interrupt on any pauses (breakpoint, exception, dom exception etc). + + New value for skip pauses state. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Changes value of variable in a callframe. Object-based scopes are not supported and must be + mutated manually. + + 0-based number of scope as was listed in scope chain. Only 'local', 'closure' and 'catch'scope types are allowed. Other scopes could be manipulated manually. + Variable name. + New variable value. + Id of callframe that holds variable. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Steps into the function call. + + Debugger will pause on the execution of the first async task which was scheduledbefore next pause. + The skipList specifies location ranges that should be skipped on step into. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Steps out of the function call. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Steps over the statement. + + The skipList specifies location ranges that should be skipped on step over. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Sampling Heap Profile node. Holds callsite information, allocation statistics and child nodes. + + + + + Function location. + + + + + Allocations size in bytes for the node excluding children. + + + + + Node id. Ids are unique across all profiles collected between startSampling and stopSampling. + + + + + Child nodes. + + + + + A single sample from a sampling profile. + + + + + Allocation size in bytes attributed to the sample. + + + + + Id of the corresponding profile tree node. + + + + + Time-ordered sample ordinal number. It is unique across all profiles retrieved + between startSampling and stopSampling. + + + + + Sampling profile. + + + + + Head + + + + + Samples + + + + + addHeapSnapshotChunk + + + + + Chunk + + + + + If heap objects tracking has been started then backend may send update for one or more fragments + + + + + An array of triplets. Each triplet describes a fragment. The first integer is the fragment + index, the second integer is a total count of objects for the fragment, the third integer is + a total size of the objects for the fragment. + + + + + If heap objects tracking has been started then backend regularly sends a current value for last + seen object id and corresponding timestamp. If the were changes in the heap since last event + then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + + + + + LastSeenObjectId + + + + + Timestamp + + + + + reportHeapSnapshotProgress + + + + + Done + + + + + Total + + + + + Finished + + + + + GetHeapObjectIdResponse + + + + + heapSnapshotObjectId + + + + + GetObjectByHeapObjectIdResponse + + + + + result + + + + + GetSamplingProfileResponse + + + + + profile + + + + + StopSamplingResponse + + + + + profile + + + + + HeapProfiler + + + + + HeapProfiler + + DevToolsClient + + + + AddHeapSnapshotChunk + + + + + If heap objects tracking has been started then backend may send update for one or more fragments + + + + + If heap objects tracking has been started then backend regularly sends a current value for last + seen object id and corresponding timestamp. If the were changes in the heap since last event + then one or more heapStatsUpdate events will be sent before a new lastSeenObjectId event. + + + + + ReportHeapSnapshotProgress + + + + + ResetProfiles + + + + + Enables console to refer to the node with given id via $x (see Command Line API for more details + $x functions). + + Heap snapshot object id to be accessible by means of $x command line API. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + CollectGarbage + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Disable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + GetHeapObjectId + + Identifier of the object to get heap object id for. + returns System.Threading.Tasks.Task<GetHeapObjectIdResponse> + + + + GetObjectByHeapObjectId + + objectId + Symbolic group name that can be used to release multiple objects. + returns System.Threading.Tasks.Task<GetObjectByHeapObjectIdResponse> + + + + GetSamplingProfile + + returns System.Threading.Tasks.Task<GetSamplingProfileResponse> + + + + StartSampling + + Average sample interval in bytes. Poisson distribution is used for the intervals. Thedefault value is 32768 bytes. + By default, the sampling heap profiler reports only objects which arestill alive when the profile is returned via getSamplingProfile orstopSampling, which is useful for determining what functions contributethe most to steady-state memory usage. This flag instructs the samplingheap profiler to also include information about objects discarded bymajor GC, which will show which functions cause large temporary memoryusage or long GC pauses. + By default, the sampling heap profiler reports only objects which arestill alive when the profile is returned via getSamplingProfile orstopSampling, which is useful for determining what functions contributethe most to steady-state memory usage. This flag instructs the samplingheap profiler to also include information about objects discarded byminor GC, which is useful when tuning a latency-sensitive applicationfor minimal GC activity. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + StartTrackingHeapObjects + + trackAllocations + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + StopSampling + + returns System.Threading.Tasks.Task<StopSamplingResponse> + + + + StopTrackingHeapObjects + + If true 'reportHeapSnapshotProgress' events will be generated while snapshot is being takenwhen the tracking is stopped. + Deprecated in favor of `exposeInternals`. + If true, numerical values are included in the snapshot + If true, exposes internals of the snapshot. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + TakeHeapSnapshot + + If true 'reportHeapSnapshotProgress' events will be generated while snapshot is being taken. + If true, a raw snapshot without artificial roots will be generated.Deprecated in favor of `exposeInternals`. + If true, numerical values are included in the snapshot + If true, exposes internals of the snapshot. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Profile node. Holds callsite information, execution statistics and child nodes. + + + + + Unique id of the node. + + + + + Function location. + + + + + Number of samples where this node was on top of the call stack. + + + + + Child node ids. + + + + + The reason of being not optimized. The function may be deoptimized or marked as don't + optimize. + + + + + An array of source position ticks. + + + + + Profile. + + + + + The list of profile nodes. First item is the root node. + + + + + Profiling start timestamp in microseconds. + + + + + Profiling end timestamp in microseconds. + + + + + Ids of samples top nodes. + + + + + Time intervals between adjacent samples in microseconds. The first delta is relative to the + profile startTime. + + + + + Specifies a number of samples attributed to a certain source position. + + + + + Source line number (1-based). + + + + + Number of samples attributed to the source line. + + + + + Coverage data for a source range. + + + + + JavaScript script source offset for the range start. + + + + + JavaScript script source offset for the range end. + + + + + Collected execution count of the source range. + + + + + Coverage data for a JavaScript function. + + + + + JavaScript function name. + + + + + Source ranges inside the function with coverage data. + + + + + Whether coverage data for this function has block granularity. + + + + + Coverage data for a JavaScript script. + + + + + JavaScript script id. + + + + + JavaScript script name or url. + + + + + Functions contained in the script that has coverage data. + + + + + consoleProfileFinished + + + + + Id + + + + + Location of console.profileEnd(). + + + + + Profile + + + + + Profile title passed as an argument to console.profile(). + + + + + Sent when new profile recording is started using console.profile() call. + + + + + Id + + + + + Location of console.profile(). + + + + + Profile title passed as an argument to console.profile(). + + + + + Reports coverage delta since the last poll (either from an event like this, or from + `takePreciseCoverage` for the current isolate. May only be sent if precise code + coverage has been started. This event can be trigged by the embedder to, for example, + trigger collection of coverage data immediately at a certain point in time. + + + + + Monotonically increasing time (in seconds) when the coverage update was taken in the backend. + + + + + Identifier for distinguishing coverage events. + + + + + Coverage data for the current isolate. + + + + + GetBestEffortCoverageResponse + + + + + result + + + + + StartPreciseCoverageResponse + + + + + timestamp + + + + + StopResponse + + + + + profile + + + + + TakePreciseCoverageResponse + + + + + result + + + + + timestamp + + + + + Profiler + + + + + Profiler + + DevToolsClient + + + + ConsoleProfileFinished + + + + + Sent when new profile recording is started using console.profile() call. + + + + + Reports coverage delta since the last poll (either from an event like this, or from + `takePreciseCoverage` for the current isolate. May only be sent if precise code + coverage has been started. This event can be trigged by the embedder to, for example, + trigger collection of coverage data immediately at a certain point in time. + + + + + Disable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Collect coverage data for the current isolate. The coverage data may be incomplete due to + garbage collection. + + returns System.Threading.Tasks.Task<GetBestEffortCoverageResponse> + + + + Changes CPU profiler sampling interval. Must be called before CPU profiles recording started. + + New sampling interval in microseconds. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Start + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enable precise code coverage. Coverage data for JavaScript executed before enabling precise code + coverage may be incomplete. Enabling prevents running optimized code and resets execution + counters. + + Collect accurate call counts beyond simple 'covered' or 'not covered'. + Collect block-based coverage. + Allow the backend to send updates on its own initiative + returns System.Threading.Tasks.Task<StartPreciseCoverageResponse> + + + + Stop + + returns System.Threading.Tasks.Task<StopResponse> + + + + Disable precise code coverage. Disabling releases unnecessary execution count records and allows + executing optimized code. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Collect coverage data for the current isolate, and resets execution counters. Precise code + coverage needs to have started. + + returns System.Threading.Tasks.Task<TakePreciseCoverageResponse> + + + + WebDriverValueType + + + + + undefined + + + + + null + + + + + string + + + + + number + + + + + boolean + + + + + bigint + + + + + regexp + + + + + date + + + + + symbol + + + + + array + + + + + object + + + + + function + + + + + map + + + + + set + + + + + weakmap + + + + + weakset + + + + + error + + + + + proxy + + + + + promise + + + + + typedarray + + + + + arraybuffer + + + + + node + + + + + window + + + + + Represents the value serialiazed by the WebDriver BiDi specification + https://w3c.github.io/webdriver-bidi. + + + + + Type + + + + + Type + + + + + Value + + + + + ObjectId + + + + + Object type. + + + + + object + + + + + function + + + + + undefined + + + + + string + + + + + number + + + + + boolean + + + + + symbol + + + + + bigint + + + + + Object subtype hint. Specified for `object` type values only. + NOTE: If you change anything here, make sure to also update + `subtype` in `ObjectPreview` and `PropertyPreview` below. + + + + + array + + + + + null + + + + + node + + + + + regexp + + + + + date + + + + + map + + + + + set + + + + + weakmap + + + + + weakset + + + + + iterator + + + + + generator + + + + + error + + + + + proxy + + + + + promise + + + + + typedarray + + + + + arraybuffer + + + + + dataview + + + + + webassemblymemory + + + + + wasmvalue + + + + + Mirror object referencing original JavaScript object. + + + + + Object type. + + + + + Object type. + + + + + Object subtype hint. Specified for `object` type values only. + NOTE: If you change anything here, make sure to also update + `subtype` in `ObjectPreview` and `PropertyPreview` below. + + + + + Object subtype hint. Specified for `object` type values only. + NOTE: If you change anything here, make sure to also update + `subtype` in `ObjectPreview` and `PropertyPreview` below. + + + + + Object class (constructor) name. Specified for `object` type values only. + + + + + Remote object value in case of primitive values or JSON values (if it was requested). + + + + + Primitive value which can not be JSON-stringified does not have `value`, but gets this + property. + + + + + String representation of the object. + + + + + WebDriver BiDi representation of the value. + + + + + Unique object identifier (for non-primitive values). + + + + + Preview containing abbreviated property values. Specified for `object` type values only. + + + + + CustomPreview + + + + + CustomPreview + + + + + The JSON-stringified result of formatter.header(object, config) call. + It contains json ML array that represents RemoteObject. + + + + + If formatter returns true as a result of formatter.hasBody call then bodyGetterId will + contain RemoteObjectId for the function that returns result of formatter.body(object, config) call. + The result value is json ML array. + + + + + Object type. + + + + + object + + + + + function + + + + + undefined + + + + + string + + + + + number + + + + + boolean + + + + + symbol + + + + + bigint + + + + + Object subtype hint. Specified for `object` type values only. + + + + + array + + + + + null + + + + + node + + + + + regexp + + + + + date + + + + + map + + + + + set + + + + + weakmap + + + + + weakset + + + + + iterator + + + + + generator + + + + + error + + + + + proxy + + + + + promise + + + + + typedarray + + + + + arraybuffer + + + + + dataview + + + + + webassemblymemory + + + + + wasmvalue + + + + + Object containing abbreviated remote object value. + + + + + Object type. + + + + + Object type. + + + + + Object subtype hint. Specified for `object` type values only. + + + + + Object subtype hint. Specified for `object` type values only. + + + + + String representation of the object. + + + + + True iff some of the properties or entries of the original object did not fit. + + + + + List of the properties. + + + + + List of the entries. Specified for `map` and `set` subtype values only. + + + + + Object type. Accessor means that the property itself is an accessor property. + + + + + object + + + + + function + + + + + undefined + + + + + string + + + + + number + + + + + boolean + + + + + symbol + + + + + accessor + + + + + bigint + + + + + Object subtype hint. Specified for `object` type values only. + + + + + array + + + + + null + + + + + node + + + + + regexp + + + + + date + + + + + map + + + + + set + + + + + weakmap + + + + + weakset + + + + + iterator + + + + + generator + + + + + error + + + + + proxy + + + + + promise + + + + + typedarray + + + + + arraybuffer + + + + + dataview + + + + + webassemblymemory + + + + + wasmvalue + + + + + PropertyPreview + + + + + Property name. + + + + + Object type. Accessor means that the property itself is an accessor property. + + + + + Object type. Accessor means that the property itself is an accessor property. + + + + + User-friendly property value string. + + + + + Nested value preview. + + + + + Object subtype hint. Specified for `object` type values only. + + + + + Object subtype hint. Specified for `object` type values only. + + + + + EntryPreview + + + + + Preview of the key. Specified for map-like collection entries. + + + + + Preview of the value. + + + + + Object property descriptor. + + + + + Property name or symbol description. + + + + + The value associated with the property. + + + + + True if the value associated with the property may be changed (data descriptors only). + + + + + A function which serves as a getter for the property, or `undefined` if there is no getter + (accessor descriptors only). + + + + + A function which serves as a setter for the property, or `undefined` if there is no setter + (accessor descriptors only). + + + + + True if the type of this property descriptor may be changed and if the property may be + deleted from the corresponding object. + + + + + True if this property shows up during enumeration of the properties on the corresponding + object. + + + + + True if the result was thrown during the evaluation. + + + + + True if the property is owned for the object. + + + + + Property symbol object, if the property is of the `symbol` type. + + + + + Object internal property descriptor. This property isn't normally visible in JavaScript code. + + + + + Conventional property name. + + + + + The value associated with the property. + + + + + Object private field descriptor. + + + + + Private property name. + + + + + The value associated with the private property. + + + + + A function which serves as a getter for the private property, + or `undefined` if there is no getter (accessor descriptors only). + + + + + A function which serves as a setter for the private property, + or `undefined` if there is no setter (accessor descriptors only). + + + + + Represents function call argument. Either remote object id `objectId`, primitive `value`, + unserializable primitive value or neither of (for undefined) them should be specified. + + + + + Primitive value or serializable javascript object. + + + + + Primitive value which can not be JSON-stringified. + + + + + Remote object handle. + + + + + Description of an isolated world. + + + + + Unique id of the execution context. It can be used to specify in which execution context + script evaluation should be performed. + + + + + Execution context origin. + + + + + Human readable name describing given context. + + + + + A system-unique execution context identifier. Unlike the id, this is unique across + multiple processes, so can be reliably used to identify specific context while backend + performs a cross-process navigation. + + + + + Embedder-specific auxiliary data. + + + + + Detailed information about exception (or error) that was thrown during script compilation or + execution. + + + + + Exception id. + + + + + Exception text, which should be used together with exception object when available. + + + + + Line number of the exception location (0-based). + + + + + Column number of the exception location (0-based). + + + + + Script ID of the exception location. + + + + + URL of the exception location, to be used when the script was not reported. + + + + + JavaScript stack trace if available. + + + + + Exception object if available. + + + + + Identifier of the context where exception happened. + + + + + Dictionary with entries of meta data that the client associated + with this exception, such as information about associated network + requests, etc. + + + + + Stack entry for runtime errors and assertions. + + + + + JavaScript function name. + + + + + JavaScript script id. + + + + + JavaScript script name or url. + + + + + JavaScript script line number (0-based). + + + + + JavaScript script column number (0-based). + + + + + Call frames for assertions or error messages. + + + + + String label of this stack trace. For async traces this may be a name of the function that + initiated the async call. + + + + + JavaScript function name. + + + + + Asynchronous JavaScript stack trace that preceded this stack, if available. + + + + + Asynchronous JavaScript stack trace that preceded this stack, if available. + + + + + If `debuggerId` is set stack trace comes from another debugger and can be resolved there. This + allows to track cross-debugger calls. See `Runtime.StackTrace` and `Debugger.paused` for usages. + + + + + Id + + + + + DebuggerId + + + + + Notification is issued every time when binding is called. + + + + + Name + + + + + Payload + + + + + Identifier of the context where the call was made. + + + + + Type of the call. + + + + + log + + + + + debug + + + + + info + + + + + error + + + + + warning + + + + + dir + + + + + dirxml + + + + + table + + + + + trace + + + + + clear + + + + + startGroup + + + + + startGroupCollapsed + + + + + endGroup + + + + + assert + + + + + profile + + + + + profileEnd + + + + + count + + + + + timeEnd + + + + + Issued when console API was called. + + + + + Type of the call. + + + + + Type of the call. + + + + + Call arguments. + + + + + Identifier of the context where the call was made. + + + + + Call timestamp. + + + + + Stack trace captured when the call was made. The async stack chain is automatically reported for + the following call types: `assert`, `error`, `trace`, `warning`. For other types the async call + chain can be retrieved using `Debugger.getStackTrace` and `stackTrace.parentId` field. + + + + + Console context descriptor for calls on non-default console context (not console.*): + 'anonymous#unique-logger-id' for call on unnamed context, 'name#unique-logger-id' for call + on named context. + + + + + Issued when unhandled exception was revoked. + + + + + Reason describing why exception was revoked. + + + + + The id of revoked exception, as reported in `exceptionThrown`. + + + + + Issued when exception was thrown and unhandled. + + + + + Timestamp of the exception. + + + + + ExceptionDetails + + + + + Issued when new execution context is created. + + + + + A newly created execution context. + + + + + Issued when execution context is destroyed. + + + + + Id of the destroyed context + + + + + Unique Id of the destroyed context + + + + + Issued when object should be inspected (for example, as a result of inspect() command line API + call). + + + + + Object + + + + + Hints + + + + + Identifier of the context where the call was made. + + + + + AwaitPromiseResponse + + + + + result + + + + + exceptionDetails + + + + + CallFunctionOnResponse + + + + + result + + + + + exceptionDetails + + + + + CompileScriptResponse + + + + + scriptId + + + + + exceptionDetails + + + + + EvaluateResponse + + + + + result + + + + + exceptionDetails + + + + + GetIsolateIdResponse + + + + + id + + + + + GetHeapUsageResponse + + + + + usedSize + + + + + totalSize + + + + + GetPropertiesResponse + + + + + result + + + + + internalProperties + + + + + privateProperties + + + + + exceptionDetails + + + + + GlobalLexicalScopeNamesResponse + + + + + names + + + + + QueryObjectsResponse + + + + + objects + + + + + RunScriptResponse + + + + + result + + + + + exceptionDetails + + + + + GetExceptionDetailsResponse + + + + + exceptionDetails + + + + + Runtime domain exposes JavaScript runtime by means of remote evaluation and mirror objects. + Evaluation results are returned as mirror object that expose object type, string representation + and unique identifier that can be used for further object reference. Original objects are + maintained in memory unless they are either explicitly released or are released along with the + other objects in their object group. + + + + + Runtime + + DevToolsClient + + + + Notification is issued every time when binding is called. + + + + + Issued when console API was called. + + + + + Issued when unhandled exception was revoked. + + + + + Issued when exception was thrown and unhandled. + + + + + Issued when new execution context is created. + + + + + Issued when execution context is destroyed. + + + + + Issued when all executionContexts were cleared in browser + + + + + Issued when object should be inspected (for example, as a result of inspect() command line API + call). + + + + + Add handler to promise with given promise object id. + + Identifier of the promise. + Whether the result is expected to be a JSON object that should be sent by value. + Whether preview should be generated for the result. + returns System.Threading.Tasks.Task<AwaitPromiseResponse> + + + + Calls function with given declaration on the given object. Object group of the result is + inherited from the target object. + + Declaration of the function to call. + Identifier of the object to call function on. Either objectId or executionContextId shouldbe specified. + Call arguments. All call arguments must belong to the same JavaScript world as the targetobject. + In silent mode exceptions thrown during evaluation are not reported and do not pauseexecution. Overrides `setPauseOnException` state. + Whether the result is expected to be a JSON object which should be sent by value. + Whether preview should be generated for the result. + Whether execution should be treated as initiated by user in the UI. + Whether execution should `await` for resulting value and return once awaited promise isresolved. + Specifies execution context which global object will be used to call function on. EitherexecutionContextId or objectId should be specified. + Symbolic group name that can be used to release multiple objects. If objectGroup is notspecified and objectId is, objectGroup will be inherited from object. + Whether to throw an exception if side effect cannot be ruled out during evaluation. + An alternative way to specify the execution context to call function on.Compared to contextId that may be reused across processes, this is guaranteed to besystem-unique, so it can be used to prevent accidental function callin context different than intended (e.g. as a result of navigation across processboundaries).This is mutually exclusive with `executionContextId`. + Whether the result should contain `webDriverValue`, serialized according tohttps://w3c.github.io/webdriver-bidi. This is mutually exclusive with `returnByValue`, butresulting `objectId` is still provided. + returns System.Threading.Tasks.Task<CallFunctionOnResponse> + + + + Compiles expression. + + Expression to compile. + Source url to be set for the script. + Specifies whether the compiled script should be persisted. + Specifies in which execution context to perform script run. If the parameter is omitted theevaluation will be performed in the context of the inspected page. + returns System.Threading.Tasks.Task<CompileScriptResponse> + + + + Disables reporting of execution contexts creation. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Discards collected exceptions and console API calls. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Enables reporting of execution contexts creation by means of `executionContextCreated` event. + When the reporting gets enabled the event will be sent immediately for each existing execution + context. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Evaluates expression on global object. + + Expression to evaluate. + Symbolic group name that can be used to release multiple objects. + Determines whether Command Line API should be available during the evaluation. + In silent mode exceptions thrown during evaluation are not reported and do not pauseexecution. Overrides `setPauseOnException` state. + Specifies in which execution context to perform evaluation. If the parameter is omitted theevaluation will be performed in the context of the inspected page.This is mutually exclusive with `uniqueContextId`, which offers analternative way to identify the execution context that is more reliablein a multi-process environment. + Whether the result is expected to be a JSON object that should be sent by value. + Whether preview should be generated for the result. + Whether execution should be treated as initiated by user in the UI. + Whether execution should `await` for resulting value and return once awaited promise isresolved. + Whether to throw an exception if side effect cannot be ruled out during evaluation.This implies `disableBreaks` below. + Terminate execution after timing out (number of milliseconds). + Disable breakpoints during execution. + Setting this flag to true enables `let` re-declaration and top-level `await`.Note that `let` variables can only be re-declared if they originate from`replMode` themselves. + The Content Security Policy (CSP) for the target might block 'unsafe-eval'which includes eval(), Function(), setTimeout() and setInterval()when called with non-callable arguments. This flag bypasses CSP for thisevaluation and allows unsafe-eval. Defaults to true. + An alternative way to specify the execution context to evaluate in.Compared to contextId that may be reused across processes, this is guaranteed to besystem-unique, so it can be used to prevent accidental evaluation of the expressionin context different than intended (e.g. as a result of navigation across processboundaries).This is mutually exclusive with `contextId`. + Whether the result should be serialized according to https://w3c.github.io/webdriver-bidi. + returns System.Threading.Tasks.Task<EvaluateResponse> + + + + Returns the isolate id. + + returns System.Threading.Tasks.Task<GetIsolateIdResponse> + + + + Returns the JavaScript heap usage. + It is the total usage of the corresponding isolate not scoped to a particular Runtime. + + returns System.Threading.Tasks.Task<GetHeapUsageResponse> + + + + Returns properties of a given object. Object group of the result is inherited from the target + object. + + Identifier of the object to return properties for. + If true, returns properties belonging only to the element itself, not to its prototypechain. + If true, returns accessor properties (with getter/setter) only; internal properties are notreturned either. + Whether preview should be generated for the results. + If true, returns non-indexed properties only. + returns System.Threading.Tasks.Task<GetPropertiesResponse> + + + + Returns all let, const and class variables from global scope. + + Specifies in which execution context to lookup global scope variables. + returns System.Threading.Tasks.Task<GlobalLexicalScopeNamesResponse> + + + + QueryObjects + + Identifier of the prototype to return objects for. + Symbolic group name that can be used to release the results. + returns System.Threading.Tasks.Task<QueryObjectsResponse> + + + + Releases remote object with given id. + + Identifier of the object to release. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Releases all remote objects that belong to a given group. + + Symbolic object group name. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Tells inspected instance to run if it was waiting for debugger to attach. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Runs script with given id in a given context. + + Id of the script to run. + Specifies in which execution context to perform script run. If the parameter is omitted theevaluation will be performed in the context of the inspected page. + Symbolic group name that can be used to release multiple objects. + In silent mode exceptions thrown during evaluation are not reported and do not pauseexecution. Overrides `setPauseOnException` state. + Determines whether Command Line API should be available during the evaluation. + Whether the result is expected to be a JSON object which should be sent by value. + Whether preview should be generated for the result. + Whether execution should `await` for resulting value and return once awaited promise isresolved. + returns System.Threading.Tasks.Task<RunScriptResponse> + + + + Enables or disables async call stacks tracking. + + Maximum depth of async call stacks. Setting to `0` will effectively disable collecting asynccall stacks (default). + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetCustomObjectFormatterEnabled + + enabled + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + SetMaxCallStackSizeToCapture + + size + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Terminate current or next JavaScript execution. + Will cancel the termination when the outer-most script execution ends. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + If executionContextId is empty, adds binding with the given name on the + global objects of all inspected contexts, including those created later, + bindings survive reloads. + Binding function takes exactly one argument, this argument should be string, + in case of any other input, function throws an exception. + Each binding function call produces Runtime.bindingCalled notification. + + name + If specified, the binding would only be exposed to the specifiedexecution context. If omitted and `executionContextName` is not set,the binding is exposed to all execution contexts of the target.This parameter is mutually exclusive with `executionContextName`.Deprecated in favor of `executionContextName` due to an unclear use caseand bugs in implementation (crbug.com/1169639). `executionContextId` will beremoved in the future. + If specified, the binding is exposed to the executionContext withmatching name, even for contexts created after the binding is added.See also `ExecutionContext.name` and `worldName` parameter to`Page.addScriptToEvaluateOnNewDocument`.This parameter is mutually exclusive with `executionContextId`. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + This method does not remove binding function from global object but + unsubscribes current runtime agent from Runtime.bindingCalled notifications. + + name + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + This method tries to lookup and populate exception details for a + JavaScript Error object. + Note that the stackTrace portion of the resulting exceptionDetails will + only be populated if the Runtime domain was enabled at the time when the + Error was thrown. + + The error object for which to resolve the exception details. + returns System.Threading.Tasks.Task<GetExceptionDetailsResponse> + + + + EventBreakpoints permits setting breakpoints on particular operations and + events in targets that run JavaScript but do not have a DOM. + JavaScript execution will stop on these operations as if there was a regular + breakpoint set. + + + + + EventBreakpoints + + DevToolsClient + + + + Sets breakpoint on particular native event. + + Instrumentation name to stop on. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Removes breakpoint on particular native event. + + Instrumentation name to stop on. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + DeviceOrientation + + + + + DeviceOrientation + + DevToolsClient + + + + Clears the overridden Device Orientation. + + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Overrides the Device Orientation. + + Mock alpha + Mock beta + Mock gamma + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + ReadResponse + + + + + base64Encoded + + + + + data + + + + + eof + + + + + ResolveBlobResponse + + + + + uuid + + + + + Input/Output operations for streams produced by DevTools. + + + + + IO + + DevToolsClient + + + + Close the stream, discard any temporary backing storage. + + Handle of the stream to close. + returns System.Threading.Tasks.Task<DevToolsMethodResponse> + + + + Read a chunk of the stream + + Handle of the stream to read. + Seek to the specified offset before reading (if not specificed, proceed with offsetfollowing the last read). Some types of streams may only support sequential reads. + Maximum number of bytes to read (left upon the agent discretion if not specified). + returns System.Threading.Tasks.Task<ReadResponse> + + + + Return UUID of Blob object specified by a remote object id. + + Object id of a Blob object wrapper. + returns System.Threading.Tasks.Task<ResolveBlobResponse> + + + + The exception that is thrown when there's a problem executing a DevTools protocol method. + + + + + Get the Error Response + + + + + Initializes a new instance of the class with its message + string set to a default message. + + + + + Initializes a new instance of the class with a specified error message. + + message + + + + Initializes a new instance of the class with a specified error message. + + message + error response + + + + Initializes a new instance of the class with a specified error message + and an inner exception. + + message + inner exception + + + + + + + DevTools Domain base class + Provides some basic helper methods + + + + + Common Base class for DevTools Domain Model classes + + + + + Error Message parsed from JSON + e.g. {"code":-32601,"message":"'Browser.getWindowForTarget' wasn't found"} + + + + + Message Id + + + + + Error Code + + + + + Error Message + + + + + DevToolsDomainEventArgsBase + + + + + DevToolsDomainResponseBase + + + + + Convert from string to base64 byte array + + string data + byte array + + + + DevToolsErrorEventArgs - Raised when an exception occurs when + attempting to raise + + + + + Event Name + + + + + Json + + + + + Exception + + + + + DevToolsErrorEventArgs + + Event Name + json + Exception + + + + DevTools Event EventAargs + + + + + Event Name + + + + + Event paramaters as Json string + + + + + DevTools Method Response + + + + + MessageId + + + + + Success + + + + + Method Response as Json string + + + + + Generic Typed Event Proxy + + Event Args Type + + + + Constructor + + Delegate used to convert from the Stream to event args + + + + Add the event handler + + event handler to add + + + + Remove the event handler + + event handler to remove + returns true if the last event handler for this proxy was removed. + + + + + + + + + + DevTools Client + + + + + Will be called on receipt of a DevTools protocol event. Events by default are disabled and need to be + enabled on a per domain basis, e.g. Sending Network.enable (or calling ) + to enable network related events. + + + + + Will be called when an error occurs when attempting to raise + + + + + Add event handler for a DevTools protocol event. Events by default are disabled and need to be + enabled on a per domain basis, e.g. Sending Network.enable (or calling ) + to enable network related events. + + The event args type to which the event will be deserialized to. + is the event name to listen to + event handler to call when the event occurs + + + + Remove event handler for a DevTools protocol event. + + The event args type to which the event will be deserialized to. + is the event name to listen to + event handler to call when the event occurs + + Returns false if all handlers for the have been removed, + otherwise returns true if there are still handlers registered. + + + + + Execute a method call over the DevTools protocol. This method can be called on any thread. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + + The type to which the method result will be deserialzed to. + is the method name + are the method parameters represented as a dictionary, + which may be empty. + return a Task that can be awaited to obtain the method result + + + + Event Proxy + + + + + Raise Event + + sender + event name + Stream containing JSON + SynchronizationContext + + + + Used to represent Drag Data. + + + + + Create a new instance of + + DragData + + + + Called before a download begins in response to a user-initiated action + (e.g. alt + link click or link click that returns a `Content-Disposition: + attachment` response from the server). + + the ChromiumWebBrowser control + The browser instance + is the target download URL + is the target method (GET, POST, etc) + Return true to proceed with the download or false to cancel the download. + + + + Called before a download begins. + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + Callback interface used to asynchronously continue a download. + + + + Called when a download's status or progress information has been updated. This may be called multiple times before and after . + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + The callback used to Cancel/Pause/Resume the process + + + + A implementation used by + to provide a fluent means of creating a . + + + + + Create a new DownloadHandler Builder + + Fluent DownloadHandler Builder + + + + Creates a new instances + where all downloads are automatically downloaded to the specified folder. + No dialog is dispolayed to the user. + + folder where files are download. + optional delegate for download updates, track progress, completion etc. + instance. + + + + Creates a new instances + where a default "Save As" dialog is displayed to the user. + + optional delegate for download updates, track progress, completion etc. + instance. + + + + Use to create a new instance of the fluent builder + + + + + + + + + + + + + + Fluent DownloadHandler Builder + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + Create a instance + + a instance + + + + Called on the CEF IO thread when the browser needs credentials from the user. + This method will only be called for requests initiated from the browser process. + + indicates whether the host is a proxy server. + the hostname. + the port number. + realm + scheme + is a callback for authentication information + + Return true to continue the request and call when the authentication information is available. + If the request has an associated browser/frame then returning false will result in a call to + on the associated with that browser, if any. + Otherwise, returning false will cancel the request immediately. + + + + + Called when some part of the response is read. This method will not be called if the flag is set on the request. + + request + A stream containing the bytes received since the last call. Cannot be used outside the scope of this method. + + + + Notifies the client of download progress. + + request + denotes the number of bytes received up to the call + is the expected total size of the response (or -1 if not determined). + + + + Notifies the client that the request has completed. + Use the property to determine if the + request was successful or not. + + request + + + + Notifies the client of upload progress. + This method will only be called if the UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + request + denotes the number of bytes sent so far. + is the total size of uploading data (or -1 if chunked upload is enabled). + + + + Fluent UrlRequestClient + + + + + Create a new UrlRequestClient Builder + + Fluent UrlRequestClient Builder + + + + Use to create a new instance of the fluent builder + + + + + + + + + + + + + + + + + + + + Fluent UrlRequestClient Builder + + + + + See for details + + function to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + See for details. + + Action to be executed when + is called + + Fluent Builder, call to create + a new instance + + + + + Create a instance + + a instance + + + + Create instance via + This is the primary object for bridging the ChromiumWebBrowser implementation and VC++ + + + + + Create a new instance which is the main method of interaction between the unmanged + CEF implementation and our ChromiumWebBrowser instances. + + reference to the ChromiumWebBrowser instance + true for WPF/OffScreen, false for WinForms and other Hwnd based implementations + instance of + + + + Native static methods for low level operations, memory copy + Avoids having to P/Invoke as we can call the C++ API directly. + + + + + Create instances of Public Api classes, , + etc. + + + + + Create a new instance of + + Dispose of browser setings after it has been used to create a browser + returns new instance of + + + + Create a new instance of + + returns new instance of + + + + Create a new instance of + + returns new instance of + + + + Create a new instance of + + returns new instance of + + + + Create a new instance of + + returns new instance of + + + + Create a new instance of + + request + url request client + returns new instance of + + + + Create a new instance of + + request + url request client + request context + returns new instance of + + + + Create a new instance of + + returns new instance of + + + + Create a new which can be used to + create a new in a fluent flashion. + Call to create the actual + instance + + RequestContextBuilder + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Create a new instance of + + PostData + + + + Class used to represent a single element in the request post data. + The methods of this class may be called on any thread. + + + + + + + + + + + + + + + + + + + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Create a new instance of + + PostDataElement + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Create a new instance + + Request + + + + + + + + + + + + + + + + + + + + + + + + + Creates a new RequestContextBuilder which can be used to fluently set + preferences + + Returns a new RequestContextBuilder + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Fluent style builder for creating IRequestContext instances. + + + + + Create the actual RequestContext instance + + Returns a new RequestContext instance. + + + + Action is called in IRequestContextHandler.OnRequestContextInitialized + + called when the context has been initialized. + Returns RequestContextBuilder instance + + + + Sets the Cache Path + + + The location where cache data for this request context will be stored on + disk. If this value is non-empty then it must be an absolute path that is + either equal to or a child directory of CefSettings.RootCachePath. + If the value is empty then browsers will be created in "incognito mode" + where in-memory caches are used for storage and no data is persisted to disk. + HTML5 databases such as localStorage will only persist across sessions if a + cache path is specified. To share the global browser cache and related + configuration set this value to match the CefSettings.CachePath value. + + Returns RequestContextBuilder instance + + + + Invoke this method tp persist user preferences as a JSON file in the cache path directory. + Can be set globally using the CefSettings.PersistUserPreferences value. + This value will be ignored if CachePath is empty or if it matches the CefSettings.CachePath value. + + Returns RequestContextBuilder instance + + + + Set the value associated with preference name when the RequestContext + is initialzied. If value is null the preference will be restored to its + default value. If setting the preference fails no error is throw, you + must check the CEF Log file. + Preferences set via the command-line usually cannot be modified. + + preference key + preference value + Returns RequestContextBuilder instance + + + + Set the Proxy server when the RequestContext is initialzied. + If value is null the preference will be restored to its + default value. If setting the preference fails no error is throw, you + must check the CEF Log file. + Proxy set via the command-line cannot be modified. + + proxy host + Returns RequestContextBuilder instance + + + + Set the Proxy server when the RequestContext is initialzied. + If value is null the preference will be restored to its + default value. If setting the preference fails no error is throw, you + must check the CEF Log file. + Proxy set via the command-line cannot be modified. + + proxy host + proxy port (optional) + Returns RequestContextBuilder instance + + + + Set the Proxy server when the RequestContext is initialzied. + If value is null the preference will be restored to its + default value. If setting the preference fails no error is throw, you + must check the CEF Log file. + Proxy set via the command-line cannot be modified. + + proxy scheme + proxy host + proxy port (optional) + Returns RequestContextBuilder instance + + + + Shares storage with other RequestContext + + shares storage with this RequestContext + Returns RequestContextBuilder instance + + + + RequestContext Settings + + + + + To persist session cookies (cookies without an expiry date or validity + interval) by default when using the global cookie manager set this value to + true. Session cookies are generally intended to be transient and most + Web browsers do not persist them. Can be set globally using the + CefSettings.PersistSessionCookies value. This value will be ignored if + CachePath is empty or if it matches the CefSettings.CachePath value. + + + + + To persist user preferences as a JSON file in the cache path directory set + this value to true. Can be set globally using the + CefSettings.PersistUserPreferences value. This value will be ignored if + CachePath is empty or if it matches the CefSettings.CachePath value. + + + + + The location where cache data for this request context will be stored on + disk. If this value is non-empty then it must be an absolute path that is + either equal to or a child directory of CefSettings.RootCachePath. + If the value is empty then browsers will be created in "incognito mode" + where in-memory caches are used for storage and no data is persisted to disk. + HTML5 databases such as localStorage will only persist across sessions if a + cache path is specified. To share the global browser cache and related + configuration set this value to match the CefSettings.CachePath value. + + + + + Comma delimited ordered list of language codes without any whitespace that + will be used in the "Accept-Language" HTTP header. Can be set globally + using the CefSettings.accept_language_list value or overridden on a per- + browser basis using the BrowserSettings.AcceptLanguageList value. If + all values are empty then "en-US,en" will be used. This value will be + ignored if CachePath matches the CefSettings.CachePath value. + + + + + Comma delimited list of schemes supported by the associated + ICookieManager. If CookieableSchemesExcludeDefaults is false the + default schemes ("http", "https", "ws" and "wss") will also be supported. + Specifying a CookieableSchemesList value and setting + CookieableSchemesExcludeDefaults to true will disable all loading + and saving of cookies for this manager. This value will be ignored if + matches the value. + + + + + If CookieableSchemesExcludeDefaults is false the + default schemes ("http", "https", "ws" and "wss") will also be supported. + Specifying a CookieableSchemesList value and setting + CookieableSchemesExcludeDefaults to true will disable all loading + and saving of cookies for this manager. This value will be ignored if + matches the value. + + + + + + + + Create a new URL request that is not associated with a specific browser or frame. + Use instead if you want the + request to have this association, in which case it may be handled differently. + For requests originating from the browser process: It may be intercepted by the client via or . + POST data may only contain only a single element of type PDE_TYPE_FILE or PDE_TYPE_BYTES. + Uses the Global RequestContext + + request + url request client + + + + Create a new URL request that is not associated with a specific browser or frame. + Use instead if you want the + request to have this association, in which case it may be handled differently. + For requests originating from the browser process: It may be intercepted by the client via or . + POST data may only contain only a single element of type PDE_TYPE_FILE or PDE_TYPE_BYTES. + + request + url request client + request context associated with this requets. + + + + + + + + + + + + + + + + Create a new URL request that is not associated with a specific browser or frame. + Use instead if you want the + request to have this association, in which case it may be handled differently. + For requests originating from the browser process: It may be intercepted by the client via or . + POST data may only contain only a single element of type PDE_TYPE_FILE or PDE_TYPE_BYTES. + Uses the Global RequestContext + + request + url request client + + + + Create a new URL request that is not associated with a specific browser or frame. + Use instead if you want the + request to have this association, in which case it may be handled differently. + For requests originating from the browser process: It may be intercepted by the client via or . + POST data may only contain only a single element of type PDE_TYPE_FILE or PDE_TYPE_BYTES. + + request + url request client + request context associated with this requets. + + + + Extended WebBrowserExtensions + + + + + Retrieve the current . Contains information like + and + + The ChromiumWebBrowser instance this method extends. + + that when executed returns the current or null + + + + + Downloads the specified and calls + when the download is complete. Makes a GET Request. + + valid frame + url to download + Action to be executed when the download is complete. + + + + Downloads the specified as a . + Makes a GET Request. + + valid frame + url to download + A task that can be awaited to get the representing the Url + + + + Toggles audio mute for the current browser. + If the is null or has been disposed + then this command will be a no-op. + + The ChromiumWebBrowser instance this method extends. + + + + Evaluate javascript code in the context of the . The script will be executed + asynchronously and the method returns a Task that can be awaited to obtain the result. + + Type + Thrown when one or more arguments are outside the required range. + Thrown if a Javascript error occurs. + The IFrame instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + + that can be awaited to obtain the result of the script execution. The + is used to convert the result to the desired type. Property names are converted from camelCase. + If the script execution returns an error then an exception is thrown. + + + + + Evaluate some Javascript code in the context of the MainFrame of the ChromiumWebBrowser. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript + + Type + Thrown when one or more arguments are outside the required range. + The IBrowser instance this method extends. + The JavaScript code that should be executed. + (Optional) The timeout after which the JavaScript code execution should be aborted. + + that can be awaited to obtain the result of the JavaScript execution. + + + + + Evaluate Javascript in the context of this Browsers Main Frame. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript + + Thrown when one or more arguments are outside the required range. + Type + The ChromiumWebBrowser instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + + that can be awaited to obtain the result of the script execution. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Create a new instance + + WindowInfo + + + diff --git a/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.dll b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.dll new file mode 100644 index 0000000..c7dbacb Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.dll differ diff --git a/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.pdb b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.pdb new file mode 100644 index 0000000..42b7075 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.Core.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.XML b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.XML new file mode 100644 index 0000000..676bedc --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.XML @@ -0,0 +1,16471 @@ + + + + CefSharp + + + + + Async extensions for different interfaces + + + + + Deletes all cookies that matches all the provided parameters asynchronously. + If both and are empty, all cookies will be deleted. + + cookie manager + The cookie URL. If an empty string is provided, any URL will be matched. + The name of the cookie. If an empty string is provided, any URL will be matched. + Returns -1 if a non-empty invalid URL is specified, or if cookies cannot be accessed; + otherwise, a task that represents the delete operation. The value of the TResult will be the number of cookies that were deleted or -1 if unknown. + + + + Sets a cookie given a valid URL and explicit user-provided cookie attributes. + This function expects each attribute to be well-formed. It will check for disallowed + characters (e.g. the ';' character is disallowed within the cookie value attribute) and will return false without setting + + cookie manager + The cookie URL. If an empty string is provided, any URL will be matched. + the cookie to be set + returns false if the cookie cannot be set (e.g. if illegal charecters such as ';' are used); + otherwise task that represents the set operation. The value of the TResult parameter contains a bool to indicate success. + + + + Visits all cookies. The returned cookies are sorted by longest path, then by earliest creation date. + + cookie manager + A task that represents the VisitAllCookies operation. The value of the TResult parameter contains a List of cookies + or null if cookies cannot be accessed. + + + + Visits a subset of the cookies. The results are filtered by the given url scheme, host, domain and path. + If is true, HTTP-only cookies will also be included in the results. The returned cookies + are sorted by longest path, then by earliest creation date. + + cookie manager + The URL to use for filtering a subset of the cookies available. + A flag that determines whether HTTP-only cookies will be shown in results. + A task that represents the VisitUrlCookies operation. The value of the TResult parameter contains a List of cookies. + or null if cookies cannot be accessed. + + + + Flush the backing store (if any) to disk. + + cookieManager instance + A task that represents the FlushStore operation. Result indicates if the flush completed successfully. + Will return false if the cookikes cannot be accessed. + + + + Retrieve a snapshot of current navigation entries + + browserHost + If true the List will only contain the current navigation entry. + If false the List will include all navigation entries will be included. Default is false + + + + Javascript binding options + + + + + Set of options with the default binding + + + + + Model binder used for passing complex classes as params to methods + + + + + Interceptor used for intercepting calls to the target object methods. For instance, can be used + for logging calls (from js) to .net methods. + + + + + Interceptor used for intercepting get/set calls to the target object property. For instance, can be used + for logging calls to .net property (from js) + + + + + Callback interface used for asynchronous continuation of authentication requests. + + + + + Continue the authentication request. + + requested username + requested password + + + + Cancel the authentication request. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used to asynchronously continue a download. + + + + + Call to continue the download. + + full file path for the download including the file name + or leave blank to use the suggested name and the default temp directory + Set to true if you do wish to show the default "Save As" dialog + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Generic callback interface used for asynchronous continuation. + + + + + Continue processing. + + + + + Cancel processing. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Generic callback interface used for asynchronous completion. + + + + + Method that will be called once the task is complete. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Interface to implement to be notified of asynchronous completion via ICookieManager.DeleteCookies(). + It will be executed asynchronously on the CEF IO thread after the cookie has been deleted + + + + + Method that will be called upon completion. + + will be the number of cookies that were deleted or -1 if unknown. + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface for . + The methods of this class will be called on the CEF UI thread. + + + + + Method that will be called on receipt of a DevTools protocol message. + Method result dictionaries include an "id" (int) value that identifies the + orginating method call sent from IBrowserHost.SendDevToolsMessage, and + optionally either a "result" (dictionary) or "error" (dictionary) value. + The "error" dictionary will contain "code" (int) and "message" (string) + values. Event dictionaries include a "method" (string) value and optionally + a "params" (dictionary) value. See the DevTools protocol documentation at + https://chromedevtools.github.io/devtools-protocol/ for details of + supported method calls and the expected "result" or "params" dictionary + contents. JSON dictionaries can be parsed using the CefParseJSON function + if desired, however be aware of performance considerations when parsing + large messages (some of which may exceed 1MB in size). + + is the originating browser instance + is a UTF8-encoded JSON dictionary representing either a method result or an event. + is only valid for the scope of this callback and should be copied if necessary + + Return true if the message was handled or false if the message + should be further processed and passed to the OnDevToolsMethodResult or + OnDevToolsEvent methods as appropriate. + + + + Method that will be called after attempted execution of a DevTools protocol + + is the originating browser instance + is the id value that identifies the originating method call message + If the method succeeded will be true and will be the + UTF8-encoded JSON "result" dictionary value (which may be empty). + If the method failed will be false and will be the UTF8-encoded + JSON "error" dictionary value. + + The stream is only valid for the scope of this + callback and should be copied if necessary. See the OnDevToolsMessage + documentation for additional details on contents + + + + Method that will be called on receipt of a DevTools protocol event. + + is the originating browser instance + is the method value + is the UTF8-encoded JSON "params" dictionary value (which + may be empty). This stream is only valid for the scope of this callback and + should be copied if necessary. See the OnDevToolsMessage documentation for + additional details on contents. + + + + + Method that will be called when the DevTools agent has attached. + This will generally occur in response to the first message sent while the agent is detached. + + is the originating browser instance + + + + Method that will be called when the DevTools agent has detached. + Any method results that were pending before the agent became detached will not be delivered, and any active + event subscriptions will be canceled. + + is the originating browser instance + + + + Callback for asynchronous continuation of . + + + + + Callback for asynchronous continuation of . If bytesRead == 0 + the response will be considered complete. + + + If bytesRead == 0 the response will be considered complete. + If bytesRead > 0 then will be called again until the request is complete (based on either the + result or the expected content length). If bytesRead < 0 then the + request will fail and the bytesRead value will be treated as the error + code. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback for asynchronous continuation of . + + + + + Callback for asynchronous continuation of Skip(). + + If bytesSkipped > 0 then either Skip() will be called + again until the requested number of bytes have been skipped or the request will proceed. + If bytesSkipped <= the request will fail with ERR_REQUEST_RANGE_NOT_SATISFIABLE. + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface for IBrowserHost.RunFileDialog. + The methods of this class will be called on the CEF UI thread. + + + + + Called asynchronously after the file dialog is dismissed. + + will be a single value or a list of values depending on the dialog mode. If the selection was cancelled filePaths will be empty + + + + Provides a callback implementation of + that does nothing with complete. + Added to workaround a CEF bug as per https://github.com/cefsharp/CefSharp/issues/2957#issuecomment-555285400 + + + + + + + + + + + + + + Callback interface used to asynchronously cancel a download. + + + + + Call to cancel the download. + + + + + Call to pause the download. + + + + + Call to resume the download. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface for asynchronous continuation of file dialog requests. + + + + + Continue the file selection. + + should be a single value or a list of values depending on the dialog mode. + An empty value is treated the same as calling Cancel(). + + + + Cancel the file selection. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used for asynchronous continuation of . + + + + + Continue the request. Read the resource contents from stream. + + stream to be used as response. + + + + Continue the request + + data to be used as response + + + + Cancel the request. + + + + + Javascript callback interface + + + + + Callback Id + + + + + Execute the javascript callback + + param array of objects + JavascriptResponse + + + + Execute the javascript callback + + timeout + param array of objects + JavascriptResponse + + + + Check to see if the underlying resource are still available to execute the callback + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used for asynchronous continuation of JavaScript dialog requests. + + + + + Continue the Javascript dialog request. + + Set to true if the OK button was pressed. + value should be specified for prompt dialogs. + + + + Continue the Javascript dialog request. + + Set to true if the OK button was pressed. + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used for asynchronous continuation of media access + permission requests. + + + + + Call to allow or deny media access. If this callback was initiated in + response to a getUserMedia (indicated by + DeviceAudioCapture and/or DeviceVideoCapture being set) then + must match requestedPermissions param passed to + + + Allowed Permissions + + + + Cancel the media access request. + + + + + Callback interface used for asynchronous continuation of permission prompts. + + + + + Complete the permissions request with the specified result. + + Permission request results. + + + + Callback interface for . The methods of this interface + will be called on the CEF UI thread. + + + + + Method that will be executed when the PDF printing has completed. + + The output path. + Will be true if the printing completed + successfully or false otherwise. + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used for asynchronous continuation of url requests. + + + + + Continue the url request. + + If is true the request will be continued, otherwise, the request will be canceled. + + + + Cancel the url request. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface for + + + + + Called after the ResolveHost request has completed. + + The result code + will be the list of resolved IP addresses or + empty if the resolution failed. + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used for continuation of custom context menu display. + + + + + Complete context menu display by selecting the specified commandId and eventFlags; + + the command Id + the event flags + + + + Cancel context menu display. + + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Callback interface used to select a client certificate for authentication. + + + + + Callback interface used to select a client certificate for authentication. + value means that no client certificate should be used. + + selected certificate + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Interface to implement to be notified of asynchronous completion via ICookieManager.SetCookie(). + It will be executed asynchronously on the CEF IO thread after the cookie has been set + + + + + Method that will be called upon completion. + + success will be true if the cookie was set successfully. + + + + Gets a value indicating whether the callback has been disposed of. + + + + + Provides a callback implementation of . + + + + + Initializes a new instance of the TaskCompletionCallback class. + + + + + Task used to await this callback + + + + + Provides a callback implementation of . + + + + + Invalid Number of Cookies + + + + + Initializes a new instance of the TaskDeleteCookiesCallback class. + + + + + Task used to await this callback + + + + + Provides a callback implementation of . + + + + + Task used to await this callback + + + + + Provides a callback implementation of . + + + + + Initializes a new instance of the TaskResolveCallback class. + + + + + Task used to await this callback + + + + + Provides a callback implementation of . + + + + + Initializes a new instance of the TaskSetCookieCallback class. + + + + + Task used to await this callback + + + + + Used in conjunction with CefSettings.RegisterScheme to register a scheme. + You can register your own custom scheme e.g. custom:// if you are using a build in scheme + (http/https) then you should directly register your using + Cef.GetGlobalRequestContext().RegisterSchemeHandlerFactory - make sure the Global RequestContext has + been initialized before doing so, you can use + for notification of RequestContext initialization (Pass an IBrowserProcessHandler instance to Cef.Initialize) + + + + + Schema Name e.g. custom + + + + + Optional Domain Name. An empty value for a standard scheme + will cause the factory to match all domain names. The |domain_name| value + will be ignored for non-standard schemes. + + + + + If true the scheme will be treated as a standard scheme. + Standard schemes are subject to URL canonicalization and parsing rules as + defined in the Common Internet Scheme Syntax RFC 1738 Section 3.1 available + at http://www.ietf.org/rfc/rfc1738.txt + + In particular, the syntax for standard scheme URLs must be of the form: +
+              [scheme]://[username]:[password]@[host]:[port]/[url-path]
+             
+ Standard scheme URLs must have a host component that is a fully qualified + domain name as defined in Section 3.5 of RFC 1034 [13] and Section 2.1 of + RFC 1123. These URLs will be canonicalized to "scheme://host/path" in the + simplest case and "scheme://username:password@host:port/path" in the most + explicit case. For example, "scheme:host/path" and "scheme:///host/path" + will both be canonicalized to "scheme://host/path". The origin of a + standard scheme URL is the combination of scheme, host and port (i.e., + "scheme://host:port" in the most explicit case). + + For non-standard scheme URLs only the "scheme:" component is parsed and + canonicalized. The remainder of the URL will be passed to the handler + as-is. For example, "scheme:///some%20text" will remain the same. + Non-standard scheme URLs cannot be used as a target for form submission. +
+
+ + + If true the scheme will be treated as local (i.e. with the + same security rules as those applied to "file" URLs). Normal pages cannot + link to or access local URLs. Also, by default, local URLs can only perform + XMLHttpRequest calls to the same URL (origin + path) that originated the + request. To allow XMLHttpRequest calls from a local URL to other URLs with + the same origin set the CefSettings.file_access_from_file_urls_allowed + value to true. To allow XMLHttpRequest calls from a local URL to all + origins set the CefSettings.universal_access_from_file_urls_allowed value + to true. + + + + + If true the scheme will be treated as display-isolated. + This means that pages cannot display these URLs unless they are + from the same scheme. For example, pages in another origin cannot create + iframes or hyperlinks to URLs with this scheme. + + + + + If true the scheme will be treated with the same security + rules as those applied to "https" URLs. For example, loading this scheme + from other secure schemes will not trigger mixed content warnings. + + + + + If true the scheme can be sent CORS requests. + This value should be true in most cases where IsStandard is true. + + + + + If true the scheme can bypass Content-Security-Policy(CSP) checks. + This value should be false in most cases where IsStandard is true. + + + + + If true the scheme can perform Fetch API requests. + + + + + Factory Class that creates instances + for handling scheme requests. Leave this null if you wish to manually register the + scheme handler with the relevant RequestContext. + + + + + Gets the underlying scheme options that represents + + + + + Creates a new CefCustomScheme. + + + + + Creates a new CefCustomScheme. + + scheme name + scheme options + + + + Method used internally + + command line arguments + list of scheme objects + + + + CefLibraryHandle is a SafeHandle that Loads libcef.dll and relesases it when disposed/finalized + Calls LoadLibraryEx with LoadLibraryFlags.LOAD_WITH_ALTERED_SEARCH_PATH + Make sure to set settings.BrowserSubprocessPath and settings.LocalesDirPath + + Adapted from http://www.pinvoke.net/default.aspx/kernel32.loadlibraryex + + + + In general not a fan of having inline classes/enums + In this case it's not something that I'd like to see exposed + as it's just a helper and outside the scope of the project + + + + + Initializes a new instance of the CefLibraryHandle class. + + libcef.dll full path. + + + + When overridden in a derived class, gets a value indicating whether the handle value is invalid. + + + true if the handle value is invalid; otherwise, false. + + + + + When overridden in a derived class, executes the code required to free the handle. + + + true if the handle is released successfully; otherwise, in the event of a catastrophic failure, false. In this case, it + generates a releaseHandleFailed MDA Managed Debugging Assistant. + + + + + CefRuntime - Used to simplify loading of the CefSharp architecture specific resources. + Typical use case would be when you are targeting AnyCPU + + + + + When using AnyCPU the architecture specific version of CefSharp.Core.Runtime.dll + needs to be loaded (x64/x86). + This method subscribes to the event + for and loads the CefSharp.Core.Runtime.dll + based on . + This method MUST be called before you call Cef.Initialize, create your first ChromiumWebBrowser instance, basically + before anything CefSharp related happens. This method is part of CefSharp.dll which is an AnyCPU library and + doesn't have any references to the CefSharp.Core.Runtime.dll so it's safe to use. + + + The path containing the x64/x86 folders which contain the CefSharp/CEF resources. + If null then AppDomain.CurrentDomain.SetupInformation.ApplicationBase will be used as the path. + ( + + + + Unsubscribe from the event + for that was added in + + + + + When using AnyCPU the architecture specific version of CefSharp.Core.Runtime.dll + needs to be loaded (x64/x86). + This method calls to immediately load CefSharp.Core.Runtime.dll + based on . + This method MUST be called before you call Cef.Initialize, create your first ChromiumWebBrowser instance, basically + before anything CefSharp related happens. This method is part of CefSharp.dll which is an AnyCPU library and + doesn't have any references to the CefSharp.Core.Runtime.dll so it's safe to use. + + + The path containing the x64/x86 folders which contain the CefSharp/CEF resources. + If null then AppDomain.CurrentDomain.SetupInformation.ApplicationBase will be used as the path. + ( + + + + Use this static class to configure some CefSharp specific settings like WcfTimeout + + + + + Set default values for CefSharpSettings + + + + + WCF is used by JavascriptObjectRepository.Register(isAsync: false) feature for + Javascript Binding. It's recomended that anyone developing a new application use + the JavascriptObjectRepository.Register(isAsync: true) version which communicates + using native Chromium IPC. + + + + + Change the Close timeout for the WCF channel used by the sync JSB binding. + The default value is currently 2 seconds. Changing this to + will result on Abort() being called on the WCF Channel Host + + + + + For the WinForms and WPF instances of ChromiumWebBrowser the relevant Application Exit event + is hooked and Cef.Shutdown() called by default. Set this to false to disable this behaviour. + This value needs to be set before the first instance of ChromiumWebBrowser is created as + the event handlers are hooked in the static constructor for the ChromiumWebBrowser class + + + + + CefSharp.BrowserSubprocess will monitor the parent process and exit if the parent process closes + before the subprocess. This currently defaults to true. + See https://github.com/cefsharp/CefSharp/issues/2359 for more information. + + + + + The proxy options that will be used for all connections + + If set before the call to Cef.Initialize, command line arguments will be set for you + If a username and password is provided and the IPs match authentication is done automatically + + NOTE: GetAuthCredentials won't be called for a proxy server that matches the IP + NOTE: It isn't possble to change the proxy after the call to Cef.Initialize + + + + + This influences the behavior of how methods are executed for objects registered using + . + By default the queues Tasks for execution in a sequential order. + A single method is exeucted at a time. Setting this property to true allows for concurrent task execution. + Method calls are executed on (ThreadPool). + + + + + If true a message will be sent from the render subprocess to the + browser when a DOM node (or no node) gets focus. The default is + false. + + + + + Class used to Represent a cookie. + The built in .Net Cookie class isn't used as some of it's properties have + internal setters + + + + + The cookie name + + + + + The cookie value. + + + + + If domain is empty a host cookie will be created instead of a domain cookie. Domain cookies are stored with a leading "." + and are visible to sub-domains whereas host cookies are not. + + + + + Ss non-empty only URLs at or below the path will get the cookie value. + + + + + If true the cookie will only be sent for HTTPS requests. + + + + + Ss true the cookie will only be sent for HTTP requests. + + + + + Expires or null if no expiry + + + + + The cookie creation date. This is automatically populated by the system on cookie creation. + + + + + The cookie last access date. This is automatically populated by the system on access. + + + + + Same site. + + + + + Priority + + + + + Used internally to set . + can only be set when fecting a Cookie from Chromium + + + Represents a wall clock time in UTC. Values are not guaranteed to be monotonically + non-decreasing and are subject to large amounts of skew. Time is stored internally + as microseconds since the Windows epoch (1601). + + + Hidden from intellisense as only meant to be used internally, unfortunately + VC++ makes it hard to use internal classes from C# + + + + + Used internally to set . + can only be set when fecting a Cookie from Chromium + + + Represents a wall clock time in UTC. Values are not guaranteed to be monotonically + non-decreasing and are subject to large amounts of skew. Time is stored internally + as microseconds since the Windows epoch (1601). + + + Hidden from intellisense as only meant to be used internally, unfortunately + VC++ makes it hard to use internal classes from C# + + + + + Default implementation of which represents the CefApp class. + + + + + + Return the handler for functionality specific to the browser process. This method is called on multiple threads. + + + The browser process handler. + + + + + Gets or sets the schemes. + + + The schemes. + + + + + Constructor. + + The browser process handler. + The schemes. + + + + Provides an opportunity to register custom schemes. Do not keep a reference to the object. This + method is called on the main thread for each process and the registered schemes should be the same across all processes. + + + scheme registra. + + + + Provides an opportunity to register custom schemes. Do not keep a reference to the object. This + method is called on the main thread for each process and the registered schemes should be the same across all processes. + + + scheme registra. + + + + Releases unmanaged and managed resources + + to release both managed and unmanaged resources; to release only unmanaged resources. + + + + + + + DependencyChecker provides a known list of Cef/CefSharp dependencies and + provides helper methods to check for their existance. + + + + + en-US Locales pak file location + + + + + File name of the Direct3D Compiler DLL. + + + + + List of Cef Dependencies + + + + + List of Cef Resources (pack files) + + + + + List of Optional CEF Dependencies + + + + + List of CefSharp Managed Dependencies (Those that are AnyCPU written in c#) + + + + + List of CefSharp Arch Specific Dependencies + Those that are arch specific, + distributed as x86, x64 and ARM64 (coming soon for .Net 5.0 only) + + + + + List of CefSharp.BrowserSubprocess.exe dependencies. + + + + + CheckDependencies iterates through the list of Cef and CefSharp dependencines + relative to the path provided and returns a list of missing ones + + check to see if optional dependencies are present + Is loading of pack files disabled? + path to check for dependencies + The path to the resources directory, if empty the Executing Assembly path is used. + The path to a separate executable that will be launched for sub-processes. + The locale pack file e.g. + List of missing dependencies, if all present an empty List will be returned + + + + CheckDependencies iterates through the list of Cef and CefSharp dependencines + relative to the path provided and returns a list of missing ones + + check to see if optional dependencies are present + Is loading of pack files disabled? + path to check for mangaed dependencies + path to check for native (unmanged) dependencies + The path to the resources directory, if empty the Executing Assembly path is used. + The path to a separate executable that will be launched for sub-processes. + The locale pack file e.g. + List of missing dependencies, if all present an empty List will be returned + + + + Loop through dependencies and add to the returned missing dependency list if not found. + + The directory of the dependencies, or the current directory if null. + The dependencies to check. + List of missing dependencies, if all present an empty List will be returned + + + + Checks if all Cef and CefSharp dependencies were found relative to the Executing Assembly. + Shortcut method that calls , throws an Exception if not files are missing. + + The locale, if empty then en-US will be used. + The path to the locales directory, if empty locales\ will be used. + The path to the resources directory, if empty the Executing Assembly path is used. + Is loading of pack files disabled? + The path to a separate executable that will be launched for sub-processes. + Throw when not all dependencies are present + + + + Represents a node in the browser's DOM. + + + + + Constructor. + + Name of the tag. + The attributes. + + + + Returns a string that represents the current object. + + + A string that represents the current object. + + + + + Get the value of an attribute. + + The name of the attribute value to get. + + The attribute value if the name exists in the DomNode's attributes. Null if the name does not exist. + + + + + The name of the HTML element. + + + The name of the tag. + + + + + Get a read only list of the attribute names. + + + A list of names of the attributes. + + + + + Determine if the DomNode has the requested attribute. + + The name of the attribute value. + + True if the attribute exists in the DomNode, false if it does not. + + + + + Gets the enumerator. + + + The enumerator. + + + + + Class used to represent a download item. + + + + + Returns true if this object is valid. Do not call any other methods if this function returns false. + + + + + Returns true if the download is in progress. + + + + + Returns true if the download is complete. + + + + + Returns true if the download has been canceled or interrupted. + + + + + Returns a simple speed estimate in bytes/s. + + + + + Returns the rough percent complete or -1 if the receive total size is unknown. + + + + + Returns the total number of bytes. + + + + + Returns the number of received bytes. + + + + + Returns the time that the download started + + + + + Returns the time that the download ended + + + + + Returns the full path to the downloaded or downloading file. + + + + + Returns the unique identifier for this download. + + + + + Returns the URL. + + + + + Returns the URL as it was before any redirects. + + + + + Returns the suggested file name. + + + + + Returns the content disposition. + + + + + Returns the mime type. + + + + + Describes how to interpret the alpha component of a pixel. + + + + + No transparency. The alpha component is ignored. + + + + + Transparency with pre-multiplied alpha component. + + + + + Transparency with post-multiplied alpha component. + + + + + Enumerates the various representations of the ordering of audio channels. + Logged to UMA, so never reuse a value, always add new/greater ones! + See media\base\channel_layout.h + + + + + None + + + + + Unsupported + + + + + Front C + + + + + Front L, Front R + + + + + Front L, Front R, Back C + + + + + Front L, Front R, Front C + + + + + Front L, Front R, Front C, Back C + + + + + Front L, Front R, Side L, Side R + + + + + Front L, Front R, Back L, Back R + + + + + Front L, Front R, Front C, Side L, Side R + + + + + Front L, Front R, Front C, LFE, Side L, Side R + + + + + Front L, Front R, Front C, Back L, Back R + + + + + Front L, Front R, Front C, LFE, Back L, Back R + + + + + Front L, Front R, Front C, Side L, Side R, Back L, Back R + + + + + Front L, Front R, Front C, LFE, Side L, Side R, Back L, Back R + + + + + Front L, Front R, Front C, LFE, Side L, Side R, Front LofC, Front RofC + + + + + Stereo L, Stereo R + + + + + Stereo L, Stereo R, LFE + + + + + Stereo L, Stereo R, Front C, LFE + + + + + Stereo L, Stereo R, Front C, Rear C, LFE + + + + + Stereo L, Stereo R, Front C, Side L, Side R, Back C + + + + + Stereo L, Stereo R, Side L, Side R, Front LofC, Front RofC + + + + + Stereo L, Stereo R, Front C, Rear L, Rear R, Rear C + + + + + Stereo L, Stereo R, Front C, LFE, Side L, Side R, Rear Center + + + + + Stereo L, Stereo R, Front C, LFE, Back L, Back R, Rear Center + + + + + Stereo L, Stereo R, Side L, Side R, Front LofC, Front RofC, LFE + + + + + Front L, Front R, Front C, Side L, Side R, Front LofC, Front RofC + + + + + Front L, Front R, Front C, LFE, Back L, Back R, Front LofC, Front RofC + + + + + Front L, Front R, Front C, Side L, Side R, Rear L, Back R, Back C. + + + + + Channels are not explicitly mapped to speakers. + + + + + Front L, Front R, Front C. Front C contains the keyboard mic audio. This + layout is only intended for input for WebRTC. The Front C channel + is stripped away in the WebRTC audio input pipeline and never seen outside + of that. + + + + + Front L, Front R, Side L, Side R, LFE + + + + + Actual channel layout is specified in the bitstream and the actual channel + count is unknown at Chromium media pipeline level (useful for audio + pass-through mode). + + + + + Front L, Front R, Front C, LFE, Side L, Side R, + Front Height L, Front Height R, Rear Height L, Rear Height R + Will be represented as six channels (5.1) due to eight channel limit + kMaxConcurrentChannels + + + + + Describes how to interpret the components of a pixel. + + + + + RGBA with 8 bits per pixel (32bits total). + + + + + BGRA with 8 bits per pixel (32bits total). + + + + + Composition underline style. + + + + + Solid + + + + + Dot + + + + + Dash + + + + + None + + + + + Cookie priority values. + + + + + Low Priority + + + + + Medium Priority + + + + + High Priority + + + + + Cookie same site values. + + + See https://source.chromium.org/chromium/chromium/src/+/master:net/cookies/cookie_constants.h + + + + + Unspecified + + + + + Cookies will be sent in all contexts, i.e sending cross-origin is allowed. + None used to be the default value, but recent browser versions made Lax the default value to have reasonably robust defense against some classes of cross-site request forgery (CSRF) attacks. + + + + + Cookies are allowed to be sent with top-level navigations and will be sent along with GET request initiated by third party website. This is the default value in modern browsers. + + + + + Cookies will only be sent in a first-party context and not be sent along with requests initiated by third party websites. + + + + + Cursor type values. + + + + + Pointer + + + + + An enum constant representing the cross option. + + + + + An enum constant representing the hand option. + + + + + An enum constant representing the beam option. + + + + + An enum constant representing the wait option. + + + + + An enum constant representing the help option. + + + + + An enum constant representing the east resize option. + + + + + An enum constant representing the north resize option. + + + + + An enum constant representing the northeast resize option. + + + + + An enum constant representing the northwest resize option. + + + + + An enum constant representing the south resize option. + + + + + An enum constant representing the southeast resize option. + + + + + An enum constant representing the southwest resize option. + + + + + An enum constant representing the west resize option. + + + + + An enum constant representing the north south resize option. + + + + + An enum constant representing the east west resize option. + + + + + An enum constant representing the northeast southwest resize option. + + + + + An enum constant representing the northwest southeast resize option. + + + + + An enum constant representing the column resize option. + + + + + An enum constant representing the row resize option. + + + + + An enum constant representing the middle panning option. + + + + + An enum constant representing the east panning option. + + + + + An enum constant representing the north panning option. + + + + + An enum constant representing the northeast panning option. + + + + + An enum constant representing the northwest panning option. + + + + + An enum constant representing the south panning option. + + + + + An enum constant representing the southeast panning option. + + + + + An enum constant representing the southwest panning option. + + + + + An enum constant representing the west panning option. + + + + + An enum constant representing the move option. + + + + + An enum constant representing the vertical text option. + + + + + An enum constant representing the cell option. + + + + + An enum constant representing the context menu option. + + + + + An enum constant representing the alias option. + + + + + An enum constant representing the progress option. + + + + + An enum constant representing the no drop option. + + + + + An enum constant representing the copy option. + + + + + An enum constant representing the none option. + + + + + An enum constant representing the not allowed option. + + + + + An enum constant representing the zoom in option. + + + + + An enum constant representing the zoom out option. + + + + + An enum constant representing the grab option. + + + + + An enum constant representing the grabbing option. + + + + + An enum constant representing the MiddlePanningVertical option. + + + + + An enum constant representing the MiddlePanningHorizontal option. + + + + + An enum constant representing the custom option. + + + + + DndNone + + + + + DndMove + + + + + DndCopy + + + + + DndLink + + + + + "Verb" of a drag-and-drop operation as negotiated between the source and destination. + + + + + None + + + + + Copy + + + + + Link + + + + + Generic + + + + + Private + + + + + Move + + + + + Delete + + + + + Every drag operation. + + + + + The device type that caused the event. + + + + + An enum constant representing the touch option. + + + + + An enum constant representing the mouse option. + + + + + An enum constant representing the pen option. + + + + + An enum constant representing the eraser option. + + + + + An enum constant representing the unknown option. + + + + + Configuration options for registering a custom scheme. + These values are used when calling AddCustomScheme. + + + + + Register scheme without options set + + + + + If Standard is set the scheme will be treated as a + standard scheme. Standard schemes are subject to URL canonicalization and + parsing rules as defined in the Common Internet Scheme Syntax RFC 1738 + Section 3.1 available at http://www.ietf.org/rfc/rfc1738.txt + + In particular, the syntax for standard scheme URLs must be of the form: +
+              [scheme]://[username]:[password]@[host]:[port]/[url-path]
+             
Standard scheme URLs must have a host component that is a fully + qualified domain name as defined in Section 3.5 of RFC 1034 [13] and + Section 2.1 of RFC 1123. These URLs will be canonicalized to + "scheme://host/path" in the simplest case and + "scheme://username:password@host:port/path" in the most explicit case. For + example, "scheme:host/path" and "scheme:///host/path" will both be + canonicalized to "scheme://host/path". The origin of a standard scheme URL + is the combination of scheme, host and port (i.e., "scheme://host:port" in + the most explicit case). + + For non-standard scheme URLs only the "scheme:" component is parsed and + canonicalized. The remainder of the URL will be passed to the handler as- + is. For example, "scheme:///some%20text" will remain the same. Non-standard + scheme URLs cannot be used as a target for form submission. +
+
+ + + If Local is set the scheme will be treated with the same + security rules as those applied to "file" URLs. Normal pages cannot link to + or access local URLs. Also, by default, local URLs can only perform + XMLHttpRequest calls to the same URL (origin + path) that originated the + request. To allow XMLHttpRequest calls from a local URL to other URLs with + the same origin set the CefSettings.FileAccessFromFileUrlsAllowed + value to true. To allow XMLHttpRequest calls from a local URL to all + origins set the CefSettings.UniversalAccessFromFileUrlsAllowed value + to true. + + + + + If DisplayIsolated is set the scheme can only be + displayed from other content hosted with the same scheme. For example, + pages in other origins cannot create iframes or hyperlinks to URLs with the + scheme. For schemes that must be accessible from other schemes don't set + this, set CorsEnabled, and use CORS "Access-Control-Allow-Origin" headers + to further restrict access. + + + + + If Secure is set the scheme will be treated with the same + security rules as those applied to "https" URLs. For example, loading this + scheme from other secure schemes will not trigger mixed content warnings. + + + + + If CorsEnabled is set the scheme can be sent CORS requests. + This value should be set in most cases where Standard is set. + + + + + If CspBypassing is set the scheme can bypass Content-Security-Policy (CSP) checks. + This value should not be set in most cases where Standard is set. + + + + + If FetchEnabled is set the scheme can perform Fetch API requests. + + + + + Input mode of a virtual keyboard. These constants match their equivalents + in Chromium's text_input_mode.h and should not be renumbered. + See https://html.spec.whatwg.org/#input-modalities:-the-inputmode-attribute + + + + + An enum constant representing the default option. + + + + + An enum constant representing the none option. + + + + + An enum constant representing the text option. + + + + + An enum constant representing the tel option. + + + + + An enum constant representing the URL option. + + + + + An enum constant representing the mail option. + + + + + An enum constant representing the numeric option. + + + + + An enum constant representing the decimal option. + + + + + An enum constant representing the search option. + + + + + An enum constant representing the Maximum option. + + + + + Touch Event Type + + + + + An enum constant representing the released option. + + + + + An enum constant representing the pressed option. + + + + + An enum constant representing the moved option. + + + + + An enum constant representing the cancelled option. + + + + + Value types supported by + + + + + Invalid type + + + + + Null + + + + + Boolean + + + + + Integer + + + + + Double + + + + + String + + + + + Binary + + + + + Dictionary + + + + + List + + + + + This file contains the list of network errors. + + For a complete up-to-date list, see the CEF source code + (cef_errorcode_t in include/internal/cef_types.h) + and the Chromium source code (net/base/net_error_list.h). + + + + + No error occurred. + + + + + An asynchronous IO operation is not yet complete. This usually does not + indicate a fatal error. Typically this error will be generated as a + notification to wait for some external notification that the IO operation + finally completed. + + + + + A generic failure occurred. + + + + + An operation was aborted (due to user action). + + + + + An argument to the function is incorrect. + + + + + The handle or file descriptor is invalid. + + + + + The file or directory cannot be found. + + + + + An operation timed out. + + + + + The file is too large. + + + + + An unexpected error. This may be caused by a programming mistake or an + invalid assumption. + + + + + Permission to access a resource, other than the network, was denied. + + + + + The operation failed because of unimplemented functionality. + + + + + There were not enough resources to complete the operation. + + + + + Memory allocation failed. + + + + + The file upload failed because the file's modification time was different + from the expectation. + + + + + The socket is not connected. + + + + + The file already exists. + + + + + The path or file name is too long. + + + + + Not enough room left on the disk. + + + + + The file has a virus. + + + + + The client chose to block the request. + + + + + The network changed. + + + + + The request was blocked by the URL block list configured by the domain + administrator. + + + + + The socket is already connected. + + + + + The upload failed because the upload stream needed to be re-read, due to a + retry or a redirect, but the upload stream doesn't support that operation. + + + + + The request failed because the URLRequestContext is shutting down, or has + been shut down. + + + + + The request failed because the response was delivered along with requirements + which are not met ('X-Frame-Options' and 'Content-Security-Policy' ancestor + checks and 'Cross-Origin-Resource-Policy' for instance). + + + + + The request was blocked by system policy disallowing some or all cleartext + requests. Used for NetworkSecurityPolicy on Android. + + + + + The request was blocked by a Content Security Policy + + + + + The request was blocked because of no H/2 or QUIC session. + + + + + The request was blocked by CORB or ORB. + + + + + A connection was closed (corresponding to a TCP FIN). + + + + + A connection was reset (corresponding to a TCP RST). + + + + + A connection attempt was refused. + + + + + A connection timed out as a result of not receiving an ACK for data sent. + This can include a FIN packet that did not get ACK'd. + + + + + A connection attempt failed. + + + + + The host name could not be resolved. + + + + + The Internet connection has been lost. + + + + + An SSL protocol error occurred. + + + + + The IP address or port number is invalid (e.g., cannot connect to the IP + address 0 or the port 0). + + + + + The IP address is unreachable. This usually means that there is no route to + the specified host or network. + + + + + The server requested a client certificate for SSL client authentication. + + + + + A tunnel connection through the proxy could not be established. + + + + + No SSL protocol versions are enabled. + + + + + The client and server don't support a common SSL protocol version or + cipher suite. + + + + + The server requested a renegotiation (rehandshake). + + + + + The proxy requested authentication (for tunnel establishment) with an + unsupported method. + + + + + The SSL handshake failed because of a bad or missing client certificate. + + + + + A connection attempt timed out. + + + + + There are too many pending DNS resolves, so a request in the queue was + aborted. + + + + + Failed establishing a connection to the SOCKS proxy server for a target host. + + + + + The SOCKS proxy server failed establishing connection to the target host + because that host is unreachable. + + + + + The request to negotiate an alternate protocol failed. + + + + + The peer sent an SSL no_renegotiation alert message. + + + + + Winsock sometimes reports more data written than passed. This is probably + due to a broken LSP. + + + + + An SSL peer sent us a fatal decompression_failure alert. This typically + occurs when a peer selects DEFLATE compression in the mistaken belief that + it supports it. + + + + + An SSL peer sent us a fatal bad_record_mac alert. This has been observed + from servers with buggy DEFLATE support. + + + + + The proxy requested authentication (for tunnel establishment). + + + + + Could not create a connection to the proxy server. An error occurred + either in resolving its name, or in connecting a socket to it. + Note that this does NOT include failures during the actual "CONNECT" method + of an HTTP proxy. + + + + + A mandatory proxy configuration could not be used. Currently this means + that a mandatory PAC script could not be fetched, parsed or executed. + + + + + We've hit the max socket limit for the socket pool while preconnecting. We + don't bother trying to preconnect more sockets. + + + + + The permission to use the SSL client certificate's private key was denied. + + + + + The SSL client certificate has no private key. + + + + + The certificate presented by the HTTPS Proxy was invalid. + + + + + An error occurred when trying to do a name resolution (DNS). + + + + + Permission to access the network was denied. This is used to distinguish + errors that were most likely caused by a firewall from other access denied + errors. See also ERR_ACCESS_DENIED. + + + + + The request throttler module cancelled this request to avoid DDOS. + + + + + A request to create an SSL tunnel connection through the HTTPS proxy + received a 302 (temporary redirect) response. The response body might + include a description of why the request failed. + + TODO(https://crbug.com/928551): This is deprecated and should not be used by + new code. + + + + + We were unable to sign the CertificateVerify data of an SSL client auth + handshake with the client certificate's private key. + + Possible causes for this include the user implicitly or explicitly + denying access to the private key, the private key may not be valid for + signing, the key may be relying on a cached handle which is no longer + valid, or the CSP won't allow arbitrary data to be signed. + + + + + The message was too large for the transport. (for example a UDP message + which exceeds size threshold). + + + + + Websocket protocol error. Indicates that we are terminating the connection + due to a malformed frame or other protocol violation. + + + + + Returned when attempting to bind an address that is already in use. + + + + + An operation failed because the SSL handshake has not completed. + + + + + SSL peer's public key is invalid. + + + + + The certificate didn't match the built-in public key pins for the host name. + The pins are set in net/http/transport_security_state.cc and require that + one of a set of public keys exist on the path from the leaf to the root. + + + + + Server request for client certificate did not contain any types we support. + + + + + An SSL peer sent us a fatal decrypt_error alert. This typically occurs when + a peer could not correctly verify a signature (in CertificateVerify or + ServerKeyExchange) or validate a Finished message. + + + + + There are too many pending WebSocketJob instances, so the new job was not + pushed to the queue. + + + + + The SSL server certificate changed in a renegotiation. + + + + + The SSL server sent us a fatal unrecognized_name alert. + + + + + Failed to set the socket's receive buffer size as requested. + + + + + Failed to set the socket's send buffer size as requested. + + + + + Failed to set the socket's receive buffer size as requested, despite success + return code from setsockopt. + + + + + Failed to set the socket's send buffer size as requested, despite success + return code from setsockopt. + + + + + Failed to import a client certificate from the platform store into the SSL + library. + + + + + Resolving a hostname to an IP address list included the IPv4 address + "127.0.53.53". This is a special IP address which ICANN has recommended to + indicate there was a name collision, and alert admins to a potential + problem. + + + + + The SSL server presented a certificate which could not be decoded. This is + not a certificate error code as no X509Certificate object is available. This + error is fatal. + + + + + Certificate Transparency: Received a signed tree head that failed to parse. + + + + + Certificate Transparency: Received a signed tree head whose JSON parsing was + OK but was missing some of the fields. + + + + + The attempt to reuse a connection to send proxy auth credentials failed + before the AuthController was used to generate credentials. The caller should + reuse the controller with a new connection. This error is only used + internally by the network stack. + + + + + Certificate Transparency: Failed to parse the received consistency proof. + + + + + The SSL server required an unsupported cipher suite that has since been + removed. This error will temporarily be signaled on a fallback for one or two + releases immediately following a cipher suite's removal, after which the + fallback will be removed. + + + + + When a WebSocket handshake is done successfully and the connection has been + upgraded, the URLRequest is cancelled with this error code. + + + + + Socket ReadIfReady support is not implemented. This error should not be user + visible, because the normal Read() method is used as a fallback. + + + + + No socket buffer space is available. + + + + + There were no common signature algorithms between our client certificate + private key and the server's preferences. + + + + + TLS 1.3 early data was rejected by the server. This will be received before + any data is returned from the socket. The request should be retried with + early data disabled. + + + + + TLS 1.3 early data was offered, but the server responded with TLS 1.2 or + earlier. This is an internal error code to account for a + backwards-compatibility issue with early data and TLS 1.2. It will be + received before any data is returned from the socket. The request should be + retried with early data disabled. + + See https://tools.ietf.org/html/rfc8446#appendix-D.3 for details. + + + + + TLS 1.3 was enabled, but a lower version was negotiated and the server + returned a value indicating it supported TLS 1.3. This is part of a security + check in TLS 1.3, but it may also indicate the user is behind a buggy + TLS-terminating proxy which implemented TLS 1.2 incorrectly. (See + https://crbug.com/boringssl/226.) + + + + + The server's certificate has a keyUsage extension incompatible with the + negotiated TLS key exchange method. + + + + + The ECHConfigList fetched over DNS cannot be parsed. + + + + + ECH was enabled, but the server was unable to decrypt the encrypted + ClientHello. + + + + + ECH was enabled, the server was unable to decrypt the encrypted ClientHello, + and additionally did not present a certificate valid for the public name. + + + + + The server responded with a certificate whose common name did not match + the host name. This could mean: + + 1. An attacker has redirected our traffic to their server and is + presenting a certificate for which they know the private key. + + 2. The server is misconfigured and responding with the wrong cert. + + 3. The user is on a wireless network and is being redirected to the + network's login page. + + 4. The OS has used a DNS search suffix and the server doesn't have + a certificate for the abbreviated name in the address bar. + + + + + + The server responded with a certificate that, by our clock, appears to + either not yet be valid or to have expired. This could mean: + + 1. An attacker is presenting an old certificate for which they have + managed to obtain the private key. + + 2. The server is misconfigured and is not presenting a valid cert. + + 3. Our clock is wrong. + + + + + + The server responded with a certificate that is signed by an authority + we don't trust. The could mean: + + 1. An attacker has substituted the real certificate for a cert that + contains their public key and is signed by their cousin. + + 2. The server operator has a legitimate certificate from a CA we don't + know about, but should trust. + + 3. The server is presenting a self-signed certificate, providing no + defense against active attackers (but foiling passive attackers). + + + + + + The server responded with a certificate that contains errors. + This error is not recoverable. + + MSDN describes this error as follows: + "The SSL certificate contains errors." + NOTE: It's unclear how this differs from ERR_CERT_INVALID. For consistency, + use that code instead of this one from now on. + + + + + + The certificate has no mechanism for determining if it is revoked. In + effect, this certificate cannot be revoked. + + + + + Revocation information for the security certificate for this site is not + available. This could mean: + + 1. An attacker has compromised the private key in the certificate and is + blocking our attempt to find out that the cert was revoked. + + 2. The certificate is unrevoked, but the revocation server is busy or + unavailable. + + + + + + The server responded with a certificate has been revoked. + We have the capability to ignore this error, but it is probably not the + thing to do. + + + + + The server responded with a certificate that is invalid. + This error is not recoverable. + + MSDN describes this error as follows: + "The SSL certificate is invalid." + + + + + + The server responded with a certificate that is signed using a weak + signature algorithm. + + + + + The host name specified in the certificate is not unique. + + + + + The server responded with a certificate that contains a weak key (e.g. + a too-small RSA key). + + + + + The certificate claimed DNS names that are in violation of name constraints. + + + + + The certificate's validity period is too long. + + + + + Certificate Transparency was required for this connection, but the server + did not provide CT information that complied with the policy. + + + + + The certificate chained to a legacy Symantec root that is no longer trusted. + https://g.co/chrome/symantecpkicerts + + + + + The certificate is known to be used for interception by an entity other + the device owner. + + + + + The value immediately past the last certificate error code. + + + + + The URL is invalid. + + + + + The scheme of the URL is disallowed. + + + + + The scheme of the URL is unknown. + + + + + Attempting to load an URL resulted in a redirect to an invalid URL. + + + + + Attempting to load an URL resulted in too many redirects. + + + + + Attempting to load an URL resulted in an unsafe redirect (e.g., a redirect + to file:// is considered unsafe). + + + + + Attempting to load an URL with an unsafe port number. These are port + numbers that correspond to services, which are not robust to spurious input + that may be constructed as a result of an allowed web construct (e.g., HTTP + looks a lot like SMTP, so form submission to port 25 is denied). + + + + + The server's response was invalid. + + + + + Error in chunked transfer encoding. + + + + + The server did not support the request method. + + + + + The response was 407 (Proxy Authentication Required), yet we did not send + the request to a proxy. + + + + + The server closed the connection without sending any data. + + + + + The headers section of the response is too large. + + + + + The evaluation of the PAC script failed. + + + + + The response was 416 (Requested range not satisfiable) and the server cannot + satisfy the range requested. + + + + + The identity used for authentication is invalid. + + + + + Content decoding of the response body failed. + + + + + An operation could not be completed because all network IO + is suspended. + + + + + FLIP data received without receiving a SYN_REPLY on the stream. + + + + + Converting the response to target encoding failed. + + + + + The server sent an FTP directory listing in a format we do not understand. + + + + + There are no supported proxies in the provided list. + + + + + There is an HTTP/2 protocol error. + + + + + Credentials could not be established during HTTP Authentication. + + + + + An HTTP Authentication scheme was tried which is not supported on this + machine. + + + + + Detecting the encoding of the response failed. + + + + + (GSSAPI) No Kerberos credentials were available during HTTP Authentication. + + + + + An unexpected, but documented, SSPI or GSSAPI status code was returned. + + + + + The environment was not set up correctly for authentication (for + example, no KDC could be found or the principal is unknown. + + + + + An undocumented SSPI or GSSAPI status code was returned. + + + + + The HTTP response was too big to drain. + + + + + The HTTP response contained multiple distinct Content-Length headers. + + + + + HTTP/2 headers have been received, but not all of them - status or version + headers are missing, so we're expecting additional frames to complete them. + + + + + No PAC URL configuration could be retrieved from DHCP. This can indicate + either a failure to retrieve the DHCP configuration, or that there was no + PAC URL configured in DHCP. + + + + + The HTTP response contained multiple Content-Disposition headers. + + + + + The HTTP response contained multiple Location headers. + + + + + HTTP/2 server refused the request without processing, and sent either a + GOAWAY frame with error code NO_ERROR and Last-Stream-ID lower than the + stream id corresponding to the request indicating that this request has not + been processed yet, or a RST_STREAM frame with error code REFUSED_STREAM. + Client MAY retry (on a different connection). See RFC7540 Section 8.1.4. + + + + + HTTP/2 server didn't respond to the PING message. + + + + + The HTTP response body transferred fewer bytes than were advertised by the + Content-Length header when the connection is closed. + + + + + The HTTP response body is transferred with Chunked-Encoding, but the + terminating zero-length chunk was never sent when the connection is closed. + + + + + There is a QUIC protocol error. + + + + + The HTTP headers were truncated by an EOF. + + + + + The QUIC crypto handshake failed. This means that the server was unable + to read any requests sent, so they may be resent. + + + + + Transport security is inadequate for the HTTP/2 version. + + + + + The peer violated HTTP/2 flow control. + + + + + The peer sent an improperly sized HTTP/2 frame. + + + + + Decoding or encoding of compressed HTTP/2 headers failed. + + + + + Proxy Auth Requested without a valid Client Socket Handle. + + + + + HTTP_1_1_REQUIRED error code received on HTTP/2 session. + + + + + HTTP_1_1_REQUIRED error code received on HTTP/2 session to proxy. + + + + + The PAC script terminated fatally and must be reloaded. + + + + + The server was expected to return an HTTP/1.x response, but did not. Rather + than treat it as HTTP/0.9, this error is returned. + + + + + Initializing content decoding failed. + + + + + Received HTTP/2 RST_STREAM frame with NO_ERROR error code. This error should + be handled internally by HTTP/2 code, and should not make it above the + SpdyStream layer. + + + + + The pushed stream claimed by the request is no longer available. + + + + + A pushed stream was claimed and later reset by the server. When this happens, + the request should be retried. + + + + + An HTTP transaction was retried too many times due for authentication or + invalid certificates. This may be due to a bug in the net stack that would + otherwise infinite loop, or if the server or proxy continually requests fresh + credentials or presents a fresh invalid certificate. + + + + + Received an HTTP/2 frame on a closed stream. + + + + + Client is refusing an HTTP/2 stream. + + + + + A pushed HTTP/2 stream was claimed by a request based on matching URL and + request headers, but the pushed response headers do not match the request. + + + + + The server returned a non-2xx HTTP response code. + + Not that this error is only used by certain APIs that interpret the HTTP + response itself. URLRequest for instance just passes most non-2xx + response back as success. + + + + + The certificate presented on a QUIC connection does not chain to a known root + and the origin connected to is not on a list of domains where unknown roots + are allowed. + + + + + A GOAWAY frame has been received indicating that the request has not been + processed and is therefore safe to retry on a different connection. + + + + + The ACCEPT_CH restart has been triggered too many times + + + + + The IP address space of the remote endpoint differed from the previous + observed value during the same request. Any cache entry for the affected + request should be invalidated. + + + + + The IP address space of the cached remote endpoint is blocked by local + network access check. + + + + + The cache does not have the requested entry. + + + + + Unable to read from the disk cache. + + + + + Unable to write to the disk cache. + + + + + The operation is not supported for this entry. + + + + + The disk cache is unable to open this entry. + + + + + The disk cache is unable to create this entry. + + + + + Multiple transactions are racing to create disk cache entries. This is an + internal error returned from the HttpCache to the HttpCacheTransaction that + tells the transaction to restart the entry-creation logic because the state + of the cache has changed. + + + + + The cache was unable to read a checksum record on an entry. This can be + returned from attempts to read from the cache. It is an internal error, + returned by the SimpleCache backend, but not by any URLRequest methods + or members. + + + + + The cache found an entry with an invalid checksum. This can be returned from + attempts to read from the cache. It is an internal error, returned by the + SimpleCache backend, but not by any URLRequest methods or members. + + + + + Internal error code for the HTTP cache. The cache lock timeout has fired. + + + + + Received a challenge after the transaction has read some data, and the + credentials aren't available. There isn't a way to get them at that point. + + + + + Internal not-quite error code for the HTTP cache. In-memory hints suggest + that the cache entry would not have been usable with the transaction's + current configuration (e.g. load flags, mode, etc.) + + + + + The disk cache is unable to doom this entry. + + + + + The disk cache is unable to open or create this entry. + + + + + The server's response was insecure (e.g. there was a cert error). + + + + + An attempt to import a client certificate failed, as the user's key + database lacked a corresponding private key. + + + + + An error adding a certificate to the OS certificate database. + + + + + An error occurred while handling a signed exchange. + + + + + An error occurred while handling a Web Bundle source. + + + + + A Trust Tokens protocol operation-executing request failed for one of a + number of reasons (precondition failure, internal error, bad response). + + + + + When handling a Trust Tokens protocol operation-executing request, the system + was able to execute the request's Trust Tokens operation without sending the + request to its destination: for instance, the results could have been present + in a local cache (for redemption) or the operation could have been diverted + to a local provider (for "platform-provided" issuance). + + + + + A generic error for failed FTP control connection command. + If possible, please use or add a more specific error code. + + + + + The server cannot fulfill the request at this point. This is a temporary + error. + FTP response code 421. + + + + + The server has aborted the transfer. + FTP response code 426. + + + + + The file is busy, or some other temporary error condition on opening + the file. + FTP response code 450. + + + + + Server rejected our command because of syntax errors. + FTP response codes 500, 501. + + + + + Server does not support the command we issued. + FTP response codes 502, 504. + + + + + Server rejected our command because we didn't issue the commands in right + order. + FTP response code 503. + + + + + PKCS #12 import failed due to incorrect password. + + + + + PKCS #12 import failed due to other error. + + + + + CA import failed - not a CA cert. + + + + + Import failed - certificate already exists in database. + Note it's a little weird this is an error but reimporting a PKCS12 is ok + (no-op). That's how Mozilla does it, though. + + + + + CA import failed due to some other error. + + + + + Server certificate import failed due to some internal error. + + + + + PKCS #12 import failed due to invalid MAC. + + + + + PKCS #12 import failed due to invalid/corrupt file. + + + + + PKCS #12 import failed due to unsupported features. + + + + + Key generation failed. + + + + + Failure to export private key. + + + + + Self-signed certificate generation failed. + + + + + The certificate database changed in some way. + + + + + DNS resolver received a malformed response. + + + + + DNS server requires TCP + + + + + DNS server failed. This error is returned for all of the following + error conditions: + 1 - Format error - The name server was unable to interpret the query. + 2 - Server failure - The name server was unable to process this query + due to a problem with the name server. + 4 - Not Implemented - The name server does not support the requested + kind of query. + 5 - Refused - The name server refuses to perform the specified + operation for policy reasons. + + + + + DNS transaction timed out. + + + + + The entry was not found in cache or other local sources, for lookups where + only local sources were queried. + TODO(ericorth): Consider renaming to DNS_LOCAL_MISS or something like that as + the cache is not necessarily queried either. + + + + + Suffix search list rules prevent resolution of the given host name. + + + + + Failed to sort addresses according to RFC3484. + + + + + Failed to resolve the hostname of a DNS-over-HTTPS server. + + + + + DNS identified the request as disallowed for insecure connection (http/ws). + Error should be handled as if an HTTP redirect was received to redirect to + https or wss. + + + + + All DNS requests associated with this job have been cancelled. + + + + + The hostname resolution of HTTPS record was expected to be resolved with + alpn values of supported protocols, but did not. + + + + + Supported event bit flags. + + + + + Mac OS-X command key. + + + + + CefFileDialogMode (Based on cef_file_dialog_mode_t) + + + + + Requires that the file exists before allowing the user to pick it. + + + + + Like Open, but allows picking multiple files to open. + + + + + Like Open, but selects a folder to open. + + + + + Allows picking a nonexistent file, and prompts to overwrite if the file already exists. + + + + + Focus Source + + + + + The source is explicit navigation via the API (LoadURL(), etc). + + + + + The source is a system-generated focus event. + + + + + Supported JavaScript dialog types. + + + + + Alert Dialog + + + + + Confirm Dialog + + + + + Prompt Dialog + + + + + Custom menu items originating from the renderer process + This is the first entry + + + + + Custom menu items originating from the renderer process + This is the last entry + + + + + Margin type for PDF printing. + + + + + Default margins of 1cm (~0.4 inches) + + + + + No margins. + + + + + Custom margins. + + + + + Return value types. + + + + + Cancel immediately. + + + + + Continue immediately. + + + + + Continue asynchronously (usually via a callback). + + + + + Represents the state of a setting. + + + + + Use the default state for the setting. + + + + + Enable or allow the setting. + + + + + Disable or disallow the setting. + + + + + Process termination status values. + + + + + Non-zero exit status. + + + + + SIGKILL or task manager kill. + + + + + Segmentation fault. + + + + + Out of memory. Some platforms may use ProcessCrashed instead. + + + + + Managed enum for cef_thread_id_t/CefThreadId + + + + + The CEF UI thread in the browser. In CefSharp this is by default + different from your main applications UI Thread + (e.g. WPF/WinForms UI Threads). Only when MultiThreadedMessageLoop + is false will this be the same as your app UI Thread. + + + + + Used for blocking tasks (e.g. file system access) where the user won't + notice if the task takes an arbitrarily long time to complete. All tasks + posted after + and before Cef.Shutdown() are guaranteed to run. + + + + + Used for blocking tasks (e.g. file system access) that affect UI or + responsiveness of future user interactions. Do not use if an immediate + response to a user interaction is expected. All tasks posted after + and before Cef.Shutdown() + are guaranteed to run. + Examples: + - Updating the UI to reflect progress on a long task. + - Loading data that might be shown in the UI after a future user + interaction. + + + + + Used for blocking tasks (e.g. file system access) that affect UI + immediately after a user interaction. All tasks posted after + and before Cef.Shutdown() + are guaranteed to run. + Example: Generating data shown in the UI immediately after a click. + + + + + Used to launch and terminate browser processes. + + + + + Used to process IPC and network messages. Do not perform blocking tasks on + this thread. All tasks posted after + and before Cef.Shutdown() are guaranteed to run. + + + + + The main thread in the renderer. Used for all WebKit and V8 interaction. + Tasks may be posted to this thread after + CefRenderProcessHandler::OnWebKitInitialized but are not guaranteed to + run before sub-process termination (sub-processes may be killed at any time + without warning). + + + + + + Supported certificate status code values. See net\cert\cert_status_flags.h + for more information. CERT_STATUS_NONE is new in CEF because we use an + enum while cert_status_flags.h uses a typedef and static const variables. + + + + + None + + + + + CommonNameInvalid + + + + + DateInvalid + + + + + AuthorityInvalid + + + + + NoRevocation_Mechanism + + + + + UnableToCheckRevocation + + + + + Revoked + + + + + Invalid + + + + + WeakSignatureAlgorithm + + + + + NonUniqueName + + + + + WeakKey + + + + + PinnedKeyMissing + + + + + NameConstraintViolation + + + + + ValidityTooLong + + + + + IsEv + + + + + RevCheckingEnabled + + + + + Sha1SignaturePresent + + + + + CtComplianceFailed + + + + + Supported context menu edit state bit flags. + + + + + A binary constant representing the none flag. + + + + + A binary constant representing the can undo flag. + + + + + A binary constant representing the can redo flag. + + + + + A binary constant representing the can cut flag. + + + + + A binary constant representing the can copy flag. + + + + + A binary constant representing the can paste flag. + + + + + A binary constant representing the can delete flag. + + + + + A binary constant representing the can select all flag. + + + + + A binary constant representing the can translate flag. + + + + + A binary constant representing the can edit richly flag. + + + + + Supported context menu media state bit flags. These constants match their + equivalents in Chromium's ContextMenuData::MediaFlags and should not be + renumbered. + + + + + None + + + + + Error + + + + + Paused + + + + + Muted + + + + + Loop + + + + + CanSave + + + + + HasAudio + + + + + Can Toggle Controls + + + + + Controls + + + + + CanPrint + + + + + CanRotate + + + + + CanPictureInPicture + + + + + PictureInPicture + + + + + CanLoop + + + + + Supported context menu media types. + + + + + No special node is in context. + + + + + An image node is selected. + + + + + A video node is selected. + + + + + An audio node is selected. + + + + + An canvas node is selected + + + + + A file node is selected. + + + + + A plugin node is selected. + + + + + ContextMenuType + + + + + No node is selected. + + + + + The top page is selected. + + + + + A subframe page is selected. + + + + + A link is selected. + + + + + A media node is selected. + + + + + There is a textual or mixed selection that is selected. + + + + + An editable element is selected. + + + + + Return values for IResponseFilter + + + + + Some or all of the pre-filter data was read successfully but more data is + needed in order to continue filtering (filtered output is pending). + + + + + Some or all of the pre-filter data was read successfully and all available filtered output has been written. + + + + + An error occurred during filtering. + + + + + Values that represent key event types. + + + + + Notification that a key transitioned from "up" to "down". + + + + + Notification that a key was pressed. This does not necessarily correspond + to a character depending on the key and language. Use KEYEVENT_CHAR for + character input. + + + + + Notification that a key was released. + + + + + Notification that a character was typed. Use this for text input. Key + down events may generate 0, 1, or more than one character event depending + on the key, locale, and operating system. + + + + + KeyType Enum. + Maps to https://magpcss.org/ceforum/apidocs3/projects/(default)/cef_key_event_type_t.html + + + + + Notification that a key transitioned from"up" to"down". + + + + + Notification that a key was pressed. This does not necessarily correspond to a character depending on the key and language. + Use for character input. + + + + + Notification that a key was released. + + + + + Notification that a character was typed. Use this for text input. Key + down events may generate 0, 1, or more than one character event depending + on the key, locale, and operating system. + + + + + LogSeverity + + + + + Default logging (currently Info logging) + + + + + Verbose logging. + + + + + Info logging + + + + + Warning logging + + + + + Error logging + + + + + Fatal logging. + + + + + Disable logging to file for all messages, and to stderr for messages with severity less than FATAL. + + + + + Media access permissions used by . + + + + + No permission. + + + + + Device audio capture permission. + + + + + Device video capture permission. + + + + + Desktop audio capture permission. + + + + + Desktop video capture permission. + + + + + Supported menu item types. + + + + + An enum constant representing the none option. + + + + + An enum constant representing the command option. + + + + + An enum constant representing the check option. + + + + + An enum constant representing the radio option. + + + + + An enum constant representing the separator option. + + + + + An enum constant representing the sub menu option. + + + + + Values that represent mouse button types. + + + + + Left Mouse Button + + + + + Middle Mouse Button + + + + + Right Mouse Button + + + + + Paint element types. + + + + + An enum constant representing the view option. + + + + + An enum constant representing the popup option. + + + + + Permission request results. + + + + + Accept the permission request as an explicit user action. + + + + + Deny the permission request as an explicit user action. + + + + + Dismiss the permission request as an explicit user action. + + + + + Ignore the permission request. If the prompt remains unhandled (e.g. + OnShowPermissionPrompt returns false and there is no default permissions + UI) then any related promises may remain unresolved. + + + + + Permission types used with . + Some types are platform-specific or only supported with the Chrome runtime. Should be kept + in sync with Chromium's permissions::RequestType type. + + + + + Post data elements may represent either bytes or files. + + + + + An enum constant representing the empty option. + + + + + An enum constant representing the bytes option. + + + + + An enum constant representing the file option. + + + + + Policy for how the Referrer HTTP header value will be sent during navigation. + If the `--no-referrers` command-line flag is specified then the policy value + will be ignored and the Referrer value will never be sent. + Must be kept synchronized with net::URLRequest::ReferrerPolicy from Chromium. + + + + + Clear the referrer header if the header value is HTTPS but the request + destination is HTTP. This is the default behavior. + + + + + Default which is equivalent to + + + + + A slight variant on : + If the request destination is HTTP, an HTTPS referrer will be cleared. If + the request's destination is cross-origin with the referrer (but does not + downgrade), the referrer's granularity will be stripped down to an origin + rather than a full URL. Same-origin requests will send the full referrer. + + + + + Strip the referrer down to an origin when the origin of the referrer is + different from the destination's origin. + + + + + Never change the referrer. + + + + + Strip the referrer down to the origin regardless of the redirect location. + + + + + Clear the referrer when the request's referrer is cross-origin with the + request's destination. + + + + + Strip the referrer down to the origin, but clear it entirely if the + referrer value is HTTPS and the destination is HTTP. + + + + + Always clear the referrer regardless of the request destination. + + + + + Always the last value in this enumeration. + + + + + Resource type for a request. + + + + + Top level page. + + + + + Frame or iframe. + + + + + CSS stylesheet. + + + + + External script. + + + + + Image (jpg/gif/png/etc). + + + + + Font. + + + + + Some other subresource. This is the default type if the actual type is unknown. + + + + + Object (or embed) tag for a plugin, or a resource that a plugin requested. + + + + + Media resource. + + + + + Main resource of a dedicated worker. + + + + + Main resource of a shared worker. + + + + + Explicitly requested prefetch. + + + + + Favicon. + + + + + XMLHttpRequest. + + + + + A request for a ping + + + + + Main resource of a service worker. + + + + + A report of Content Security Policy violations. + + + + + A resource that a plugin requested. + + + + + A main-frame service worker navigation preload request. + + + + + A sub-frame service worker navigation preload request. + + + + + Supported SSL content status flags. See content/public/common/ssl_status.h + for more information. + + + + + HTTP page, or HTTPS page with no insecure content.. + + + + + HTTPS page containing "displayed" HTTP resources (e.g. images, CSS). + + + + + HTTPS page containing "executed" HTTP resources (i.e. script) + + + + + Supported SSL version values. See net/ssl/ssl_connection_status_flags.h + for more information. + + + + + Unknown SSL version. + + + + + An enum constant representing the ssl 2 option. + + + + + An enum constant representing the ssl 3 option. + + + + + An enum constant representing the TLS 1.0 option. + + + + + An enum constant representing the TLS 1.1 option. + + + + + An enum constant representing the TLS 1.2 option. + + + + + An enum constant representing the TLS 1.3 option. + + + + + An enum constant representing the QUIC option. + + + + + Transition type for a request. Made up of one source value and 0 or more qualifiers. + + + + + Source is a link click or the JavaScript window.open function. This is + also the default value for requests like sub-resource loads that are not navigations. + + + + + Source is some other "explicit" navigation. This is the default value for + navigations where the actual type is unknown. See also . + + + + + User got to this page through a suggestion in the UI (for example, via the + destinations page). Chrome runtime only. + + + + + Source is a subframe navigation. This is any content that is automatically + loaded in a non-toplevel frame. For example, if a page consists of several + frames containing ads, those ad URLs will have this transition type. + The user may not even realize the content in these pages is a separate + frame, so may not care about the URL. + + + + + Source is a subframe navigation explicitly requested by the user that will + generate new navigation entries in the back/forward list. These are + probably more important than frames that were automatically loaded in + the background because the user probably cares about the fact that this + link was loaded. + + + + + User got to this page by typing in the URL bar and selecting an entry + that did not look like a URL. For example, a match might have the URL + of a Google search result page, but appear like "Search Google for ...". + These are not quite the same as EXPLICIT navigations because the user + didn't type or see the destination URL. Chrome runtime only. + See also TT_KEYWORD. + + + + + This is a toplevel navigation. This is any content that is automatically + loaded in a toplevel frame. For example, opening a tab to show the ASH + screen saver, opening the devtools window, opening the NTP after the safe + browsing warning, opening web-based dialog boxes are examples of + AUTO_TOPLEVEL navigations. Chrome runtime only. + + + + + Source is a form submission by the user. NOTE: In some situations + submitting a form does not result in this transition type. This can happen + if the form uses a script to submit the contents. + + + + + Source is a "reload" of the page via the Reload function or by re-visiting + the same URL. NOTE: This is distinct from the concept of whether a + particular load uses "reload semantics" (i.e. bypasses cached data). + + + + + The url was generated from a replaceable keyword other than the default + search provider. If the user types a keyword (which also applies to + tab-to-search) in the omnibox this qualifier is applied to the transition + type of the generated url. TemplateURLModel then may generate an + additional visit with a transition type of TT_KEYWORD_GENERATED against the + url 'http://' + keyword. For example, if you do a tab-to-search against + wikipedia the generated url has a transition qualifer of TT_KEYWORD, and + TemplateURLModel generates a visit for 'wikipedia.org' with a transition + type of TT_KEYWORD_GENERATED. Chrome runtime only. + + + + + Corresponds to a visit generated for a keyword. See description of + TT_KEYWORD for more details. Chrome runtime only. + + + + + General mask defining the bits used for the source values. + + + + + Attempted to visit a URL but was blocked. + + + + + Used the Forward or Back function to navigate among browsing history. + Will be ORed to the transition type for the original load. + + + + + Loaded a URL directly via CreateBrowser, LoadURL or LoadRequest. + + + + + User is navigating to the home page. Chrome runtime only. + + + + + The transition originated from an external application; the exact + definition of this is embedder dependent. Chrome runtime and + extension system only. + + + + + The beginning of a navigation chain. + + + + + The last transition in a redirect chain. + + + + + Redirects caused by JavaScript or a meta refresh tag on the page. + + + + + Redirects sent from the server by HTTP headers. + + + + + Used to test whether a transition involves a redirect. + + + + + General mask defining the bits used for the qualifiers. + + + + + Flags used to customize the behavior of CefURLRequest. + + + + + Default behavior. + + + + + If set the cache will be skipped when handling the request. Setting this + value is equivalent to specifying the "Cache-Control: no-cache" request + header. Setting this value in combination with OnlyFromCache will + cause the request to fail. + + + + + If set the request will fail if it cannot be served from the cache (or some + equivalent local store). Setting this value is equivalent to specifying the + "Cache-Control: only-if-cached" request header. Setting this value in + combination with SkipCache or DisableCache will cause the + request to fail. + + + + + If set the cache will not be used at all. Setting this value is equivalent + to specifying the "Cache-Control: no-store" request header. Setting this + value in combination with OnlyFromCache will cause the request to + fail. + + + + + If set user name, password, and cookies may be sent with the request, and + cookies may be saved from the response. + + + + + If set upload progress events will be generated when a request has a body. + + + + + If set the CefURLRequestClient::OnDownloadData method will not be called. + + + + + If set 5XX redirect errors will be propagated to the observer instead of + automatically re-tried. This currently only applies for requests + originated in the browser process. + + + + + If set 3XX responses will cause the fetch to halt immediately rather than + continue through the redirect. + + + + + Flags that represent CefURLRequest status. + + + + + Unknown status. + + + + + Request succeeded. + + + + + An IO request is pending, and the caller will be informed when it is completed. + + + + + Request was canceled programatically. + + + + + Request failed for some reason. + + + + + The manner in which a link click should be opened. + + + + + An enum constant representing the unknown option. + + + + + An enum constant representing the current tab option. + + + + + Indicates that only one tab with the url should exist in the same window + + + + + An enum constant representing the new foreground tab option. + + + + + An enum constant representing the new background tab option. + + + + + An enum constant representing the new popup option. + + + + + An enum constant representing the new window option. + + + + + An enum constant representing the save to disk option. + + + + + An enum constant representing the off the record option. + + + + + An enum constant representing the ignore action option. + + + + + Activates an existing tab containing the url, rather than navigating. + This is similar to SINGLETON_TAB, but searches across all windows from + the current profile and anonymity (instead of just the current one); + closes the current tab on switching if the current tab was the NTP with + no session history; and behaves like CURRENT_TAB instead of + NEW_FOREGROUND_TAB when no existing tab is found. + + + + + Creates a new document picture-in-picture window showing a child WebView. + + + + + Event arguments for the AddressChanged event handler. + + + + + Access to the underlying object + + + + + The new address + + + + + Creates a new AddressChangedEventArgs event argument. + + the browser object + the address + + + + Event arguments for the ConsoleMessage event handler set up in IWebBrowser. + + + + + Creates a new ConsoleMessageEventArgs event argument. + + browser + level + message + source + line number + + + + Access to the underlying object + + + + + Log level + + + + + The message text of the console message. + + + + + The source of the console message. + + + + + The line number that generated the console message. + + + + + Event arguments to the FrameLoadEnd event handler set up in IWebBrowser. + + + + + Creates a new FrameLoadEnd event args + + browser + frame + http statusCode + + + + The browser that contains the frame that finished loading. + + + + + The frame that finished loading. + + + + + The URL that was loaded. + + + + + Http Status Code + + + + + Event arguments to the FrameLoadStart event handler set up in IWebBrowser. + + + + + Creates a new FrameLoadStart event args + + browser + frame + provides information about the source of the navigation and an accurate value is only + available in the browser process + + + + The browser object + + + + + The frame that just started loading. + + + + + The URL that was loaded. + + + + + TransitionType provides information about the source of the navigation. + + + + + Event arguments for the event + + + + + The javascript object repository, used to register objects + + + + + Name of the object + + + + + Was the object already bound. The default is false for the first js call to + CefSharp.BindObjectAsync, and subsequently true if already bound in a given context. + + + + + Is the object cached + + + + + JavascriptBindingCompleteEventArgs + + javascript object repository + object name + is the object already bound + is the object cached + + + + Event arguments for the event + + + + + The javascript object repository, used to register objects + + + + + Name of the object + + + + + Constructor + + object repository + object name + + + + Event arguments for the event + + + + + The javascript object repository, used to register objects + + + + + Name of the objects bound + + + + + JavascriptBindingMultipleCompleteEventArgs + + Javascript object repository + object names + + + + Calling CefSharp.PostMessage in Javascript triggers the JavascriptMessageReceived + This event args contains the frame, browser and message corrisponding to that call + + + + + The frame that called CefSharp.PostMessage in Javascript + + + + + The browser that hosts the + + + + + Message can be a primative type or a simple object that represents a copy + of the data sent from the browser + + + + + Constructor. + + The browser that hosts the + The frame that called CefSharp.PostMessage in Javascript. + Message can be a primative type or a simple object that represents a copy of the data sent from the + browser. + + + + Converts the to a specific type using the + that CefSharp provides + + Type + Type + + + + Provide a custom instance of + that will be used when + is called. You may wish to provide a custom instance in cases where you + wish to override the name conversion. + e.g. You wish to convert names from camelCase + + binder instance + + JavascriptMessageReceivedEventArgs.SetBinder(new DefaultBinder(new CamelCaseJavascriptNameConverter())); + + + + + Event arguments to the LoadError event handler set up in IWebBrowser. + + + + + LoadErrorEventArgs + + browser + frame + error code + error text + failed url + + + + The browser object + + + + + The frame that failed to load. + + + + + The URL that failed to load. + + + + + The error code. + + + + + The error text. + + + + + Event arguments to the LoadingStateChanged event handler set up in IWebBrowser. + + + + + Returns true if the browser can navigate forwards. + + + + + Returns true if the browser can navigate backwards. + + + + + Returns true if the browser can reload. + + + + + Returns true if the browser is loading. + + + + + Access to the underlying object + + + + + LoadingStateChangedEventArgs + + browser + can go back + can go forward + is loading + + + + Event arguments to the StatusMessage event handler set up in IWebBrowser. + + + + + StatusMessageEventArgs + + browser + status message value + + + + The browser object + + + + + The value of the status message. + + + + + Event arguments to the TitleChanged event handler. + + + + + Access to the underlying object + + + + + The new title + + + + + Creates a new TitleChanged event arg + + browser + the new title + + + + Inherit from this class to receive accessibility notification when accessibility events have been registered. + It's important to note that the methods of this interface are called on a CEF UI thread, + which by default is not the same as your application UI thread. + + + + + + + + Called after renderer process sends accessibility location changes to the browser process. + + Updated location info. + + + + + + + Called after renderer process sends accessibility tree changes to the browser process. + + Updated tree info. + + + + Inherit from this class to handle audio events + All methods will be called on the CEF UI thread + + + + + Gets a value indicating this instance + has been disposed. + + + + + + + + Called on the CEF UI thread to allow configuration of audio stream parameters. + Audio stream paramaters can optionally be configured by modifying + + the ChromiumWebBrowser control + the browser object + audio stream parameters can optionally be configured here, they are + pre-filled with some sensible defaults. + Return true to proceed with audio stream capture, or false to cancel it + + + + + + + Called on a browser audio capture thread when the browser starts streaming audio. + OnAudioStreamStopped will always be called after OnAudioStreamStarted; both methods may be called multiple + times for the same browser. + + the ChromiumWebBrowser control + the browser object + contains the audio parameters like sample rate and channel layout. + Changing the param values will have no effect here. + is the number of channels + + + + + + + Called on the audio stream thread when a PCM packet is received for the stream. + Based on and the value passed to + you can calculate the size of the array in bytes. + + + the browser object + is an array representing the raw PCM data as a floating point type, i.e. 4-byte value(s). + is the number of frames in the PCM packet + is the presentation timestamp (in milliseconds since the Unix Epoch) + and represents the time at which the decompressed packet should be presented to the user + + + + + + + Called on the CEF UI thread when the stream has stopped. OnAudioStreamStopped will always be called after ; + both methods may be called multiple times for the same stream. + + the ChromiumWebBrowser control + the browser object + + + + + + + Called on the CEF UI thread or audio stream thread when an error occurred. During the + stream creation phase this callback will be called on the UI thread while + in the capturing phase it will be called on the audio stream thread. The + stream will be stopped immediately. + + the ChromiumWebBrowser control + the browser object + error message + + + + Releases unmanaged and managed resources + + to release both managed and unmanaged resources; to release only unmanaged resources. + + + + + + + Inherit from this class to handle events related to browser process callbacks. + The methods of this class will be called on the CEF UI thread unless otherwise indicated. . + + + + + + + + Called on the CEF UI thread immediately after the CEF context has been initialized. + You can now access the Global RequestContext through Cef.GetGlobalRequestContext() - this is the + first place you can set Preferences (e.g. proxy settings, spell check dictionaries). + + + + + + + + Called from any thread when work has been scheduled for the browser process + main (UI) thread. This callback is used in combination with CefSettings. + ExternalMessagePump and Cef.DoMessageLoopWork() in cases where the CEF + message loop must be integrated into an existing application message loop + (see additional comments and warnings on Cef.DoMessageLoopWork). This + callback should schedule a Cef.DoMessageLoopWork() call to happen on the + main (UI) thread. + + is the requested delay in milliseconds. If + delay is less than or equal to 0 then the call should happen reasonably soon. If + delay is greater than 0 then the call should be scheduled to happen after the + specified delay and any currently pending scheduled call should be + cancelled. + + + + IsDisposed + + + + + Disposes of the resources + + true to release both managed and unmanaged resources; false to release only unmanaged resources. + + + + + + + Inherit from this class to handle context menu events. + + + + + + + + Called before a context menu is displayed. The model can be cleared to show no context menu or + modified to show a custom menu. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + provides information about the context menu state + initially contains the default context menu + + + + + + + Called to execute a command selected from the context menu. See + cef_menu_id_t for the command ids that have default implementations. All + user-defined command ids should be between MENU_ID_USER_FIRST and + MENU_ID_USER_LAST. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + will have the same values as what was passed to + menu command id + event flags + Return true if the command was handled or false for the default implementation. + + + + + + + Called when the context menu is dismissed irregardless of whether the menu + was canceled or a command was selected. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + + + + + + + Called to allow custom display of the context menu. + For custom display return true and execute callback either synchronously or asynchronously with the selected command Id. + For default display return false. Do not keep references to parameters or model outside of this callback. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + provides information about the context menu state + contains the context menu model resulting from OnBeforeContextMenu + the callback to execute for custom display + For custom display return true and execute callback either synchronously or asynchronously with the selected command ID. + + + + Inherit from this class to filter cookies that may be sent or received from + resource requests. The methods of this class will be called on the CEF IO thread + unless otherwise indicated. + + + + + + + + Called on the CEF IO thread before a resource request is sent. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the cookie object + Return true if the specified cookie can be sent with the request or false otherwise. + + + + + + + Called on the CEF IO thread after a resource response is received. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the response object - cannot be modified in this callback + the cookie object + Return true if the specified cookie returned with the response can be saved or false otherwise. + + + + Implement this interface to handle dialog events. The methods of this class will be called on the CEF UI thread. + + + + + + + + Runs a file chooser dialog. + + + To test assign something like TempFileDialogHandler (from CefSharp.Example) to DialogHandler e.g. + + browser.DialogHandler = new TempFileDialogHandler(); + + Example URL to use for file browsing http://www.cs.tut.fi/~jkorpela/forms/file.html#example + Simply click browse, the space next to the browse button should be populated with a randomly generated filename. + + the ChromiumWebBrowser control + the browser object + represents the type of dialog to display + the title to be used for the dialog. It may be empty to show the default title ("Open" or "Save" + depending on the mode). + is the path with optional directory and/or file name component that + should be initially selected in the dialog. + are used to restrict the selectable file types and may any combination of + (a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), + (b) individual file extensions (e.g. ".txt" or ".png"), + (c) combined description and file extension delimited using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg"). + Callback interface for asynchronous continuation of file dialog requests. + To display a custom dialog return true. To display the default dialog return false. + + + + Handle events related to browser display state. + + + + + + + + Called when a frame's address has changed. + + the ChromiumWebBrowser control + args + + + + + + + Called when auto-resize is enabled via IBrowserHost.SetAutoResizeEnabled and the contents have auto-resized. + + the ChromiumWebBrowser control + the browser object + will be the desired size in view coordinates + Return true if the resize was handled or false for default handling. + + + + + + + Called when the browser's cursor has changed. + + the ChromiumWebBrowser control + the browser object + If type is Custom then customCursorInfo will be populated with the custom cursor information + cursor type + custom cursor Information + Return true if the cursor change was handled or false for default handling. + + + + + + + Called when the page title changes. + + the ChromiumWebBrowser control + args + + + + + + + Called when the page icon changes. + + the ChromiumWebBrowser control + the browser object + list of urls where the favicons can be downloaded + + + + + + + Called when web content in the page has toggled fullscreen mode. The client is + responsible for resizing the browser if desired. + + The ChromiumWebBrowser control + the browser object + If true the content will automatically be sized to fill the browser content area. + If false the content will automatically return to its original size and position. + + + + + + + Called when the overall page loading progress has changed + + The ChromiumWebBrowser control + the browser object + ranges from 0.0 to 1.0. + + + + + + + Called when the browser is about to display a tooltip. text contains the + text that will be displayed in the tooltip. You can optionally modify text + and then return false to allow the browser to display the tooltip. + When window rendering is disabled the application is responsible for + drawing tooltips and the return value is ignored. + + The ChromiumWebBrowser control + the text that will be displayed in the tooltip + To handle the display of the tooltip yourself return true otherwise return false + to allow the browser to display the tooltip. + Only called when using Off-screen rendering (WPF and OffScreen) + + + + + + + Called when the browser receives a status message. + + The control this popup is related to. + args + + + + + + + Called to display a console message. + + The ChromiumWebBrowser control + args + Return true to stop the message from being output to the console. + + + + Class used to handle file downloads. + The methods of this class will called on the CEF UI thread. + + + + + + + + Called before a download begins in response to a user-initiated action + (e.g. alt + link click or link click that returns a `Content-Disposition: + attachment` response from the server). + + the ChromiumWebBrowser control + The browser instance + is the target download URL + is the target method (GET, POST, etc) + Return true to proceed with the download or false to cancel the download. + + + + Called before a download begins. + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + Callback interface used to asynchronously continue a download. + + + + Called before a download begins. + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + Callback interface used to asynchronously continue a download. + + + + Called when a download's status or progress information has been updated. This may be called multiple times before and after . + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + The callback used to Cancel/Pause/Resume the process + + + + Called when a download's status or progress information has been updated. This may be called multiple times before and after . + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + The callback used to Cancel/Pause/Resume the process + + + + Inherit from this class to handle events related to dragging. + The methods of this class will be called on the UI thread. + + + + + Called when an external drag event enters the browser window. + + the ChromiumWebBrowser control + the browser object + contains the drag event data + represents the type of drag operation + Return false for default drag handling behavior or true to cancel the drag event. + + + + Called when an external drag event enters the browser window. + + the ChromiumWebBrowser control + the browser object + contains the drag event data + represents the type of drag operation + Return false for default drag handling behavior or true to cancel the drag event. + + + + Called whenever draggable regions for the browser window change. + These can be specified using the '-webkit-app-region: drag/no-drag' CSS-property. + If draggable regions are never defined in a document this method will also never be called. + If the last draggable region is removed from a document this method will be called with an empty IList. + + the ChromiumWebBrowser control + the browser object + The frame + List of objects or null if last region was removed. + + + + Called whenever draggable regions for the browser window change. + These can be specified using the '-webkit-app-region: drag/no-drag' CSS-property. + If draggable regions are never defined in a document this method will also never be called. + If the last draggable region is removed from a document this method will be called with an empty IList. + + the ChromiumWebBrowser control + the browser object + The frame + List of objects or null if last region was removed. + + + + Implement this interface to handle events related to browser extensions. + The methods of this class will be called on the CEF UI thread. + See for information about extension loading. + + + + + Called if the request fails. + + error code + + + + Called if the request fails. + + error code + + + + Called if the request succeeds. + + is the loaded extension. + + + + Called if the request succeeds. + + is the loaded extension. + + + + Called after the IExtension.Unload request has completed. + + is the unloaded extension + + + + Called after the IExtension.Unload request has completed. + + is the unloaded extension + + + + Called when an extension needs a browser to host a background script specified via the "background" manifest key. + The browser will have no visible window and cannot be displayed. To allow creation of the browser optionally + modify newBrowser and settings and return false. To cancel creation of the browser + (and consequently cancel load of the background script) return true. Successful creation will be indicated by a call to + ILifeSpanHandler.OnAfterCreated, and IBrowserHost.IsBackgroundHost + will return true for the resulting browser. See https://developer.chrome.com/extensions/event_pages for more information + about extension background script usage. + + is the extension that is loading the background script + is an internally generated reference to an HTML page that will be used to + load the background script via a script src attribute + browser settings + To cancel creation of the browser (and consequently cancel load of the background script) return true, otherwise return false. + + + + Called when an extension needs a browser to host a background script specified via the "background" manifest key. + The browser will have no visible window and cannot be displayed. To allow creation of the browser optionally + modify newBrowser and settings and return false. To cancel creation of the browser + (and consequently cancel load of the background script) return true. Successful creation will be indicated by a call to + ILifeSpanHandler.OnAfterCreated, and IBrowserHost.IsBackgroundHost + will return true for the resulting browser. See https://developer.chrome.com/extensions/event_pages for more information + about extension background script usage. + + is the extension that is loading the background script + is an internally generated reference to an HTML page that will be used to + load the background script via a script src attribute + browser settings + To cancel creation of the browser (and consequently cancel load of the background script) return true, otherwise return false. + + + + Called when an extension API (e.g. chrome.tabs.create) requests creation of a new browser. + Successful creation will be indicated by a call to . + + the source of the API call + the source of the API call + may optionally be specified via the windowId property or + returned via the GetActiveBrowser() callback and provides the default for the new browser + is the position value optionally specified via the index property + is the URL that will be loaded in the browser + is true if the new browser should be active when opened + optionally modify if you are going to allow creation of the browser + optionally modify browser settings + To cancel creation of the browser return true. To allow creation return false and optionally modify windowInfo and settings + + + + Called when an extension API (e.g. chrome.tabs.create) requests creation of a new browser. + Successful creation will be indicated by a call to . + + the source of the API call + the source of the API call + may optionally be specified via the windowId property or + returned via the GetActiveBrowser() callback and provides the default for the new browser + is the position value optionally specified via the index property + is the URL that will be loaded in the browser + is true if the new browser should be active when opened + optionally modify if you are going to allow creation of the browser + optionally modify browser settings + To cancel creation of the browser return true. To allow creation return false and optionally modify windowInfo and settings + + + + Called when no tabId is specified to an extension API call that accepts a tabId parameter (e.g. chrome.tabs.*). + + extension the call originates from + browser the call originates from + Incognito browsers should not be considered unless the source extension has incognito + access enabled, inwhich case this will be true + Return the browser that will be acted on by the API call or return null to act on . + The returned browser must share the same IRequestContext as + + + + Called when no tabId is specified to an extension API call that accepts a tabId parameter (e.g. chrome.tabs.*). + + extension the call originates from + browser the call originates from + Incognito browsers should not be considered unless the source extension has incognito + access enabled, inwhich case this will be true + Return the browser that will be acted on by the API call or return null to act on . + The returned browser must share the same IRequestContext as + + + + Called when the tabId associated with is specified to an extension API call that accepts a tabId + parameter (e.g. chrome.tabs.*). + + extension the call originates from + browser the call originates from + Access to incognito browsers should not be allowed unless the source extension has + incognito access + enabled, in which case this will be true. + + Return true to allow access of false to deny access. + + + + Called when the tabId associated with is specified to an extension API call that accepts a tabId + parameter (e.g. chrome.tabs.*). + + extension the call originates from + browser the call originates from + Access to incognito browsers should not be allowed unless the source extension has + incognito access + enabled, in which case this will be true. + + Return true to allow access of false to deny access. + + + + Called to retrieve an extension resource that would normally be loaded from disk + (e.g. if a file parameter is specified to chrome.tabs.executeScript). + Localization substitutions will not be applied to resources handled via this method. + + extension the call originates from + browser the call originates from + is the requested relative file path. + callback used to handle custom resource requests + To handle the resource request return true and execute either synchronously or asynchronously. + For the default behavior which reads the resource from the extension directory on disk return false + + + + Called to retrieve an extension resource that would normally be loaded from disk + (e.g. if a file parameter is specified to chrome.tabs.executeScript). + Localization substitutions will not be applied to resources handled via this method. + + extension the call originates from + browser the call originates from + is the requested relative file path. + callback used to handle custom resource requests + To handle the resource request return true and execute either synchronously or asynchronously. + For the default behavior which reads the resource from the extension directory on disk return false + + + + IsDisposed + + + + + + + + Implement this interface to handle events related to find results. + The methods of this class will be called on the CEF UI thread. + + + + + + + + Called to report find results returned by + + the ChromiumWebBrowser control + the browser object + is a unique incremental identifier for the currently active search. + is the number of matches currently identified + is the location of where the match was found (in window coordinates) + is the current position in the search results + is true if this is the last find notification. + + + + Implement this interface to handle events related to focus. + The methods of this class will be called on the CEF UI thread. + + + + + Called when the browser component has received focus. + + the ChromiumWebBrowser control + the browser object + + + + Called when the browser component has received focus. + + the ChromiumWebBrowser control + the browser object + + + + Called when the browser component is requesting focus. + + the ChromiumWebBrowser control + the browser object, do not keep a reference to this object outside of this method + Indicates where the focus request is originating from. + Return false to allow the focus to be set or true to cancel setting the focus. + + + + Called when the browser component is requesting focus. + + the ChromiumWebBrowser control + the browser object, do not keep a reference to this object outside of this method + Indicates where the focus request is originating from. + Return false to allow the focus to be set or true to cancel setting the focus. + + + + Called when the browser component is about to lose focus. + For instance, if focus was on the last HTML element and the user pressed the TAB key. + + the ChromiumWebBrowser control + the browser object + Will be true if the browser is giving focus to the next component + and false if the browser is giving focus to the previous component. + + + + Called when the browser component is about to lose focus. + For instance, if focus was on the last HTML element and the user pressed the TAB key. + + the ChromiumWebBrowser control + the browser object + Will be true if the browser is giving focus to the next component + and false if the browser is giving focus to the previous component. + + + + Inherit from this class to handle frame events + All methods will be called on the CEF UI thread + + + + + + + + Called when a frame can begin routing commands to/from the associated + renderer process. Any commands that were queued have now been dispatched. + + the ChromiumWebBrowser control + the browser object + the frame object + will be true if the frame was re-attached after exiting the BackForwardCache. + + + + + + + Called when a new frame is created. This will be the first notification + that references . Any commands that require transport to the + associated renderer process (LoadRequest, SendProcessMessage, GetSource, + etc.) will be queued until OnFrameAttached is called for . + + the ChromiumWebBrowser control + the browser object + the frame object + + + + + + + Called when a frame loses its connection to the renderer process and will + be destroyed. Any pending or future commands will be discarded and + will now return false for . If called after + during browser destruction then + will return false for . + + the ChromiumWebBrowser control + the browser object + the frame object + + + + + + + Called when the main frame changes due to one of the following: + - (a) initial browser creation + - (b) final browser destruction + - (c) cross-origin navigation + - (d) re-navigation after renderer process termination (due to crashes, etc). + + will be null and will be non-null when a main frame is assigned + to for the first time. + will be non-null and will be null when a main frame is + removed from for the last time. + Both and will be non-nullfor cross-origin + navigations or re-navigation after renderer process termination. + This method will be called after for and/or after + for . If called after + during browser destruction then + will return false for . + + the ChromiumWebBrowser control + the browser object + the old frame object + the new frame object + + + + Inherit from this class to handle events related to JavaScript dialogs. + The methods of this class will be called on the CEF UI thread. + + + + + Called to run a JavaScript dialog. + + the ChromiumWebBrowser control + the browser object + originating url + Dialog Type + Message Text + value will be specified for prompt dialogs only + Callback can be executed inline or in an async fashion + Set suppressMessage to true and return false to suppress the message (suppressing messages is preferable to immediately executing the callback as this is used to detect presumably malicious behavior like spamming alert messages in onbeforeunload). Set suppressMessage to false and return false to use the default implementation (the default implementation will show one modal dialog at a time and suppress any additional dialog requests until the displayed dialog is dismissed). + Return true if the application will use a custom dialog or if the callback has been executed immediately. Custom dialogs may be either modal or modeless. If a custom dialog is used the application must execute |callback| once the custom dialog is dismissed. + + + + Called to run a JavaScript dialog. + + the ChromiumWebBrowser control + the browser object + originating url + Dialog Type + Message Text + value will be specified for prompt dialogs only + Callback can be executed inline or in an async fashion + Set suppressMessage to true and return false to suppress the message (suppressing messages is preferable to immediately executing the callback as this is used to detect presumably malicious behavior like spamming alert messages in onbeforeunload). Set suppressMessage to false and return false to use the default implementation (the default implementation will show one modal dialog at a time and suppress any additional dialog requests until the displayed dialog is dismissed). + Return true if the application will use a custom dialog or if the callback has been executed immediately. Custom dialogs may be either modal or modeless. If a custom dialog is used the application must execute |callback| once the custom dialog is dismissed. + + + + Called to run a dialog asking the user if they want to leave a page. Return false to use the default dialog implementation. + Return true if the application will use a custom dialog or if the callback has been executed immediately. + Custom dialogs may be either modal or modeless. If a custom dialog is used the application must execute + once the custom dialog is dismissed. + + the ChromiumWebBrowser control + the browser object + message text (optional) + indicates a page reload + Callback can be executed inline or in an async fashion + Return false to use the default dialog implementation otherwise return true to handle with your own custom implementation. + + + + Called to run a dialog asking the user if they want to leave a page. Return false to use the default dialog implementation. + Return true if the application will use a custom dialog or if the callback has been executed immediately. + Custom dialogs may be either modal or modeless. If a custom dialog is used the application must execute + once the custom dialog is dismissed. + + the ChromiumWebBrowser control + the browser object + message text (optional) + indicates a page reload + Callback can be executed inline or in an async fashion + Return false to use the default dialog implementation otherwise return true to handle with your own custom implementation. + + + + Called to cancel any pending dialogs and reset any saved dialog state. Will + be called due to events like page navigation irregardless of whether any + dialogs are currently pending. + + the ChromiumWebBrowser control + the browser object + + + + Called to cancel any pending dialogs and reset any saved dialog state. Will + be called due to events like page navigation irregardless of whether any + dialogs are currently pending. + + the ChromiumWebBrowser control + the browser object + + + + Called when the default implementation dialog is closed. + + the ChromiumWebBrowser control + the browser object + + + + Called when the default implementation dialog is closed. + + the ChromiumWebBrowser control + the browser object + + + + Inherit from this class to handle events related to keyboard input. + + + + + Called before a keyboard event is sent to the renderer. + Return true if the event was handled or false + otherwise. If the event will be handled in as a keyboard + shortcut set isKeyboardShortcut to true and return false. + + the ChromiumWebBrowser control + The browser instance. + Whether this was a key up/down/raw/etc... + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + The native key code. On Windows this appears to be in the format of WM_KEYDOWN/WM_KEYUP/etc... lParam data. + What other modifier keys are currently down: Shift/Control/Alt/OS X Command/etc... + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + + See the summary for an explanation of when to set this to true. + Returns true if the event was handled or false otherwise. + + + + Called before a keyboard event is sent to the renderer. + Return true if the event was handled or false + otherwise. If the event will be handled in as a keyboard + shortcut set isKeyboardShortcut to true and return false. + + the ChromiumWebBrowser control + The browser instance. + Whether this was a key up/down/raw/etc... + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + The native key code. On Windows this appears to be in the format of WM_KEYDOWN/WM_KEYUP/etc... lParam data. + What other modifier keys are currently down: Shift/Control/Alt/OS X Command/etc... + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + + See the summary for an explanation of when to set this to true. + Returns true if the event was handled or false otherwise. + + + + Called after the renderer and JavaScript in the page has had a chance to + handle the event. Return true if the keyboard event was handled or false otherwise. + + the ChromiumWebBrowser control + The browser instance. + Whether this was a key up/down/raw/etc... + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + The native key code. On Windows this appears to be in the format of WM_KEYDOWN/WM_KEYUP/etc... lParam data. + What other modifier keys are currently down: Shift/Control/Alt/OS X Command/etc... + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + + Return true if the keyboard event was handled or false otherwise. + + + + Called after the renderer and JavaScript in the page has had a chance to + handle the event. Return true if the keyboard event was handled or false otherwise. + + the ChromiumWebBrowser control + The browser instance. + Whether this was a key up/down/raw/etc... + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + The native key code. On Windows this appears to be in the format of WM_KEYDOWN/WM_KEYUP/etc... lParam data. + What other modifier keys are currently down: Shift/Control/Alt/OS X Command/etc... + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + + Return true if the keyboard event was handled or false otherwise. + + + + Default implementation of . This class provides default implementations of the methods from + , therefore providing a convenience base class for a custom implementation. + You need only override the methods you require. + IMPORTANT: behaviour of this implementation differs + from the default, the WM_CLOSE message is only sent by default for popups (return false), for the main browser + we return true to cancel this behaviour. + + + + + + + + + Called when a browser has recieved a request to close. This may result + directly from a call to CefBrowserHost::CloseBrowser() or indirectly if the + browser is a top-level OS window created by CEF and the user attempts to + close the window. This method will be called after the JavaScript + 'onunload' event has been fired. It will not be called for browsers after + the associated OS window has been destroyed (for those browsers it is no + longer possible to cancel the close). + + If CEF created an OS window for the browser returning false will send an OS + close notification to the browser window's top-level owner (e.g. WM_CLOSE + on Windows). If no OS window exists (window rendering disabled) returning false + will cause the browser object to be destroyed immediately. Return true if + the browser is parented to another window and that other window needs to + receive close notification via some non-standard technique. + + !!IMPORTANT!!: Behaviour of this implementation differs from the default, + the WM_CLOSE message is only sent by default for popups (return false), + for the main browser we return true to cancel this behaviour. + + If an application provides its own top-level window it should handle OS + close notifications by calling CefBrowserHost::CloseBrowser(false) instead + of immediately closing (see the example below). This gives CEF an + opportunity to process the 'onbeforeunload' event and optionally cancel the + close before DoClose() is called. + + The CefLifeSpanHandler::OnBeforeClose() method will be called immediately + before the browser object is destroyed. The application should only exit + after OnBeforeClose() has been called for all existing browsers. + + If the browser represents a modal window and a custom modal loop + implementation was provided in CefLifeSpanHandler::RunModal() this callback + should be used to restore the opener window to a usable state. + + By way of example consider what should happen during window close when the + browser is parented to an application-provided top-level OS window. + 1. User clicks the window close button which sends an OS close + notification (e.g. WM_CLOSE on Windows, performClose: on OS-X and + "delete_event" on Linux). + 2. Application's top-level window receives the close notification and: + A. Calls CefBrowserHost::CloseBrowser(false). + B. Cancels the window close. + 3. JavaScript 'onbeforeunload' handler executes and shows the close + confirmation dialog (which can be overridden via + CefJSDialogHandler::OnBeforeUnloadDialog()). + 4. User approves the close. + 5. JavaScript 'onunload' handler executes. + 6. Application's DoClose() handler is called. Application will: + A. Set a flag to indicate that the next close attempt will be allowed. + B. Return false. + 7. CEF sends an OS close notification. + 8. Application's top-level window receives the OS close notification and + allows the window to close based on the flag from #6B. + 9. Browser OS window is destroyed. + 10. Application's CefLifeSpanHandler::OnBeforeClose() handler is called and + the browser object is destroyed. + 11. Application exits by calling CefQuitMessageLoop() if no other browsers + exist. + + the ChromiumWebBrowser control + The browser instance - check if IsDisposed as it's possible when the browser is disposing + For default behaviour return false + + + + + + + Called after a new browser is created. + + the ChromiumWebBrowser control + The browser instance + + + + + + + Called before a CefBrowser window (either the main browser for , + or one of its children) + + the ChromiumWebBrowser control + The browser instance + + + + + + + Called before a popup window is created. By default the popup (browser) is created in a new native window. + + the ChromiumWebBrowser control + The browser instance that launched this popup. + The HTML frame that launched this popup. + The URL of the popup content. (This may be empty/null) + The name of the popup. (This may be empty/null) + The value indicates where the user intended to + open the popup (e.g. current tab, new tab, etc) + The value will be true if the popup was opened via explicit user gesture + (e.g. clicking a link) or false if the popup opened automatically (e.g. via the DomContentLoaded event). + structure contains additional information about the requested popup window + window information + browser settings, defaults to source browsers + value indicates whether the new browser window should be scriptable + and in the same process as the source browser. + + EXPERIMENTAL - Low level this allows for assigning the CefClient instance associated with the new ChromiumWebBrowser instance to the CefClient param of the CefLifeSpanHandler::OnBeforeBrowser method. + This allows for all the handlers, LifeSpanHandler, DisplayHandler, etc to be associated with the CefClient of the new ChromiumWebBrowser instance to be associated with the popup (browser). + WPF/WinForms specific code is still required to host the popup (browser) in the new ChromiumWebBrowser instance. + Set to null for default behaviour. If you return true (cancel popup creation) then his property **MUST** be null, an exception will be thrown otherwise. + + + By default the popup (browser) is opened in a new native window. If you return true then creation of the popup (browser) is cancelled, no further action will occur. + Otherwise return false to allow creation of the popup (browser). + + + If you return true and set to not null then an exception will be thrown as creation of the popup (browser) was cancelled. + WinForms - To host the popup (browser) in a TAB/Custom Window see https://github.com/cefsharp/CefSharp/wiki/General-Usage#winforms---hosting-popup-using-tab-control for an easy method. + WPF - For an example of hosting the popup (browser) in a custom window see https://github.com/cefsharp/CefSharp/wiki/General-Usage#wpf---hosting-popup-in-new-window-experimental + Same can be applied for hosting the popup in a TAB. + This method is still EXPERIMENTAL and will likely require upstream bug fixes in CEF (https://bitbucket.org/chromiumembedded/cef). + + + + + Implement this interface to handle events related to browser load status. + The methods of this interface will be called on the CEF UI thread. Blocking in these methods + will likely cause your UI to become unresponsive and/or hang. + + + + + Called when the loading state has changed. This callback will be executed twice + once when loading is initiated either programmatically or by user action, + and once when loading is terminated due to completion, cancellation of failure. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the loading state has changed. This callback will be executed twice + once when loading is initiated either programmatically or by user action, + and once when loading is terminated due to completion, cancellation of failure. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the browser begins loading a frame. + The value will never be empty + Check the method to see if this frame is the main frame. + Multiple frames may be loading at the same time. Sub-frames may start or continue loading after the main frame load has ended. + This method may not be called for a particular frame if the load request for that frame fails. + For notification of overall browser load status use instead. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + Whilst thist may seem like a logical place to execute js, it's called before the DOM has been loaded, implement + as it's called when the underlying V8Context is created + (Only called for the main frame at this stage) + + + + Called when the browser begins loading a frame. + The value will never be empty + Check the method to see if this frame is the main frame. + Multiple frames may be loading at the same time. Sub-frames may start or continue loading after the main frame load has ended. + This method may not be called for a particular frame if the load request for that frame fails. + For notification of overall browser load status use instead. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + Whilst thist may seem like a logical place to execute js, it's called before the DOM has been loaded, implement + as it's called when the underlying V8Context is created + (Only called for the main frame at this stage) + + + + Called when the browser is done loading a frame. + The value will never be empty + Check the method to see if this frame is the main frame. + Multiple frames may be loading at the same time. Sub-frames may start or continue loading after the main frame load has ended. + This method will always be called for all frames irrespective of whether the request completes successfully. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the browser is done loading a frame. + The value will never be empty + Check the method to see if this frame is the main frame. + Multiple frames may be loading at the same time. Sub-frames may start or continue loading after the main frame load has ended. + This method will always be called for all frames irrespective of whether the request completes successfully. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the resource load for a navigation fails or is canceled. + is the error code number, is the error text and + is the URL that failed to load. See net\base\net_error_list.h + for complete descriptions of the error codes. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the resource load for a navigation fails or is canceled. + is the error code number, is the error text and + is the URL that failed to load. See net\base\net_error_list.h + for complete descriptions of the error codes. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + + + + + + + Called when a page requests permission to access media. + With the Chrome runtime, default handling will display the + permission request UI.With the Alloy runtime, default handling will deny + the request.This method will not be called if the "--enable-media-stream" + command-line switch is used to grant all permissions. + + The ChromiumWebBrowser control + The browser object + The frame object + is the URL origin requesting permission. + is a combination of values that represent the requested permissions + Callback interface used for asynchronous continuation of media access. + Return true and call CefMediaAccessCallback methods either in this method or at a later time to continue or cancel the request. + Return false to proceed with default handling. + + + + + + + + Called when a page should show a permission prompt. + + The ChromiumWebBrowser control + The browser object + Uniquely identifies the prompt. + Is the URL origin requesting permission. + Is a combination of values from that represent the requested permissions. + Callback interface used for asynchronous continuation of permission prompts. + Return true and call either in this method or at a later time to continue or cancel the request. + Return false to proceed with default handling. + With the Chrome runtime, default handling + will display the permission prompt UI. With the Alloy runtime, default + handling is . + + + + + + + Called when a permission prompt handled via is dismissed. + will be the value passed to + or if + the dialog was dismissed for other reasons such as navigation, browser + closure, etc. This method will not be called if + returned false for . + + The ChromiumWebBrowser control + The browser object + Will match the value that was passed to . + will be the value passed to or if the dialog was dismissed for other reasons such as navigation, browser closure, etc. This method will not be called if returned false for . + + + + Implement this interface to provide handler implementations. The handler + instance will not be released until all objects related to the context have + been destroyed. + + + + + The is executed when the RequestContext has been initialized, after the + preferences/proxy preferences have been set, before OnRequestContextInitialized. + + action to perform on context initialize + A instance allowing you to chain multiple AddPreference calls together + Only a single action reference is maintained, multiple calls will result in the + previous action reference being overriden. + + + + Sets the preferences when the + method is called. If is null the preference will be restored + to its default value. Preferences set via the command-line usually cannot be modified. + + preference name + preference value + A instance allowing you to chain multiple AddPreference calls together + + + + Sets the proxy preferences when the + method is called. Proxy set via the command-line usually cannot be modified. + + proxy host + proxy port + A instance allowing you to chain multiple AddPreference calls together + + + + Sets the proxy preferences when the + method is called. Proxy set via the command-line usually cannot be modified. + + is the protocol of the proxy server, and is one of: 'http', 'socks', 'socks4', 'socks5'. Also note that 'socks' is equivalent to 'socks5'. + proxy host + proxy port + A instance allowing you to chain multiple AddPreference calls together + + + + Called on the CEF IO thread before a resource request is initiated. + This method will not be called if the client associated with returns a non-NULL value + from for the same request (identified by ). + + represent the source browser of the request, and may be null for requests originating from service workers. + represent the source frame of the request, and may be null for requests originating from service workers. + represents the request contents and cannot be modified in this callback + will be true if the resource request is a navigation + will be true if the resource request is a download + is the origin (scheme + domain) of the page that initiated the request + Set to true to disable default handling of the request, in which case it will need to be handled via or it will be canceled + To allow the resource load to proceed with default handling return null. To specify a handler for the resource return a object. + + + + Called immediately after the request context has been initialized. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. + + the request context + + + + Default implementation of . This class provides default implementations of the methods from + , therefore providing a convenience base class for any custom request handler. + + + + + + + + + Called before browser navigation. If the navigation is allowed and + + will be called. If the navigation is canceled will be called with an ErrorCode value of + . + + the ChromiumWebBrowser control. + the browser object. + The frame the request is coming from. + the request object - cannot be modified in this callback. + The value will be true if the browser navigated via explicit user gesture (e.g. clicking a link) or + false if it navigated automatically (e.g. via the DomContentLoaded event). + has the request been redirected. + + Return true to cancel the navigation or false to allow the navigation to proceed. + + + + + + + + Called on the UI thread before OnBeforeBrowse in certain limited cases where navigating a new or different browser might be + desirable. This includes user-initiated navigation that might open in a special way (e.g. links clicked via middle-click or + ctrl + left-click) and certain types of cross-origin navigation initiated from the renderer process (e.g. navigating the top- + level frame to/from a file URL). + + the ChromiumWebBrowser control. + the browser object. + The frame object. + target url. + The value indicates where the user intended to navigate the browser based on standard + Chromium behaviors (e.g. current tab, new tab, etc). + The value will be true if the browser navigated via explicit user gesture (e.g. clicking a link) or + false if it navigated automatically (e.g. via the DomContentLoaded event). + + Return true to cancel the navigation or false to allow the navigation to proceed in the source browser's top-level frame. + + + + + + + + Called on the CEF IO thread before a resource request is initiated. + + the ChromiumWebBrowser control. + represent the source browser of the request. + represent the source frame of the request. + represents the request contents and cannot be modified in this callback. + will be true if the resource request is a navigation. + will be true if the resource request is a download. + is the origin (scheme + domain) of the page that initiated the request. + [in,out] to true to disable default handling of the request, in which case it will need + to be handled via or it will be canceled. + + To allow the resource load to proceed with default handling return null. To specify a handler for the resource return a + object. If this callback returns null the same method will be called on the associated + , if any. + + + + + + + + Called when the browser needs credentials from the user. + + The ChromiumWebBrowser control. + the browser object. + is the origin making this authentication request. + indicates whether the host is a proxy server. + hostname. + port number. + realm. + scheme. + Callback interface used for asynchronous continuation of authentication requests. + + Return true to continue the request and call when the authentication + information is available. Return false to cancel the request. + + + + + + + + Called to handle requests for URLs with an invalid SSL certificate. Return true and call + either in this method or at a later time to continue or cancel the request. + If CefSettings.IgnoreCertificateErrors is set all invalid certificates will be accepted without calling this method. + + the ChromiumWebBrowser control. + the browser object. + the error code for this invalid certificate. + the url of the request for the invalid certificate. + ssl certificate information. + Callback interface used for asynchronous continuation of url requests. If empty the error cannot be + recovered from and the request will be canceled automatically. + + Return false to cancel the request immediately. Return true and use to execute in an async + fashion. + + + + + + + + Called when the browser needs user to select Client Certificate for authentication requests (eg. PKI authentication). + + The ChromiumWebBrowser control. + the browser object. + indicates whether the host is a proxy server. + hostname. + port number. + List of Client certificates for selection. + Callback interface used for asynchronous continuation of client certificate selection for + authentication requests. + + Return true to continue the request and call ISelectClientCertificateCallback.Select() with the selected certificate for + authentication. Return false to use the default behavior where the browser selects the first certificate from the list. + + + + + + + + + Called on the CEF UI thread when the render view associated with browser is ready to receive/handle IPC messages in the + render process. + + The ChromiumWebBrowser control. + the browser object. + + + + + + + Called when the render process terminates unexpectedly. + + The ChromiumWebBrowser control. + the browser object. + indicates how the process terminated. + + + + + + + Called on the CEF UI thread when the window.document object of the main frame has been created. + + the ChromiumWebBrowser control + the browser object + + + + Default implementation of . This class provides default implementations of the methods + from , therefore providing a convenience base class for any custom resource request + handler. + + + + + + Called on the CEF IO thread before a resource request is loaded. To optionally filter cookies for the request return a + object. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - can be modified in this callback. + To optionally filter cookies for the request return a ICookieAccessFilter instance otherwise return null. + + + + Called on the CEF IO thread before a resource request is loaded. To optionally filter cookies for the request return a + object. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - can be modified in this callback. + To optionally filter cookies for the request return a ICookieAccessFilter instance otherwise return null. + + + + Called on the CEF IO thread before a resource is loaded. To specify a handler for the resource return a + object. + + The browser UI control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + + To allow the resource to load using the default network loader return null otherwise return an instance of + with a valid stream. + + + + + Called on the CEF IO thread before a resource is loaded. To specify a handler for the resource return a + object. + + The browser UI control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + + To allow the resource to load using the default network loader return null otherwise return an instance of + with a valid stream. + + + + Called on the CEF IO thread to optionally filter resource response content. + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + the response object - cannot be modified in this callback. + Return an IResponseFilter to intercept this response, otherwise return null. + + + Called on the CEF IO thread to optionally filter resource response content. + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + the response object - cannot be modified in this callback. + Return an IResponseFilter to intercept this response, otherwise return null. + + + + Called on the CEF IO thread before a resource request is loaded. To redirect or change the resource load optionally modify + . Modification of the request URL will be treated as a redirect. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - can be modified in this callback. + Callback interface used for asynchronous continuation of url requests. + + Return to continue the request immediately. Return + and call or + at a later time to continue or the cancel the request asynchronously. Return + to cancel the request immediately. + + + + + Called on the CEF IO thread before a resource request is loaded. To redirect or change the resource load optionally modify + . Modification of the request URL will be treated as a redirect. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - can be modified in this callback. + Callback interface used for asynchronous continuation of url requests. + + Return to continue the request immediately. Return + and call or + at a later time to continue or the cancel the request asynchronously. Return + to cancel the request immediately. + + + + + Called on the CEF UI thread to handle requests for URLs with an unknown protocol component. SECURITY WARNING: YOU SHOULD USE + THIS METHOD TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR OTHER URL ANALYSIS BEFORE ALLOWING OS EXECUTION. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + + return to true to attempt execution via the registered OS protocol handler, if any. Otherwise return false. + + + + + Called on the CEF UI thread to handle requests for URLs with an unknown protocol component. SECURITY WARNING: YOU SHOULD USE + THIS METHOD TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR OTHER URL ANALYSIS BEFORE ALLOWING OS EXECUTION. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + + return to true to attempt execution via the registered OS protocol handler, if any. Otherwise return false. + + + + + Called on the CEF IO thread when a resource load has completed. This method will be called for all requests, including + requests that are aborted due to CEF shutdown or destruction of the associated browser. In cases where the associated browser + is destroyed this callback may arrive after the callback for that browser. The + method can be used to test for this situation, and care + should be taken not to call or methods that modify state (like LoadURL, + SendProcessMessage, etc.) if the frame is invalid. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + the response object - cannot be modified in this callback. + indicates the load completion status. + is the number of response bytes actually read. + + + + Called on the CEF IO thread when a resource load has completed. This method will be called for all requests, including + requests that are aborted due to CEF shutdown or destruction of the associated browser. In cases where the associated browser + is destroyed this callback may arrive after the callback for that browser. The + method can be used to test for this situation, and care + should be taken not to call or methods that modify state (like LoadURL, + SendProcessMessage, etc.) if the frame is invalid. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + the response object - cannot be modified in this callback. + indicates the load completion status. + is the number of response bytes actually read. + + + + Called on the CEF IO thread when a resource load is redirected. The parameter will contain the old + URL and other request-related information. The parameter will contain the response that resulted + in the redirect. The parameter will contain the new URL and can be changed if desired. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + the response object - cannot be modified in this callback. + [in,out] the new URL and can be changed if desired. + + + + Called on the CEF IO thread when a resource load is redirected. The parameter will contain the old + URL and other request-related information. The parameter will contain the response that resulted + in the redirect. The parameter will contain the new URL and can be changed if desired. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object - cannot be modified in this callback. + the response object - cannot be modified in this callback. + [in,out] the new URL and can be changed if desired. + + + + Called on the CEF IO thread when a resource response is received. To allow the resource load to proceed without modification + return false. To redirect or retry the resource load optionally modify and return true. + Modification of the request URL will be treated as a redirect. Requests handled using the default network loader cannot be + redirected in this callback. + + WARNING: Redirecting using this method is deprecated. Use OnBeforeResourceLoad or GetResourceHandler to perform redirects. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object. + the response object - cannot be modified in this callback. + + To allow the resource load to proceed without modification return false. To redirect or retry the resource load optionally + modify and return true. Modification of the request URL will be treated as a redirect. Requests + handled using the default network loader cannot be redirected in this callback. + + + + + Called on the CEF IO thread when a resource response is received. To allow the resource load to proceed without modification + return false. To redirect or retry the resource load optionally modify and return true. + Modification of the request URL will be treated as a redirect. Requests handled using the default network loader cannot be + redirected in this callback. + + WARNING: Redirecting using this method is deprecated. Use OnBeforeResourceLoad or GetResourceHandler to perform redirects. + + The ChromiumWebBrowser control. + the browser object - may be null if originating from ServiceWorker or CefURLRequest. + the frame object - may be null if originating from ServiceWorker or CefURLRequest. + the request object. + the response object - cannot be modified in this callback. + + To allow the resource load to proceed without modification return false. To redirect or retry the resource load optionally + modify and return true. Modification of the request URL will be treated as a redirect. Requests + handled using the default network loader cannot be redirected in this callback. + + + + + Called when the unmanaged resource is freed. + Unmanaged resources are ref counted and freed when + the last reference is released, this works differently + to .Net garbage collection. + + + + + Implement this interface to receive accessibility notification when accessibility events have been registered. + It's important to note that the methods of this interface are called on a CEF UI thread, + which by default is not the same as your application UI thread. + + + + + Called after renderer process sends accessibility location changes to the browser process. + + Updated location info. + + + + Called after renderer process sends accessibility tree changes to the browser process. + + Updated tree info. + + + + Implement this interface to handle audio events + All methods will be called on the CEF UI thread + + + + + Called on the CEF UI thread to allow configuration of audio stream parameters. + Audio stream paramaters can optionally be configured by modifying + + the ChromiumWebBrowser control + the browser object + audio stream parameters can optionally be configured here, they are + pre-filled with some sensible defaults. + Return true to proceed with audio stream capture, or false to cancel it + + + + Called on a browser audio capture thread when the browser starts streaming audio. + OnAudioStreamStopped will always be called after OnAudioStreamStarted; both methods may be called multiple + times for the same browser. + + the ChromiumWebBrowser control + the browser object + contains the audio parameters like sample rate and channel layout. + Changing the param values will have no effect here. + is the number of channels + + + + Called on the audio stream thread when a PCM packet is received for the stream. + Based on and the value passed to + you can calculate the size of the array in bytes. + + + is an array representing the raw PCM data as a floating point type, i.e. 4-byte value(s). + is the number of frames in the PCM packet + is the presentation timestamp (in milliseconds since the Unix Epoch) + and represents the time at which the decompressed packet should be presented to the user + + + + Called on the CEF UI thread when the stream has stopped. OnAudioStreamStopped will always be called after ; + both methods may be called multiple times for the same stream. + + the ChromiumWebBrowser control + the browser object + + + + Called on the CEF UI thread or audio stream thread when an error occurred. During the + stream creation phase this callback will be called on the UI thread while + in the capturing phase it will be called on the audio stream thread. The + stream will be stopped immediately. + + the ChromiumWebBrowser control + the browser object + error message + + + + Implement this interface to handle events related to browser process callbacks. + The methods of this class will be called on the CEF UI thread unless otherwise indicated. . + + + + + Called on the CEF UI thread immediately after the CEF context has been initialized. + You can now access the Global RequestContext through Cef.GetGlobalRequestContext() - this is the + first place you can set Preferences (e.g. proxy settings, spell check dictionaries). + + + + + Called from any thread when work has been scheduled for the browser process + main (UI) thread. This callback is used in combination with CefSettings. + ExternalMessagePump and Cef.DoMessageLoopWork() in cases where the CEF + message loop must be integrated into an existing application message loop + (see additional comments and warnings on Cef.DoMessageLoopWork). This + callback should schedule a Cef.DoMessageLoopWork() call to happen on the + main (UI) thread. + + is the requested delay in milliseconds. If + delay is less than or equal to 0 then the call should happen reasonably soon. If + delay is greater than 0 then the call should be scheduled to happen after the + specified delay and any currently pending scheduled call should be + cancelled. + + + + Implement this interface to handle context menu events. + + + + + Called before a context menu is displayed. The model can be cleared to show no context menu or + modified to show a custom menu. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + provides information about the context menu state + initially contains the default context menu + + + + Called to execute a command selected from the context menu. See + cef_menu_id_t for the command ids that have default implementations. All + user-defined command ids should be between MENU_ID_USER_FIRST and + MENU_ID_USER_LAST. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + will have the same values as what was passed to + menu command id + event flags + Return true if the command was handled or false for the default implementation. + + + + Called when the context menu is dismissed irregardless of whether the menu + was canceled or a command was selected. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + + + + Called to allow custom display of the context menu. + For custom display return true and execute callback either synchronously or asynchronously with the selected command Id. + For default display return false. Do not keep references to parameters or model outside of this callback. + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + provides information about the context menu state + contains the context menu model resulting from OnBeforeContextMenu + the callback to execute for custom display + For custom display return true and execute callback either synchronously or asynchronously with the selected command ID. + + + + Implement this interface to filter cookies that may be sent or received from + resource requests. The methods of this class will be called on the CEF IO thread + unless otherwise indicated. + + + + + Called on the CEF IO thread before a resource request is sent. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the cookie object + Return true if the specified cookie can be sent with the request or false otherwise. + + + + Called on the CEF IO thread after a resource response is received. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the response object - cannot be modified in this callback + the cookie object + Return true if the specified cookie returned with the response can be saved or false otherwise. + + + + Implement this interface to handle dialog events. The methods of this class will be called on the CEF UI thread. + + + + + Runs a file chooser dialog. + + + To test assign something like TempFileDialogHandler (from CefSharp.Example) to DialogHandler e.g. + + browser.DialogHandler = new TempFileDialogHandler(); + + Example URL to use for file browsing http://www.cs.tut.fi/~jkorpela/forms/file.html#example + Simply click browse, the space next to the browse button should be populated with a randomly generated filename. + + the ChromiumWebBrowser control + the browser object + represents the type of dialog to display + the title to be used for the dialog. It may be empty to show the default title ("Open" or "Save" + depending on the mode). + is the path with optional directory and/or file name component that + should be initially selected in the dialog. + are used to restrict the selectable file types and may any combination of + (a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), + (b) individual file extensions (e.g. ".txt" or ".png"), + (c) combined description and file extension delimited using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg"). + Callback interface for asynchronous continuation of file dialog requests. + To display a custom dialog return true. To display the default dialog return false. + + + + Handle events related to browser display state. + + + + + Called when a frame's address has changed. + + the ChromiumWebBrowser control + args + + + + Called when auto-resize is enabled via IBrowserHost.SetAutoResizeEnabled and the contents have auto-resized. + + the ChromiumWebBrowser control + the browser object + will be the desired size in view coordinates + Return true if the resize was handled or false for default handling. + + + + Called when the browser's cursor has changed. . + + the ChromiumWebBrowser control + the browser object + If type is Custom then customCursorInfo will be populated with the custom cursor information + cursor type + custom cursor Information + Return true if the cursor change was handled or false for default handling. + + + + Called when the page title changes. + + the ChromiumWebBrowser control + args + + + + Called when the page icon changes. + + the ChromiumWebBrowser control + the browser object + list of urls where the favicons can be downloaded + + + + Called when web content in the page has toggled fullscreen mode. The client is + responsible for resizing the browser if desired. + + The ChromiumWebBrowser control + the browser object + If true the content will automatically be sized to fill the browser content area. + If false the content will automatically return to its original size and position. + + + + Called when the overall page loading progress has changed + + The ChromiumWebBrowser control + the browser object + ranges from 0.0 to 1.0. + + + + Called when the browser is about to display a tooltip. text contains the + text that will be displayed in the tooltip. You can optionally modify text + and then return false to allow the browser to display the tooltip. + When window rendering is disabled the application is responsible for + drawing tooltips and the return value is ignored. + + The ChromiumWebBrowser control + the text that will be displayed in the tooltip + To handle the display of the tooltip yourself return true otherwise return false + to allow the browser to display the tooltip. + Only called when using Off-screen rendering (WPF and OffScreen) + + + + Called when the browser receives a status message. + + The control this popup is related to. + args + + + + Called to display a console message. + + The ChromiumWebBrowser control + args + Return true to stop the message from being output to the console. + + + + Class used to handle file downloads. + The methods of this class will called on the CEF UI thread. + + + + + Called before a download begins in response to a user-initiated action + (e.g. alt + link click or link click that returns a `Content-Disposition: + attachment` response from the server). + + the ChromiumWebBrowser control + The browser instance + is the target download URL + is the target method (GET, POST, etc) + Return true to proceed with the download or false to cancel the download. + + + + Called before a download begins. + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + Callback interface used to asynchronously continue a download. + + + + Called when a download's status or progress information has been updated. This may be called multiple times before and after . + + the ChromiumWebBrowser control + The browser instance + Represents the file being downloaded. + The callback used to Cancel/Pause/Resume the process + + + + Implement this interface to handle events related to dragging. + The methods of this class will be called on the UI thread. + + + + + Called when an external drag event enters the browser window. + + the ChromiumWebBrowser control + the browser object + contains the drag event data + represents the type of drag operation + Return false for default drag handling behavior or true to cancel the drag event. + + + + Called whenever draggable regions for the browser window change. + These can be specified using the '-webkit-app-region: drag/no-drag' CSS-property. + If draggable regions are never defined in a document this method will also never be called. + If the last draggable region is removed from a document this method will be called with an empty IList. + + the ChromiumWebBrowser control + the browser object + The frame + List of objects or null if last region was removed. + + + + Implement this interface to handle events related to browser extensions. + The methods of this class will be called on the CEF UI thread. + See for information about extension loading. + + + + + Called if the request fails. + + error code + + + + Called if the request succeeds. + + is the loaded extension. + + + + Called after the IExtension.Unload request has completed. + + is the unloaded extension + + + + Called when an extension needs a browser to host a background script specified via the "background" manifest key. + The browser will have no visible window and cannot be displayed. To allow creation of the browser optionally + modify newBrowser and settings and return false. To cancel creation of the browser + (and consequently cancel load of the background script) return true. Successful creation will be indicated by a call to + ILifeSpanHandler.OnAfterCreated, and IBrowserHost.IsBackgroundHost + will return true for the resulting browser. See https://developer.chrome.com/extensions/event_pages for more information + about extension background script usage. + + is the extension that is loading the background script + is an internally generated reference to an HTML page that will be used to + load the background script via a script src attribute + browser settings + To cancel creation of the browser (and consequently cancel load of the background script) return true, otherwise return false. + + + + Called when an extension API (e.g. chrome.tabs.create) requests creation of a new browser. + Successful creation will be indicated by a call to . + + the source of the API call + the source of the API call + may optionally be specified via the windowId property or + returned via the GetActiveBrowser() callback and provides the default for the new browser + is the position value optionally specified via the index property + is the URL that will be loaded in the browser + is true if the new browser should be active when opened + optionally modify if you are going to allow creation of the browser + optionally modify browser settings + To cancel creation of the browser return true. To allow creation return false and optionally modify windowInfo and settings + + + + Called when no tabId is specified to an extension API call that accepts a tabId parameter (e.g. chrome.tabs.*). + + extension the call originates from + browser the call originates from + Incognito browsers should not be considered unless the source extension has incognito + access enabled, inwhich case this will be true + Return the browser that will be acted on by the API call or return null to act on . + The returned browser must share the same IRequestContext as + + + + Called when the tabId associated with is specified to an extension API call that accepts a tabId + parameter (e.g. chrome.tabs.*). + + extension the call originates from + browser the call originates from + Access to incognito browsers should not be allowed unless the source extension has + incognito access + enabled, in which case this will be true. + + Return true to allow access of false to deny access. + + + + Called to retrieve an extension resource that would normally be loaded from disk + (e.g. if a file parameter is specified to chrome.tabs.executeScript). + Localization substitutions will not be applied to resources handled via this method. + + extension the call originates from + browser the call originates from + is the requested relative file path. + callback used to handle custom resource requests + To handle the resource request return true and execute either synchronously or asynchronously. + For the default behavior which reads the resource from the extension directory on disk return false + + + + Implement this interface to handle events related to find results. + The methods of this class will be called on the CEF UI thread. + + + + + Called to report find results returned by + + the ChromiumWebBrowser control + the browser object + is a unique incremental identifier for the currently active search. + is the number of matches currently identified + is the location of where the match was found (in window coordinates) + is the current position in the search results + is true if this is the last find notification. + + + + Implement this interface to handle events related to focus. + The methods of this class will be called on the CEF UI thread. + + + + + Called when the browser component has received focus. + + the ChromiumWebBrowser control + the browser object + + + + Called when the browser component is requesting focus. + + the ChromiumWebBrowser control + the browser object, do not keep a reference to this object outside of this method + Indicates where the focus request is originating from. + Return false to allow the focus to be set or true to cancel setting the focus. + + + + Called when the browser component is about to lose focus. + For instance, if focus was on the last HTML element and the user pressed the TAB key. + + the ChromiumWebBrowser control + the browser object + Will be true if the browser is giving focus to the next component + and false if the browser is giving focus to the previous component. + + + + Implement this interface to handle frame events + All methods will be called on the CEF UI thread + + + + + Called when a frame can begin routing commands to/from the associated + renderer process. Any commands that were queued have now been dispatched. + + the ChromiumWebBrowser control + the browser object + the frame object + will be true if the frame was re-attached after exiting the BackForwardCache. + + + + Called when a new frame is created. This will be the first notification + that references . Any commands that require transport to the + associated renderer process (LoadRequest, SendProcessMessage, GetSource, + etc.) will be queued until OnFrameAttached is called for . + + the ChromiumWebBrowser control + the browser object + the frame object + + + + Called when a frame loses its connection to the renderer process and will + be destroyed. Any pending or future commands will be discarded and + will now return false for . If called after + during browser destruction then + will return false for . + + the ChromiumWebBrowser control + the browser object + the frame object + + + + Called when the main frame changes due to one of the following: + - (a) initial browser creation + - (b) final browser destruction + - (c) cross-origin navigation + - (d) re-navigation after renderer process termination (due to crashes, etc). + + will be null and will be non-null when a main frame is assigned + to for the first time. + will be non-null and will be null when a main frame is + removed from for the last time. + Both and will be non-nullfor cross-origin + navigations or re-navigation after renderer process termination. + This method will be called after for and/or after + for . If called after + during browser destruction then + will return false for . + + the ChromiumWebBrowser control + the browser object + the old frame object + the new frame object + + + + Implement this interface to handle events related to JavaScript dialogs. + The methods of this class will be called on the CEF UI thread. + + + + + Called to run a JavaScript dialog. + + the ChromiumWebBrowser control + the browser object + originating url + Dialog Type + Message Text + value will be specified for prompt dialogs only + Callback can be executed inline or in an async fashion + Set suppressMessage to true and return false to suppress the message (suppressing messages is preferable to immediately executing the callback as this is used to detect presumably malicious behavior like spamming alert messages in onbeforeunload). Set suppressMessage to false and return false to use the default implementation (the default implementation will show one modal dialog at a time and suppress any additional dialog requests until the displayed dialog is dismissed). + Return true if the application will use a custom dialog or if the callback has been executed immediately. Custom dialogs may be either modal or modeless. If a custom dialog is used the application must execute |callback| once the custom dialog is dismissed. + + + + Called to run a dialog asking the user if they want to leave a page. Return false to use the default dialog implementation. + Return true if the application will use a custom dialog or if the callback has been executed immediately. + Custom dialogs may be either modal or modeless. If a custom dialog is used the application must execute + once the custom dialog is dismissed. + + the ChromiumWebBrowser control + the browser object + message text (optional) + indicates a page reload + Callback can be executed inline or in an async fashion + Return false to use the default dialog implementation otherwise return true to handle with your own custom implementation. + + + + Called to cancel any pending dialogs and reset any saved dialog state. Will + be called due to events like page navigation irregardless of whether any + dialogs are currently pending. + + the ChromiumWebBrowser control + the browser object + + + + Called when the dialog is closed. + + the ChromiumWebBrowser control + the browser object + + + + Implement this interface to handle events related to keyboard input. + + + + + Called before a keyboard event is sent to the renderer. + Return true if the event was handled or false + otherwise. If the event will be handled in as a keyboard + shortcut set isKeyboardShortcut to true and return false. + + the ChromiumWebBrowser control + The browser instance. + Whether this was a key up/down/raw/etc... + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + The native key code. On Windows this appears to be in the format of WM_KEYDOWN/WM_KEYUP/etc... lParam data. + What other modifier keys are currently down: Shift/Control/Alt/OS X Command/etc... + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + + See the summary for an explanation of when to set this to true. + Returns true if the event was handled or false otherwise. + + + + Called after the renderer and JavaScript in the page has had a chance to + handle the event. Return true if the keyboard event was handled or false otherwise. + + the ChromiumWebBrowser control + The browser instance. + Whether this was a key up/down/raw/etc... + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + The native key code. On Windows this appears to be in the format of WM_KEYDOWN/WM_KEYUP/etc... lParam data. + What other modifier keys are currently down: Shift/Control/Alt/OS X Command/etc... + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + + Return true if the keyboard event was handled or false otherwise. + + + + Implement this interface to handle events related to browser life span. + The methods of this class will be called on the CEF UI thread unless otherwise indicated. + + + + + Called before a popup window is created. By default the popup (browser) is created in a new native window. + + the ChromiumWebBrowser control + The browser instance that launched this popup. + The HTML frame that launched this popup. + The URL of the popup content. (This may be empty/null) + The name of the popup. (This may be empty/null) + The value indicates where the user intended to + open the popup (e.g. current tab, new tab, etc) + The value will be true if the popup was opened via explicit user gesture + (e.g. clicking a link) or false if the popup opened automatically (e.g. via the DomContentLoaded event). + structure contains additional information about the requested popup window + window information + browser settings, defaults to source browsers + value indicates whether the new browser window should be scriptable + and in the same process as the source browser. + + EXPERIMENTAL - Low level this allows for assigning the CefClient instance associated with the new ChromiumWebBrowser instance to the CefClient param of the CefLifeSpanHandler::OnBeforeBrowser method. + This allows for all the handlers, LifeSpanHandler, DisplayHandler, etc to be associated with the CefClient of the new ChromiumWebBrowser instance to be associated with the popup (browser). + WPF/WinForms specific code is still required to host the popup (browser) in the new ChromiumWebBrowser instance. + Set to null for default behaviour. If you return true (cancel popup creation) then his property **MUST** be null, an exception will be thrown otherwise. + + + By default the popup (browser) is opened in a new native window. If you return true then creation of the popup (browser) is cancelled, no further action will occur. + Otherwise return false to allow creation of the popup (browser). + + + If you return true and set to not null then an exception will be thrown as creation of the popup (browser) was cancelled. + WinForms - To host the popup (browser) in a TAB/Custom Window see https://github.com/cefsharp/CefSharp/wiki/General-Usage#winforms---hosting-popup-using-tab-control for an easy method. + WPF - For an example of hosting the popup (browser) in a custom window see https://github.com/cefsharp/CefSharp/wiki/General-Usage#wpf---hosting-popup-in-new-window-experimental + Same can be applied for hosting the popup in a TAB. + This method is still EXPERIMENTAL and will likely require upstream bug fixes in CEF (https://bitbucket.org/chromiumembedded/cef). + + + + + Called after a new browser is created. + + the ChromiumWebBrowser control + The browser instance + + + + Called when a browser has recieved a request to close. This may result + directly from a call to CefBrowserHost::CloseBrowser() or indirectly if the + browser is a top-level OS window created by CEF and the user attempts to + close the window. This method will be called after the JavaScript + 'onunload' event has been fired. It will not be called for browsers after + the associated OS window has been destroyed (for those browsers it is no + longer possible to cancel the close). + + If CEF created an OS window for the browser returning false will send an OS + close notification to the browser window's top-level owner (e.g. WM_CLOSE + on Windows, performClose: on OS-X and "delete_event" on Linux). If no OS + window exists (window rendering disabled) returning false will cause the + browser object to be destroyed immediately. Return true if the browser is + parented to another window and that other window needs to receive close + notification via some non-standard technique. + + If an application provides its own top-level window it should handle OS + close notifications by calling CefBrowserHost::CloseBrowser(false) instead + of immediately closing (see the example below). This gives CEF an + opportunity to process the 'onbeforeunload' event and optionally cancel the + close before DoClose() is called. + + The CefLifeSpanHandler::OnBeforeClose() method will be called immediately + before the browser object is destroyed. The application should only exit + after OnBeforeClose() has been called for all existing browsers. + + If the browser represents a modal window and a custom modal loop + implementation was provided in CefLifeSpanHandler::RunModal() this callback + should be used to restore the opener window to a usable state. + + By way of example consider what should happen during window close when the + browser is parented to an application-provided top-level OS window. + 1. User clicks the window close button which sends an OS close + notification (e.g. WM_CLOSE on Windows, performClose: on OS-X and + "delete_event" on Linux). + 2. Application's top-level window receives the close notification and: + A. Calls CefBrowserHost::CloseBrowser(false). + B. Cancels the window close. + 3. JavaScript 'onbeforeunload' handler executes and shows the close + confirmation dialog (which can be overridden via + CefJSDialogHandler::OnBeforeUnloadDialog()). + 4. User approves the close. + 5. JavaScript 'onunload' handler executes. + 6. Application's DoClose() handler is called. Application will: + A. Set a flag to indicate that the next close attempt will be allowed. + B. Return false. + 7. CEF sends an OS close notification. + 8. Application's top-level window receives the OS close notification and + allows the window to close based on the flag from #6B. + 9. Browser OS window is destroyed. + 10. Application's CefLifeSpanHandler::OnBeforeClose() handler is called and + the browser object is destroyed. + 11. Application exits by calling CefQuitMessageLoop() if no other browsers + exist. + + the ChromiumWebBrowser control + The browser instance - check if IsDisposed as it's possible when the browser is disposing + For default behaviour return false + + + + Called before a CefBrowser window (either the main browser for , + or one of its children) + + the ChromiumWebBrowser control + The browser instance + + + + Implement this interface to handle events related to browser load status. + The methods of this interface will be called on the CEF UI thread. Blocking in these methods + will likely cause your UI to become unresponsive and/or hang. + + + + + Called when the loading state has changed. This callback will be executed twice + once when loading is initiated either programmatically or by user action, + and once when loading is terminated due to completion, cancellation of failure. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the browser begins loading a frame. + The value will never be empty + Check the method to see if this frame is the main frame. + Multiple frames may be loading at the same time. Sub-frames may start or continue loading after the main frame load has ended. + This method may not be called for a particular frame if the load request for that frame fails. + For notification of overall browser load status use instead. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + Whilst thist may seem like a logical place to execute js, it's called before the DOM has been loaded, implement + as it's called when the underlying V8Context is created + (Only called for the main frame at this stage) + + + + Called when the browser is done loading a frame. + The value will never be empty + Check the method to see if this frame is the main frame. + Multiple frames may be loading at the same time. Sub-frames may start or continue loading after the main frame load has ended. + This method will always be called for all frames irrespective of whether the request completes successfully. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Called when the resource load for a navigation fails or is canceled. + is the error code number, is the error text and + is the URL that failed to load. See net\base\net_error_list.h + for complete descriptions of the error codes. + This method will be called on the CEF UI thread. + Blocking this thread will likely cause your UI to become unresponsive and/or hang. + + the ChromiumWebBrowser control + args + + + + Implement this interface to handle events related to permission requests. + It's important to note that the methods of this interface are called on a CEF UI thread, + which by default is not the same as your application UI thread. + + + + + Called when a page requests permission to access media. + With the Chrome runtime, default handling will display the + permission request UI.With the Alloy runtime, default handling will deny + the request.This method will not be called if the "--enable-media-stream" + command-line switch is used to grant all permissions. + + The ChromiumWebBrowser control + The browser object + The frame object + is the URL origin requesting permission. + is a combination of values that represent the requested permissions + Callback interface used for asynchronous continuation of media access. + Return true and call CefMediaAccessCallback methods either in this method or at a later time to continue or cancel the request. + Return false to proceed with default handling. + + + + + Called when a page should show a permission prompt. + + The ChromiumWebBrowser control + The browser object + Uniquely identifies the prompt. + Is the URL origin requesting permission. + Is a combination of values from that represent the requested permissions. + Callback interface used for asynchronous continuation of permission prompts. + + Return true and call either in this method or at a later time to continue or cancel the request. + Return false to proceed with default handling. + With the Chrome runtime, default handling will display the permission prompt UI. + With the Alloy runtime, default handling is . + + + + + Called when a permission prompt handled via is dismissed. + will be the value passed to + or if + the dialog was dismissed for other reasons such as navigation, browser + closure, etc. This method will not be called if + returned false for . + + The ChromiumWebBrowser control + The browser object + Will match the value that was passed to . + will be the value passed to or if the dialog was dismissed for other reasons such as navigation, browser closure, etc. This method will not be called if returned false for . + + + + Messages sent by the render process can be handled by implementing this + interface. + + + + + OnContextCreated is called in the Render process immediately after a CefV8Context is created. + An IPC message is immediately sent to notify the context has been created (should be safe to execute javascript). + If the page has no javascript then no V8Context will be created and as a result this method will not be called. + Called for every V8Context. To determine if V8Context is from Main frame check + + The ChromiumWebBrowser control + The browser object + The frame. + + + + OnContextReleased is called in the Render process immediately before the CefV8Context is released. + An IPC message is immediately sent to notify the context has been released (cannot execute javascript this point). + If the page had no javascript then the context would not have been created and as a result this method will not be called. + Called for every V8Context. To determine if V8Context is from Main frame check + + The ChromiumWebBrowser control + The browser object + The frame. + + + + Invoked when an element in the UI gains focus (or possibly no + element gains focus; i.e. an element lost focus). + + The ChromiumWebBrowser control + The browser object + The frame object + An object with information about the node (if any) that has focus. + + + + OnUncaughtException is called for global uncaught exceptions in a frame. Execution of this callback is disabled by default. + To enable set CefSettings.UncaughtExceptionStackSize > 0. + + The ChromiumWebBrowser control + The browser object + The frame + The exception object with the message and stacktrace. + + + + Implement this interface to provide handler implementations. The handler + instance will not be released until all objects related to the context have + been destroyed. + + + + + Called immediately after the request context has been initialized. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. + + the request context + + + + Called on the CEF IO thread before a resource request is initiated. + This method will not be called if the client associated with returns a non-NULL value + from for the same request (identified by ). + + represent the source browser of the request, and may be null for requests originating from service workers. + represent the source frame of the request, and may be null for requests originating from service workers. + represents the request contents and cannot be modified in this callback + will be true if the resource request is a navigation + will be true if the resource request is a download + is the origin (scheme + domain) of the page that initiated the request + Set to true to disable default handling of the request, in which case it will need to be handled via or it will be canceled + To allow the resource load to proceed with default handling return null. To specify a handler for the resource return a object. + + + + Implement this interface to handle events related to browser requests. + The methods of this class will be called on the thread indicated. + + + + + Called before browser navigation. + If the navigation is allowed and + will be called. If the navigation is canceled will be called with an ErrorCode + value of . + + the ChromiumWebBrowser control + the browser object + The frame the request is coming from + the request object - cannot be modified in this callback + The value will be true if the browser navigated via explicit user gesture + (e.g. clicking a link) or false if it navigated automatically (e.g. via the DomContentLoaded event). + has the request been redirected + Return true to cancel the navigation or false to allow the navigation to proceed. + + + + Called on the CEF UI thread when the window.document object of the main frame has been created. + + the ChromiumWebBrowser control + the browser object + + + + Called on the UI thread before OnBeforeBrowse in certain limited cases + where navigating a new or different browser might be desirable. This + includes user-initiated navigation that might open in a special way (e.g. + links clicked via middle-click or ctrl + left-click) and certain types of + cross-origin navigation initiated from the renderer process (e.g. + navigating the top-level frame to/from a file URL). + + the ChromiumWebBrowser control + the browser object + The frame object + target url + The value indicates where the user intended to navigate the browser based + on standard Chromium behaviors (e.g. current tab, new tab, etc). + The value will be true if the browser navigated via explicit user gesture + (e.g. clicking a link) or false if it navigated automatically (e.g. via the DomContentLoaded event). + Return true to cancel the navigation or false to allow the navigation + to proceed in the source browser's top-level frame. + + + + Called on the CEF IO thread before a resource request is initiated. + + the ChromiumWebBrowser control + represent the source browser of the request + represent the source frame of the request + represents the request contents and cannot be modified in this callback + will be true if the resource request is a navigation + will be true if the resource request is a download + is the origin (scheme + domain) of the page that initiated the request + to true to disable default handling of the request, in which case it will need to be handled via or it will be canceled + To allow the resource load to proceed with default handling return null. To specify a handler for the resource return a object. If this callback returns null the same method will be called on the associated , if any + + + + Called when the browser needs credentials from the user. + + The ChromiumWebBrowser control + the browser object + is the origin making this authentication request + indicates whether the host is a proxy server + hostname + port number + realm + scheme + Callback interface used for asynchronous continuation of authentication requests. + Return true to continue the request and call when the authentication information is available. Return false to cancel the request. + + + + Called to handle requests for URLs with an invalid SSL certificate. + Return true and call either + in this method or at a later time to continue or cancel the request. + If CefSettings.IgnoreCertificateErrors is set all invalid certificates + will be accepted without calling this method. + + the ChromiumWebBrowser control + the browser object + the error code for this invalid certificate + the url of the request for the invalid certificate + ssl certificate information + Callback interface used for asynchronous continuation of url requests. + If empty the error cannot be recovered from and the request will be canceled automatically. + Return false to cancel the request immediately. Return true and use to + execute in an async fashion. + + + + Called when the browser needs user to select Client Certificate for authentication requests (eg. PKI authentication). + + The ChromiumWebBrowser control + the browser object + indicates whether the host is a proxy server + hostname + port number + List of Client certificates for selection + Callback interface used for asynchronous continuation of client certificate selection for authentication requests. + Return true to continue the request and call ISelectClientCertificateCallback.Select() with the selected certificate for authentication. + Return false to use the default behavior where the browser selects the first certificate from the list. + + + + Called on the CEF UI thread when the render view associated + with browser is ready to receive/handle IPC messages in the render + process. + + The ChromiumWebBrowser control + the browser object + + + + Called when the render process terminates unexpectedly. + + The ChromiumWebBrowser control + the browser object + indicates how the process terminated. + + + + Class used to implement a custom resource handler. The methods of this class will always be called on the CEF IO thread. + Blocking the CEF IO thread will adversely affect browser performance. We suggest you execute your code in a Task (or similar). + To implement async handling, spawn a new Task (or similar), keep a reference to the callback. When you have a + fully populated stream, execute the callback. Once the callback Executes, GetResponseHeaders will be called where you + can modify the response including headers, or even redirect to a new Url. Set your responseLength and headers + Populate the dataOut stream in ReadResponse. For those looking for a sample implementation or upgrading from + a previous version . For those upgrading, inherit from ResourceHandler instead of IResourceHandler + add the override keyword to existing methods e.g. ProcessRequestAsync. + + + + + Open the response stream. + - To handle the request immediately set to true and return true. + - To decide at a later time set to false, return true, and execute + to continue or cancel the request. + - To cancel the request immediately set to true and return false. + This method will be called in sequence but not from a dedicated thread. + For backwards compatibility set to false and return false and the method + will be called. + + request + see main summary + callback + see main summary + + + + Begin processing the request. + + The request object. + The callback used to Continue or Cancel the request (async). + To handle the request return true and call + once the response header information is available + can also be called from inside this method if + header information is available immediately). + To cancel the request return false. + + + + Retrieve response header information. If the response length is not known + set to -1 and ReadResponse() will be called until it + returns false. If the response length is known set + to a positive value and ReadResponse() will be called until it returns + false or the specified number of bytes have been read. + + It is also possible to set to a redirect http status code + and pass the new URL via a Location header. Likewise with it + is valid to set a relative or fully qualified URL as the Location header + value. If an error occured while setting up the request you can call + on to indicate the error condition. + + Use the response object to set the mime type, http status code and other optional header values. + If the response length is not known set responseLength to -1 + To redirect the request to a new URL set this to the new URL. Can be either a relative or fully qualified URL. + + + + Skip response data when requested by a Range header. + Skip over and discard bytesToSkip bytes of response data. + - If data is available immediately set bytesSkipped to the number of of bytes skipped and return true. + - To read the data at a later time set bytesSkipped to 0, return true and execute callback when the data is available. + - To indicate failure set bytesSkipped to < 0 (e.g. -2 for ERR_FAILED) and return false. + This method will be called in sequence but not from a dedicated thread. + + number of bytes to be skipped + + If data is available immediately set bytesSkipped to the number of of bytes skipped and return true. + To read the data at a later time set bytesSkipped to 0, return true and execute callback when the data is available. + + To read the data at a later time set bytesSkipped to 0, + return true and execute callback when the data is available. + See summary + + + + Read response data. If data is available immediately copy up to + dataOut.Length bytes into dataOut, set bytesRead to the number of + bytes copied, and return true. To read the data at a later time keep a + pointer to dataOut, set bytesRead to 0, return true and execute + callback when the data is available (dataOut will remain valid until + the callback is executed). To indicate response completion set bytesRead + to 0 and return false. To indicate failure set bytesRead to < 0 (e.g. -2 + for ERR_FAILED) and return false. This method will be called in sequence + but not from a dedicated thread. + + For backwards compatibility set bytesRead to -1 and return false and the ReadResponse method will be called. + + If data is available immediately copy up to bytes into dataOut. + To indicate response completion set bytesRead to 0 and return false. + set to 0, return true and execute callback when the data is available + (dataOut will remain valid until the callback is executed). If you have no need + of the callback then Dispose of it immediately. + return true or false depending on the criteria, see summary. + + + + Read response data. If data is available immediately copy to + dataOut, set bytesRead to the number of bytes copied, and return true. + To read the data at a later time set bytesRead to 0, return true and call ICallback.Continue() when the + data is available. To indicate response completion return false. + + Stream to write to + Number of bytes copied to the stream + The callback used to Continue or Cancel the request (async). + If data is available immediately copy to dataOut, set bytesRead to the number of bytes copied, + and return true.To indicate response completion return false. + Depending on this size of your response this method may be called multiple times + + + + Request processing has been canceled. + + + + + Implement this interface to handle events related to browser requests. + The methods of this class will be called on the CEF IO thread unless otherwise indicated. + + + + + Called on the CEF IO thread before a resource request is loaded. + To optionally filter cookies for the request return a object. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - can be modified in this callback. + To optionally filter cookies for the request return a ICookieAccessFilter instance otherwise return null. + + + + Called on the CEF IO thread before a resource request is loaded. + To redirect or change the resource load optionally modify . + Modification of the request URL will be treated as a redirect + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - can be modified in this callback. + Callback interface used for asynchronous continuation of url requests. + + Return to continue the request immediately. + Return and call or at a later time to continue or the cancel the request asynchronously. + Return to cancel the request immediately. + + + + + Called on the CEF IO thread before a resource is loaded. To specify a handler for the resource return a object + + The browser UI control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + To allow the resource to load using the default network loader return null otherwise return an instance of with a valid stream + + + + Called on the CEF IO thread when a resource load is redirected. + The parameter will contain the old URL and other request-related information. + The parameter will contain the response that resulted in the + redirect. The parameter will contain the new URL and can be changed if desired. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the response object - cannot be modified in this callback + the new URL and can be changed if desired + + + + Called on the CEF IO thread when a resource response is received. + To allow the resource load to proceed without modification return false. To redirect or + retry the resource load optionally modify and return true. + Modification of the request URL will be treated as a redirect. Requests + handled using the default network loader cannot be redirected in this + callback. + + WARNING: Redirecting using this method is deprecated. Use + OnBeforeResourceLoad or GetResourceHandler to perform redirects. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object + the response object - cannot be modified in this callback + + To allow the resource load to proceed without modification return false. To redirect or + retry the resource load optionally modify and return true. + Modification of the request URL will be treated as a redirect. + Requests handled using the default network loader cannot be redirected in this callback. + + + + + Called on the CEF IO thread to optionally filter resource response content. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the response object - cannot be modified in this callback + Return an IResponseFilter to intercept this response, otherwise return null + + + + Called on the CEF IO thread when a resource load has completed. + This method will be called for all requests, including requests that are + aborted due to CEF shutdown or destruction of the associated browser. In + cases where the associated browser is destroyed this callback may arrive + after the callback for that browser. The + method can be used to test for this situation, and care + should be taken not to call or methods that modify state + (like LoadURL, SendProcessMessage, etc.) if the frame is invalid. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + the response object - cannot be modified in this callback + indicates the load completion status + is the number of response bytes actually read. + + + + Called on the CEF UI thread to handle requests for URLs with an unknown protocol component. + SECURITY WARNING: YOU SHOULD USE THIS METHOD TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR OTHER URL ANALYSIS BEFORE ALLOWING OS EXECUTION. + + The ChromiumWebBrowser control + the browser object - may be null if originating from ServiceWorker or CefURLRequest + the frame object - may be null if originating from ServiceWorker or CefURLRequest + the request object - cannot be modified in this callback + return to true to attempt execution via the registered OS protocol handler, if any. Otherwise return false. + + + + Implement this interface to provide handler implementations. + Methods will be called by the process and/or thread indicated. + + + + + Return the handler for functionality specific to the browser process. + This method is called on multiple threads. + + + + + Provides an opportunity to register custom schemes. Do not keep a reference to the object. + This method is called on the main thread for each process and the registered schemes should be the same across all processes. + + scheme registra + + + + CefSharp interface for CefBrowser. + + + + + Returns True if this object is currently valid. This will return false after + is called. + + + + + Returns the browser host object. This method can only be called in the browser process. + + the browser host object + + + + Returns true if the browser can navigate backwards. + + + + + Navigate backwards. + + + + + Returns true if the browser can navigate forwards. + + + + + Navigate forwards. + + + + + Returns true if the browser is currently loading. + + + + + Request that the browser close. The JavaScript 'onbeforeunload' event will be fired. + + + If forceClose is false the event handler, if any, will be allowed to prompt the user and the + user can optionally cancel the close. If forceClose is true the prompt will not be displayed + and the close will proceed. Results in a call to if + the event handler allows the close or if forceClose is true + See documentation for additional usage information. + + + + + Reload the current page. + + + true a reload is performed ignoring browser cache; false a reload is + performed using files from the browser cache, if available. + + + + + Stop loading the page. + + + + + Returns the globally unique identifier for this browser. + + + + + Returns true if this object is pointing to the same handle as that object. + + compare browser instances + returns true if the same instance + + + + Returns true if the window is a popup window. + + + + + Returns true if a document has been loaded in the browser. + + + + + Returns the main (top-level) frame for the browser window. + Returns null if there is currently no MainFrame. + + + + + Returns the focused frame for the browser window or null. + + + + + Returns the frame with the specified identifier, or NULL if not found. + + identifier + frame or null + + + + Returns the frame with the specified name, or NULL if not found. + + name of frame + frame or null + + + + Returns the number of frames that currently exist. + + the number of frames + + + + Returns the identifiers of all existing frames. + + list of frame identifiers + + + + Returns the names of all existing frames. + + frame names + + + + Gets a value indicating whether the browser has been disposed of. + + + + + Interface used to represent the browser process aspects of a browser window. + They may be called on any thread in that process unless otherwise indicated in the comments. + + + + + Add the specified word to the spelling dictionary. + + custom word to be added to dictionary + + + + Request that the browser close. The JavaScript 'onbeforeunload' event will be fired. + + + If forceClose is false the event handler, if any, will be allowed to prompt the user and the + user can optionally cancel the close. If forceClose is true the prompt will not be displayed + and the close will proceed. Results in a call to if + the event handler allows the close or if forceClose is true + See documentation for additional usage information. + + + + + Helper for closing a browser. Call this method from the top-level window close handler. Internally this calls CloseBrowser(false) if the close has not yet been initiated. This method returns false while the close is pending and true after the close has completed. + See and documentation for additional usage information. This method must be called on the CEF UI thread. + + + This method returns false while the close is pending and true after the close has completed + + + + + Explicitly close the developer tools window if one exists for this browser instance. + + + + + Returns true if this browser currently has an associated DevTools browser. + Must be called on the CEF UI thread. + + + + + Send a method call message over the DevTools protocol. must be a + UTF8-encoded JSON dictionary that contains "id" (int), "method" (string) + and "params" (dictionary, optional) values. See the DevTools protocol + documentation at https://chromedevtools.github.io/devtools-protocol/ for + details of supported methods and the expected "params" dictionary contents. + will be copied if necessary. This method will return true if + called on the CEF UI thread and the message was successfully submitted for + validation, otherwise false. Validation will be applied asynchronously and + any messages that fail due to formatting errors or missing parameters may + be discarded without notification. Prefer ExecuteDevToolsMethod if a more + structured approach to message formatting is desired. + + Every valid method call will result in an asynchronous method result or + error message that references the sent message "id". Event messages are + received while notifications are enabled (for example, between method calls + for "Page.enable" and "Page.disable"). All received messages will be + delivered to the observer(s) registered with AddDevToolsMessageObserver. + See documentation for details + of received message contents. + + Usage of the SendDevToolsMessage, ExecuteDevToolsMethod and + AddDevToolsMessageObserver methods does not require an active DevTools + front-end or remote-debugging session. Other active DevTools sessions will + continue to function independently. However, any modification of global + browser state by one session may not be reflected in the UI of other + sessions. + + Communication with the DevTools front-end (when displayed) can be logged + for development purposes by passing the + `--devtools-protocol-log-file=<path>` command-line flag. + + must be a UTF8-encoded JSON dictionary that contains "id" (int), "method" (string) + and "params" (dictionary, optional) values. See comments above for further details. + returns true if called on the CEF UI thread and the message was successfully submitted for + validation, otherwise false. + + + + Execute a method call over the DevTools protocol. This is a more structured + version of SendDevToolsMessage. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + See the SendDevToolsMessage documentation for additional usage information. + + is an incremental number that uniquely identifies the message (pass 0 to have the next number assigned + automatically based on previous values) + is the method name + are the method parameters represented as a JSON string, + which may be empty. + return the assigned message Id if called on the CEF UI thread and the message was + successfully submitted for validation, otherwise 0 + + + + Execute a method call over the DevTools protocol. This is a more structured + version of SendDevToolsMessage. + See the DevTools protocol documentation at https://chromedevtools.github.io/devtools-protocol/ for details + of supported methods and the expected dictionary contents. + See the SendDevToolsMessage documentation for additional usage information. + + is an incremental number that uniquely identifies the message (pass 0 to have the next number assigned + automatically based on previous values) + is the method name + are the method parameters represented as a dictionary, + which may be empty. + return the assigned message Id if called on the CEF UI thread and the message was + successfully submitted for validation, otherwise 0 + + + + Returns the next unique message id which can be used in or + . + + The next unique message id. + + + + Add an observer for DevTools protocol messages (method results and events). + The observer will remain registered until the returned Registration object + is destroyed. See the SendDevToolsMessage documentation for additional + usage information. + + DevTools observer + The observer will remain registered until the returned IRegistration object is Disposed. + + + + Call this method when the user drags the mouse into the web view (before calling //). + + + + + Call this method each time the mouse is moved across the web view during a drag operation (after calling and before calling /). + This method is only used when window rendering is disabled. + + + + + Call this method when the user completes the drag operation by dropping the object onto the web view (after calling ). + The object being dropped is , given as an argument to the previous call. + This method is only used when window rendering is disabled. + + + + + Call this method when the drag operation started by a call has ended either in a drop or by being cancelled. + If the web view is both the drag source and the drag target then all DragTarget* methods should be called before DragSource* methods. + This method is only used when window rendering is disabled. + + x mouse coordinate relative to the upper-left corner of the view. + y mouse coordinate relative to the upper-left corner of the view. + Drag Operations mask + + + + Call this method when the user drags the mouse out of the web view (after calling ). + This method is only used when window rendering is disabled. + + + + + Call this method when the drag operation started by a call has completed. + This method may be called immediately without first calling DragSourceEndedAt to cancel a drag operation. + If the web view is both the drag source and the drag target then all DragTarget* methods should be called before DragSource* mthods. + This method is only used when window rendering is disabled. + + + + + Search for . + + text to search for + indicates whether to search forward or backward within the page + indicates whether the search should be case-sensitive + indicates whether this is the first request or a follow-up + The instance, if any, will be called to report find results. + + + + Returns the extension hosted in this browser or null if no extension is hosted. See for details. + + + + + Retrieve the window handle of the browser that opened this browser. + + The handler + + + + Retrieve the window handle for this browser. + + The handler + + + + Gets the current zoom level. The default zoom level is 0.0. This method can only be called on the CEF UI thread. + + zoom level (default is 0.0) + + + + Get the current zoom level. The default zoom level is 0.0. This method executes GetZoomLevel on the CEF UI thread + in an async fashion. + + a that when executed returns the zoom level as a double. + + + + Invalidate the view. The browser will call CefRenderHandler::OnPaint asynchronously. + This method is only used when window rendering is disabled (OSR). + + indicates which surface to re-paint either View or Popup. + + + + Returns true if this browser is hosting an extension background script. Background hosts do not have a window and are not displayable. + See for details. + + Returns true if this browser is hosting an extension background script. + + + + Begins a new composition or updates the existing composition. Blink has a + special node (a composition node) that allows the input method to change + text without affecting other DOM nodes. + + This method may be called multiple times as the composition changes. When + the client is done making changes the composition should either be canceled + or completed. To cancel the composition call ImeCancelComposition. To + complete the composition call either ImeCommitText or + ImeFinishComposingText. Completion is usually signaled when: + The client receives a WM_IME_COMPOSITION message with a GCS_RESULTSTR + flag (on Windows). + This method is only used when window rendering is disabled. (WPF and OffScreen) + + is the optional text that + will be inserted into the composition node + is an optional set + of ranges that will be underlined in the resulting text. + is an optional range of the existing text that will be replaced. (MAC OSX ONLY) + is an optional range of the resulting text that + will be selected after insertion or replacement. + + + + Completes the existing composition by optionally inserting the specified + text into the composition node. + This method is only used when window rendering is disabled. (WPF and OffScreen) + + text that will be committed + is an optional range of the existing text that will be replaced. (MAC OSX ONLY) + is where the cursor will be positioned relative to the current cursor position. (MAC OSX ONLY) + + + + Completes the existing composition by applying the current composition node + contents. See comments on ImeSetComposition for usage. + This method is only used when window rendering is disabled. (WPF and OffScreen) + + If keepSelection is false the current selection, if any, will be discarded. + + + + Cancels the existing composition and discards the composition node + contents without applying them. See comments on ImeSetComposition for + usage. + This method is only used when window rendering is disabled. (WPF and OffScreen) + + + + + Notify the browser that the window hosting it is about to be moved or resized. + This will dismiss any existing popups (dropdowns). + + + + + Send a notification to the browser that the screen info has changed. + The browser will then call CefRenderHandler::GetScreenInfo to update the screen information with the new values. + This simulates moving the webview window from one display to another, or changing the properties of the current display. + This method is only used when window rendering is disabled. + + + + + Print the current browser contents. + + + + + Asynchronously prints the current browser contents to the Pdf file specified. + The caller is responsible for deleting the file when done. + + Output file location. + Print Settings, can be null + Callback executed when printing complete + + + + If a misspelled word is currently selected in an editable node calling this method will replace it with the specified word. + + word to be replaced + + + + Call to run a file chooser dialog. Only a single file chooser dialog may be pending at any given time. + The dialog will be initiated asynchronously on the CEF UI thread. + + represents the type of dialog to display + to the title to be used for the dialog and may be empty to show the default title ("Open" or "Save" depending on the mode) + is the path with optional directory and/or file name component that will be initially selected in the dialog + are used to restrict the selectable file types and may any combination of (a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), (b) individual file extensions (e.g. ".txt" or ".png"), or (c) combined description and file extension delimited using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg") + will be executed after the dialog is dismissed or immediately if another dialog is already pending. + + + + Returns the request context for this browser. + + + + + Issue a BeginFrame request to Chromium. + Only valid when is set to true. + + + + + Send a capture lost event to the browser. + + + + + Send a focus event to the browser. . (Used for OSR Rendering e.g. WPF or OffScreen) + + set focus + + + + Send a key event to the browser. + + represents keyboard event + + + + Send key event to browser based on operating system message + + message + wParam + lParam + + + + Send a mouse click event to the browser. + + mouse event - x, y and modifiers + Mouse ButtonType + mouse up + click count + + + + Send a mouse wheel event to the browser. + + mouse event - x, y and modifiers + Movement delta for X direction. + movement delta for Y direction. + + + + Send a touch event to the browser. + WPF and OffScreen browsers only + + touch event + + + + Set accessibility state for all frames. If accessibilityState is Default then accessibility will be disabled by default + and the state may be further controlled with the "force-renderer-accessibility" and "disable-renderer-accessibility" + command-line switches. If accessibilityState is STATE_ENABLED then accessibility will be enabled. + If accessibilityState is STATE_DISABLED then accessibility will be completely disabled. For windowed browsers + accessibility will be enabled in Complete mode (which corresponds to kAccessibilityModeComplete in Chromium). + In this mode all platform accessibility objects will be created and managed by Chromium's internal implementation. + The client needs only to detect the screen reader and call this method appropriately. For example, on Windows the + client can handle WM_GETOBJECT with OBJID_CLIENT to detect accessibility readers. For windowless browsers accessibility + will be enabled in TreeOnly mode (which corresponds to kAccessibilityModeWebContentsOnly in Chromium). In this mode + renderer accessibility is enabled, the full tree is computed, and events are passed to IAccessibiltyHandler, + but platform accessibility objects are not created. The client may implement platform accessibility objects using + IAccessibiltyHandler callbacks if desired. + + may be default, enabled or disabled. + + + + Enable notifications of auto resize via IDisplayHandler.OnAutoResize. Notifications are disabled by default. + + enable auto resize + minimum size + maximum size + + + + Set whether the browser is focused. (Used for Normal Rendering e.g. WinForms) + + set focus + + + + Change the zoom level to the specified value. Specify 0.0 to reset the zoom level. + If called on the CEF UI thread the change will be applied immediately. + Otherwise, the change will be applied asynchronously on the UI thread. + + zoom level + + + + Open developer tools in its own window. If inspectElementAtX and/or inspectElementAtY are specified then + the element at the specified (x,y) location will be inspected. + + window info used for showing dev tools + x coordinate (used for inspectElement) + y coordinate (used for inspectElement) + + + + Download the file at url using . + + url to download + + + + Cancel all searches that are currently going on. + + clear the selection + + + + Send a mouse move event to the browser, coordinates, + + mouse information, x and y values are relative to upper-left corner of view + mouse leave + + + + Notify the browser that it has been hidden or shown. + Layouting and rendering notification will stop when the browser is hidden. + This method is only used when window rendering is disabled (WPF/OffScreen). + + if true the browser will be notified that it was hidden. + + + + Notify the browser that the widget has been resized. + The browser will first call CefRenderHandler::GetViewRect to get the new size and then call CefRenderHandler::OnPaint asynchronously with the updated regions. + This method is only used when window rendering is disabled. + + + + + Retrieve a snapshot of current navigation entries as values sent to the + specified visitor. + + visitor + If true only the current navigation + entry will be sent, otherwise all navigation entries will be sent. + + + + Returns the current visible navigation entry for this browser. This method + can only be called on the CEF UI thread which by default is not the same + as your application UI thread. + + the current navigation entry + + + + Gets/sets the maximum rate in frames per second (fps) that CefRenderHandler:: + OnPaint will be called for a windowless browser. The actual fps may be + lower if the browser cannot generate frames at the requested rate. The + minimum value is 1 and the maximum value is 60 (default 30). This method + can only be called on the UI thread. Can also be set at browser creation + via BrowserSettings.WindowlessFrameRate. + + + + + Returns true if window rendering is disabled. + + + + + Set whether the browser's audio is muted. + + true or false + + + + Returns true if the browser's audio is muted. + This method can only be called on the CEF UI thread. + + + + + Gets a value indicating whether the browserHost has been disposed of. + + + + + Interface representing browser initialization settings. + + + + + StandardFontFamily + + + + + FixedFontFamily + + + + + SerifFontFamily + + + + + SansSerifFontFamily + + + + + CursiveFontFamily + + + + + FantasyFontFamily + + + + + DefaultFontSize + + + + + DefaultFixedFontSize + + + + + MinimumFontSize + + + + + MinimumLogicalFontSize + + + + + Default encoding for Web content. If empty "ISO-8859-1" will be used. Also + configurable using the "default-encoding" command-line switch. + + + + + Controls the loading of fonts from remote sources. Also configurable using + the "disable-remote-fonts" command-line switch. + + + + + Controls whether JavaScript can be executed. (Used to Enable/Disable javascript) + Also configurable using the "disable-javascript" command-line switch. + + + + + Controls whether JavaScript can be used to close windows that were not + opened via JavaScript. JavaScript can still be used to close windows that + were opened via JavaScript. Also configurable using the + "disable-javascript-close-windows" command-line switch. + + + + + Controls whether JavaScript can access the clipboard. Also configurable + using the "disable-javascript-access-clipboard" command-line switch. + + + + + Controls whether DOM pasting is supported in the editor via + execCommand("paste"). The |javascript_access_clipboard| setting must also + be enabled. Also configurable using the "disable-javascript-dom-paste" + command-line switch. + + + + + Controls whether image URLs will be loaded from the network. A cached image + will still be rendered if requested. Also configurable using the + "disable-image-loading" command-line switch. + + + + + Controls whether standalone images will be shrunk to fit the page. Also + configurable using the "image-shrink-standalone-to-fit" command-line + switch. + + + + + Controls whether text areas can be resized. Also configurable using the + "disable-text-area-resize" command-line switch. + + + + + Controls whether the tab key can advance focus to links. Also configurable + using the "disable-tab-to-links" command-line switch. + + + + + Controls whether local storage can be used. Also configurable using the + "disable-local-storage" command-line switch. + + + + + Controls whether databases can be used. Also configurable using the + "disable-databases" command-line switch. + + + + + Controls whether WebGL can be used. Note that WebGL requires hardware + support and may not work on all systems even when enabled. Also + configurable using the "disable-webgl" command-line switch. + + + + + Opaque background color used for the browser before a document is loaded + and when no document color is specified. By default the background color + will be the same as CefSettings.BackgroundColor. Only the RGB compontents + of the specified value will be used. The alpha component must greater than + 0 to enable use of the background color but will be otherwise ignored. + + + + + Comma delimited ordered list of language codes without any whitespace that + will be used in the "Accept-Language" HTTP header. May be overridden on a + per-browser basis using the CefBrowserSettings.AcceptLanguageList value. + If both values are empty then "en-US,en" will be used. Can be overridden + for individual RequestContext instances via the + RequestContextSettings.AcceptLanguageList value. + + + + + The maximum rate in frames per second (fps) that CefRenderHandler::OnPaint + will be called for a windowless browser. The actual fps may be lower if + the browser cannot generate frames at the requested rate. The minimum + value is 1 and the maximum value is 60 (default 30). This value can also be + changed dynamically via IBrowserHost.SetWindowlessFrameRate. + + + + + Gets a value indicating if the browser settings has been disposed. + + + + + Gets a value indicating if the browser settings instance was created internally by CefSharp. + Instances created by CefSharp will be Disposed of after use. To control the lifespan yourself + create an set BrowserSettings yourself. + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Interface for common events/methods/properties for ChromiumWebBrowser and popup host implementations. + + + + + + Event handler for receiving Javascript console messages being sent from web pages. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. It is unwise to block on this thread for any length of time as your browser will become unresponsive and/or hang.. + To access UI elements you'll need to Invoke/Dispatch onto the UI Thread. + (The exception to this is when you're running with settings.MultiThreadedMessageLoop = false, then they'll be the same thread). + + + + + Event handler for changes to the status message. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. It is unwise to block on this thread for any length of time as your browser will become unresponsive and/or hang. + To access UI elements you'll need to Invoke/Dispatch onto the UI Thread. + (The exception to this is when you're running with settings.MultiThreadedMessageLoop = false, then they'll be the same thread). + + + + + Event handler that will get called when the browser begins loading a frame. Multiple frames may be loading at the same + time. Sub-frames may start or continue loading after the main frame load has ended. This method may not be called for a + particular frame if the load request for that frame fails. For notification of overall browser load status use + OnLoadingStateChange instead. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. It is unwise to block on this thread for any length of time as your browser will become unresponsive and/or hang.. + To access UI elements you'll need to Invoke/Dispatch onto the UI Thread. + + Whilst this may seem like a logical place to execute js, it's called before the DOM has been loaded, implement + as it's called when the underlying V8Context is created + + + + + Event handler that will get called when the browser is done loading a frame. Multiple frames may be loading at the same + time. Sub-frames may start or continue loading after the main frame load has ended. This method will always be called + for all frames irrespective of whether the request completes successfully. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. It is unwise to block on this thread for any length of time as your browser will become unresponsive and/or hang.. + To access UI elements you'll need to Invoke/Dispatch onto the UI Thread. + + + + + Event handler that will get called when the resource load for a navigation fails or is canceled. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. It is unwise to block on this thread for any length of time as your browser will become unresponsive and/or hang.. + To access UI elements you'll need to Invoke/Dispatch onto the UI Thread. + + + + + Event handler that will get called when the Loading state has changed. + This event will be fired twice. Once when loading is initiated either programmatically or + by user action, and once when loading is terminated due to completion, cancellation of failure. + It's important to note this event is fired on a CEF UI thread, which by default is not the same as your application UI + thread. It is unwise to block on this thread for any length of time as your browser will become unresponsive and/or hang.. + To access UI elements you'll need to Invoke/Dispatch onto the UI Thread. + + + + + Loads the specified in the Main Frame. + Same as calling + + The URL to be loaded. + + This is exactly the same as calling Load(string), it was added + as the method name is more meaningful and easier to discover + via Intellisense. + + + + + Load the in the main frame of the browser + + url to load + + A that can be awaited to load the and return the HttpStatusCode and . + A HttpStatusCode equal to 200 and is considered a success. + + + + + This resolves when the browser navigates to a new URL or reloads. + It is useful for when you run code which will indirectly cause the browser to navigate. + A common use case would be when executing javascript that results in a navigation. e.g. clicks a link + This must be called before executing the action that navigates the browser. It may not resolve correctly + if called after. + + + Usage of the History API to change the URL is considered a navigation + + optional timeout, if not specified defaults to five(5) seconds. + optional CancellationToken + Task which resolves when has been called with false. + or when is called to signify a load failure. + + + + + + + + + + A flag that indicates whether the WebBrowser is initialized (true) or not (false). + + true if this instance is browser initialized; otherwise, false. + In the WPF control there are two IsBrowserInitialized properties, the ChromiumWebBrowser.IsBrowserInitialized + property is implemented as a Dependency Property and fully supports data binding. This property + can only be called from the UI Thread. The explicit IWebBrowser.IsBrowserInitialized interface implementation that + can be called from any Thread. + + + + A flag that indicates whether the WebBrowser has been disposed () or not () + + if this instance is disposed; otherwise, + + + + A flag that indicates whether the control is currently loading one or more web pages (true) or not (false). + + true if this instance is loading; otherwise, false. + In the WPF control, this property is implemented as a Dependency Property and fully supports data + binding. + + + + A flag that indicates whether the state of the control current supports the GoBack action (true) or not (false). + + true if this instance can go back; otherwise, false. + In the WPF control, this property is implemented as a Dependency Property and fully supports data + binding. + + + + A flag that indicates whether the state of the control currently supports the GoForward action (true) or not (false). + + true if this instance can go forward; otherwise, false. + In the WPF control, this property is implemented as a Dependency Property and fully supports data + binding. + + + + The address (URL) which the browser control is currently displaying. + Will automatically be updated as the user navigates to another page (e.g. by clicking on a link). + + The address. + In the WPF control, this property is implemented as a Dependency Property and fully supports data + binding. + + + + Attempts to give focus to the IWebBrowser control. + + true if keyboard focus and logical focus were set to this element; false if only logical focus + was set to this element, or if the call to this method did not force the focus to change. + + + + Returns the current IBrowser Instance or null. + is the the underlying CefBrowser + instance and provides access to frames/browserhost etc. + + + + + Wrapper for the CefContextMenuParams + + + + + Returns the Y coordinate of the mouse where the context menu was invoked. + Coords are relative to the associated RenderView's origin. + + + + + Returns the X coordinate of the mouse where the context menu was invoked. + Coords are relative to the associated RenderView's origin. + + + + + Returns flags representing the type of node that the context menu was invoked on. + + + + + Returns the URL of the link, if any, that encloses the node that the + context menu was invoked on. + + + + + Returns the link URL, if any, to be used ONLY for "copy link address". We + don't validate this field in the frontend process. + + + + + Returns the source URL, if any, for the element that the context menu was + invoked on. Example of elements with source URLs are img, audio, and video. + + + + + Returns true if the context menu was invoked on an image which has + non-empty contents. + + + + + Returns the URL of the top level page that the context menu was invoked on. + + + + + Returns the URL of the subframe that the context menu was invoked on. + + + + + Returns the character encoding of the subframe that the context menu was + invoked on. + + + + + Returns the type of context node that the context menu was invoked on. + + + + + Returns flags representing the actions supported by the media element, if + any, that the context menu was invoked on. + + + + + Returns the text of the selection, if any, that the context menu was + invoked on. + + + + + Returns the text of the misspelled word, if any, that the context menu was + invoked on. + + + + + Returns a list of strings from the spell check service for the misspelled word if there is one. + + + + + Returns true if the context menu was invoked on an editable node. + + + + + Returns true if the context menu was invoked on an editable node where + spell-check is enabled. + + + + + Returns flags representing the actions supported by the editable node, if + any, that the context menu was invoked on. + + Returns ContextMenuEditState as flags + + + + Returns true if the context menu contains items specified by the renderer + process. + + + + + Gets a value indicating whether the object has been disposed of. + + + + + Used for managing cookies. The methods may be called on any thread unless otherwise indicated. + + + + + Delete all cookies that match the specified parameters. + If both and values are specified all host and domain cookies matching both will be deleted. + If only is specified all host cookies (but not domain cookies) irrespective of path will be deleted. + If is empty all cookies for all hosts and domains will be deleted. + Cookies can alternately be deleted using the Visit*Cookies() methods. + + The cookie URL. + The name of the cookie. + If non-NULL it will be executed asynchronously on the CEF UI thread after the cookies have been deleted. + Returns false if a non-empty invalid URL is specified or if cookies cannot be accessed; otherwise, true. + + + + Sets a cookie given a valid URL and explicit user-provided cookie attributes. This function expects each attribute to be well-formed. It will check for disallowed + characters (e.g. the ';' character is disallowed within the cookie value attribute) and fail without setting the cookie if such characters are found. + This method will be executed on the CEF UI thread in an async fashion, to be notified upon completion implement + and pass in as + + The cookie URL + The cookie + If non-NULL it will be executed asynchronously on the CEF UI thread after the cookie has been set. + Returns false if an invalid URL is specified or if cookies cannot be accessed. + + + + Visit all cookies on the UI thread. The returned cookies are ordered by longest path, then by earliest creation date. + + A user-provided Cookie Visitor implementation. + Returns false if cookies cannot be accessed; otherwise, true. + + + + Visit a subset of cookies on the CEF UI thread. + The results are filtered by the given url scheme, host, domain and path. + The returned cookies are ordered by longest path, then by earliest creation date. + + The URL to use for filtering a subset of the cookies available. + If true HTTP-only cookies will also be included in the results. + A user-provided Cookie Visitor implementation. + Returns false if cookies cannot be accessed; otherwise, true. + + + + Flush the backing store (if any) to disk + This method will be executed on the CEF UI thread in an async fashion, to be notified upon completion implement + and pass in as + + If non-NULL it will be executed asynchronously on the CEF UI thread after the flush is complete. + Returns false if cookies cannot be accessed. + + + + Returns true if disposed + + + + + Represents the tag name and attribute data belonging to a node in the + browser's DOM. + + + + + Get the value of an attribute. + + + The name of the attribute value to get. + + + The attribute value if the name exists in the DomNode's attributes. + Null if the name does not exist. + + + + + The name of the HTML element. + + + + + Get a read only list of the attribute names. + + + + + Determine if the DomNode has the requested attribute. + + + The name of the attribute value. + + + True if the attribute exists in the DomNode, false if it does not. + + + + + Used to represent drag data. + + + + + Gets a copy of the current drag data + + a clone of the current object + + + + Returns true if this object is read-only. + + + + + Return the name of the file being dragged out of the browser window. + + + + + Retrieve the list of file names that are being dragged into the browser window + + + + + Return the base URL that the fragment came from. This value is used for resolving relative URLs and may be empty. + + + + + Return the text/html fragment that is being dragged. + + + + + Return the plain text fragment that is being dragged. + + + + + Returns true if an image representation of drag data is available. + + + + + Get the image representation of drag data. + May return NULL if no image representation is available. + + + + + Get the image hotspot (drag start location relative to image dimensions). + + + + + Return the metadata, if any, associated with the link being dragged. + + + + + Return the title associated with the link being dragged. + + + + + Return the link URL that is being dragged. + + + + + Returns true if the drag data is a file. + + + + + Returns true if the drag data is a text or html fragment. + + + + + Returns true if the drag data is a link + + + + + Add a file that is being dragged into the webview. + + File Path + Optional Display Name + + + + Reset the file contents. You should do this before calling + CefBrowserHost::DragTargetDragEnter as the web view does not allow us to + drag in this kind of data. + + + + + Write the contents of the file being dragged out of the web view into the provided + For a suggested filename check the property + + Stream data is to be written to. If null this method will return the + size of the file contents in bytes. + Returns the number of bytes written to the stream + + + + Clear list of filenames. + + + + + Gets a value indicating whether the object has been disposed of. + + + + + Object representing an extension. Methods may be called on any thread unless otherwise indicated. + + + + + Returns the unique extension identifier. This is calculated based on the + extension public key, if available, or on the extension path. See + https://developer.chrome.com/extensions/manifest/key for details. + + + + + Returns the absolute path to the extension directory on disk. This value + will be prefixed with PK_DIR_RESOURCES if a relative path was passed to + IRequestContext.LoadExtension. + + + + + Returns the extension manifest contents as a CefDictionaryValue object. See + https://developer.chrome.com/extensions/manifest for details. + + + + + Returns true if this object is the same extension as that object. + Extensions are considered the same if identifier, path and loader context + match. + + extension to compare + return true if the same extension + + + + Returns the request context that loaded this extension. Will return NULL + for internal extensions or if the extension has been unloaded. See the + CefRequestContext::LoadExtension documentation for more information about + loader contexts. Must be called on the CEF UI thread. + + + + + Returns true if this extension is currently loaded. Must be called on the + CEF UI thread. + + + + + Unload this extension if it is not an internal extension and is currently + loaded. Will result in a call to IExtensionHandler.OnExtensionUnloaded + on success. + + + + + This interface represents a CefFrame object (i.e. a HTML frame) + + + + + True if this object is currently attached to a valid frame. + + + + + Execute undo in this frame. + + + + + Execute redo in this frame. + + + + + Execute cut in this frame. + + + + + Execute copy in this frame. + + + + + Execute paste in this frame. + + + + + Execute delete in this frame. + + + + + Execute select all in this frame. + + + + + Save this frame's HTML source to a temporary file and open it in the + default text viewing application. This method can only be called from the + browser process. + + + + + Retrieve this frame's HTML source as a string sent to the specified visitor. + + + a that when executed returns this frame's HTML source as a string. + + + + + Retrieve this frame's HTML source as a string sent to the specified visitor. + Use the method for a Task based async wrapper + + visitor will receive string values asynchronously + + + + Retrieve this frame's display text as a string sent to the specified visitor. + + + a that when executed returns the frame's display text as a string. + + + + + Retrieve this frame's display text as a string sent to the specified visitor. + Use the method for a Task based async wrapper + + visitor will receive string values asynchronously + + + + Load the custom request. + WARNING: This method will fail with "bad IPC message" reason + INVALID_INITIATOR_ORIGIN (213) unless you first navigate to the + request origin using some other mechanism (LoadURL, link click, etc). + + request to be loaded in the frame + + + + Load the specified url. + + url to be loaded in the frame + + + + Execute a string of JavaScript code in this frame. + + Javascript to execute + is the URL where the script in question can be found, if any. + The renderer may request this URL to show the developer the source of the error. + is the base line number to use for error reporting. + + + + Execute some Javascript code in the context of this WebBrowser, and return the result of the evaluation + in an Async fashion + + The Javascript code that should be executed. + is the URL where the script in question can be found, if any. + is the base line number to use for error reporting. + The timeout after which the Javascript code execution should be aborted. + When true the script is wrapped in a self executing function. + Make sure to use a return statement in your javascript. e.g. (function () { return 42; })(); + When false don't include a return statement e.g. 42; + + A Task that can be awaited to perform the script execution + + + + Returns true if this is the main (top-level) frame. + + + + + Returns true if this is the focused frame. + + + + + Returns the name for this frame. If the frame has an assigned name (for + example, set via the iframe "name" attribute) then that value will be + returned. Otherwise a unique name will be constructed based on the frame + parent hierarchy. The main (top-level) frame will always have an empty name + value. + + + + + Returns the globally unique identifier for this frame or < 0 if the underlying frame does not yet exist. + + + + + Returns the parent of this frame or NULL if this is the main (top-level) frame. + + + + + Returns the URL currently loaded in this frame. + + + + + Returns the browser that this frame belongs to. + + + + + Gets a value indicating whether the frame has been disposed of. + + + + + Create a custom request for use with + + Initialize the PostData object when creating this request + A new instance of the request + + + + Create a new URL request that will be treated as originating from this frame + and the associated browser. This request may be intercepted by the client via + or . + Use IUrlRequest.Create instead if you do not want the request to have + this association, in which case it may be handled differently (see documentation on that method). + + Requests may originate from both the browser process and the render process. + For requests originating from the browser process: - POST data may only contain a single element + of type PDE_TYPE_FILE or PDE_TYPE_BYTES. + For requests originating from the render process: - POST data may only contain a single element of type PDE_TYPE_BYTES. + - If the response contains Content-Disposition or Mime-Type header values that would not normally be rendered then + the response may receive special handling inside the browser + for example, via the file download code path instead of the URL request code path). + + The request object will be marked as read-only after calling this method. + + the web request + the client + + + + Container for a single image represented at different scale factors. + All image representations should be the same size in density independent pixel (DIP) units. + For example, if the image at scale factor 1.0 is 100x100 pixels then the image at scale factor 2.0 should be 200x200 pixels -- both images will display with a DIP size of 100x100 units. + The methods of this class must be called on the browser process UI thread. + + + + + Returns the bitmap representation that most closely matches scaleFactor. + + scale factor + color type + alpha type + pixel width + pixel height + A stream represending the bitmap or null. + + + + Returns the JPEG representation that most closely matches scaleFactor. + + scale factor + image quality + pixel width + pixel height + A stream representing the JPEG or null. + + + + Returns the PNG representation that most closely matches scaleFactor. + + scale factor + is the PNG transparent + pixel width + pixel height + A stream represending the PNG or null. + + + + Returns information for the representation that most closely matches scaleFactor. + + scale factor + actual scale factor + pixel width + pixel height + return if information found for scale factor + + + + Returns the image height in density independent pixel(DIP) units. + + + + + Returns true if this image contains a representation for scaleFactor. + + + + + + + Returns true if this Image is empty. + + + + + Returns true if this Image and that Image share the same underlying storage. + + image to compare + returns true if share same underlying storage + + + + Removes the representation for scaleFactor. + + + true for success + + + + Returns the image width in density independent pixel(DIP) units. + + + + + Javascript object repository, object are registered for binding + One repository per ChromiumWebBrowser instance + + + + + Javascript Binding Settings + + + + + Converted .Net method/property/field names to the name that + will be used in Javasript. Used for when .Net naming conventions + differ from Javascript naming conventions. + + + + binding options, by default method/property names are camelCased, you can control this + and other advanced options though this class. + + + + UnRegister all the currently bound objects from the repository. If you unregister an object that is currently + bound in JavaScript then the method/property calls will fail. + + + + + UnRegister a bound object from the repository. If you unregister an object that is currently + bound in JavaScript then the method/property calls will fail. + + object name + returns true if the object was successfully unbound otherwise false. + + + + Has bound objects + + + + + Is object bound + + name + true if object with matching name bound + + + + Event handler is called when an object with a given name is requested for binding and is not yet + registered with the repository. Use + to register objects (using + + + + + Event handler is triggered when a object has been successfully bound in javascript + + + + + Event handler is triggered when multiple objects has been successfully bound in javascript, this event only + contains the names of objects successfully bound. + + + + + Supports creation and modification of menus. See for the command ids that have default implementations. + All user-defined command ids should be between and . + The methods of this class can only be accessed on the CEF UI thread, which by default is not the same as your application UI thread. + + + + + Returns the number of items in this menu. + + + + + Remove all menu items. Can be used to disable the context menu. Returns true on success. + + Returns true on success + + + + Returns the label at the specified index or empty if not found due to + invalid range or the index being a separator. + + specified index + Label or empty if not found due to invalid range or the index being a separator. + + + + Returns the command id at the specified index or -1 if not found due to invalid range or the index being a separator. + + the index + Command or -1 if not found due to invalid range or the index being a separator. + + + + Removes the item with the specified commandId. + + the command Id + Returns true on success + + + + Add an item to the menu. + + the command Id + the label of the item + Returns true on success. + + + + Add a separator to the menu. + + Returns true on success. + + + + Add a check item to the menu. + + the command Id + the label of the item + Returns true on success. + + + + Add a radio item to the menu. Only a single item with the specified groupId can be checked at a time. + + the command Id + the label of the item + the group id + Returns true on success. + + + + Add a sub-menu to the menu. The new sub-menu is returned. + + the command Id + the label of the item + Returns the newly created . + + + + Insert a separator in the menu at the specified index. + + index + Returns true on success. + + + + Insert an item in the menu at the specified index. + + index + the command Id + the label of the item + Returns true on success. + + + + Insert a check item in the menu at the specified index. + + index + the command Id + the label of the item + Returns true on success. + + + + Insert a radio item in the menu at the specified index. + Only a single item with the specified groupId can be checked at a time. + + index + the command Id + the label of the item + the group id + Returns true on success. + + + + Insert a sub-menu in the menu at the specified index. + + index + the command Id + the label of the item + Returns the newly created . + + + + Removes the item at the specified index. + + index + Returns true on success. + + + + Returns the index associated with the specified commandId or -1 if not found due to the command id not existing in the menu. + + the command Id + Returns the index associated with the specified commandId or -1 if not found due to the command id not existing in the menu. + + + + Sets the command id at the specified index. + + index + the command Id + Returns true on success. + + + + Returns the label for the specified commandId or empty if not found. + + the command Id + Returns the label for the specified commandId or empty if not found. + + + + Sets the label for the specified commandId. + + the command Id + the label + Returns true on success. + + + + Set the label at the specified index. + + index + the label + Returns true on success. + + + + Returns the item type for the specified commandId. + + the command Id + Returns the item type for the specified commandId. + + + + Returns the item type at the specified index. + + index + Returns the item type at the specified index. + + + + Returns the group id for the specified commandId or -1 if invalid. + + the command Id + Returns the group id for the specified commandId or -1 if invalid. + + + + Returns the group id at the specified index or -1 if invalid. + + index + Returns the group id at the specified index or -1 if invalid. + + + + Sets the group id for the specified commandId. + + the command Id + the group id + Returns true on success. + + + + Sets the group id at the specified index. + + index + the group id + Returns true on success. + + + + Returns the for the specified commandId or null if invalid. + + the command Id + Returns the for the specified commandId or null if invalid. + + + + Returns the at the specified index or empty if invalid. + + index + Returns the for the specified commandId or null if invalid. + + + + Returns true if the specified commandId is visible. + + the command Id + Returns true if the specified commandId is visible. + + + + Returns true if the specified index is visible. + + index + Returns true if the specified index is visible. + + + + Change the visibility of the specified commandId. + + the command Id + visible + Returns true on success. + + + + Change the visibility at the specified index. + + index + visible + Returns true on success. + + + + Returns true if the specified commandId is enabled. + + the command Id + Returns true if the specified commandId is enabled. + + + + Returns true if the specified index is enabled. + + index + Returns true if the specified index is enabled. + + + + Change the enabled status of the specified commandId. + + the command Id + is enabled + Returns true on success. + + + + Change the enabled status at the specified index. + + index + is enabled + Returns true on success. + + + + Returns true if the specified commandId is checked. Only applies to check and radio items. + + the command Id + Returns true if the specified commandId is checked. Only applies to check and radio items. + + + + Returns true if the specified index is checked. Only applies to check and radio items. + + index + Returns true if the specified index is checked. Only applies to check and radio items. + + + + Check the specified commandId. Only applies to check and radio items. + + the command Id + set checked + Returns true on success. + + + + Check the specified index. Only applies to check and radio items. + + index + set checked + Returns true on success. + + + + Returns true if the specified commandId has a keyboard accelerator assigned. + + the command Id + Returns true if the specified commandId has a keyboard accelerator assigned. + + + + Returns true if the specified index has a keyboard accelerator assigned. + + index + Returns true if the specified index has a keyboard accelerator assigned. + + + + Set the keyboard accelerator for the specified commandId. + + the command Id + keyCode can be any key or character value. + shift key pressed + ctrl key pressed + alt key pressed + Returns true on success. + + + + Set the keyboard accelerator at the specified index. keyCode can be any key or character value. + + index + keyCode can be any key or character value. + shift key pressed + ctrl key pressed + alt key pressed + Returns true on success. + + + + Remove the keyboard accelerator for the specified commandId. + + the command Id + Returns true on success. + + + + Remove the keyboard accelerator at the specified index. + + index + Returns true on success. + + + + Retrieves the keyboard accelerator for the specified commandId. + + the command Id + keyCode can be any key or character value. + shift key pressed + ctrl key pressed + alt key pressed + Returns true on success. + + + + Retrieves the keyboard accelerator for the specified index. + + index + keyCode can be any key or character value. + shift key pressed + ctrl key pressed + alt key pressed + Returns true on success. + + + + + + + + + + + + + Tracks the number of browser instances currently open + The cound will be incrmented and decremented each time a CefBrowser is created/closed. + This includes CefBrowser popup instances. + + + Roughtly based on , unforeunately + doesn't reset the internal when Count is aleady 0. + In our case it's valid to increase the number of browsers and reset the event. + + + + TODO: Refactor this so it's not static. + + + + If logging is enabled the will be appended to + the internal log. + + text to append to log if logging enabled. + + + + + + + + + + + + + + + + + + + + + + + + + To access the CEF threads we expose a TaskFactory, as this requires managed vc++ this + exists in CefSharp.Core it cannot be directly accessed in CefSharp.dll. When + Cef.Initialized is called we pass a reference to the TaskFactory here so we + can write methods (typically extension methods) in this assembly. + + TODO: This can likely be removed and code that depends on this can be moved + to CefSharp.Core and interact directly with the C++ api + + + + TaskFactory will be null before Cef.Initialize is called + and null after Cef.Shutdown is called. + + + + + Event fired after Cef.Initialze has been called, we can now start + posting Tasks to the CEF UI Thread. + + + + + Delegate used to wrap the native call to CefCurrentlyOn(CefThreadId::TID_UI). + + + + + true if we have a reference to the UiThreadTaskFactory + TaskFactory, otherwise false + + + The current implementation isn't thread safe, generally speaking this shouldn't be a problem + + + + + Currently on the CEF UI Thread + + + + + returns true if Cef.Shutdown been called, otherwise false. + + + + + Execute the provided function on the CEF UI Thread + + result + function + Task{Result} + + + + Execute the provided action on the CEF UI Thread + + action + Task + + + + Wait for CEF to Initialize, continuation happens on + the CEF UI Thraed. + + Task that can be awaited + + + + Wait for CEF to Initialize, continuation happens on + the CEF UI Thraed. + + Task that can be awaited + + + + Called when the CEF UI Thread is a + + + + + !!WARNING!! DO NOT CALL THIS YOURSELF, THIS WILL BE CALLED INTERNALLY. + Called when Cef.Shutdown is called to cleanup our references + and release any event handlers. + + + + + Mapping to/from CefBaseTime + + + + + Assign your own custom converter + used to convert to/from CefBaseTime + + converter + + Must be called in all processes for custom conversion of DateTime + used by the Sync Javascript Binding (.Net 4.x only) + + + + + Converts from CefBaseTime to DateTime? + + + Represents a wall clock time in UTC. Values are not guaranteed to be monotonically + non-decreasing and are subject to large amounts of skew. Time is stored internally + as microseconds since the Windows epoch (1601). + + if is 0 then returns null otherwise returns a of + + + + Converts from CefBaseTime to DateTime + + + Represents a wall clock time in UTC. Values are not guaranteed to be monotonically + non-decreasing and are subject to large amounts of skew. Time is stored internally + as microseconds since the Windows epoch (1601). + + returns a of + + + + Converts from DateTime to CefBaseTime + + DateTime + + Represents a wall clock time in UTC. Time as microseconds since the Windows epoch (1601). + + + + + Custom Dictionary that provides an Add(string) method for appending CEF Command line + args that don't have a switch value. + + + + + Adds the command line argument + + command line argument + + + + Simple helper class used for checking/parsing command line arguments + + + + + ConcurrentMethodRunnerQueue - Async Javascript Binding methods are run + on the ThreadPool in parallel, when a method returns a Task + the we use ContinueWith to be notified of completion then + raise the MethodInvocationComplete event + + + + + + + + Default constructor + + javascript object repository + + + + + + + + + + CookieManager with additional checks to ensure the store is initialized. + Throws an exception when attempting to access the store before it's ready. + + + + + Base classes for Feezable settings objects + + + + + We need to be sure the CEF Global Context has been initialized before + we create the browser. If the CefRequestContext has already been initialzed + then we'll execute syncroniously. If the CefRequestContext hasn't been + initialized then we will continue on the CEF UI Thread. + https://github.com/cefsharp/CefSharp/issues/3850 + + action to invoke + + + + A implementation + that can optionally be set to ReadOnly (used to represent the CefHeaderMap) + + + + + Set the NameValueCollection to Readonly after it's been updated + + + + + Convert to/from and CefBaseTime + + + + + Converts from CefBaseTime to DateTime + + + Represents a wall clock time in UTC. Values are not guaranteed to be monotonically + non-decreasing and are subject to large amounts of skew. Time is stored internally + as microseconds since the Windows epoch (1601). + + returns a + + + + Converts from DateTime to CefBaseTime + + DateTime + + Represents a wall clock time in UTC. Time as microseconds since the Windows epoch (1601). + + + + + Interface used to break reference cycles in CefSharp.Core C++ code. + This will ALWAYS be a ManagedCefBrowserAdapter instance. + + + + + Browser Ref counter + Used internally to keep track of open browser instances + The ref count is incremented when a browser is created, + and decremented when the browser has successfully closed. + + + + + Increment browser count + + Browser type, used for logging internally + + + + Decrement browser count + + Browser type, used for logging internally + returns true if the count is 0, otherwise false + + + + Gets the number of CefBrowser instances currently open (this includes popups) + + + The count. + + + + + Enable logging + + + + + Gets the log (empty if not enabled). + + string + + + + Blocks until the CefBrowser count has reached 0 or the timeout has been reached + + (Optional) The timeout in miliseconds. + + + + Blocks until the CefBrowser count has reached 0 or the timeout has been reached + + (Optional) The timeout in miliseconds. + (Optional) The cancellation token. + + + + Interface to convert a JavascriptCallback dto to a callable implementation. + + + + + Run (execute) calls made from Javascript to .Net methods + + + + + Method invocation was completed. + + + + + Enqueue a method invocation + + method invocation + + + + BrowserProcessHandler implementation that takes a + and resolves when is called. + + + + + Default constructor + + task complection source + + + + + + + InMemoryResourceRequestHandler + + + + + Default constructor + + data + mime (content) type + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Do an unchecked conversion from IntPtr to int + so overflow exceptions don't get thrown. + + the IntPtr to cast + a 32-bit signed integer + + + + IRenderWebBrowser is an internal interface used by CefSharp for the WPF/Offscreen implementation + The ChromiumWebBrowser instances implement this interface + + + + + Implement to handle events related to accessibility. + + The accessibility handler. + + + + Called to allow the client to return a ScreenInfo object with appropriate values. + If null is returned then the rectangle from GetViewRect will be used. + If the rectangle is still empty or invalid popups may not be drawn correctly. + + Return null if no screenInfo structure is provided. + + + + Called to retrieve the view rectangle which is relative to screen coordinates. + + Return a ViewRect strict containing the rectangle or null. If the rectangle is + still empty or invalid popups may not be drawn correctly. + + + + Called to retrieve the translation from view coordinates to actual screen coordinates. + + x + y + screen x + screen y + Return true if the screen coordinates were provided. + + + + Called when an element has been rendered to the shared texture handle. + This method is only called when is set to true + + indicates whether the element is the view or the popup widget. + contains the set of rectangles in pixel coordinates that need to be repainted + is the handle for a D3D11 Texture2D that can be accessed via ID3D11Device using the OpenSharedResource method. + + + + Called when an element should be painted. Pixel values passed to this method are scaled relative to view coordinates based on the + value of returned from . + Called on the CEF UI Thread + + indicates whether the element is the view or the popup widget. + contains the set of rectangles in pixel coordinates that need to be repainted + The bitmap will be will be width * height *4 bytes in size and represents a BGRA image with an upper-left origin + width + height + + + + Called when the browser's cursor has changed. . + + If type is Custom then customCursorInfo will be populated with the custom cursor information + cursor type + custom cursor Information + + + + Called when the user starts dragging content in the web view. Contextual information about the dragged content is + supplied by dragData. (|x|, |y|) is the drag start location in screen coordinates. OS APIs that run a system message + loop may be used within the StartDragging call. Return false to abort the drag operation. Don't call any of + CefBrowserHost::DragSource*Ended* methods after returning false. Return true to handle the drag operation. + Call IBrowserHost::DragSourceEndedAt and DragSourceSystemDragEnded either synchronously or asynchronously to inform + the web view that the drag operation has ended. + + drag data + operation mask + x coordinate + y coordinate + Return false to abort the drag operation. + + + + Called when the web view wants to update the mouse cursor during a drag & drop operation. + + describes the allowed operation (none, move, copy, link). + + + + Called when the browser wants to show or hide the popup widget. + + The popup should be shown if show is true and hidden if show is false. + + + + Called when the browser wants to move or resize the popup widget. + + contains the new location and size in view coordinates. + + + + Called when the IME composition range has changed. + + is the range of characters that have been selected + is the bounds of each character in view coordinates. + + + + Called when an on-screen keyboard should be shown or hidden for the specified browser. + + the browser + specifies what kind of keyboard should be opened. If , any existing keyboard for this browser should be hidden. + + + + Interface implemented by UI control that contains + a ManagedCefBrowserAdapter instance. + + + + + Gets or sets a delegate which is used to invoke the method if the member is a method. + + + + + Identifies the for BrowserProcess to RenderProcess communication + + + + + Gets or sets the name of the managed property. + + + + + Gets or sets the name of the property in the JavaScript runtime. + + + + + Params this method expects + + + + + Number of Params this function exepects + + + + + The Return type of the method + + + + + This maps the registered objects in the browser process + to the reflection data necessary to update the objects, + and mapping information to how the object/method/proprerty + will be exposed to JavaScript. + + + + + Identifies the for BrowserProcess to RenderProcess communication + + + + + Indicate if this object bound as async + + + + + Gets the methods of the . + + + + + Gets the properties of the . + + + + + A javascript object is created for every object, even those that are sub objects + it's important we only transmit the Root Objects (top level/parent) + + + + + Gets or sets the value. + + + + + This class manages the registration of objects in the browser + process to be exposed to JavaScript in the renderer process. + Registration performs method, parameter, property type analysis + of the registered objects into meta-data tied to reflection data + for later use. + + This class also is the adaptation layer between the BrowserProcessService + and the registered objects. This means when the renderer wants to call an + exposed method, get a property of an object, or + set a property of an object in the browser process, that this + class does deals with the previously created meta-data and invokes the correct + behavior via reflection APIs. + + All of the registered objects are tracked via meta-data for the objects + expressed starting with the JavaScriptObject type. + + + + + CefSharp.BindObjectAsync was called from Javascript without pasing in any params + the will be called with + set to this value. + + + + + Legacy Javascript Binding is enabled, the event + will be called with + set to this value + + + + + + + + + + + + + + A hash from assigned object ids to the objects, + this is done to speed up finding the object in O(1) time + instead of traversing the JavaScriptRootObject tree. + + + + + Javascript Name converter + + + + + Has the browser this repository is associated with been initilized (set in OnAfterCreated) + + + + + + + + + + + Configurable settings for this repository, such as the property names CefSharp injects into the window. + + + + + Converted .Net method/property/field names to the name that + will be used in Javasript. Used for when .Net naming conventions + differ from Javascript naming conventions. + + + + + JavascriptObjectRepository + + + + + + + + + + + + + + Analyse the object and generate metadata which will + be used by the browser subprocess to interact with Cef. + Method is called recursively + + Javascript object + Analyse methods for inclusion in metadata model + Analyse properties for inclusion in metadata model + When analysis is done on a property, if true then get it's value for transmission over WCF + + + + Gets or sets a delegate which is used to set the property / field value in the managed object. + + + + + Gets or sets a delegate which is used to get the property / field value from the managed object. + + + + + Identifies the for BrowserProcess to RenderProcess communication + + + + + Gets or sets the name of the managed property. + + + + + Gets or sets the name of the property in the JavaScript runtime. + + + + + Gets or sets if this property represents a complex type + + + + + Gets or sets if this property is read-only + + + + + Gets or sets the property value + Only primative types can be stored in this property + + + + + MethodRunnerQueue - Async Javascript Binding methods are run + on the ThreadPool sequentially + + + + + + + + Default constructor + + javascript object repository + + + + + + + + + + Internal Mime Type Mappings. + + + + + Dictionary containing our custom mimeType mapping, you can add your own file extension + to mimeType mappings to this dictionary. + + + + + Lookup MimeType from the + dictionary based on file extension. + + extension + custom mimeType or application/octet-stream if no mapping found + + + + NoFocusHandler - Used when disposing of the ChromiumWebBrowser controls + Doesn't take focus for the main browser (leaves default behaviour for popup). + OnGotFocus and OnTakeFocus are both noops. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Monitor the parent process and exit if the parent process closes + before the subprocess. This class is used by the CefSharp.BrowserSubprocess to + self terminate if the parent dies without notifying it to exit. + See https://github.com/cefsharp/CefSharp/issues/2359 for more information. + + + + + Starts a long running task (spawns new thread) used to monitor the parent process + and calls if the parent exits unexpectedly (usually result of a crash). + + process Id of the parent application + + + + Path Validation utility class + + + + + Allow user to disable the assert. + As a temporary measure we'll allow users to disable the assert + as the check may not yet be 100% bulletproof. + + + + + True if the given character is a directory separator. + + + + + Throw exception if the path provided is non-asbolute + CEF now explicitly requires absolute paths + https://github.com/chromiumembedded/cef/issues/2916 + Empty paths are ignored + + path + string to appear at the start of + the exception, e.g. CefSettings.BrowserSubProcessPath + + + + Valid path is absolute, based on Chromium implementation. + + path + + + + Class to store TaskCompletionSources indexed by a unique id. There are two distinct ConcurrentDictionary + instances as we have some Tasks that are created from the browser process (EvaluateScriptAsync) calls, and + some that are created for instances for which the Id's are created + in the render process. + + The type of the result produced by the tasks held. + + + + Creates a new pending task with a timeout. + + The maximum running time of the task. + The unique id of the newly created pending task and the newly created . + + + + Creates a new pending task with a timeout. + + Id passed in from the render process + The maximum running time of the task. + The unique id of the newly created pending task and the newly created . + + + + If a is found matching + then it is removed from the ConcurrentDictionary and returned. + + Unique id of the pending task. + + The associated with the given id + or null if no matching TaskComplectionSource found. + + + + + If a is found matching + then it is removed from the ConcurrentDictionary and returned. + + Unique id of the pending task. + + The associated with the given id + or null if no matching TaskComplectionSource found. + + + + + String validation + + + + + Regex check to ensure string contains only letters, numbers and underscores. + + + false if string is invalid + + + + Return true if the first chracter of the specified string is lowercase + + string + returns false if empty or null, otherwise true if first character is lowercase + + + + TaskExtension based on the following + https://github.com/ChadBurggraf/parallel-extensions-extras/blob/master/Extensions/TaskExtrasExtensions.cs + https://github.com/ChadBurggraf/parallel-extensions-extras/blob/ec803e58eee28c698e44f55f49c5ad6671b1aa58/Extensions/TaskCompletionSourceExtensions.cs + + + + Creates a new Task that mirrors the supplied task but that will be canceled after the specified timeout. + Specifies the type of data contained in the task. + The task. + The timeout. + The new Task that may time out. + + + Attempts to transfer the result of a Task to the TaskCompletionSource. + Specifies the type of the result. + The TaskCompletionSource. + The task whose completion results should be transfered. + Whether the transfer could be completed. + + + Attempts to transfer the result of a Task to the TaskCompletionSource. + Specifies the type of the result. + The TaskCompletionSource. + The task whose completion results should be transfered. + Whether the transfer could be completed. + + + + Set the TaskCompletionSource in an async fashion. This prevents the Task Continuation being executed sync on the same thread + This is required otherwise continuations will happen on CEF UI threads + + Generic param + tcs + result + + + + Calls in an async fashion. This prevents the Task Continuation being executed sync on the same thread + This is required otherwise continuations will happen on CEF UI threads + + Generic param + tcs + exception + + + + Calls in an async fashion. This prevents the Task Continuation being executed sync on the same thread + This is required otherwise continuations will happen on CEF UI threads + + Generic param + tcs + + + + Provides a task scheduler that ensures a maximum concurrency level while + running on top of the ThreadPool. + + + + Whether the current thread is processing work items. + + + The list of tasks to be executed. + + + The maximum concurrency level allowed by this scheduler. + + + Whether the scheduler is currently processing work items. + + + + Initializes an instance of the LimitedConcurrencyLevelTaskScheduler class with the + specified degree of parallelism. + + The maximum degree of parallelism provided by this scheduler. + + + Queues a task to the scheduler. + The task to be queued. + + + + Informs the ThreadPool that there's work to be executed for this scheduler. + + + + Attempts to execute the specified task on the current thread. + The task to be executed. + + Whether the task could be executed on the current thread. + + + Attempts to remove a previously scheduled task from the scheduler. + The task to be removed. + Whether the task could be found and removed. + + + Gets the maximum concurrency level supported by this scheduler. + + + Gets an enumerable of the tasks currently scheduled on this scheduler. + An enumerable of the tasks currently scheduled. + + + + TaskCompletionSource that executes it's continuation on the captured + . If is null. + then the current **executing** thread will be called. e.g. The thread that + called + (or other Set/Try set methods). + + Result Type + + + + Captured Sync Context + + + + + WaitAsync polyfills imported from .Net Runtime + as we don't get access to this method in older .net versions + + + + + ByteArrayResourceHandler is used as a placeholder class which uses native CEF implementations. + CefStreamReader::CreateForData(); reads the byte array that is passed to a new instance + of CefStreamResourceHandler + TODO: Move this class into Handler namespace + + + + + Underlying byte array that represents the data + + + + + Gets or sets the Mime Type. + + + + + Initializes a new instance of the class. + + mimeType + byte array + + + + FileResourceHandler is used as a placeholder class which uses native CEF implementations. + CefStreamReader::CreateForFile is used to create a CefStreamReader instance which is passed to + a new instance of CefStreamResourceHandler + (Was previously ResourceHandlerType::File to differentiate, going for a more flexible approach now) + TODO: Move this class into Handler namespace + + + + + Path of the underlying file + + + + + Gets or sets the Mime Type. + + + + + Initializes a new instance of the class. + + mimeType + filePath + + + + Class representing popup window features. + + + + + Gets the x coordinate. + + + The x coordinate. + + + + + Gets the y coordinate. + + + The y coordinate. + + + + + Gets the width. + + + The width. + + + + + Gets the height. + + + The height. + + + + + Returns true if browser interface elements should be hidden. + + + + + Class used to represent post data for a web request. The methods of this class may be called on any thread. + + + + + Add the specified . + + element to be added. + Returns true if the add succeeds. + + + + Remove the specified . + + element to be removed. + Returns true if the add succeeds. + + + + Retrieve the post data elements. + + + + + Returns true if this object is read-only. + + + + + Remove all existing post data elements. + + + + + Gets a value indicating whether the object has been disposed of. + + + + + Create a new instance + + PostDataElement + + + + Returns true if the underlying POST data includes elements that are not + represented by this IPostData object (for example, multi-part file upload + data). Modifying IPostData objects with excluded elements may result in + the request failing. + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Class used to represent a single element in the request post data. + The methods of this class may be called on any thread. + + + + + Gets or sets the file name. + + + + + Gets if the object is read-only. + + + + + Remove all contents from the post data element. + + + + + Gets the type of this . + + + + + Gets or sets the bytes of this . + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Generic callback interface used for managing the lifespan of a registration. + + + + + Class used to represent a web request. The methods of this class may be called on any thread. + + + + + Get/Set request flags, can be used to control caching policy + + + + + Request Url + + + + + Returns the globally unique identifier for this request or 0 if not specified. + Can be used by implementations in the browser process to track a + single request across multiple callbacks. + + + + + Request Method GET/POST etc + + + + + Set the referrer URL and policy. If non-empty the referrer URL must be + fully qualified with an HTTP or HTTPS scheme component. Any username, + password or ref component will be removed. + + the referrer url + referrer policy + + + + Get the referrer URL. + + + + + Get the resource type for this request. + + + + + Get the referrer policy. + + + + + Header Collection - If dealing with headers that only contain a single value then + it's easier to use or . + You cannot modify the referrer using headers, use . + NOTE: This collection is a copy of the underlying type, to make changes, take a reference to the collection, + make your changes, then reassign the collection. + + + This example shows how to modify headers, make sure you reassign the collection + once it's been modified. + + var headers = request.Headers; + var userAgent = headers["User-Agent"]; + headers["User-Agent"] = userAgent + " CefSharp"; + request.Headers = headers; + + + + + + Post data + + + + + Get the transition type for this request. + Applies to requests that represent a main frame or sub-frame navigation. + + + + + Gets a value indicating whether the request has been disposed of. + + + + + Returns true if this object is read-only. + + + + + Initialize a new instance of . + Make sure to check if the is null + before calling otherwise the existing data will be overridden. + + + + + Returns the first header value for name or an empty string if not found. + Will not return the Referer value if any. Use instead if name might have multiple values. + + header name + Returns the first header value for name or an empty string if not found. + + + + Set the header name to value. The Referer value cannot be set using this method. + Use instead. + + header name + new header value + If overwrite is true any existing values will be replaced with the new value. If overwrite is false any existing values will not be overwritten + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + A request context provides request handling for a set of related browser or URL request objects. + A request context can be specified when creating a new browser by setting the + property (Passing in via the constructor for the OffScreen + control is preferred). + Browser objects with different request contexts will never be hosted in the same render process. + Browser objects with the same request context may or may not be hosted in the same render process + depending on the process model.Browser objects created indirectly via the JavaScript window.open + function or targeted links will share the same render process and the same request context as + the source browser. + + + + + Gets a value indicating whether the RequestContext has been disposed of. + + + + + Returns true if this object is pointing to the same context object. + + context to compare + Returns true if the same + + + + Returns true if this object is sharing the same storage as the specified context. + + context to compare + Returns true if same storage + + + + Returns true if this object is the global context. The global context is + used by default when creating a browser or URL request with a NULL context + argument. + + + + + Returns the default cookie manager for this object. This will be the global + cookie manager if this object is the global request context. + + If callback is non-NULL it will be executed asynchronously on the CEF IO thread + after the manager's storage has been initialized. + Returns the default cookie manager for this object + + + + Register a scheme handler factory for the specified schemeName and optional domainName. + An empty domainName value for a standard scheme will cause the factory to match all domain + names. The domainName value will be ignored for non-standard schemes. If schemeName is + a built-in scheme and no handler is returned by factory then the built-in scheme handler + factory will be called. If schemeName is a custom scheme then you must also implement the + CefApp::OnRegisterCustomSchemes() method in all processes. This function may be called multiple + times to change or remove the factory that matches the specified schemeName and optional + domainName. + + Scheme Name + Optional domain name + Scheme handler factory + Returns false if an error occurs. + + + + Clear all registered scheme handler factories. + + Returns false on error. + + + + Returns the cache path for this object. If empty an "incognito mode" + in-memory cache is being used. + + + + + Returns true if a preference with the specified name exists. This method + must be called on the CEF UI thread. + + name of preference + bool if the preference exists + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both + executed on the CEF UI thread, so can be called directly. + When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main + application thread will be the CEF UI thread. + + + + Returns the value for the preference with the specified name. Returns + NULL if the preference does not exist. The returned object contains a copy + of the underlying preference value and modifications to the returned object + will not modify the underlying preference value. This method must be called + on the CEF UI thread. + + preference name + Returns the value for the preference with the specified name + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both + executed on the CEF UI thread, so can be called directly. + When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main + application thread will be the CEF UI thread. + + + + Returns all preferences as a dictionary. The returned + object contains a copy of the underlying preference values and + modifications to the returned object will not modify the underlying + preference values. This method must be called on the browser process UI + thread. + + If true then + preferences currently at their default value will be included. + Preferences (dictionary can have sub dictionaries) + + + + Returns true if the preference with the specified name can be modified + using SetPreference. As one example preferences set via the command-line + usually cannot be modified. This method must be called on the CEF UI thread. + + preference key + Returns true if the preference with the specified name can be modified + using SetPreference + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both + executed on the CEF UI thread, so can be called directly. + When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main + application thread will be the CEF UI thread. + + + + Set the value associated with preference name. If value is null the + preference will be restored to its default value. If setting the preference + fails then error will be populated with a detailed description of the + problem. This method must be called on the CEF UI thread. + Preferences set via the command-line usually cannot be modified. + + preference key + preference value + out error + Returns true if the value is set successfully and false otherwise. + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both + executed on the CEF UI thread, so can be called directly. + When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main + application thread will be the CEF UI thread. + + + + Clears all certificate exceptions that were added as part of handling + . If you call this it is + recommended that you also call or you risk not + being prompted again for server certificates if you reconnect quickly. + + If is non-NULL it will be executed on the CEF UI thread after + completion. This param is optional + + + + Clears all HTTP authentication credentials that were added as part of handling + . + + If is non-NULL it will be executed on the CEF UI thread after + completion. This param is optional + + + + Clears all active and idle connections that Chromium currently has. + This is only recommended if you have released all other CEF objects but + don't yet want to call Cef.Shutdown(). + + If is non-NULL it will be executed on the CEF UI thread after + completion. This param is optional + + + + Attempts to resolve origin to a list of associated IP addresses. + + host name to resolve + A task that represents the Resoolve Host operation. The value of the TResult parameter contains ResolveCallbackResult. + + + + Returns true if this context was used to load the extension identified by extensionId. Other contexts sharing the same storage will also have access to the extension (see HasExtension). + This method must be called on the CEF UI thread. + + Returns true if this context was used to load the extension identified by extensionId + + + + Returns the extension matching extensionId or null if no matching extension is accessible in this context (see HasExtension). + This method must be called on the CEF UI thread. + + extension Id + Returns the extension matching extensionId or null if no matching extension is accessible in this context + + + + Retrieve the list of all extensions that this context has access to (see HasExtension). + will be populated with the list of extension ID values. + This method must be called on the CEF UI thread. + + output a list of extensions Ids + returns true on success otherwise false + + + + Returns true if this context has access to the extension identified by extensionId. + This may not be the context that was used to load the extension (see DidLoadExtension). + This method must be called on the CEF UI thread. + + extension id + Returns true if this context has access to the extension identified by extensionId + + + + Load an extension. If extension resources will be read from disk using the default load implementation then rootDirectoy + should be the absolute path to the extension resources directory and manifestJson should be null. + If extension resources will be provided by the client (e.g. via IRequestHandler and/or IExtensionHandler) then rootDirectory + should be a path component unique to the extension (if not absolute this will be internally prefixed with the PK_DIR_RESOURCES path) + and manifestJson should contain the contents that would otherwise be read from the "manifest.json" file on disk. + The loaded extension will be accessible in all contexts sharing the same storage (HasExtension returns true). + However, only the context on which this method was called is considered the loader (DidLoadExtension returns true) and only the + loader will receive IRequestContextHandler callbacks for the extension. + + will be called on load success or + will be called on load failure. + + If the extension specifies a background script via the "background" manifest key then + will be called to create the background browser. See that method for additional information about background scripts. + + For visible extension views the client application should evaluate the manifest to determine the correct extension URL to load and then + load the extension URL in a ChromiumWebBrowser instance after the extension has loaded. + + For example, the client can look for the "browser_action" manifest key as documented at https://developer.chrome.com/extensions/browserAction. + Extension URLs take the form "chrome-extension://<extension_id>/<path>" + Browsers that host extensions differ from normal browsers as follows: + + - Can access chrome.* JavaScript APIs if allowed by the manifest. Visit chrome://extensions-support for the list of extension APIs currently supported by CEF. + - Main frame navigation to non-extension content is blocked. + - Pinch-zooming is disabled. + - returns the hosted extension. + - CefBrowserHost::IsBackgroundHost returns true for background hosts. + + See https://developer.chrome.com/extensions for extension implementation and usage documentation. + + If extension resources will be read from disk using the default load implementation then rootDirectoy + should be the absolute path to the extension resources directory and manifestJson should be null + If extension resources will be provided by the client then rootDirectory should be a path component unique to the extension + and manifestJson should contain the contents that would otherwise be read from the manifest.json file on disk + handle events related to browser extensions + + For extensions that load a popup you are required to query the Manifest, build a Url in the format + chrome-extension://{extension.Identifier}/{default_popup} with default_popup url coming from the mainfest. With the extension + url you then need to open a new Form/Window/Tab and create a new ChromiumWebBrowser instance to host the extension popup. + To load a crx file you must first unzip them to a folder and pass the path containing the extension as . + It in theory should be possible to load a crx file in memory, passing it's manifest.json file content as + then fulfilling the resource rquests made to . + + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + Class that creates instances for handling custom requests. + The methods of this class will always be called on the CEF IO thread. This interface + maps to the CefRequestHandler::GetResourceHandler method. It was split out to allow for + the implementation that provides support + for the LoadHtml extension method. + + + + + Return to have + called for every resource request. Otherwise return . + + + If you return then + will not be called. + + + + + Called on the CEF IO thread before a resource request is initiated. + + the ChromiumWebBrowser control + represent the source browser of the request + represent the source frame of the request + represents the request contents and cannot be modified in this callback + will be true if the resource request is a navigation + will be true if the resource request is a download + is the origin (scheme + domain) of the page that initiated the request + to true to disable default handling of the request, in which case it will need to be handled via or it will be canceled + To allow the resource load to proceed with default handling return null. To specify a handler for the resource return a object. If this callback returns null the same method will be called on the associated , if any + + + + Class used to represent a web response. The methods of this class may be called on any thread. + + + + + Get/Set the response charset. + + + + + MimeType + + + + + Response Headers + + + + + Returns true if this object is read-only. + + + + + Get/set the response error code. + + + + + The status code of the response. Unless set, the default value used is 200 + (corresponding to HTTP status OK). + + + + + Status Text + + + + + Returns the first header value for name or an empty string if not found. + Will not return the Referer value if any. Use instead if name might have multiple values. + + header name + Returns the first header value for name or an empty string if not found. + + + + Set the header name to value. + + header name + new header value + If overwrite is true any existing values will be replaced with the new value. If overwrite is false any existing values will not be overwritten + + + + Implement this interface to filter resource response content. + The methods of this class will be called on the CEF IO thread. + + + + + Initialize the response filter. Will only be called a single time. + The filter will not be installed if this method returns false. + + The filter will not be installed if this method returns false. + + + + Called to filter a chunk of data. + This method will be called repeatedly until there is no more data to filter (resource response is complete), + dataInRead matches dataIn.Length (all available pre-filter bytes have been read), and the method + returns FilterStatus.Done or FilterStatus.Error. + + is a Stream wrapping the underlying input buffer containing pre-filter data. Can be null. + Set to the number of bytes that were read from dataIn + is a Stream wrapping the underlying output buffer that can accept filtered output data. + Check dataOut.Length for maximum buffer size + Set to the number of bytes that were written into dataOut + If some or all of the pre-filter data was read successfully but more data is needed in order + to continue filtering (filtered output is pending) return FilterStatus.NeedMoreData. If some or all of the pre-filter + data was read successfully and all available filtered output has been written return FilterStatus.Done. If an error + occurs during filtering return FilterStatus.Error. + Do not keep a reference to the buffers(Streams) passed to this method. + + + + Manages custom scheme registrations. + + + + + Register a custom scheme. This method should not be called for the built-in + HTTP, HTTPS, FILE, FTP, ABOUT and DATA schemes. + + See for possible values for + + This function may be called on any thread. It should only be called once + per unique value. + + scheme name + scheme options + If is already registered or if an error occurs this method will return false. + + + + Class representing SSL information. + + + + + Returns a bitmask containing any and all problems verifying the server + certificate. + + + + + Returns the X.509 certificate. + + + + + Class used to make a URL request. URL requests are not associated with + a browser instance so no CefClient callbacks will be executed. + URL requests can be created on any valid CEF thread in either the browser + or render process. Once created the methods of the URL request object must + be accessed on the same thread that created it. + + + + + True if the response was served from the cache. + + + + + The response, or null if no response information is available + + + + + The request status. + + + + + Interface that should be implemented by the CefURLRequest client. + The methods of this class will be called on the same thread that created the request unless otherwise documented. + + + + + Called on the CEF IO thread when the browser needs credentials from the user. + This method will only be called for requests initiated from the browser process. + + indicates whether the host is a proxy server. + the hostname. + the port number. + realm + scheme + is a callback for authentication information + + Return true to continue the request and call when the authentication information is available. + If the request has an associated browser/frame then returning false will result in a call to + on the associated with that browser, if any. + Otherwise, returning false will cancel the request immediately. + + + + + Called when some part of the response is read. This method will not be called if the flag is set on the request. + + request + A stream containing the bytes received since the last call. Cannot be used outside the scope of this method. + + + + Notifies the client of download progress. + + request + denotes the number of bytes received up to the call + is the expected total size of the response (or -1 if not determined). + + + + Notifies the client that the request has completed. + Use the property to determine if the + request was successful or not. + + request + + + + Notifies the client of upload progress. + This method will only be called if the UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + request + denotes the number of bytes sent so far. + is the total size of uploading data (or -1 if chunked upload is enabled). + + + + Interface representing CefValue. + + + + + Returns the underlying value type. + + + Returns the underlying value type. + + + + + Returns the underlying value as type bool. + + + Returns the underlying value as type bool. + + + + + Returns the underlying value as type double. + + + Returns the underlying value as type double. + + + + + Returns the underlying value as type int. + + + Returns the underlying value as type int. + + + + + Returns the underlying value as type string. + + + Returns the underlying value as type string. + + + + + Returns the underlying value as type dictionary. + + + Returns the underlying value as type dictionary. + + + + + Returns the underlying value as type list. + + + Returns the underlying value as type list. + + + + + Returns the underlying value converted to a managed object. + + + Returns the underlying value converted to a managed object. + + + + + ChromiumWebBrowser implementations implement this interface. Can be cast to + the concrete implementation to access UI specific features. + + + + + Event handler that will get called when the message that originates from CefSharp.PostMessage + + + + + Loads the specified in the Main Frame. + If is true then the method call will be ignored. + Same as calling + + The URL to be loaded. + + + + Wait for the Browser to finish loading the initial web page. + + + A that can be awaited which returns the HttpStatusCode and . + A HttpStatusCode equal to 200 and is considered a success. + + + + + The javascript object repository, one repository per ChromiumWebBrowser instance. + + + + + Implement and assign to handle dialog events. + + The dialog handler. + + + + Implement and assign to handle events related to browser requests. + + The request handler. + + + + Implement and assign to handle events related to browser display state. + + The display handler. + + + + Implement and assign to handle events related to browser load status. + + The load handler. + + + + Implement and assign to handle events related to popups. + + The life span handler. + + + + Implement and assign to handle events related to key press. + + The keyboard handler. + + + + Implement and assign to handle events related to JavaScript Dialogs. + + The js dialog handler. + + + + Implement and assign to handle events related to dragging. + + The drag handler. + + + + Implement and assign to handle events related to downloading files. + + The download handler. + + + + Implement and assign to handle events related to the browser context menu + + The menu handler. + + + + Implement and assign to handle events related to the browser component's focus + + The focus handler. + + + + Implement and control the loading of resources + + The resource handler factory. + + + + Implement and assign to handle messages from the render process. + + The render process message handler. + + + + Implement to handle events related to find results. + + The find handler. + + + + Implement to handle audio events. + + + + + Implement to handle frame events. + + + + + Implement to handle events related to permission requests. + + + + + The text that will be displayed as a ToolTip + + The tooltip text. + + + + A flag that indicates if you can execute javascript in the main frame. + Flag is set to true in IRenderProcessMessageHandler.OnContextCreated. + and false in IRenderProcessMessageHandler.OnContextReleased + + + + + Gets the custom request context assigned to this browser instance + If no instance was assigned this will be null and the global + request context will have been used for this browser. + You can access the global request context through Cef.GetGlobalRequestContext() + + + + + Returns the current CEF Browser Instance + + browser instance or null + + + + Try and get a reference to the instance that matches the . + Primarily used for geting a reference to the used by popups. + + browser Id + When this method returns, contains the object reference that matches the specified , or null if no matching instance found. + true if a instance was found matching ; otherwise, false. + + + + Size of scrollable area in CSS pixels + + A task that can be awaited to get the size of the scrollable area in CSS pixels. + + + + Class representing window information. + + + + + X coordinate + + + + + Y coordinate + + + + + Width + + + + + Height + + + + + Window style + + + + + Ex window style + + + + + Parent window handle + + + + + Set to true to create the browser using windowless (off-screen) rendering. + No window will be created for the browser and all rendering will occur via the + IRenderHandler interface. The value will be used to identify monitor info + and to act as the parent window for dialogs, context menus, etc. If | is not provided then the main screen monitor will be used and some functionality that requires a parent window may not function correctly. + In order to create windowless browsers the CefSettings.WindowlessRenderingEnabled value must be set to true. + Transparent painting is enabled by default but can be disabled by setting to an opaque value. + + + + + Set to true to enable shared textures for windowless rendering. Only + valid if is also set to true. Currently + only supported on Windows (D3D11). This feature is experimental and has many bugs + at the moment. + + + + + Set to true to enable the ability to issue BeginFrame requests from the + client application by calling . + + + + + Handle for the new browser window. Only used with windowed rendering. + + + + + Window Name + + + + + Create the browser as a child window. + Calls GetClientRect(Hwnd) to obtain the window bounds + + parent handle + + + + Create the browser as a child window. + + parent handle + window bounds + + + + Create the browser as a child window. + + parent handle + left + top + right + bottom + + + + Create the browser as a popup window. + + parent handle + window name + + + + Create the browser using windowless (off-screen) rendering. + No window will be created for the browser and all rendering will occur via the CefRenderHandler interface. This window will automatically be transparent unless a colored backgrond is set in the browser settings. + + Value will be used to identify monitor info and to act as the parent window for dialogs, context menus, etc. + If not provided then the main screen monitor will be used and some functionality that requires a parent window may not function correctly. + In order to create windowless browsers the CefSettings.windowless_rendering_enabled value must be set to true. + + + + Used internally to get the underlying instance. + Unlikely you'll use this yourself. + + the inner most instance + + + + CamelCaseJavascriptNameConverter converts .Net property/method names + to camcel case. + + + + + Get the javascript name for the property/field/method. + Typically this would be based on + + property/field/method + javascript name + + + + This method exists for backwards compatability reasons, historically + only the bound methods/fields/properties were converted. Objects returned + from a method call were not translated. To preserve this functionality + for upgrading users we split this into two methods. Typically thie method + would return the same result as + Issue #2442 + + property/field/method + javascript name + + + + Converts the to CamelCase + + memberInfo + camelcased name + + + + Implement this interface to have control of how the names + are converted when binding/executing javascript. + + + + + Get the javascript name for the property/field/method. + Typically this would be based on + + property/field/method + javascript name + + + + This method exists for backwards compatability reasons, historically + only the bound methods/fields/properties were converted. Objects returned + from a method call were not translated. To preserve this functionality + for upgrading users we split this into two methods. Typically thie method + would return the same result as + Issue #2442 + + property/field/method + javascript name + + + + Javascript Binding Settings + + + + + The Javascript methods that CefSharp provides in relation to JavaScript Binding are + created using a Global (window) Object. Settings this property allows you to disable + the creation of this object. Features like EvaluateScriptAsPromiseAsync that rely on + the creation of this object will no longer function. + + + + + The Javascript methods that CefSharp provides in relation to JavaScript Binding are + created using a Global (window) Object. Settings this property allows you to customise + the name of this object. If not specified then both cefSharp and CefSharp objects will + be created e.g. cefSharp.bindObjectAsync, CefSharp.BindObjectAsync. + If specified then your custom name will be used, if the name starts with a lowercase letter + then all the functions will be lowercase, e.g. myObjName.bindObjectAsync otherwise + the functions will start with a uppercase letter e.g. MyObjName.BindObjectAsync + + + This object is also accessible through the window property. e.g. window.cefSharp.bindObjectAsync + + + + + Objects registered using + will be automatically bound when a V8Context is created. (Soon as the Javascript + context is created for a browser). This behaviour is like that seen with Javascript + Binding in version 57 and earlier. + + + + + When using an + the + method is call for all methods (the default is to call InterceptAsync only for methods that return a Task). + This only applies when is of type + + + + + Legacy Naming converter. + Used by default for backwards compatability + Issue #2442 + + + + + Javascript binding extension methods + + + + + Make sure an object is bound in javascript. Executes against the main frame + + browser + object names + List of objects that were bound + + + + Javascript exception + + + + + Message + + + + + Stack trace in javascript frames + + + + + JavascriptIgnoreAttribute - Methods and Properties marked with this attribute + will be excluded from Javascript Binding + + + + + Javascript Response + + + + + Error message + + + + + Was the javascript executed successfully + + + + + Javascript response + + + + + A Javascript(V8) stack frame + + TODO: Refactor to pass params in throw constructor and make properties readonly + + + + Gets or sets the name of the function. + + + The name of the function. + + + + + Gets or sets the line number. + + + The line number. + + + + + Gets or sets the column number. + + + The column number. + + + + + Gets or sets the name of the source. + + + The name of the source. + + + + + Legacy ResourceHandler, will be removed when CEF removes the old code path for + it's CefResourceHandler implementation. This is the older and well tested variant. + It doesn't however support range request headers (seek). + + + + + Gets or sets the Charset + + + + + Gets or sets the Mime Type. + + + + + Gets or sets the resource stream. + + + + + Gets or sets the http status code. + + + + + Gets or sets the status text. + + + + + Gets or sets ResponseLength, when you know the size of your + Stream (Response) set this property. This is optional. + If you use a MemoryStream and don't provide a value + here then it will be cast and it's size used + + + + + Gets or sets the headers. + + The headers. + + + + When true the Stream will be Disposed when + this instance is Disposed. The default value for + this property is false. + + + + + If the ErrorCode is set then the response will be ignored and + the errorCode returned. + + + + + Initializes a new instance of the class. + + Optional mimeType defaults to + Optional Stream - must be set at some point to provide a valid response + When true the Stream will be disposed when this instance is Diposed, you will + be unable to use this ResourceHandler after the Stream has been disposed + response charset + + + + Begin processing the request. If you have the data in memory you can execute the callback + immediately and return true. For Async processing you would typically spawn a Task to perform processing, + then return true. When the processing is complete execute callback.Continue(); In your processing Task, simply set + the StatusCode, StatusText, MimeType, ResponseLength and Stream + + The request object. + The callback used to Continue or Cancel the request (async). + To handle the request return true and call + once the response header information is available + can also be called from inside this method if + header information is available immediately). + To cancel the request return false. + + + + Called if the request is cancelled + + + + + Dispose of resources here + + + + + Populate the response stream, response length. When this method is called + the response should be fully populated with data. + It is possible to redirect to another url at this point in time. + NOTE: It's no longer manditory to implement this method, you can simply populate the + properties of this instance and they will be set by the default implementation. + + The response object used to set Headers, StatusCode, etc + length of the response + If set the request will be redirect to specified Url + The response stream + + + + Response returned from + + + + + Error Code. If the network request was made successfully this value will be + (no error occured) + + + + + Http Status Code. If is not equal to + then this value will be -1. + + + + + If is equal to and + is equal to 200 (OK) then the main frame loaded without + critical error. + + + + + Initializes a new instance of the LoadUrlAsyncResponse class. + + CEF Error Code + Http Status Code + + + + Represents a bindable member of a type, which can be a property or a field. + + + + + Gets the name of the property or field represented by this BindingMemberInfo. + + + + + Gets the data type of the property or field represented by this BindingMemberInfo. + + + + + Constructs a BindingMemberInfo instance for a property. + + The bindable property to represent. + + + + Constructs a BindingMemberInfo instance for a field. + + The bindable field to represent. + + + + Sets the value from a specified object associated with the property or field represented by this BindingMemberInfo. + + The object whose property or field should be assigned. + The value to assign in the specified object to this BindingMemberInfo's property or field. + + + + Returns an enumerable sequence of bindable properties for the specified type. + + The type to enumerate. + Bindable properties. + + + + Default binder - used as a fallback when a specific modelbinder + is not available. + + + + + Static Instance of this binding that can be reused as it doesn't store any state information. + Uses the naming converter + + + + + Javascript Binder + + name converter + + + + Bind to the given model type + + object to be converted into a model + the target param type + Bound model + + + + Bind collection. + + the target param type. + Type of the object. + object to be converted into a model. + + An object. + + + + + Bind object. + + the target param type. + Type of the object. + object to be converted into a model. + + An object. + + + + + Provides the capability intercept async/sync Net method calls made from javascript as part of the + JavascriptBinding (JSB) implementation. One example use case is logging method calls. + Extends to add async support. + + + + + Called before an async method is invoked. You are now responsible for evaluating + the function and returning the result. Only methods that return a + will call this method, other non asynchronous types will call + . + (async void method will also call Intercept as they do not return a Task). + + A Func that represents the method to be called + paramaters to be passed to + Name of the method to be called + A Task representing the method result + + Task<object> IAsyncMethodInterceptor.InterceptAsync(Func<object[], object> method, object[] parameters, string methodName) + { + object result = method(parameters); + Debug.WriteLine("Called " + methodName); + return result; + } + + + + + Converts input params into complex .Net types (can also be used for type conversion). + This feature is similar in concept to ASP.NET MVC Model Binding. + Objects passed from javascript are represented as + and arrays/lists as + See for the default implementation. + + + A model binder can be specified in and passed into + + + + + + Bind to the given model type, can also be used for type conversion e.g. int to uint + + object to be converted into a model + the target param type + if the modelType is directly assignable then do so, otherwise perform a conversion + or create a complex object that matches + + + + Provides the capability intercept Net method calls made from javascript as part of the + JavascriptBinding (JSB) implementation. One example use case is logging method calls. + + + + + Called before the method is invokved. You are now responsible for evaluating + the function and returning the result. + + A Func that represents the method to be called + paramaters to be passed to + Name of the method to be called + The method result + + + object IMethodInterceptor.Intercept(Func<object[], object> method, object[] parameters, string methodName) + { + object result = method(parameters); + Debug.WriteLine("Called " + methodName); + return result; + } + + + + + + Provides the capability intercepting get/set property calls made from javascript as part of the + JavascriptBinding (JSB) implementation. + + + + + Called before the get property is invokved. You are now responsible for evaluating + the property and returning the result. + + A Func that represents the property to be called + Name of the property to be called + The property result + + + propertyGetter, string propertyName) + { + object result = propertyGetter(); + Debug.WriteLine("InterceptGet " + propertyName); + return result; + } + ]]> + + + + + + Called before the set property is invokved. You are now responsible for evaluating + the property. + + A Func that represents the property to be called + paramater to be set to property + Name of the property to be called + + + propertySetter, object parameter, string propertName) + { + Debug.WriteLine("InterceptSet " + propertName); + propertySetter(parameter); + } + ]]> + + + + + + Containing extensions for the object. + + + + + Checks if a type is an array or not + + The type to check. + if the type is an array, otherwise . + + + + Checks if a type is an collection or not + + The type to check. + if the type is a collection, otherwise . + + + + Checks if a type is enumerable or not + + The type to check. + if the type is an enumerable, otherwise . + + + + Represents an entry in navigation history. + + + + + Returns the time for the last known successful navigation completion. + + + + + Returns a display-friendly version of the URL. + + + + + Returns the HTTP status code for the last known successful navigation response. + + + + + Returns the original URL that was entered by the user before any redirects. + + + + + Returns the title set by the page. + + + + + Returns the transition type which indicates what the user did to move to this page from the previous page. + + + + + Returns the actual URL of the page. + + + + + Returns true if this navigation includes post data. + + + + + Returns true if this object is valid. + + + + + If true if this entry is the currently loaded navigation entry + + + + + Returns the SSL information for this navigation entry. + + + + + NavigationEntry + + completionTime + displayUrl + httpStatusCode + originalUrl + title + transitionType + url + hasPostData + isValid + is the current entry + the ssl status + + + + Print to Pdf Settings + + + + + Set to true for landscape mode or false for portrait mode. + + + + + Set to true to print background graphics or false to not print + background graphics. + + + + + The percentage to scale the PDF by before printing (e.g. .5 is 50%). + If this value is less than or equal to zero the default value of 1.0 + will be used. + + + + + Output paper size in inches. If either of these values is less than or + equal to zero then the default paper size (letter, 8.5 x 11 inches) will + be used. + + + + + Output paper size in inches. If either of these values is less than or + equal to zero then the default paper size (letter, 8.5 x 11 inches) will + be used. + + + + + Set to true to prefer page size as defined by css. Defaults to false + in which case the content will be scaled to fit the paper size. + + + + + Margin type. + + + + + Margins in inches. Only used if is set to + . + + + + + Margins in inches. Only used if is set to + . + + + + + Margins in inches. Only used if is set to + . + + + + + Margins in inches. Only used if is set to + . + + + + + Paper ranges to print, one based, e.g. '1-5, 8, 11-13'. Pages are printed + in the document order, not in the order specified, and no more than once. + Defaults to empty string, which implies the entire document is printed. + The page numbers are quietly capped to actual page count of the document, + and ranges beyond the end of the document are ignored. If this results in + no pages to print, an error is reported. It is an error to specify a range + with start greater than end. + + + + + Set to true to display the header and/or footer. Modify + |header_template| and/or |footer_template| to customize the display. + + + + + HTML template for the print header. Only displayed if + is true. Should be valid HTML markup with + the following classes used to inject printing values into them: + + - date: formatted print date + - title: document title + - url: document location + - pageNumber: current page number + - totalPages: total pages in the document + + For example, "<span class=title></span>" would generate a span containing + the title. + + + + + HTML template for the print footer. Only displayed if + is true. Should be valid HTML markup with + the following classes used to inject printing values into them: + + - date: formatted print date + - title: document title + - url: document location + - pageNumber: current page number + - totalPages: total pages in the document + + For example, "<span class=title></span>" would generate a span containing + the title. + + + + + Set to true to print background graphics or false to not print + background graphics. + + + + + Set to true to print headers and footers or false to not print + headers and footers. + + + + + Post Data extension methods - Makes accessing post data easier + + + + + A convenience extension method that extracts the Character set from + the content-type header. Can be used in conjuncation with + + the request + character set e.g. UTF-8 + + + + Converts the property into a string + using the specified charset (Encoding) or if unable to parse then uses + the + + post data + character set + encoded string + + + + Add a new that represents the specified file + + post data instance + file name + + + + Add a new that represents the key and value + The data is encoded using + + Post Data + Data to be encoded for the post data element + Specified Encoding. If null then will be used + + + + Add a new that represents the key and value + + Post Data + byte array that represents the post data + + + + Response when + is called in an async fashion + + + + + Success + + + + + Error Message + + + + + Initializes a new instance of the SetPreferenceResponse class. + + success + error message + + + + Response when either + or are called. + + + + + Initializes a new instance of the SetProxyResponse class. + + success + error message + + + + + + + Proxy options + + + + + The IP address for the proxy + + + + + The port for the proxy + + + + + The username for authentication + + + + + The password for authentication + + + + + The list of domains that shouldn't be affected by the proxy, Format: example.com;example2.com + + + + + Checks if username and password is set + + Returns true if both username and password is set, otherwise false + + + The IP address for the proxy + The port for the proxy + The username required for authentication + The password required for authentication + The list of domains that shouldn't be affected by the proxy, Format: example.com;example2.com + + + + Class used to implement render process callbacks. + The methods of this class will be called on the render process main thread (TID_RENDERER) unless otherwise indicated. + + + + + Called immediately after the V8 context for a frame has been created. + V8 handles can only be accessed from the thread on which they are created. + + the browser + the frame + the V8Context + + + + Called immediately before the V8 context for a frame is released. + No references to the context should be kept after this method is called. + + the browser + the frame + the V8Context + + + + Called after WebKit has been initialized. + + + + + V8 context handle. + V8 handles can only be accessed from the thread on which they are created. + Valid threads for creating a V8 handle include the render process main thread (TID_RENDERER) and WebWorker threads. + A task runner for posting tasks on the associated thread can be retrieved via the CefV8Context::GetTaskRunner() method. + + + V8 is Google’s open source high-performance JavaScript and WebAssembly engine. + + + + + Execute a string of JavaScript code in this V8 context. + + JavaScript code to execute + Is the URL where the script in question can be found, if any + Is the base line number to use for error reporting. + Is the exception if any. + On success the function will return true. On failure will be set to the exception, if any, and the function will return false. + + + + Class representing a V8 exception. + + + V8 is Google’s open source high-performance JavaScript and WebAssembly engine. + + + + + Returns the index within the line of the last character where the error occurred. + + Returns the index within the line of the last character where the error occurred. + + + + Returns the index within the script of the last character where the error occurred. + + Returns the index within the script of the last character where the error occurred. + + + + Returns the 1-based number of the line where the error occurred or 0 if the line number is unknown. + + Returns the 1-based number of the line where the error occurred or 0 if the line number is unknown. + + + + Returns the exception message. + + Returns the exception message. + + + + Returns the resource name for the script from where the function causing the error originates. + + Returns the resource name for the script from where the function causing the error originates. + + + + Returns the line of source code that the exception occurred within. + + Returns the line of source code that the exception occurred within. + + + + Returns the index within the line of the first character where the error occurred. + + Returns the index within the line of the first character where the error occurred. + + + + Returns the index within the script of the first character where the error occurred. + + Returns the index within the script of the first character where the error occurred. + + + + V8 Exception + + index within the line of the last character where the error occurred. + index within the script of the last character where the error occurred. + 1-based number of the line where the error occurred or 0 if the line number is unknown. + exception message. + resource name for the script from where the function causing the error originates. + line of source code that the exception occurred within. + index within the line of the first character where the error occurred. + index within the script of the first character where the error occurred. + + + + RequestContext extensions. + + + + + Array of valid proxy schemes + + + + + Load an extension from the given directory. To load a crx file you must unzip it first. + For further details see + + request context + absolute path to the directory that contains the extension to be loaded. + handle events related to browser extensions + + + + Load extension(s) from the given directory. This methods obtains all the sub directories of + and calls if manifest.json + is found in the sub folder. To load crx file(s) you must unzip them first. + For further details see + + request context + absolute path to the directory that contains the extension(s) to be loaded. + handle events related to browser extensions + + + + Gets the cookie manager associated with the . Once the cookie manager + storage has been initialized the method will return. + + Thrown when an exception error condition occurs. + The instance this method extends. + returns if the store was successfully loaded otherwise null. + + + + Set the value associated with preference name. If value is null the + preference will be restored to its default value. If setting the preference + fails then error will be populated with a detailed description of the + problem. This method must be called on the CEF UI thread. + Preferences set via the command-line usually cannot be modified. + + request context + preference key + preference value + returns true if successfull, false otherwise. + Use Cef.UIThreadTaskFactory to execute this method if required, + and ChromiumWebBrowser.IsBrowserInitializedChanged are both + executed on the CEF UI thread, so can be called directly. + When CefSettings.MultiThreadedMessageLoop == false (the default is true) then the main + application thread will be the CEF UI thread. + + + + Sets the proxy server for the specified . + Protocol for the proxy server is http + + request context + proxy host + proxy port + returns true if successfull, false otherwise. + Internally calls with + preference 'proxy' and mode of 'fixed_servers' + + + + Sets the proxy server for the specified + + request context + is the protocol of the proxy server, and is one of: 'http', 'socks', 'socks4', 'socks5'. Also note that 'socks' is equivalent to 'socks5'. + proxy host + proxy port + returns true if successfull, false otherwise. + Internally calls with + preference 'proxy' and mode of 'fixed_servers' + + + + Sets the proxy server for the specified + MUST be called on the CEF UI Thread + + request context + is the protocol of the proxy server, and is one of: 'http', 'socks', 'socks4', 'socks5'. Also note that 'socks' is equivalent to 'socks5'. + proxy host + proxy port + error message + returns true if successfull, false otherwise. + Internally calls with + preference 'proxy' and mode of 'fixed_servers' + + + + Sets the proxy server for the specified . + Protocol for the proxy server is http + MUST be called on the CEF UI Thread + + request context + proxy host + proxy port + error message + returns true if successfull, false otherwise. + Internally calls with + preference 'proxy' and mode of 'fixed_servers' + + + + Sets the proxy server for the specified . + Protocol for the proxy server is http + MUST be called on the CEF UI Thread + + request context + proxy host + error message + returns true if successfull, false otherwise. + Internally calls with + preference 'proxy' and mode of 'fixed_servers' + + + + Creates a Dictionary that can be used with + + is the protocol of the proxy server, and is one of: 'http', 'socks', 'socks4', 'socks5'. Also note that 'socks' is equivalent to 'socks5'. + proxy host + proxy port + + + + + Clears all HTTP authentication credentials that were added as part of handling + . + + request context + A task that represents the ClearHttpAuthCredentials operation. + Result indicates if the credentials cleared successfully. + + + + Extension method to register a instance of the with the provided + for the + + request context + scheme name, e.g. http(s). If registering for a custom scheme then that scheme must be already registered. + It's recommended that you use https or http with a domain name rather than using a custom scheme. + Optional domain name + OWIN AppFunc as defined at owin.org + + + + Default implementation of . This latest implementation provides some simplification, at + a minimum you only need to override ProcessRequestAsync. See the project source on GitHub for working examples. + used to implement a custom request handler interface. The methods of this class will always be called on the IO thread. + Static helper methods are included like FromStream and FromString that make dealing with fixed resources easy. + + + + + MimeType to be used if none provided + + + + + We reuse a temp buffer where possible for copying the data from the stream + into the output stream + + + + + Gets or sets the Charset + + + + + Gets or sets the Mime Type. + + + + + Gets or sets the resource stream. + + + + + Gets or sets the http status code. + + + + + Gets or sets the status text. + + + + + Gets or sets ResponseLength, when you know the size of your + Stream (Response) set this property. This is optional. + If you use a MemoryStream and don't provide a value + here then it will be cast and its size used + + + + + Gets or sets the headers. + + The headers. + + + + When true the Stream will be Disposed when + this instance is Disposed. The default value for + this property is false. + + + + + If the ErrorCode is set then the response will be ignored and + the errorCode returned. + + + + + Initializes a new instance of the class. + + Optional mimeType defaults to + Optional Stream - must be set at some point to provide a valid response + When true the Stream will be disposed when this instance is Disposed, you will + be unable to use this ResourceHandler after the Stream has been disposed + response charset + + + + Begin processing the request. If you have the data in memory you can execute the callback + immediately and return true. For Async processing you would typically spawn a Task to perform processing, + then return true. When the processing is complete execute callback.Continue(); In your processing Task, simply set + the StatusCode, StatusText, MimeType, ResponseLength and Stream + + The request object. + The callback used to Continue or Cancel the request (async). + To handle the request return true and call + once the response header information is available + can also be called from inside this method if + header information is available immediately). + To cancel the request return false. + + + + Gets the resource from the file path specified. Use the Cef.GetMimeType() + helper method to lookup the mimeType if required. Uses CefStreamResourceHandler for reading the data + + Location of the file. + The mimeType if null then text/html is used. + Dispose of the stream when finished with (you will only be able to serve one + request). + IResourceHandler. + + + + Creates a IResourceHandler that represents a Byte[], uses CefStreamResourceHandler for reading the data + + data + mimeType + response charset + IResourceHandler + + + + Gets the resource from the string. + + The text. + The file extension. + ResourceHandler. + + + + Gets a that represents a string. + Without a Preamble, Cef will use BrowserSettings.DefaultEncoding to load the html. + + The html string + Character Encoding + Include encoding preamble + Mime Type + ResourceHandler + + + + Generates a ResourceHandler that has it's StatusCode set + + Body the response to be displayed + StatusCode + ResourceHandler + + + + Gets the resource from a stream. + + A stream of the resource. + Type of MIME. + Dispose of the stream when finished with (you will only be able to serve one + request). + response charset + ResourceHandler. + + + + Gets a MemoryStream from the given string using the provided encoding + + string to be converted to a stream + encoding + if true a BOM will be written to the beginning of the stream + A memory stream from the given string + + + + Gets a byteArray from the given string using the provided encoding + + string to be converted to a stream + encoding + if true a BOM will be written to the beginning of the stream + A memory stream from the given string + + + + Gets the MIME type of the content. + + The extension. + System.String. + extension + In most cases it's preferable to use Cef.GetMimeType(extension); instead. See https://github.com/cefsharp/CefSharp/issues/3041 for details. + + + + Dispose of resources here + + + + + Default implementation of it's used + internally for the LoadHtml implementation - basically a resource handler is + registered for a specific Url. + + + + + Resource handler thread safe dictionary + + + + + Create a new instance of DefaultResourceHandlerFactory + + string equality comparer + + + + Register a handler for the specified Url + + url + The data in byte[] format that will be used for the response + mime type + Whether or not the handler should be used once (true) or until manually unregistered (false) + returns true if the Url was successfully parsed into a Uri otherwise false + + + + Unregister a handler for the specified Url + + Url + returns true if successfully removed + + + + Are there any 's registered? + + + + + + + + Called on the CEF IO thread before a resource request is initiated. + + the ChromiumWebBrowser control + represent the source browser of the request + represent the source frame of the request + represents the request contents and cannot be modified in this callback + will be true if the resource request is a navigation + will be true if the resource request is a download + is the origin (scheme + domain) of the page that initiated the request + to true to disable default handling of the request, in which case it will need to be handled via or it will be canceled + To allow the resource load to proceed with default handling return null. To specify a handler for the resource return a object. If this callback returns null the same method will be called on the associated , if any + + + + A resource request handler factory item. + + + + + Data + + + + + Mime Type + + + + + Whether or not the handler should be used once (true) or until manually unregistered (false) + + + + + DefaultResourceHandlerFactoryItem constructor + + The data in byte[] format that will be used for the response + mime type + Whether or not the handler should be used once (true) or until manually unregistered (false) + + + + StreamResponseFilter - copies all data from IResponseFilter.Filter + to the provided Stream. The must be writable, no data will be copied otherwise. + The StreamResponseFilter will release it's reference (set to null) to the when it's Disposed. + + + + + StreamResponseFilter constructor + + a writable stream + + + + + + + FolderSchemeHandlerFactory is a very simple scheme handler that allows you + to map requests for urls to a folder on your file system. For example + creating a setting the rootFolder to c:\projects\CefSharp\CefSharp.Example\Resources + registering the scheme handler + + + + + is being deprecated in favour of using + Chromiums native mimeType lookup which is accessible using Cef.GetMimeType, this method is however + not directly available as it exists in CefSharp.Core, to get around this we set + this static delegate with a reference to Cef.GetMimeType when Cef.Initialize is called. + + + + + Initialize a new instance of FolderSchemeHandlerFactory + + Root Folder where all your files exist, requests cannot be made outside of this folder + if not null then schemeName checking will be implemented + if not null then hostName checking will be implemented + default page if no page specified, defaults to index.html + file share mode used to open resources, defaults to FileShare.Read + + + + If the file requested is within the rootFolder then a IResourceHandler reference to the file requested will be returned + otherwise a 404 ResourceHandler will be returned. + + the browser window that originated the + request or null if the request did not originate from a browser window + (for example, if the request came from CefURLRequest). + frame that originated the request + or null if the request did not originate from a browser window + (for example, if the request came from CefURLRequest). + the scheme name + The request. (will not contain cookie data) + + A IResourceHandler + + + + + If the file requested is within the rootFolder then a IResourceHandler reference to the file requested will be returned + otherwise a 404 ResourceHandler will be returned. + + the browser window that originated the + request or null if the request did not originate from a browser window + (for example, if the request came from CefURLRequest). + frame that originated the request + or null if the request did not originate from a browser window + (for example, if the request came from CefURLRequest). + the scheme name + The request. (will not contain cookie data) + + A IResourceHandler + + + + + implementation that uses an OWIN capable host of fulfilling requests. + Can be used with NancyFx or AspNet Core + + TODO: + - Multipart post data + - Cancellation Token + + + + OwinResourceHandler + + Owin pipeline func + + + + Read the request, then process it through the OWEN pipeline + then populate the response properties. + + request + callback + always returns true as we'll handle all requests this handler is registered for. + + + + implementation that takes an OWIN AppFunc + and uses an to fulfill each requests. + + + + + OwinSchemeHandlerFactory + + Owin pipeline func + + + + + + + Class that creates instances for handling scheme requests. + The methods of this class will always be called on the CEF IO thread. + + + + + Return a new instance to handle the request or an empty + reference to allow default handling of the request. + + the browser window that originated the + request or null if the request did not originate from a browser window + (for example, if the request came from CefURLRequest). + frame that originated the request + or null if the request did not originate from a browser window + (for example, if the request came from CefURLRequest). + the scheme name + The request. (will not contain cookie data) + + Return a new instance to handle the request or an empty + reference to allow default handling of the request + + + + + Class representing the SSL information for a navigation entry. + + + + + Returns true if the status is related to a secure SSL/TLS connection. + + + + + Returns a bitmask containing any and all problems verifying the server certificate. + If the certificate is valid then is returned. + + + + + Returns the SSL version used for the SSL connection. + + + + + + Returns a bitmask containing the page security content status. + + + + + Returns the X.509 certificate. + + + + + SslStatus + + is secure + cert status + ssl version + content status + certificate + + + + Structure representing the audio parameters for setting up the audio handler. + + + + + Layout of the audio channels + + + + + Sample rate + + + + + Number of frames per buffer + + + + + Init with default values + + channel layout + sample rate + frames per buffer + + + + Represents an IME composition underline. + + + + + Underline character range. + + + + + Text color. 32-bit ARGB color value, not premultiplied. The color components are always + in a known order. Equivalent to the SkColor type. + + + + + Background color. 32-bit ARGB color value, not premultiplied. The color components are always + in a known order. Equivalent to the SkColor type. + + + + + true for thickunderline + + + + + Style + + + + + Constructor. + + Underline character range. + Text color. 32-bit ARGB color value, not premultiplied. The color components are always in a known order. + Equivalent to the SkColor type. + Background color. 32-bit ARGB color value, not premultiplied. The color components are always in + a known order. Equivalent to the SkColor type. + True for thickunderline. + + + + Constructor. + + Underline character range. + Text color. 32-bit ARGB color value, not premultiplied. The color components are always in a known order. + Equivalent to the SkColor type. + Background color. 32-bit ARGB color value, not premultiplied. The color components are always in + a known order. Equivalent to the SkColor type. + True for thickunderline. + Style + + + + Struct representing cursor information. + + + + + Cursor buffer + + + + + Hotspot + + + + + Image scale factor + + + + + Size + + + + + CursorInfo + + buffer + hotspot + image scale factor + size + + + + Dom Rect + + + + + X coordinate + + + + + Y coordinate + + + + + Rectangle width + + + + + Rectangle height + + + + + Constructor + + x + y + width + height + + + + Class representing a point. + + + + + X coordinate + + + + + Y coordinate + + + + + Point + + x coordinate + y coordinate + + + + Represents a range + + + + + From + + + + + To + + + + + Range + + from + to + + + + Represents a rectangle + + + + + X coordinate + + + + + Y coordinate + + + + + Width + + + + + Height + + + + + Rect + + x coordinate + y coordinate + width + height + + + + Returns a new Rect with Scaled values + + Dpi to scale by + New rect with scaled values + + + + Class representing the virtual screen information for use when window + rendering is disabled. + + + See also
Chrome Source + + + + + Device scale factor. Specifies the ratio between physical and logical pixels. + + + + + The screen depth in bits per pixel. + + + + + The bits per color component. This assumes that the colors are balanced equally. + + + + + This can be true for black and white printers. + + + + + This is set from the rcMonitor member of MONITORINFOEX, to whit: + "A RECT structure that specifies the display monitor rectangle, + expressed in virtual-screen coordinates. Note that if the monitor + is not the primary display monitor, some of the rectangle's + coordinates may be negative values." + The Rect and AvailableRect properties are used to determine the + available surface for rendering popup views. + + + + + This is set from the rcWork member of MONITORINFOEX, to whit: + "A RECT structure that specifies the work area rectangle of the + display monitor that can be used by applications, expressed in + virtual-screen coordinates. Windows uses this rectangle to + maximize an application on the monitor. The rest of the area in + rcMonitor contains system windows such as the task bar and side + bars. Note that if the monitor is not the primary display monitor, + some of the rectangle's coordinates may be negative values". + + The Rect and AvailableRect properties are used to determine the + available surface for rendering popup views. + + + + + Structure representing a size. + + + + + Width + + + + + Height + + + + + Size + + width + height + + + + Touch Event + + + + + Id of a touch point. Must be unique per touch, can be any number except -1. + Note that a maximum of 16 concurrent touches will be tracked; touches + beyond that will be ignored. + + + + + X coordinate relative to the left side of the view. + + + + + Y coordinate relative to the top side of the view. + + + + + X radius in pixels. Set to 0 if not applicable. + + + + + Y radius in pixels. Set to 0 if not applicable. + + + + + Rotation angle in radians. Set to 0 if not applicable. + + + + + The device type that caused the event. + + + + + The normalized pressure of the pointer input in the range of [0,1]. + Set to 0 if not applicable. + + + + + The state of the touch point. Touches begin with one event + followed by zero or more events and finally one + or event. + Events not respecting this order will be ignored. + + + + + Bit flags describing any pressed modifier keys. + + + + + Representing a draggable region. + + + + + Width + + + + + Height + + + + + X coordinate + + + + + Y coordinate + + + + + Is this region draggable + + + + + Creates a new DraggableRegion + + width + height + x coordinate + y coordinate + is draggable? + + + + Class representing a a keyboard event. + + + + + The type of keyboard event. + + + + + Bit flags describing any pressed modifier keys. See + cef_event_flags_t for values. + + + + + The Windows key code for the key event. This value is used by the DOM + specification. Sometimes it comes directly from the event (i.e. on + Windows) and sometimes it's determined using a mapping function. See + WebCore/platform/chromium/KeyboardCodes.h for the list of values. + + + + + The actual key code genenerated by the platform. + + + + + Indicates whether the event is considered a "system key" event (see + http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for details). + This value will always be false on non-Windows platforms. + + + + + True if the focus is currently on an editable field on the page. This is useful for determining if standard key events should be intercepted. + + + + + Struct representing a mouse event. + + + + + x coordinate - relative to upper-left corner of view + + + + + y coordinate - relative to upper-left corner of view + + + + + Bit flags describing any pressed modifier keys. + + + + + Mouse Event + + x coordinate relative to the upper-left corner of the view. + y coordinate relative to the upper-left corner of the view. + modifiers + + + + IP Address solution callback result + + + + + The result code - on success + + + + + List of resolved IP addresses or empty if the resolution failed. + + + + + ResolveCallbackResult + + result + list of ip addresses + + + + The complete URL specification. + + + + + Scheme component not including the colon (e.g., "http"). + + + + + User name component. + + + + + Password component. + + + + + Host component. This may be a hostname, an IPv4 address or an IPv6 literal + surrounded by square brackets (e.g., "[2001:db8::1]"). + + + + + Port number component. + + + + + Origin contains just the scheme, host, and port from a URL. Equivalent to + clearing any username and password, replacing the path with a slash, and + clearing everything after that. This value will be empty for non-standard + URLs. + + + + + Path component including the first slash following the host. + + + + + Query string component (i.e., everything following the '?'). + + + + + Fragment (hash) identifier component (i.e., the string following the '#'). + + + + + Interface that should be implemented by the CefURLRequest client. + The methods of this class will be called on the same thread that created the request unless otherwise documented. + + + + + Called on the CEF IO thread when the browser needs credentials from the user. + This method will only be called for requests initiated from the browser process. + + indicates whether the host is a proxy server. + the hostname. + the port number. + realm + scheme + is a callback for authentication information + + Return true to continue the request and call when the authentication information is available. + If the request has an associated browser/frame then returning false will result in a call to + on the associated with that browser, if any. + Otherwise, returning false will cancel the request immediately. + + + + + Called on the CEF IO thread when the browser needs credentials from the user. + This method will only be called for requests initiated from the browser process. + + indicates whether the host is a proxy server. + the hostname. + the port number. + realm + scheme + is a callback for authentication information + + Return true to continue the request and call when the authentication information is available. + If the request has an associated browser/frame then returning false will result in a call to + on the associated with that browser, if any. + Otherwise, returning false will cancel the request immediately. + + + + + Called when some part of the response is read. This method will not be called if the flag is set on the request. + + request + A stream containing the bytes received since the last call. Cannot be used outside the scope of this method. + + + + Called when some part of the response is read. This method will not be called if the flag is set on the request. + + request + A stream containing the bytes received since the last call. Cannot be used outside the scope of this method. + + + + Notifies the client of download progress. + + request + denotes the number of bytes received up to the call + is the expected total size of the response (or -1 if not determined). + + + + Notifies the client of download progress. + + request + denotes the number of bytes received up to the call + is the expected total size of the response (or -1 if not determined). + + + + Notifies the client that the request has completed. + Use the property to determine if the + request was successful or not. + + request + + + + Notifies the client that the request has completed. + Use the property to determine if the + request was successful or not. + + request + + + + Notifies the client of upload progress. + This method will only be called if the UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + request + denotes the number of bytes sent so far. + is the total size of uploading data (or -1 if chunked upload is enabled). + + + + Notifies the client of upload progress. + This method will only be called if the UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request. + + request + denotes the number of bytes sent so far. + is the total size of uploading data (or -1 if chunked upload is enabled). + + + + Interface to implement for visiting cookie values. + The methods of this class will always be called on the IO thread. + If there are no cookies then Visit will never be called, you must implement + Dispose to handle this scenario. + + + + + Method that will be called once for each cookie. This method may never be called if no cookies are found. + + cookie + is the 0-based index for the current cookie. + is the total number of cookies. + Set to true to delete the cookie currently being visited. + Return false to stop visiting cookies otherwise true + + + + Callback interface for IBrowserHost.GetNavigationEntries. + The methods of this class will be called on the CEF UI thread. + + + + + Method that will be executed. + + if the navigationEntry will be invalid then + is true if this entry is the currently loaded navigation entry + is the 0-based index of this entry + is the total number of entries. + Return true to continue visiting entries or false to stop. + + + + Implement this interface to receive string values asynchronously. + + + + + Method that will be executed. + + string (result of async execution) + + + + Cookie Visitor implementation that uses a TaskCompletionSource + to return a List of cookies + + + + + Initializes a new instance of the TaskCookieVisitor class. + + + + + + + + + + + Task that can be awaited for the result to be retrieved async + + + + + A implementation that uses a + that allows you to call await/ContinueWith to get the list of NavigationEntries + + + + + Initializes a new instance of the TaskNavigationEntryVisitor class. + + + + + + + + + + + Task that can be awaited for the result to be retrieved async + + + + + A that uses a + that allows you to call await/ContinueWith to get the result string. + + + + + Initializes a new instance of the TaskStringVisitor class. + + + + + Method that will be executed. + + string (result of async execution) + + + + Task that can be awaited for the result to be retrieved async + + + + + WaitForNavigationAsyncResponse + + + + + Error Code. If the network request was made successfully this value will be + (no error occured) + + + + + Http Status Code. If is not equal to + then this value will be -1. + + + + + If is equal to and + is equal to 200 (OK) then the main frame loaded without + critical error. + + + + + Initializes a new instance of the WaitForNavigationAsyncResponse class. + + CEF Error Code + Http Status Code + + + + WaitForSelectorAsyncResponse + + + + + Element Id + + + + + Tag Name + + + + + True if the javascript was executed successfully + + + + + Error Message + + + + + True if the element was added to the DOM otherwise false if it was removed + + + + + WebBrowser extensions - These methods make performing common tasks easier. + + + + + Registers a Javascript object in this specific browser instance. + + The browser to perform the registering on. + The name of the object. (e.g. "foo", if you want the object to be accessible as window.foo). + The object to be made accessible to Javascript. + (Optional) binding options - camelCaseJavascriptNames default to true. + Browser is already initialized. RegisterJsObject must be + + called before the underlying CEF browser is created. + + + + Asynchronously registers a Javascript object in this specific browser instance. + Only methods of the object will be availabe. + + The browser to perform the registering on + The name of the object. (e.g. "foo", if you want the object to be accessible as window.foo). + The object to be made accessible to Javascript. + binding options - camelCaseJavascriptNames default to true + Browser is already initialized. RegisterJsObject must be + + called before the underlying CEF browser is created. + The registered methods can only be called in an async way, they will all return immediately and the resulting + object will be a standard javascript Promise object which is usable to wait for completion or failure. + + + + Returns the main (top-level) frame for the browser window. + + the ChromiumWebBrowser instance. + the main frame. + + + + Returns the focused frame for the browser window. + + the ChromiumWebBrowser instance. + the focused frame. + + + + Execute Undo on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute Undo on the focused frame. + + The IBrowser instance this method extends. + + + + Execute Redo on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute Redo on the focused frame. + + The IBrowser instance this method extends. + + + + Execute Cut on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute Cut on the focused frame. + + The IBrowser instance this method extends. + + + + Execute Copy on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute Copy on the focused frame. + + The IBrowser instance this method extends. + + + + Execute Paste on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute Paste on the focused frame. + + The IBrowser instance this method extends. + + + + Execute Delete on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute Delete on the focused frame. + + The IBrowser instance this method extends. + + + + Execute SelectAll on the focused frame. + + The ChromiumWebBrowser instance this method extends. + + + + Execute SelectAll on the focused frame. + + The IBrowser instance this method extends. + + + + Opens up a new program window (using the default text editor) where the source code of the currently displayed web page is + shown. + + The ChromiumWebBrowser instance this method extends. + + + + Opens up a new program window (using the default text editor) where the source code of the currently displayed web page is + shown. + + The IBrowser instance this method extends. + + + + Retrieve the main frame's HTML source using a . + + The ChromiumWebBrowser instance this method extends. + + that when executed returns the main frame source as a string. + + + + + Retrieve the main frame's HTML source using a . + + The IBrowser instance this method extends. + + that when executed returns the main frame source as a string. + + + + + Retrieve the main frame's display text using a . + + The ChromiumWebBrowser instance this method extends. + + that when executed returns the main frame display text as a string. + + + + + Retrieve the main frame's display text using a . + + The IBrowser instance this method extends. + + that when executed returns the main frame display text as a string. + + + + + Download the file at url using . + + The ChromiumWebBrowser instance this method extends. + url to download + + + + Download the file at url using . + + The IBrowser instance this method extends. + url to download + + + + See for details + + ChromiumWebBrowser instance (cannot be null) + + Load the in the main frame of the browser + + url to load + See for details + + + + This resolves when the browser navigates to a new URL or reloads. + It is useful for when you run code which will indirectly cause the browser to navigate. + A common use case would be when executing javascript that results in a navigation. e.g. clicks a link + This must be called before executing the action that navigates the browser. It may not resolve correctly + if called after. + + + Usage of the History API to change the URL is considered a navigation + + ChromiumWebBrowser instance (cannot be null) + optional timeout, if not specified defaults to five(5) seconds. + optional CancellationToken + Task which resolves when has been called with false. + or when is called to signify a load failure. + + + + + + + + + + Waits for a DOM element specified by the string to be added to or removed from the DOM. + A simplified version of Puppeteer WaitForSelector. Uses a MutationObserver to wait for the element to become added or removed. + + ChromiumWebBrowser instance (cannot be null) + querySelector for the element e.g. #idOfMyElement + timeout + + (Optional) if true waits for element to be removed from the DOM. If the querySelector immediately resolves + to null then the element is considered removed. If false (default) waits for the element to be added to the DOM. + + A Task that resolves when element specified by selector string is added to or removed from the DOM. + + + + + + + This function is typically used in conjunction with javascript that directly or indirectly adds/removes an element from the DOM. + Unlike the puppeteer version navigations aren't handled internally, the method will throw a if a navigation + occurs whilst waiting to resolve. + + + + + Execute Javascript code in the context of this Browser. As the method name implies, the script will be executed + asynchronously, and the method therefore returns before the script has actually been executed. This simple helper extension + will encapsulate params in single quotes (unless int, uint, etc) + + The ChromiumWebBrowser instance this method extends. + The javascript method name to execute. + the arguments to be passed as params to the method. Args are encoded using + , you can provide a custom implementation if you require one. + + + + Execute Javascript code in the context of this WebBrowser. As the method name implies, the script will be executed + asynchronously, and the method therefore returns before the script has actually been executed. This simple helper extension + will encapsulate params in single quotes (unless int, uint, etc) + + The IBrowser instance this method extends. + The javascript method name to execute. + the arguments to be passed as params to the method. Args are encoded using + , you can provide a custom implementation if you require one. + + + + Execute Javascript in the context of this Browsers Main Frame. As the method name implies, the script will be executed + asynchronously, and the method therefore returns before the script has actually been executed. + + The ChromiumWebBrowser instance this method extends. + The Javascript code that should be executed. + + + + Execute Javascript in the context of this Browser Main Frame. As the method name implies, the script will be executed + asynchronously, and the method therefore returns before the script has actually been executed. + + The IBrowser instance this method extends. + The Javascript code that should be executed. + + + + Execute Javascript code in the context of this Browsers Main Frame. This extension method uses the LoadingStateChanged event. As the + method name implies, the script will be executed asynchronously, and the method therefore returns before the script has + actually been executed. + + + Best effort is made to make sure the script is executed, there are likely a few edge cases where the script won't be executed, + if you suspect your script isn't being executed, then try executing in the LoadingStateChanged event handler to confirm that + it does indeed get executed. + + The ChromiumWebBrowser instance this method extends. + The Javascript code that should be executed. + (Optional) The script will only be executed on first page load, subsequent page loads will be ignored. + + + + Creates a new instance of IRequest with the specified Url and Method = POST and then calls + . + + browser this method extends + url to load + post data as byte array + (Optional) if set the Content-Type header will be set + + + + Creates a new instance of IRequest with the specified Url and Method = POST and then calls + . + + browser this method extends + url to load + post data as byte array + (Optional) if set the Content-Type header will be set + + + + Registers and loads a that represents the HTML content. + + + `Cef` Native `LoadHtml` is unpredictable and only works sometimes, this method wraps the provided HTML in a + and loads the provided url using the method. Defaults to using + for character encoding The url must start with a valid schema, other uri's such as about:blank + are invalid A valid example looks like http://test/page. + + The ChromiumWebBrowser instance this method extends. + The HTML content. + The URL that will be treated as the address of the content. + + returns false if the Url was not successfully parsed into a Uri. + + + + + Loads html as Data Uri See https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs for details If + base64Encode is false then html will be Uri encoded. + + The ChromiumWebBrowser instance this method extends. + Html to load as data uri. + (Optional) if true the html string will be base64 encoded using UTF8 encoding. + + + + Loads html as Data Uri See https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs for details If + base64Encode is false then html will be Uri encoded. + + The instance this method extends. + Html to load as data uri. + (Optional) if true the html string will be base64 encoded using UTF8 encoding. + + + + Registers and loads a that represents the HTML content. + + + `Cef` Native `LoadHtml` is unpredictable and only works sometimes, this method wraps the provided HTML in a + and loads the provided url using the method. + + Thrown when an exception error condition occurs. + The ChromiumWebBrowser instance this method extends. + The HTML content. + The URL that will be treated as the address of the content. + Character Encoding. + (Optional) Whether or not the handler should be used once (true) or until manually unregistered + (false) + + returns false if the Url was not successfully parsed into a Uri. + + + + + Register a ResourceHandler. Can only be used when browser.ResourceHandlerFactory is an instance of + DefaultResourceHandlerFactory. + + Thrown when an exception error condition occurs. + The ChromiumWebBrowser instance this method extends. + the url of the resource to unregister. + Stream to be registered, the stream should not be shared with any other instances of + DefaultResourceHandlerFactory. + (Optional) the mimeType. + (Optional) Whether or not the handler should be used once (true) or until manually unregistered + (false). If true the Stream will be Diposed of when finished. + + + + Unregister a ResourceHandler. Can only be used when browser.ResourceHandlerFactory is an instance of + DefaultResourceHandlerFactory. + + Thrown when an exception error condition occurs. + The ChromiumWebBrowser instance this method extends. + the url of the resource to unregister. + + + + Stops loading the current page. + + The ChromiumWebBrowser instance this method extends. + + + + Stops loading the current page. + + The IBrowser instance this method extends. + + + + Navigates back, must check before calling this method. + + The ChromiumWebBrowser instance this method extends. + + + + Navigates back, must check before calling this method. + + The IBrowser instance this method extends. + + + + Navigates forward, must check before calling this method. + + The ChromiumWebBrowser instance this method extends. + + + + Navigates forward, must check before calling this method. + + The IBrowser instance this method extends. + + + + Reloads the page being displayed. This method will use data from the browser's cache, if available. + + The ChromiumWebBrowser instance this method extends. + + + + Reloads the page being displayed, optionally ignoring the cache (which means the whole page including all .css, .js etc. + resources will be re-fetched). + + The ChromiumWebBrowser instance this method extends. + true A reload is performed ignoring browser cache; false A reload is performed using + files from the browser cache, if available. + + + + Reloads the page being displayed, optionally ignoring the cache (which means the whole page including all .css, .js etc. + resources will be re-fetched). + + The IBrowser instance this method extends. + true A reload is performed ignoring browser cache; false A reload is performed using + files from the browser cache, if available. + + + + Gets the default cookie manager associated with the instance. + + Thrown when an exception error condition occurs. + The ChromiumWebBrowser instance this method extends. + (Optional) If not null it will be executed asynchronously on the CEF IO thread after the manager's + storage has been initialized. + + Cookie Manager. + + + + + Gets the RequestContext associated with the instance. + + Thrown when an exception error condition occurs. + The ChromiumWebBrowser instance this method extends. + + RequestContext + + + + + Asynchronously gets the current Zoom Level. + + The ChromiumWebBrowser instance this method extends. + + An asynchronous result that yields the zoom level. + + + + + Asynchronously gets the current Zoom Level. + + the ChromiumWebBrowser instance. + + An asynchronous result that yields the zoom level. + + + + + Change the ZoomLevel to the specified value. Can be set to 0.0 to clear the zoom level. + + + If called on the CEF UI thread the change will be applied immediately. Otherwise, the change will be applied asynchronously + on the CEF UI thread. The CEF UI thread is different to the WPF/WinForms UI Thread. + + The ChromiumWebBrowser instance this method extends. + zoom level. + + + + Change the ZoomLevel to the specified value. Can be set to 0.0 to clear the zoom level. + + + If called on the CEF UI thread the change will be applied immediately. Otherwise, the change will be applied asynchronously + on the CEF UI thread. The CEF UI thread is different to the WPF/WinForms UI Thread. + + The ChromiumWebBrowser instance this method extends. + zoom level. + + + + Search for text within the current page. + + The instance this method extends. + text to search for + indicates whether to search forward or backward within the page + indicates whether the search should be case-sensitive + indicates whether this is the first request or a follow-up + The instance, if any, will be called to report find results. + + + + Search for text within the current page. + + The ChromiumWebBrowser instance this method extends. + text to search for + indicates whether to search forward or backward within the page + indicates whether the search should be case-sensitive + indicates whether this is the first request or a follow-up + The instance, if any, will be called to report find results. + + + + Cancel all searches that are currently going on. + + The instance this method extends. + clear the current search selection. + + + + Cancel all searches that are currently going on. + + The ChromiumWebBrowser instance this method extends. + clear the current search selection. + + + + Opens a Print Dialog which if used (can be user cancelled) will print the browser contents. + + The browser instance this method extends. + + + + Opens a Print Dialog which if used (can be user cancelled) will print the browser contents. + + The ChromiumWebBrowser instance this method extends. + + + + Asynchronously prints the current browser contents to the PDF file specified. The caller is responsible for deleting the file + when done. + + The object this method extends. + Output file location. + (Optional) Print Settings. + + A task that represents the asynchronous print operation. The result is true on success or false on failure to generate the + Pdf. + + + + + Asynchronously prints the current browser contents to the PDF file specified. The caller is responsible for deleting the file + when done. + + The ChromiumWebBrowser instance this method extends. + Output file location. + (Optional) Print Settings. + + A task that represents the asynchronous print operation. The result is true on success or false on failure to generate the + Pdf. + + + + + Open developer tools in its own window. + + The instance this method extends. + (Optional) window info used for showing dev tools. + (Optional) x coordinate (used for inspectElement) + (Optional) y coordinate (used for inspectElement) + + + + Open developer tools in its own window. + + The ChromiumWebBrowser instance this method extends. + (Optional) window info used for showing dev tools. + (Optional) x coordinate (used for inspectElement) + (Optional) y coordinate (used for inspectElement) + + + + Explicitly close the developer tools window if one exists for this browser instance. + + The instance this method extends. + + + + Explicitly close the developer tools window if one exists for this browser instance. + + The ChromiumWebBrowser instance this method extends. + + + + If a misspelled word is currently selected in an editable node calling this method will replace it with the specified word. + + The instance this method extends. + The new word that will replace the currently selected word. + + + + If a misspelled word is currently selected in an editable node calling this method will replace it with the specified word. + + The ChromiumWebBrowser instance this method extends. + The new word that will replace the currently selected word. + + + + Add the specified word to the spelling dictionary. + + The instance this method extends. + The new word that will be added to the dictionary. + + + + Add the specified word to the spelling dictionary. + + The ChromiumWebBrowser instance this method extends. + The new word that will be added to the dictionary. + + + + Shortcut method to get the browser IBrowserHost. + + The ChromiumWebBrowser instance this method extends. + + browserHost or null. + + + + + Send a mouse wheel event to the browser. + + The ChromiumWebBrowser instance this method extends. + The x coordinate relative to upper-left corner of view. + The y coordinate relative to upper-left corner of view. + The delta x coordinate. + The delta y coordinate. + The modifiers. + + + + Send a mouse wheel event to the browser. + + The instance this method extends. + The x coordinate relative to upper-left corner of view. + The y coordinate relative to upper-left corner of view. + The delta x coordinate. + The delta y coordinate. + The modifiers. + + + + Send a mouse wheel event to the browser. + + browserHost. + The x coordinate relative to upper-left corner of view. + The y coordinate relative to upper-left corner of view. + The delta x coordinate. + The delta y coordinate. + The modifiers. + + + + Send a mouse click event to the browser. + + browserHost. + The x coordinate relative to upper-left corner of view. + The y coordinate relative to upper-left corner of view. + Type of the mouse button. + True to mouse up. + Number of clicks. + The modifiers. + + + + Send a mouse move event to the browser. + + browserHost. + The x coordinate relative to upper-left corner of view. + The y coordinate relative to upper-left corner of view. + mouse leave. + The modifiers. + + + + Evaluate Javascript in the context of the MainFrame of the ChromiumWebBrowser. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript. The result of the script execution + in javascript is Promise.resolve so even no promise values will be treated as a promise. Your javascript should return a value. + The javascript will be wrapped in an Immediately Invoked Function Expression. + When the promise either trigger then/catch this returned Task will be completed. + + Thrown when one or more arguments are outside the required range. + The ChromiumWebBrowser instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + + that can be awaited to perform the script execution. + + + + + Evaluate Javascript in the context of this Browsers Main Frame. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript. The result of the script execution + in javascript is Promise.resolve so even no promise values will be treated as a promise. Your javascript should return a value. + The javascript will be wrapped in an Immediately Invoked Function Expression. + When the promise either trigger then/catch this returned Task will be completed. + + Thrown when one or more arguments are outside the required range. + The IBrowser instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + + that can be awaited to perform the script execution. + + + + + Evaluate Javascript in the context of this Browsers Main Frame. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript. The result of the script execution + in javascript is Promise.resolve so even no promise values will be treated as a promise. Your javascript should return a value. + The javascript will be wrapped in an Immediately Invoked Function Expression. + When the promise either trigger then/catch this returned Task will be completed. + + Thrown when one or more arguments are outside the required range. + The instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + + Only required if a custom value was specified for + then this param must match that value. Otherwise exclude passing a value for this param or pass in null. + + + that can be awaited to perform the script execution. + + + + + Evaluate Javascript in the context of this Browsers Main Frame. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript + + Thrown when one or more arguments are outside the required range. + The ChromiumWebBrowser instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + When true the script is wrapped in a self executing function. + Make sure to use a return statement in your javascript. e.g. (function () { return 42; })(); + When false don't include a return statement e.g. 42; + + + that can be awaited to obtain the result of the script execution. + + + + + Evaluate some Javascript code in the context of the MainFrame of the ChromiumWebBrowser. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript + + Thrown when one or more arguments are outside the required range. + The IBrowser instance this method extends. + The Javascript code that should be executed. + (Optional) The timeout after which the Javascript code execution should be aborted. + When true the script is wrapped in a self executing function. + Make sure to use a return statement in your javascript. e.g. (function () { return 42; })(); + When false don't include a return statement e.g. 42; + + + that can be awaited to obtain the result of the script execution. + + + + + Evaluate some Javascript code in the context of this WebBrowser. The script will be executed asynchronously and the method + returns a Task encapsulating the response from the Javascript This simple helper extension will encapsulate params in single + quotes (unless int, uint, etc) + + The ChromiumWebBrowser instance this method extends. + The javascript method name to execute. + the arguments to be passed as params to the method. + + that can be awaited to obtain the result of the script execution. + + + + + Evaluate Javascript code in the context of this WebBrowser using the specified timeout. The script will be executed + asynchronously and the method returns a Task encapsulating the response from the Javascript This simple helper extension will + encapsulate params in single quotes (unless int, uint, etc). + + The ChromiumWebBrowser instance this method extends. + The timeout after which the Javascript code execution should be aborted. + The javascript method name to execute. + the arguments to be passed as params to the method. Args are encoded using + , you can provide a custom implementation if you require a custom implementation. + + that can be awaited to perform the script execution. + + + + + An IWebBrowser extension method that sets the + property used when passing a ChromiumWebBrowser instance to + + The ChromiumWebBrowser instance this method extends. + + + + Dispose of the DevToolsContext (if any). Used in conjunction with CefSharp.Dom + + ChromiumWebBrowser instance + + + + Set the property to null. Used in conjunction with CefSharp.Dom + + ChromiumWebBrowser instance + + + + Function used to encode the params passed to , + and + + Provide your own custom function to perform custom encoding. You can use your choice of JSON encoder here if you should so + choose. + + + A function delegate that yields a string. + + + + + Checks if the given object is a numerical object. + + The object to check. + + True if numeric, otherwise false. + + + + + Transforms the methodName and arguments into valid Javascript code. Will encapsulate params in single quotes (unless int, + uint, etc) + + The javascript method name to execute. + the arguments to be passed as params to the method. + + The Javascript code. + + + + + Throw exception if frame null. + + Thrown when an exception error condition occurs. + The instance this method extends. + + + + An IBrowser extension method that throw exception if browser null. + + Thrown when an exception error condition occurs. + The ChromiumWebBrowser instance this method extends. + + + + Throw exception if browser host null. + + Thrown when an exception error condition occurs. + The browser host. + + + + Throw exception if can execute javascript in main frame false. + + Thrown when an exception error condition occurs. + + + + Represents an raw Html (not already encoded) + When passed to a ChromiumWebBrowser constructor, the html will be converted to a Data Uri + and loaded in the browser. + See https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs for details + + + + + Initializes a new instance of the HtmlString class. + + raw html string (not already encoded) + if true the html string will be base64 encoded using UTF8 encoding. + if not null then charset will specified. e.g. UTF-8 + + + + The html as a Data Uri encoded string + + data Uri string suitable for passing to + + + + HtmlString that will be base64 encoded + + raw html (not already encoded) + + + + Creates a HtmlString for the given file name + Uses to read the + text using encoding. + + file name + HtmlString + + + + Represents a JsonString that is converted to a V8 Object + Used as a return type of bound methods + + + + + JSON String + + + + + Default constructor + + JSON string + + + + + + + Create a JsonString from the specfied object using the build in + + object to seriaize + optional settings + If is null then return nulls otherwise a JsonString. + + + diff --git a/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.dll b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.dll new file mode 100644 index 0000000..bcef210 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.dll differ diff --git a/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.pdb b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.pdb new file mode 100644 index 0000000..51e4d58 Binary files /dev/null and b/packages/CefSharp.Common.113.1.40/lib/net452/CefSharp.pdb differ diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/AssemblyInfo.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/AssemblyInfo.cpp new file mode 100644 index 0000000..1aee054 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/AssemblyInfo.cpp @@ -0,0 +1,24 @@ +#include "Stdafx.h" + +using namespace System; +using namespace System::Reflection; +using namespace System::Runtime::CompilerServices; +using namespace System::Runtime::InteropServices; +using namespace System::Security::Permissions; +using namespace CefSharp; + +//[assembly:AssemblyTitle("CefSharpBrowserSubprocess.Core")]; +//[assembly:AssemblyCompany(AssemblyInfo::AssemblyCompany)]; +//[assembly:AssemblyProduct(AssemblyInfo::AssemblyProduct)]; +//[assembly:AssemblyCopyright(AssemblyInfo::AssemblyCopyright)]; + +[assembly:AssemblyVersion(AssemblyInfo::AssemblyVersion)]; +[assembly:ComVisible(AssemblyInfo::ComVisible)]; +[assembly:CLSCompliant(AssemblyInfo::ClsCompliant)]; + +[assembly:AssemblyDescription("")]; +[assembly:AssemblyConfiguration("")]; +[assembly:AssemblyTrademark("")]; +[assembly:AssemblyCulture("")]; + +[assembly:InternalsVisibleTo(AssemblyInfo::CefSharpBrowserSubprocessProject)]; diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodCallback.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodCallback.cpp new file mode 100644 index 0000000..b7c6b55 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodCallback.cpp @@ -0,0 +1,49 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "stdafx.h" +#include "JavascriptAsyncMethodCallback.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + void JavascriptAsyncMethodCallback::Success(const CefRefPtr& result) + { + if (_resolve.get() && _context.get() && _context->Enter()) + { + try + { + CefV8ValueList args; + args.push_back(result); + _resolve->ExecuteFunction(nullptr, args); + } + finally + { + _context->Exit(); + } + } + } + + void JavascriptAsyncMethodCallback::Fail(const CefString& exception) + { + if (_reject.get() && _context.get() && _context->Enter()) + { + try + { + CefV8ValueList args; + args.push_back(CefV8Value::CreateString(exception)); + _reject->ExecuteFunction(nullptr, args); + } + finally + { + _context->Exit(); + } + } + } + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodCallback.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodCallback.h new file mode 100644 index 0000000..27411d7 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodCallback.h @@ -0,0 +1,47 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + private ref class JavascriptAsyncMethodCallback + { + private: + MCefRefPtr _context; + MCefRefPtr _resolve; + MCefRefPtr _reject; + + public: + JavascriptAsyncMethodCallback(CefRefPtr context, CefRefPtr resolve, CefRefPtr reject) + :_context(context), _resolve(resolve.get()), _reject(reject.get()) + { + + } + + !JavascriptAsyncMethodCallback() + { + _resolve = nullptr; + _reject = nullptr; + _context = nullptr; + } + + ~JavascriptAsyncMethodCallback() + { + this->!JavascriptAsyncMethodCallback(); + } + + void Success(const CefRefPtr& result); + + void Fail(const CefString& exception); + }; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp new file mode 100644 index 0000000..71628d7 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.cpp @@ -0,0 +1,74 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "stdafx.h" +#include "JavascriptAsyncMethodHandler.h" +#include "../CefSharp.Core.Runtime/Internals/Messaging/Messages.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/Primitives.h" +#include "Serialization/V8Serialization.h" +#include "CefAppUnmanagedWrapper.h" + +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::Internals::Serialization; +using namespace CefSharp::BrowserSubprocess::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + bool JavascriptAsyncMethodHandler::Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception) + { + auto context = CefV8Context::GetCurrentContext(); + auto frame = context->GetFrame(); + + CefRefPtr promiseData; + CefRefPtr promiseException; + //this will create a promise and give us the reject/resolve functions {p: Promise, res: resolve(), rej: reject()} + if (!context->Eval(CefAppUnmanagedWrapper::kPromiseCreatorScript, CefString(), 0, promiseData, promiseException)) + { + LOG(WARNING) << "JavascriptAsyncMethodHandler::Execute promiseData returned exception: " + promiseException->GetMessage().ToString(); + + exception = promiseException->GetMessage(); + + return true; + } + + //when refreshing the browser this is sometimes null, in this case return true and log message + //https://github.com/cefsharp/CefSharp/pull/2446 + if (promiseData == nullptr) + { + LOG(WARNING) << "JavascriptAsyncMethodHandler::Execute promiseData returned nullptr"; + + return true; + } + + retval = promiseData->GetValue("p"); + + auto resolve = promiseData->GetValue("res"); + auto reject = promiseData->GetValue("rej"); + auto callback = gcnew JavascriptAsyncMethodCallback(context, resolve, reject); + auto callbackId = _methodCallbackSave->Invoke(callback); + + auto request = CefProcessMessage::Create(kJavascriptAsyncMethodCallRequest); + auto argList = request->GetArgumentList(); + auto params = CefListValue::Create(); + for (size_t i = 0; i < arguments.size(); i++) + { + SerializeV8Object(arguments[i], params, i, _callbackRegistry); + } + + SetInt64(argList, 0, _objectId); + SetInt64(argList, 1, callbackId); + argList->SetString(2, name); + argList->SetList(3, params); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, request); + + return true; + } + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.h new file mode 100644 index 0000000..c98a4ba --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodHandler.h @@ -0,0 +1,45 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "JavascriptCallbackRegistry.h" +#include "JavascriptAsyncMethodCallback.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + private class JavascriptAsyncMethodHandler : public virtual CefV8Handler + { + private: + gcroot _callbackRegistry; + gcroot^> _methodCallbackSave; + int64 _objectId; + + public: + JavascriptAsyncMethodHandler(int64 objectId, JavascriptCallbackRegistry^ callbackRegistry, Func^ methodCallbackSave) + :_callbackRegistry(callbackRegistry), _objectId(objectId), _methodCallbackSave(methodCallbackSave) + { + + } + + virtual bool Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception); + + ~JavascriptAsyncMethodHandler() + { + // The callback registry is a shared instance among all method handlers (async & sync). + // It's lifecycle is managed in the JavascriptRootObjectWrapper. + _callbackRegistry = nullptr; + _methodCallbackSave = nullptr; + } + + IMPLEMENT_REFCOUNTINGM(JavascriptAsyncMethodHandler); + }; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodWrapper.cpp new file mode 100644 index 0000000..9d60fc2 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodWrapper.cpp @@ -0,0 +1,24 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "stdafx.h" +#include "JavascriptCallbackRegistry.h" +#include "JavascriptAsyncMethodWrapper.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + void JavascriptAsyncMethodWrapper::Bind(JavascriptMethod^ method, const CefRefPtr& value) + { + auto methodName = StringUtils::ToNative(method->JavascriptName); + auto v8Function = CefV8Value::CreateFunction(methodName, _javascriptMethodHandler.get()); + + value->SetValue(methodName, v8Function, V8_PROPERTY_ATTRIBUTE_NONE); + } + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodWrapper.h new file mode 100644 index 0000000..0231667 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncMethodWrapper.h @@ -0,0 +1,32 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "JavascriptAsyncMethodHandler.h" +#include "JavascriptCallbackRegistry.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + private ref class JavascriptAsyncMethodWrapper + { + private: + MCefRefPtr _javascriptMethodHandler; + + public: + JavascriptAsyncMethodWrapper(int64 ownerId, JavascriptCallbackRegistry^ callbackRegistry, Func^ methodCallbackSave) + : _javascriptMethodHandler(new JavascriptAsyncMethodHandler(ownerId, callbackRegistry, methodCallbackSave)) + { + + } + + void Bind(JavascriptMethod^ method, const CefRefPtr& value); + }; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncObjectWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncObjectWrapper.cpp new file mode 100644 index 0000000..401b85a --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncObjectWrapper.cpp @@ -0,0 +1,35 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "stdafx.h" +#include "JavascriptCallbackRegistry.h" +#include "JavascriptAsyncObjectWrapper.h" +#include "JavascriptAsyncMethodWrapper.h" + +using namespace System::Linq; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + void JavascriptAsyncObjectWrapper::Bind(JavascriptObject^ object, const CefRefPtr &value) + { + //V8Value that represents this javascript object - only one per complex type, no accessor + auto javascriptObject = CefV8Value::CreateObject(nullptr, nullptr); + auto objectName = StringUtils::ToNative(object->JavascriptName); + value->SetValue(objectName, javascriptObject, V8_PROPERTY_ATTRIBUTE_NONE); + + for each (JavascriptMethod^ method in Enumerable::OfType(object->Methods)) + { + auto wrappedMethod = gcnew JavascriptAsyncMethodWrapper(object->Id, _callbackRegistry, _methodCallbackSave); + wrappedMethod->Bind(method, javascriptObject); + + _wrappedMethods->Add(wrappedMethod); + } + } + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncObjectWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncObjectWrapper.h new file mode 100644 index 0000000..6aa5d00 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Async/JavascriptAsyncObjectWrapper.h @@ -0,0 +1,45 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "JavascriptAsyncMethodCallback.h" +#include "JavascriptCallbackRegistry.h" +#include "JavascriptAsyncMethodWrapper.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Async + { + private ref class JavascriptAsyncObjectWrapper + { + private: + initonly List^ _wrappedMethods; + Func^ _methodCallbackSave; + JavascriptCallbackRegistry^ _callbackRegistry; + + public: + JavascriptAsyncObjectWrapper(JavascriptCallbackRegistry^ callbackRegistry, Func^ saveMethod) + : _wrappedMethods(gcnew List()), _methodCallbackSave(saveMethod), _callbackRegistry(callbackRegistry) + { + + } + + ~JavascriptAsyncObjectWrapper() + { + _callbackRegistry = nullptr; + _methodCallbackSave = nullptr; + for each (JavascriptAsyncMethodWrapper^ var in _wrappedMethods) + { + delete var; + } + } + + void Bind(JavascriptObject^ object, const CefRefPtr &value); + }; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h new file mode 100644 index 0000000..bbe39fe --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/BindObjectAsyncHandler.h @@ -0,0 +1,328 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "RegisterBoundObjectRegistry.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" + +using namespace System; +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::Internals::Serialization; +using namespace CefSharp::BrowserSubprocess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + const CefString kBindObjectAsync = CefString("BindObjectAsync"); + const CefString kBindObjectAsyncCamelCase = CefString("bindObjectAsync"); + + private class BindObjectAsyncHandler : public CefV8Handler + { + private: + gcroot _callbackRegistry; + gcroot^> _javascriptObjects; + gcroot _browserWrapper; + + public: + BindObjectAsyncHandler(RegisterBoundObjectRegistry^ callbackRegistery, Dictionary^ javascriptObjects, CefBrowserWrapper^ browserWrapper) + { + _callbackRegistry = callbackRegistery; + _javascriptObjects = javascriptObjects; + _browserWrapper = browserWrapper; + } + + ~BindObjectAsyncHandler() + { + _callbackRegistry = nullptr; + _javascriptObjects = nullptr; + _browserWrapper = nullptr; + } + + bool Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception) override + { + auto context = CefV8Context::GetCurrentContext(); + + if (context.get() && context->Enter()) + { + try + { + auto params = CefListValue::Create(); + //We need to store a seperate index into our params as + //there are instances we skip over already cached objects + //and end up with empty strings in the list. + //e.g. first object is already bound/cached, we previously + //second object isn't we end up with a list of "", "secondObject" + int paramsIndex = 0; + + auto boundObjectRequired = false; + auto notifyIfAlreadyBound = false; + auto ignoreCache = false; + auto cachedObjects = gcnew List(); + //TODO: Create object to represent this information + auto objectNamesWithBoundStatus = gcnew List^>(); + auto objectCount = 0; + + if (arguments.size() > 0) + { + objectCount = (int)arguments.size(); + + //If first argument is an object, we'll see if it contains config values + if (arguments[0]->IsObject()) + { + //Upper and camelcase options are supported + notifyIfAlreadyBound = GetV8BoolValue(arguments[0], "NotifyIfAlreadyBound", "notifyIfAlreadyBound"); + ignoreCache = GetV8BoolValue(arguments[0], "IgnoreCache", "ignoreCache"); + + //If we have a config object then we remove that from the count + objectCount = objectCount - 1; + } + + auto global = context->GetGlobal(); + + //Loop through all arguments and ignore anything that's not a string + for (size_t i = 0; i < arguments.size(); i++) + { + //Validate arg as being a string + if (arguments[i]->IsString()) + { + auto objectName = arguments[i]->GetStringValue(); + auto managedObjectName = StringUtils::ToClr(objectName); + auto alreadyBound = global->HasValue(objectName); + auto cached = false; + + //Check if the object has already been bound + if (alreadyBound) + { + cached = _javascriptObjects->ContainsKey(managedObjectName); + } + else + { + //If no matching object found then we'll add the object name to the list + boundObjectRequired = true; + params->SetString(paramsIndex++, objectName); + + JavascriptObject^ obj; + if (_javascriptObjects->TryGetValue(managedObjectName, obj)) + { + cachedObjects->Add(obj); + + cached = true; + } + } + + objectNamesWithBoundStatus->Add(Tuple::Create(managedObjectName, alreadyBound, cached)); + } + } + } + else + { + //No objects names were specified so we default to makeing the request + boundObjectRequired = true; + } + + auto frame = context->GetFrame(); + + if (frame.get() && frame->IsValid()) + { + if (boundObjectRequired || ignoreCache) + { + //If the number of cached objects matches the number of args + //(we have a cached copy of all requested objects) + //then we'll immediately bind the cached objects + //If objectCount and cachedObject count are both 0 then we'll + //send the kJavascriptRootObjectRequest message + //https://github.com/cefsharp/CefSharp/issues/3470 + if (objectCount > 0 && cachedObjects->Count == objectCount && ignoreCache == false) + { + if (Object::ReferenceEquals(_browserWrapper, nullptr)) + { + exception = "BindObjectAsyncHandler::Execute - Browser wrapper null, unable to bind objects"; + + return true; + } + + auto browser = context->GetBrowser(); + + auto rootObjectWrappers = _browserWrapper->JavascriptRootObjectWrappers; + + JavascriptRootObjectWrapper^ rootObject; + if (!rootObjectWrappers->TryGetValue(frame->GetIdentifier(), rootObject)) + { +#ifdef NETCOREAPP + rootObject = gcnew JavascriptRootObjectWrapper(browser->GetIdentifier()); +#else + rootObject = gcnew JavascriptRootObjectWrapper(browser->GetIdentifier(), _browserWrapper->BrowserProcess); +#endif + rootObjectWrappers->TryAdd(frame->GetIdentifier(), rootObject); + } + + //Cached objects only contains a list of objects not already bound + rootObject->Bind(cachedObjects, context->GetGlobal()); + + //Objects already bound or ignore cache + CefRefPtr promiseResolve; + CefRefPtr promiseException; + + auto promiseResolveScript = StringUtils::ToNative("Promise.resolve({Success:true, Count:" + cachedObjects->Count + ", Message:'OK'});"); + + if (context->Eval(promiseResolveScript, CefString(), 0, promiseResolve, promiseException)) + { + retval = promiseResolve; + } + else + { + exception = promiseException->GetMessage(); + + return true; + } + + NotifyObjectBound(frame, objectNamesWithBoundStatus); + } + else + { + CefRefPtr promiseData; + CefRefPtr promiseException; + //this will create a promise and give us the reject/resolve functions {p: Promise, res: resolve(), rej: reject()} + if (!context->Eval(CefAppUnmanagedWrapper::kPromiseCreatorScript, CefString(), 0, promiseData, promiseException)) + { + exception = promiseException->GetMessage(); + + return true; + } + + //when refreshing the browser this is sometimes null, in this case return true and log message + //https://github.com/cefsharp/CefSharp/pull/2446 + if (promiseData == nullptr) + { + LOG(WARNING) << "BindObjectAsyncHandler::Execute promiseData returned nullptr"; + + return true; + } + + //return the promose + retval = promiseData->GetValue("p"); + + //References to the promise resolve and reject methods + auto resolve = promiseData->GetValue("res"); + auto reject = promiseData->GetValue("rej"); + + auto callback = gcnew JavascriptAsyncMethodCallback(context, resolve, reject); + + auto request = CefProcessMessage::Create(kJavascriptRootObjectRequest); + auto argList = request->GetArgumentList(); + + //Obtain a callbackId then send off the Request for objects + auto callbackId = _callbackRegistry->SaveMethodCallback(callback); + + SetInt64(argList, 0, callbackId); + argList->SetList(1, params); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, request); + } + } + else + { + //Objects already bound or ignore cache + CefRefPtr promiseResolve; + CefRefPtr promiseException; + + auto promiseResolveScript = CefString("Promise.resolve({Success:false, Count:0, Message:'Object(s) already bound'});"); + + if (context->Eval(promiseResolveScript, CefString(), 0, promiseResolve, promiseException)) + { + retval = promiseResolve; + + if (notifyIfAlreadyBound) + { + NotifyObjectBound(frame, objectNamesWithBoundStatus); + } + } + else + { + exception = promiseException->GetMessage(); + } + } + } + else + { + exception = "BindObjectAsyncHandler::Execute - Frame is invalid."; + } + } + finally + { + context->Exit(); + } + } + else + { + exception = "BindObjectAsyncHandler::Execute - Unable to Get or Enter Context"; + } + + + return true; + } + + private: + void NotifyObjectBound(const CefRefPtr frame, List^>^ objectNamesWithBoundStatus) + { + //Send message notifying Browser Process of which objects were bound + //We do this after the objects have been created in the V8Context to gurantee + //they are accessible. + auto msg = CefProcessMessage::Create(kJavascriptObjectsBoundInJavascript); + auto args = msg->GetArgumentList(); + + auto boundObjects = CefListValue::Create(); + auto index = 0; + + for each (auto obj in objectNamesWithBoundStatus) + { + auto dict = CefDictionaryValue::Create(); + + auto name = obj->Item1; + auto alreadyBound = obj->Item2; + auto isCached = obj->Item3; + dict->SetString("Name", StringUtils::ToNative(name)); + dict->SetBool("IsCached", isCached); + dict->SetBool("AlreadyBound", alreadyBound); + + boundObjects->SetDictionary(index++, dict); + } + + args->SetList(0, boundObjects); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, msg); + } + + bool GetV8BoolValue(const CefRefPtr val, const CefString key, const CefString camelCaseKey) + { + if (val->HasValue(key)) + { + auto obj = val->GetValue(key); + if (obj->IsBool()) + { + return obj->GetBoolValue(); + } + } + + if (val->HasValue(camelCaseKey)) + { + auto obj = val->GetValue(camelCaseKey); + if (obj->IsBool()) + { + return obj->GetBoolValue(); + } + } + + return false; + } + + IMPLEMENT_REFCOUNTINGM(BindObjectAsyncHandler); + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/BrowserSubprocessExecutable.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/BrowserSubprocessExecutable.h new file mode 100644 index 0000000..7d624dc --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/BrowserSubprocessExecutable.h @@ -0,0 +1,164 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "SubProcess.h" + +using namespace System; +using namespace CefSharp::Internals; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + /// + /// BrowserSubprocessExecutable provides the fundimental browser process handling for + /// CefSharp.BrowserSubprocess.exe and can be used to self host the BrowserSubProcess in your + /// existing application (preferred approach for .Net Core). + /// + public ref class BrowserSubprocessExecutable + { + public: + BrowserSubprocessExecutable() + { + + } + + /// + /// This function should be called from the application entry point function (typically Program.Main) + /// to execute a secondary process e.g. gpu, renderer, utility + /// This overload is specifically used for .Net Core. For hosting your own BrowserSubProcess + /// it's preferable to use the Main method provided by this class. + /// - Obtains the command line args via a call to Environment::GetCommandLineArgs + /// + /// + /// If called for the browser process (identified by no "type" command-line value) it will return immediately + /// with a value of -1. If called for a recognized secondary process it will block until the process should exit + /// and then return the process exit code. + /// ^ args) + { + auto subProcess = gcnew BrowserSubprocessExecutable(); + return subProcess->Main(args, nullptr); + } + + /// + /// This function should be called from the application entry point function (typically Program.Main) + /// to execute a secondary process e.g. gpu, renderer, utility + /// This overload is specifically used for .Net Core. For hosting your own BrowserSubProcess + /// it's preferable to use the Main method provided by this class. + /// - Obtains the command line args via a call to Environment::GetCommandLineArgs + /// + /// + /// If called for the browser process (identified by no "type" command-line value) it will return immediately + /// with a value of -1. If called for a recognized secondary process it will block until the process should exit + /// and then return the process exit code. + /// Main(args, nullptr); + } + + /// + /// This function should be called from the application entry point function (typically Program.Main) + /// to execute a secondary process e.g. gpu, renderer, utility + /// It can be used to run secondary processes (BrowserSubProcess) from your main applications executable + /// or from a separate executable specified by the CefSettings.BrowserSubprocessPath value. + /// CefSharp defaults to using the latter approach, a default implementation (CefSharp.BrowserSubProcess.exe) is + /// supplied, see https://github.com/cefsharp/CefSharp/wiki/General-Usage#processes for more details. + /// + /// command line args + /// + /// If called for the browser process (identified by no "type" command-line value) it will return immediately + /// with a value of -1. If called for a recognized secondary process it will block until the process should exit + /// and then return the process exit code. + /// ^ args) + { + return Main(args, nullptr); + } + + /// + /// This function should be called from the application entry point function (typically Program.Main) + /// to execute a secondary process e.g. gpu, renderer, utility + /// It can be used to run secondary processes (BrowserSubProcess) from your main applications executable + /// or from a separate executable specified by the CefSettings.BrowserSubprocessPath value. + /// CefSharp defaults to using the latter approach, a default implementation (CefSharp.BrowserSubProcess.exe) is + /// supplied, see https://github.com/cefsharp/CefSharp/wiki/General-Usage#processes for more details. + /// + /// command line args + /// An option IRenderProcessHandler implementation, use null if no handler is required + /// + /// If called for the browser process (identified by no "type" command-line value) it will return immediately + /// with a value of -1. If called for a recognized secondary process it will block until the process should exit + /// and then return the process exit code. + /// + int Main(IEnumerable^ args, IRenderProcessHandler^ handler) + { + auto type = CommandLineArgsParser::GetArgumentValue(args, CefSharpArguments::SubProcessTypeArgument); + + if (String::IsNullOrEmpty(type)) + { + //If --type param missing from command line CEF/Chromium assums + //this is the main process (as all subprocesses must have a type param). + //Return -1 to indicate this behaviour. + return -1; + } + + auto parentProcessId = -1; + + // The Crashpad Handler doesn't have any HostProcessIdArgument, so we must not try to + // parse it lest we want an ArgumentNullException. + if (type == "crashpad-handler") + { + //Lower the shutdown priority so the browser process is shutdown first (Issue #3155) + //The system terminates the process without displaying a retry dialog box for the user. + //Crashpad is lower than other sub processes so it can still monitor process exit crashes. + SetProcessShutdownParameters(0x100, SHUTDOWN_NORETRY); + } + else + { + //Lower the shutdown priority so the browser process is shutdown first (Issue #3155) + //The system terminates the process without displaying a retry dialog box for the user. + SetProcessShutdownParameters(0x200, SHUTDOWN_NORETRY); + + parentProcessId = int::Parse(CommandLineArgsParser::GetArgumentValue(args, CefSharpArguments::HostProcessIdArgument)); + if (CommandLineArgsParser::HasArgument(args, CefSharpArguments::ExitIfParentProcessClosed)) + { + ParentProcessMonitor::StartMonitorTask(parentProcessId); + } + } + + // Use our custom subProcess provides features like EvaluateJavascript + if (type == "renderer") + { + auto subProcess = GetSubprocess(args, parentProcessId, handler); + + try + { + return subProcess->Run(); + } + finally + { + delete subProcess; + } + } + + return SubProcess::ExecuteProcess(args); + } + + protected: + virtual SubProcess^ GetSubprocess(IEnumerable^ args, int parentProcessId, IRenderProcessHandler^ handler) + { + return gcnew SubProcess(handler, args); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Cef.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Cef.h new file mode 100644 index 0000000..61187e8 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Cef.h @@ -0,0 +1,34 @@ +// Copyright © 2020 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include\cef_v8.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + /// + /// Global CEF methods are exposed through this class. e.g. CefRegisterExtension maps to Cef.RegisterExtension + /// Only methods relevant to the Render Process are included in this class. + /// CEF API Doc https://magpcss.org/ceforum/apidocs3/projects/(default)/(_globals).html + /// This class cannot be inherited. + /// + public ref class Cef sealed + { + public: + /// + /// Register a new V8 extension with the specified JavaScript extension code. + /// + /// name + /// JavaScript code + static void RegisterExtension(String^ name, String^ javascriptCode) + { + CefRegisterExtension(StringUtils::ToNative(name), StringUtils::ToNative(javascriptCode), nullptr); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp new file mode 100644 index 0000000..dfbdb75 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp @@ -0,0 +1,776 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "CefBrowserWrapper.h" +#include "CefAppUnmanagedWrapper.h" +#include "RegisterBoundObjectHandler.h" +#include "BindObjectAsyncHandler.h" +#include "JavascriptPostMessageHandler.h" +#include "JavascriptRootObjectWrapper.h" +#include "JavascriptPromiseHandler.h" +#include "JavascriptPromiseResolverCatch.h" +#include "JavascriptPromiseResolverThen.h" +#include "Async\JavascriptAsyncMethodCallback.h" +#include "Serialization\V8Serialization.h" +#include "Serialization\JsObjectsSerialization.h" +#include "Wrapper\V8Context.h" +#include "Wrapper\Frame.h" +#include "Wrapper\Browser.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" + +using namespace System; +using namespace System::Diagnostics; +using namespace System::Collections::Generic; +using namespace CefSharp::BrowserSubprocess::Serialization; +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::Internals::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + const CefString CefAppUnmanagedWrapper::kPromiseCreatorScript = "" + "(function()" + "{" + " var result = {};" + " var promise = new Promise(function(resolve, reject) {" + " result.res = resolve; result.rej = reject;" + " });" + " result.p = promise;" + " return result;" + "})();"; + + const CefString kRenderProcessId = CefString("RenderProcessId"); + const CefString kRenderProcessIdCamelCase = CefString("renderProcessId"); + + CefRefPtr CefAppUnmanagedWrapper::GetRenderProcessHandler() + { + return this; + }; + + // CefRenderProcessHandler + void CefAppUnmanagedWrapper::OnBrowserCreated(CefRefPtr browser, CefRefPtr extraInfo) + { + auto wrapper = gcnew CefBrowserWrapper(browser); + _onBrowserCreated->Invoke(wrapper); + + //Multiple CefBrowserWrappers created when opening popups + _browserWrappers->TryAdd(browser->GetIdentifier(), wrapper); + + //For the main browser only we check LegacyBindingEnabled and + //load the objects. Popups don't send this information and checking + //will override the _legacyBindingEnabled field + if (!browser->IsPopup()) + { + _legacyBindingEnabled = extraInfo->GetBool("LegacyBindingEnabled"); + + if (_legacyBindingEnabled) + { + auto objects = extraInfo->GetList("LegacyBindingObjects"); + if (objects.get() && objects->IsValid()) + { + auto javascriptObjects = DeserializeJsObjects(objects, 0); + + for each (JavascriptObject ^ obj in Enumerable::OfType(javascriptObjects)) + { + //Using LegacyBinding with multiple ChromiumWebBrowser instances that share the same + //render process and using LegacyBinding will cause problems for the limited caching implementation + //that exists at the moment, for now we'll remove an object if already exists, same behaviour + //as the new binding method. + //TODO: This should be removed when https://github.com/cefsharp/CefSharp/issues/2306 + //Is complete as objects will be stored at the browser level + if (_javascriptObjects->ContainsKey(obj->JavascriptName)) + { + _javascriptObjects->Remove(obj->JavascriptName); + } + _javascriptObjects->Add(obj->JavascriptName, obj); + } + } + } + + _jsBindingApiEnabled = extraInfo->GetBool("JavascriptBindingApiEnabled"); + + if (extraInfo->HasKey("JsBindingPropertyName") || extraInfo->HasKey("JsBindingPropertyNameCamelCase")) + { + //TODO: Create constant for these and legacy binding strings above + _jsBindingPropertyName = extraInfo->GetString("JsBindingPropertyName"); + _jsBindingPropertyNameCamelCase = extraInfo->GetString("JsBindingPropertyNameCamelCase"); + } + } + } + + void CefAppUnmanagedWrapper::OnBrowserDestroyed(CefRefPtr browser) + { + CefBrowserWrapper^ wrapper; + if (_browserWrappers->TryRemove(browser->GetIdentifier(), wrapper)) + { + _onBrowserDestroyed->Invoke(wrapper); + delete wrapper; + } + }; + + void CefAppUnmanagedWrapper::OnContextCreated(CefRefPtr browser, CefRefPtr frame, CefRefPtr context) + { + if (!Object::ReferenceEquals(_handler, nullptr)) + { + Browser browserWrapper(browser); + Frame frameWrapper(frame); + V8Context contextWrapper(context); + + _handler->OnContextCreated(% browserWrapper, % frameWrapper, % contextWrapper); + } + + auto rootObject = GetJsRootObjectWrapper(browser->GetIdentifier(), frame->GetIdentifier()); + + if (_legacyBindingEnabled) + { + if (_javascriptObjects->Count > 0 && rootObject != nullptr) + { + rootObject->Bind(_javascriptObjects->Values, context->GetGlobal()); + } + } + + if (_jsBindingApiEnabled) + { + //TODO: Look at adding some sort of javascript mapping layer to reduce the code duplication + auto global = context->GetGlobal(); + auto browserWrapper = FindBrowserWrapper(browser->GetIdentifier()); + auto processId = System::Diagnostics::Process::GetCurrentProcess()->Id; + + //TODO: JSB: Split functions into their own classes + //Browser wrapper is only used for BindObjectAsync + auto bindObjAsyncFunction = CefV8Value::CreateFunction(kBindObjectAsync, new BindObjectAsyncHandler(_registerBoundObjectRegistry, _javascriptObjects, browserWrapper)); + auto unBindObjFunction = CefV8Value::CreateFunction(kDeleteBoundObject, new RegisterBoundObjectHandler(_javascriptObjects)); + auto removeObjectFromCacheFunction = CefV8Value::CreateFunction(kRemoveObjectFromCache, new RegisterBoundObjectHandler(_javascriptObjects)); + auto isObjectCachedFunction = CefV8Value::CreateFunction(kIsObjectCached, new RegisterBoundObjectHandler(_javascriptObjects)); + auto postMessageFunction = CefV8Value::CreateFunction(kPostMessage, new JavascriptPostMessageHandler(rootObject == nullptr ? nullptr : rootObject->CallbackRegistry)); + auto promiseHandlerFunction = CefV8Value::CreateFunction(kSendEvalScriptResponse, new JavascriptPromiseHandler()); + + //By default We'll support both CefSharp and cefSharp, for those who prefer the JS style + auto createCefSharpObj = !_jsBindingPropertyName.empty(); + auto createCefSharpObjCamelCase = !_jsBindingPropertyNameCamelCase.empty(); + + if (createCefSharpObj) + { + auto cefSharpObj = CefV8Value::CreateObject(nullptr, nullptr); + cefSharpObj->SetValue(kBindObjectAsync, bindObjAsyncFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObj->SetValue(kDeleteBoundObject, unBindObjFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObj->SetValue(kRemoveObjectFromCache, removeObjectFromCacheFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObj->SetValue(kIsObjectCached, isObjectCachedFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObj->SetValue(kPostMessage, postMessageFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObj->SetValue(kSendEvalScriptResponse, promiseHandlerFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObj->SetValue(kRenderProcessId, CefV8Value::CreateInt(processId), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + + global->SetValue(_jsBindingPropertyName, cefSharpObj, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + } + + if (createCefSharpObjCamelCase) + { + auto cefSharpObjCamelCase = CefV8Value::CreateObject(nullptr, nullptr); + cefSharpObjCamelCase->SetValue(kBindObjectAsyncCamelCase, bindObjAsyncFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObjCamelCase->SetValue(kDeleteBoundObjectCamelCase, unBindObjFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObjCamelCase->SetValue(kRemoveObjectFromCacheCamelCase, removeObjectFromCacheFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObjCamelCase->SetValue(kIsObjectCachedCamelCase, isObjectCachedFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObjCamelCase->SetValue(kPostMessageCamelCase, postMessageFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObjCamelCase->SetValue(kSendEvalScriptResponseCamelCase, promiseHandlerFunction, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + cefSharpObjCamelCase->SetValue(kRenderProcessIdCamelCase, CefV8Value::CreateInt(processId), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + + global->SetValue(_jsBindingPropertyNameCamelCase, cefSharpObjCamelCase, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + } + } + + //Send a message to the browser processing signaling that OnContextCreated has been called + //only param is the FrameId. Previous sent only for main frame, now sent for all frames + //Message sent after legacy objects have been bound and the CefSharp bind async helper methods + //have been created + auto contextCreatedMessage = CefProcessMessage::Create(kOnContextCreatedRequest); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, contextCreatedMessage); + }; + + void CefAppUnmanagedWrapper::OnContextReleased(CefRefPtr browser, CefRefPtr frame, CefRefPtr context) + { + if (!Object::ReferenceEquals(_handler, nullptr)) + { + Browser browserWrapper(browser); + Frame frameWrapper(frame); + V8Context contextWrapper(context); + + _handler->OnContextReleased(% browserWrapper, % frameWrapper, % contextWrapper); + } + + auto contextReleasedMessage = CefProcessMessage::Create(kOnContextReleasedRequest); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, contextReleasedMessage); + + auto browserWrapper = FindBrowserWrapper(browser->GetIdentifier()); + + //If we no longer have a browser wrapper reference then there's nothing we can do + if (browserWrapper == nullptr) + { + return; + } + + auto rootObjectWrappers = browserWrapper->JavascriptRootObjectWrappers; + + JavascriptRootObjectWrapper^ wrapper; + if (rootObjectWrappers->TryRemove(frame->GetIdentifier(), wrapper)) + { + delete wrapper; + } + }; + + void CefAppUnmanagedWrapper::OnFocusedNodeChanged(CefRefPtr browser, CefRefPtr frame, CefRefPtr node) + { + if (!_focusedNodeChangedEnabled) + { + return; + } + + auto focusedNodeChangedMessage = CefProcessMessage::Create(kOnFocusedNodeChanged); + auto list = focusedNodeChangedMessage->GetArgumentList(); + + // The node will be empty if an element loses focus but another one + // doesn't gain focus. Only transfer information if the node is an + // element. + if (node != nullptr && node->IsElement()) + { + // True when a node exists, false if it doesn't. + list->SetBool(0, true); + + // Store the tag name. + list->SetString(1, node->GetElementTagName()); + + // Transfer the attributes in a Dictionary. + auto attributes = CefDictionaryValue::Create(); + CefDOMNode::AttributeMap attributeMap; + node->GetElementAttributes(attributeMap); + for (auto iter : attributeMap) + { + attributes->SetString(iter.first, iter.second); + } + + list->SetDictionary(2, attributes); + } + else + { + list->SetBool(0, false); + } + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, focusedNodeChangedMessage); + } + + void CefAppUnmanagedWrapper::OnUncaughtException(CefRefPtr browser, CefRefPtr frame, CefRefPtr context, CefRefPtr exception, CefRefPtr stackTrace) + { + auto uncaughtExceptionMessage = CefProcessMessage::Create(kOnUncaughtException); + auto list = uncaughtExceptionMessage->GetArgumentList(); + + list->SetString(0, exception->GetMessage()); + + auto frames = CefListValue::Create(); + for (auto i = 0; i < stackTrace->GetFrameCount(); i++) + { + auto stackTraceFrame = CefListValue::Create(); + auto frameArg = stackTrace->GetFrame(i); + + stackTraceFrame->SetString(0, frameArg->GetFunctionName()); + stackTraceFrame->SetInt(1, frameArg->GetLineNumber()); + stackTraceFrame->SetInt(2, frameArg->GetColumn()); + stackTraceFrame->SetString(3, frameArg->GetScriptNameOrSourceURL()); + + frames->SetList(i, stackTraceFrame); + } + + list->SetList(1, frames); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, uncaughtExceptionMessage); + } + + JavascriptRootObjectWrapper^ CefAppUnmanagedWrapper::GetJsRootObjectWrapper(int browserId, int64 frameId) + { + auto browserWrapper = FindBrowserWrapper(browserId); + + if (browserWrapper == nullptr) + { + return nullptr; + } + + auto rootObjectWrappers = browserWrapper->JavascriptRootObjectWrappers; + + JavascriptRootObjectWrapper^ rootObject; + if (!rootObjectWrappers->TryGetValue(frameId, rootObject)) + { +#ifdef NETCOREAPP + rootObject = gcnew JavascriptRootObjectWrapper(browserId); +#else + rootObject = gcnew JavascriptRootObjectWrapper(browserId, browserWrapper->BrowserProcess); +#endif + rootObjectWrappers->TryAdd(frameId, rootObject); + } + + return rootObject; + } + + CefBrowserWrapper^ CefAppUnmanagedWrapper::FindBrowserWrapper(int browserId) + { + CefBrowserWrapper^ wrapper = nullptr; + + _browserWrappers->TryGetValue(browserId, wrapper); + + if (wrapper == nullptr) + { + //TODO: Find the syntax for delcaring the native string directly + LOG(ERROR) << StringUtils::ToNative("Failed to identify BrowserWrapper in OnContextCreated BrowserId:" + browserId).ToString(); + } + + return wrapper; + } + + bool CefAppUnmanagedWrapper::OnProcessMessageReceived(CefRefPtr browser, CefRefPtr frame, CefProcessId sourceProcessId, CefRefPtr message) + { + auto handled = false; + auto name = message->GetName(); + auto argList = message->GetArgumentList(); + + auto browserWrapper = FindBrowserWrapper(browser->GetIdentifier()); + //Error handling for missing/closed browser + if (browserWrapper == nullptr) + { + if (name == kJavascriptCallbackDestroyRequest || + name == kJavascriptRootObjectResponse || + name == kJavascriptAsyncMethodCallResponse) + { + //If we can't find the browser wrapper then we'll just + //ignore this as it's likely already been disposed of + return true; + } + + CefString responseName; + if (name == kEvaluateJavascriptRequest) + { + responseName = kEvaluateJavascriptResponse; + } + else if (name == kJavascriptCallbackRequest) + { + responseName = kJavascriptCallbackResponse; + } + else + { + //TODO: Should be throw an exception here? It's likely that only a CefSharp developer would see this + // when they added a new message and haven't yet implemented the render process functionality. + throw gcnew Exception("Unsupported message type"); + } + + auto callbackId = GetInt64(argList, 0); + auto response = CefProcessMessage::Create(responseName); + auto responseArgList = response->GetArgumentList(); + auto errorMessage = String::Format("Request BrowserId : {0} not found it's likely the browser is already closed", browser->GetIdentifier()); + + //success: false + responseArgList->SetBool(0, false); + SetInt64(responseArgList, 1, callbackId); + responseArgList->SetString(2, StringUtils::ToNative(errorMessage)); + frame->SendProcessMessage(sourceProcessId, response); + + return true; + } + + //these messages are roughly handled the same way + if (name == kEvaluateJavascriptRequest || name == kJavascriptCallbackRequest) + { + bool sendResponse = true; + bool success = false; + CefRefPtr result; + CefString errorMessage; + CefRefPtr response; + + if (name == kEvaluateJavascriptRequest) + { + response = CefProcessMessage::Create(kEvaluateJavascriptResponse); + } + else + { + response = CefProcessMessage::Create(kJavascriptCallbackResponse); + } + + //both messages have callbackId stored at index 0 + auto frameId = frame->GetIdentifier(); + int64 callbackId = GetInt64(argList, 0); + + if (name == kEvaluateJavascriptRequest) + { + JavascriptRootObjectWrapper^ rootObjectWrapper; + browserWrapper->JavascriptRootObjectWrappers->TryGetValue(frameId, rootObjectWrapper); + + //NOTE: In the rare case when when OnContextCreated hasn't been called we need to manually create the rootObjectWrapper + //It appears that OnContextCreated is only called for pages that have javascript on them, which makes sense + //as without javascript there is no need for a context. + if (rootObjectWrapper == nullptr) + { +#ifdef NETCOREAPP + rootObjectWrapper = gcnew JavascriptRootObjectWrapper(browser->GetIdentifier()); +#else + rootObjectWrapper = gcnew JavascriptRootObjectWrapper(browser->GetIdentifier(), browserWrapper->BrowserProcess); +#endif + + browserWrapper->JavascriptRootObjectWrappers->TryAdd(frameId, rootObjectWrapper); + } + + auto callbackRegistry = rootObjectWrapper->CallbackRegistry; + + auto script = argList->GetString(1); + auto scriptUrl = argList->GetString(2); + auto startLine = argList->GetInt(3); + + if (frame.get() && frame->IsValid()) + { + auto context = frame->GetV8Context(); + + if (context.get() && context->Enter()) + { + try + { + CefRefPtr exception; + success = context->Eval(script, scriptUrl, startLine, result, exception); + + //we need to do this here to be able to store the v8context + if (success) + { + //If the response is a string of CefSharpDefEvalScriptRes then + //we don't send the response, we'll let that happen when the promise has completed. + if (result->IsString() && result->GetStringValue() == "CefSharpDefEvalScriptRes") + { + sendResponse = false; + } + else if (result->IsPromise()) + { + sendResponse = false; + + auto promiseThen = result->GetValue("then"); + auto promiseCatch = result->GetValue("catch"); + + auto promiseThenFunc = CefV8Value::CreateFunction("promiseResolverThen", new JavascriptPromiseResolverThen(callbackId, false)); + auto promiseCatchFunc = CefV8Value::CreateFunction("promiseResolverCatch", new JavascriptPromiseResolverCatch(callbackId, false)); + + CefV8ValueList promiseThenArgs; + promiseThenArgs.push_back(promiseThenFunc); + promiseThen->ExecuteFunction(result, promiseThenArgs); + + CefV8ValueList promiseCatchArgs; + promiseCatchArgs.push_back(promiseCatchFunc); + promiseCatch->ExecuteFunction(result, promiseCatchArgs); + } + else + { + auto responseArgList = response->GetArgumentList(); + SerializeV8Object(result, responseArgList, 2, callbackRegistry); + } + } + else + { + errorMessage = StringUtils::CreateExceptionString(exception); + } + } + finally + { + context->Exit(); + } + } + else + { + errorMessage = "Unable to Enter Context"; + } + } + else + { + errorMessage = StringUtils::ToNative("Frame " + frameId + " is no longer available, most likely the Frame has been Disposed or Removed."); + } + } + else + { + JavascriptRootObjectWrapper^ rootObjectWrapper; + browserWrapper->JavascriptRootObjectWrappers->TryGetValue(frameId, rootObjectWrapper); + auto callbackRegistry = rootObjectWrapper == nullptr ? nullptr : rootObjectWrapper->CallbackRegistry; + if (callbackRegistry == nullptr) + { + errorMessage = StringUtils::ToNative("The callback registry for Frame " + frameId + " is no longer available, most likely the Frame has been Disposed."); + } + else + { + auto jsCallbackId = GetInt64(argList, 1); + + auto callbackWrapper = callbackRegistry->FindWrapper(jsCallbackId); + if (callbackWrapper == nullptr) + { + errorMessage = StringUtils::ToNative("Unable to find JavascriptCallback with Id " + jsCallbackId + " for Frame " + frameId); + } + else + { + auto context = callbackWrapper->GetContext(); + auto value = callbackWrapper->GetValue(); + + if (context.get() && context->Enter()) + { + try + { + auto parameterList = argList->GetList(2); + CefV8ValueList params; + + //Needs to be called within the context as for Dictionary (mapped to struct) + //a V8Object will be created + for (CefV8ValueList::size_type i = 0; i < parameterList->GetSize(); i++) + { + params.push_back(DeserializeV8Object(parameterList, static_cast(i))); + } + + result = value->ExecuteFunction(nullptr, params); + success = result.get() != nullptr; + + //we need to do this here to be able to store the v8context + if (success) + { + //If the response is a string of CefSharpDefEvalScriptRes then + //we don't send the response, we'll let that happen when the promise has completed. + if (result->IsString() && result->GetStringValue() == "CefSharpDefEvalScriptRes") + { + sendResponse = false; + } + else if (result->IsPromise()) + { + sendResponse = false; + + auto promiseThen = result->GetValue("then"); + auto promiseCatch = result->GetValue("catch"); + + auto promiseThenFunc = CefV8Value::CreateFunction("promiseResolverThen", new JavascriptPromiseResolverThen(callbackId, true)); + auto promiseCatchFunc = CefV8Value::CreateFunction("promiseResolverCatch", new JavascriptPromiseResolverCatch(callbackId, true)); + + CefV8ValueList promiseThenArgs; + promiseThenArgs.push_back(promiseThenFunc); + promiseThen->ExecuteFunction(result, promiseThenArgs); + + CefV8ValueList promiseCatchArgs; + promiseCatchArgs.push_back(promiseCatchFunc); + promiseCatch->ExecuteFunction(result, promiseCatchArgs); + } + else + { + auto responseArgList = response->GetArgumentList(); + SerializeV8Object(result, responseArgList, 2, callbackRegistry); + } + } + else + { + auto exception = value->GetException(); + errorMessage = StringUtils::CreateExceptionString(exception); + } + } + finally + { + context->Exit(); + } + } + else + { + errorMessage = "Unable to Enter Context"; + } + } + } + } + + if (sendResponse) + { + auto responseArgList = response->GetArgumentList(); + responseArgList->SetBool(0, success); + SetInt64(responseArgList, 1, callbackId); + if (!success) + { + responseArgList->SetString(2, errorMessage); + } + frame->SendProcessMessage(sourceProcessId, response); + } + + handled = true; + } + else if (name == kJavascriptCallbackDestroyRequest) + { + if (frame.get() && frame->IsValid()) + { + auto jsCallbackId = GetInt64(argList, 0); + JavascriptRootObjectWrapper^ rootObjectWrapper; + browserWrapper->JavascriptRootObjectWrappers->TryGetValue(frame->GetIdentifier(), rootObjectWrapper); + if (rootObjectWrapper != nullptr && rootObjectWrapper->CallbackRegistry != nullptr) + { + rootObjectWrapper->CallbackRegistry->Deregister(jsCallbackId); + } + } + + handled = true; + } + else if (name == kJavascriptRootObjectResponse) + { + if (browser.get() && frame.get() && frame->IsValid()) + { + auto callbackId = GetInt64(argList, 0); + auto javascriptObjects = DeserializeJsObjects(argList, 1); + + //Caching of JavascriptObjects + //TODO: JSB Should caching be configurable? On a per object basis? + for each (JavascriptObject ^ obj in Enumerable::OfType(javascriptObjects)) + { + if (_javascriptObjects->ContainsKey(obj->JavascriptName)) + { + _javascriptObjects->Remove(obj->JavascriptName); + } + _javascriptObjects->Add(obj->JavascriptName, obj); + } + + auto rootObject = GetJsRootObjectWrapper(browser->GetIdentifier(), frame->GetIdentifier()); + + if (rootObject == nullptr) + { + return false; + } + + auto context = frame->GetV8Context(); + + if (context.get() && context->Enter()) + { + JavascriptAsyncMethodCallback^ callback; + + try + { + rootObject->Bind(javascriptObjects, context->GetGlobal()); + + if (_registerBoundObjectRegistry->TryGetAndRemoveMethodCallback(callbackId, callback)) + { + //Response object has no Accessor or Interceptor + auto response = CefV8Value::CreateObject(nullptr, nullptr); + + response->SetValue("Count", CefV8Value::CreateInt(javascriptObjects->Count), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + + if (javascriptObjects->Count > 0) + { + //TODO: JSB Should we include a list of successfully bound object names? + response->SetValue("Success", CefV8Value::CreateBool(true), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + response->SetValue("Message", CefV8Value::CreateString("OK"), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + callback->Success(response); + } + else + { + response->SetValue("Success", CefV8Value::CreateBool(false), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + response->SetValue("Message", CefV8Value::CreateString("Zero objects bounds"), CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_READONLY); + callback->Success(response); + } + + //Send message notifying Browser Process of which objects were bound + //We do this after the objects have been created in the V8Context to gurantee + //they are accessible. + auto msg = CefProcessMessage::Create(kJavascriptObjectsBoundInJavascript); + auto args = msg->GetArgumentList(); + + auto boundObjects = CefListValue::Create(); + + for (auto i = 0; i < javascriptObjects->Count; i++) + { + auto dict = CefDictionaryValue::Create(); + auto objectName = javascriptObjects[i]->JavascriptName; + dict->SetString("Name", StringUtils::ToNative(objectName)); + dict->SetBool("IsCached", false); + dict->SetBool("AlreadyBound", false); + + boundObjects->SetDictionary(i, dict); + } + + args->SetList(0, boundObjects); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, msg); + } + } + finally + { + context->Exit(); + + delete callback; + } + } + } + else + { + LOG(INFO) << "CefAppUnmanagedWrapper Frame Invalid"; + } + + handled = true; + } + else if (name == kJavascriptAsyncMethodCallResponse) + { + if (frame.get() && frame->IsValid()) + { + auto frameId = frame->GetIdentifier(); + auto callbackId = GetInt64(argList, 0); + + JavascriptRootObjectWrapper^ rootObjectWrapper; + browserWrapper->JavascriptRootObjectWrappers->TryGetValue(frameId, rootObjectWrapper); + + if (rootObjectWrapper != nullptr) + { + JavascriptAsyncMethodCallback^ callback; + if (rootObjectWrapper->TryGetAndRemoveMethodCallback(callbackId, callback)) + { + try + { + auto context = frame->GetV8Context(); + + if (context.get() && context->Enter()) + { + try + { + auto success = argList->GetBool(1); + if (success) + { + callback->Success(DeserializeV8Object(argList, 2)); + } + else + { + callback->Fail(argList->GetString(2)); + } + } + finally + { + context->Exit(); + } + } + else + { + callback->Fail("Unable to Enter Context"); + } + } + finally + { + //dispose + delete callback; + } + } + } + } + handled = true; + } + + return handled; + }; + + void CefAppUnmanagedWrapper::OnWebKitInitialized() + { + if (!Object::ReferenceEquals(_handler, nullptr)) + { + _handler->OnWebKitInitialized(); + } + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.h new file mode 100644 index 0000000..b202f31 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.h @@ -0,0 +1,90 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_base.h" + +#include "SubProcessApp.h" +#include "CefBrowserWrapper.h" +#include "RegisterBoundObjectRegistry.h" + +using namespace System::Collections::Generic; +using namespace CefSharp::RenderProcess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + // This class is the native subprocess level CEF object wrapper. + private class CefAppUnmanagedWrapper : SubProcessApp, CefRenderProcessHandler + { + private: + gcroot _handler; + gcroot^> _onBrowserCreated; + gcroot^> _onBrowserDestroyed; + gcroot^> _browserWrappers; + bool _focusedNodeChangedEnabled; + bool _legacyBindingEnabled; + bool _jsBindingApiEnabled = true; + + // The property names used to call bound objects + CefString _jsBindingPropertyName; + CefString _jsBindingPropertyNameCamelCase; + + // The serialized registered object data waiting to be used. + gcroot^> _javascriptObjects; + + gcroot _registerBoundObjectRegistry; + + public: + static const CefString kPromiseCreatorScript; + + CefAppUnmanagedWrapper(IRenderProcessHandler^ handler, List^ schemes, bool enableFocusedNodeChanged, Action^ onBrowserCreated, Action^ onBrowserDestroyed) : SubProcessApp(schemes) + { + _handler = handler; + _onBrowserCreated = onBrowserCreated; + _onBrowserDestroyed = onBrowserDestroyed; + _browserWrappers = gcnew ConcurrentDictionary(); + _focusedNodeChangedEnabled = enableFocusedNodeChanged; + _javascriptObjects = gcnew Dictionary(); + _registerBoundObjectRegistry = gcnew RegisterBoundObjectRegistry(); + _legacyBindingEnabled = false; + _jsBindingPropertyName = "CefSharp"; + _jsBindingPropertyNameCamelCase = "cefSharp"; + } + + ~CefAppUnmanagedWrapper() + { + if (!Object::ReferenceEquals(_browserWrappers, nullptr)) + { + for each (CefBrowserWrapper ^ browser in Enumerable::OfType(_browserWrappers)) + { + delete browser; + } + + _browserWrappers = nullptr; + } + delete _onBrowserCreated; + delete _onBrowserDestroyed; + } + + CefBrowserWrapper^ FindBrowserWrapper(int browserId); + JavascriptRootObjectWrapper^ GetJsRootObjectWrapper(int browserId, int64 frameId); + + virtual DECL CefRefPtr GetRenderProcessHandler() override; + virtual DECL void OnBrowserCreated(CefRefPtr browser, CefRefPtr extraInfo) override; + virtual DECL void OnBrowserDestroyed(CefRefPtr browser) override; + virtual DECL void OnContextCreated(CefRefPtr browser, CefRefPtr frame, CefRefPtr context) override; + virtual DECL void OnContextReleased(CefRefPtr browser, CefRefPtr frame, CefRefPtr context) override; + virtual DECL bool OnProcessMessageReceived(CefRefPtr browser, CefRefPtr frame, CefProcessId sourceProcessId, CefRefPtr message) override; + virtual DECL void OnWebKitInitialized() override; + virtual DECL void OnFocusedNodeChanged(CefRefPtr browser, CefRefPtr frame, CefRefPtr node) override; + virtual DECL void OnUncaughtException(CefRefPtr browser, CefRefPtr frame, CefRefPtr context, CefRefPtr exception, CefRefPtr stackTrace) override; + + IMPLEMENT_REFCOUNTINGM(CefAppUnmanagedWrapper); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefBrowserWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefBrowserWrapper.h new file mode 100644 index 0000000..1e32ece --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/CefBrowserWrapper.h @@ -0,0 +1,77 @@ +// Copyright © 2013 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_browser.h" +#include "include/cef_v8.h" + +#include "TypeUtils.h" +#include "Stdafx.h" +#include "JavascriptRootObjectWrapper.h" + +using namespace CefSharp::BrowserSubprocess::Async; +#ifndef NETCOREAPP +using namespace System::ServiceModel; +#endif +using namespace System::Threading; +using namespace System::Threading::Tasks; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + // "Master class" for wrapping everything that the Cef Subprocess needs + // for ONE CefBrowser. + public ref class CefBrowserWrapper + { + private: + MCefRefPtr _cefBrowser; + + internal: + //Frame Identifier is used as Key + property ConcurrentDictionary^ JavascriptRootObjectWrappers; + + public: + CefBrowserWrapper(CefRefPtr cefBrowser) + { + _cefBrowser = cefBrowser.get(); + BrowserId = cefBrowser->GetIdentifier(); + IsPopup = cefBrowser->IsPopup(); + + JavascriptRootObjectWrappers = gcnew ConcurrentDictionary(); + } + + !CefBrowserWrapper() + { + _cefBrowser = nullptr; + } + + ~CefBrowserWrapper() + { + this->!CefBrowserWrapper(); + + if (JavascriptRootObjectWrappers != nullptr) + { + for each (KeyValuePair entry in JavascriptRootObjectWrappers) + { + delete entry.Value; + } + + JavascriptRootObjectWrappers = nullptr; + } + } + + property int BrowserId; + property bool IsPopup; + +#ifndef NETCOREAPP + // This allows us to create the WCF proxies back to our parent process. + property ChannelFactory^ ChannelFactory; + // The WCF proxy to the parent process. + property IBrowserProcess^ BrowserProcess; +#endif + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackRegistry.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackRegistry.cpp new file mode 100644 index 0000000..0cea75e --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackRegistry.cpp @@ -0,0 +1,45 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "stdafx.h" +#include "JavascriptCallbackRegistry.h" + +using namespace System::Threading; +using namespace CefSharp::BrowserSubprocess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + JavascriptCallback^ JavascriptCallbackRegistry::Register(const CefRefPtr& context, const CefRefPtr& value) + { + Int64 newId = Interlocked::Increment(_lastId); + JavascriptCallbackWrapper^ wrapper = gcnew JavascriptCallbackWrapper(value, context); + _callbacks->TryAdd(newId, wrapper); + + auto result = gcnew JavascriptCallback(); + result->Id = newId; + result->BrowserId = _browserId; + result->FrameId = context->GetFrame()->GetIdentifier(); + return result; + } + + JavascriptCallbackWrapper^ JavascriptCallbackRegistry::FindWrapper(int64 id) + { + JavascriptCallbackWrapper^ callback; + _callbacks->TryGetValue(id, callback); + return callback; + } + + void JavascriptCallbackRegistry::Deregister(Int64 id) + { + JavascriptCallbackWrapper^ callback; + if (_callbacks->TryRemove(id, callback)) + { + delete callback; + } + } + + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackRegistry.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackRegistry.h new file mode 100644 index 0000000..46db9b2 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackRegistry.h @@ -0,0 +1,54 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "JavascriptCallbackWrapper.h" + +using namespace System::Collections::Concurrent; +using namespace CefSharp::BrowserSubprocess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class JavascriptCallbackRegistry + { + private: + //Only access through Interlocked::Increment - used to generate unique callback Id's + //Is static so ids are unique to this process, which is required until #1984 is implemented + //and callbacks are disposed of properly between contexts + static Int64 _lastId; + int _browserId; + ConcurrentDictionary^ _callbacks; + + internal: + JavascriptCallbackWrapper^ FindWrapper(int64 id); + + public: + JavascriptCallbackRegistry(int browserId) : _browserId(browserId) + { + _callbacks = gcnew ConcurrentDictionary(); + } + + ~JavascriptCallbackRegistry() + { + if (_callbacks != nullptr) + { + for each (JavascriptCallbackWrapper^ callback in _callbacks->Values) + { + delete callback; + } + _callbacks->Clear(); + _callbacks = nullptr; + } + } + + JavascriptCallback^ Register(const CefRefPtr& context, const CefRefPtr& value); + + void Deregister(Int64 id); + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackWrapper.h new file mode 100644 index 0000000..ac20728 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptCallbackWrapper.h @@ -0,0 +1,48 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include\cef_v8.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class JavascriptCallbackWrapper + { + private: + MCefRefPtr _value; + MCefRefPtr _context; + + internal: + CefRefPtr GetValue() + { + return _value.get(); + } + + CefRefPtr GetContext() + { + return _context.get(); + } + + public: + JavascriptCallbackWrapper(CefRefPtr value, CefRefPtr context) + : _value(value), _context(context) + { + } + + !JavascriptCallbackWrapper() + { + _value = nullptr; + _context = nullptr; + } + + ~JavascriptCallbackWrapper() + { + this->!JavascriptCallbackWrapper(); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodHandler.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodHandler.cpp new file mode 100644 index 0000000..2426787 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodHandler.cpp @@ -0,0 +1,80 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" +#include "TypeUtils.h" +#include "JavascriptMethodHandler.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + bool JavascriptMethodHandler::Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception) + { + auto size = static_cast(arguments.size()); + auto parameter = gcnew array(size); + + for (int i = 0; i < size; i++) + { + parameter[i] = TypeUtils::ConvertFromCef(arguments[i], _callbackRegistry); + } + + try + { + auto response = _method->Invoke(parameter); + + retval = ConvertToCefObject(response->Result); + if (!response->Success) + { + exception = StringUtils::ToNative(response->Message); + } + } + catch (Exception^ ex) + { + exception = StringUtils::ToNative(ex->ToString()); + } + + //NOTE: Return true otherwise exception is ignored + return true; + } + + CefRefPtr JavascriptMethodHandler::ConvertToCefObject(Object^ obj) + { + if (obj == nullptr) + { + return CefV8Value::CreateNull(); + } + + auto type = obj->GetType(); + + if (type == JavascriptObject::typeid) + { + JavascriptObject^ javascriptObject = (JavascriptObject^)obj; + CefRefPtr cefObject = CefV8Value::CreateObject(nullptr, nullptr); + + for (int i = 0; i < javascriptObject->Properties->Count; i++) + { + auto prop = javascriptObject->Properties[i]; + + if (prop->IsComplexType) + { + auto v8Value = ConvertToCefObject(prop->JsObject); + + cefObject->SetValue(StringUtils::ToNative(prop->JavascriptName), v8Value, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + } + else + { + auto v8Value = TypeUtils::ConvertToCef(prop->PropertyValue, nullptr); + + cefObject->SetValue(StringUtils::ToNative(prop->JavascriptName), v8Value, CefV8Value::PropertyAttribute::V8_PROPERTY_ATTRIBUTE_NONE); + } + } + + return cefObject; + } + + return TypeUtils::ConvertToCef(obj, nullptr); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodHandler.h new file mode 100644 index 0000000..36ee2c3 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodHandler.h @@ -0,0 +1,44 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "JavascriptCallbackRegistry.h" + +using namespace CefSharp::Internals::Wcf; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private class JavascriptMethodHandler : public CefV8Handler + { + private: + gcroot^, BrowserProcessResponse^>^> _method; + gcroot _callbackRegistry; + + public: + JavascriptMethodHandler(Func^, BrowserProcessResponse^>^ method, JavascriptCallbackRegistry^ callbackRegistry) + { + _method = method; + _callbackRegistry = callbackRegistry; + } + + ~JavascriptMethodHandler() + { + delete _method; + // The callback registry is a shared instance among all method handlers (async & sync). + // It's lifecycle is managed in the JavascriptRootObjectWrapper. + _callbackRegistry = nullptr; + } + + virtual bool Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception) override; + + CefRefPtr ConvertToCefObject(Object^ obj); + + IMPLEMENT_REFCOUNTINGM(JavascriptMethodHandler); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodWrapper.cpp new file mode 100644 index 0000000..ab8feed --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodWrapper.cpp @@ -0,0 +1,29 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "JavascriptMethodWrapper.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + void JavascriptMethodWrapper::Bind(JavascriptMethod^ javascriptMethod, const CefRefPtr& v8Value) + { + _javascriptMethodName = javascriptMethod->JavascriptName; + auto methodName = StringUtils::ToNative(javascriptMethod->JavascriptName); + auto v8Function = CefV8Value::CreateFunction(methodName, _javascriptMethodHandler.get()); + + v8Value->SetValue(methodName, v8Function, V8_PROPERTY_ATTRIBUTE_NONE); + }; + + BrowserProcessResponse^ JavascriptMethodWrapper::Execute(array^ parameters) + { + return _browserProcess->CallMethod(_ownerId, _javascriptMethodName, parameters); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodWrapper.h new file mode 100644 index 0000000..3f402f5 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptMethodWrapper.h @@ -0,0 +1,51 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_v8.h" + +#include "JavascriptMethodHandler.h" + +using namespace System::Runtime::Serialization; +using namespace CefSharp::Internals::Wcf; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class JavascriptMethodWrapper + { + private: + MCefRefPtr _javascriptMethodHandler; + int64 _ownerId; + String^ _javascriptMethodName; + IBrowserProcess^ _browserProcess; + + public: + JavascriptMethodWrapper(int64 ownerId, IBrowserProcess^ browserProcess, JavascriptCallbackRegistry^ callbackRegistry) + { + _ownerId = ownerId; + _browserProcess = browserProcess; + _javascriptMethodHandler = new JavascriptMethodHandler(gcnew Func^, BrowserProcessResponse^>(this, &JavascriptMethodWrapper::Execute), callbackRegistry); + } + + !JavascriptMethodWrapper() + { + _javascriptMethodHandler = nullptr; + } + + ~JavascriptMethodWrapper() + { + this->!JavascriptMethodWrapper(); + + _browserProcess = nullptr; + } + + void Bind(JavascriptMethod^ javascriptMethod, const CefRefPtr& v8Value); + BrowserProcessResponse^ Execute(array^ parameters); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptObjectWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptObjectWrapper.cpp new file mode 100644 index 0000000..afb2926 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptObjectWrapper.cpp @@ -0,0 +1,57 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "JavascriptObjectWrapper.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + void JavascriptObjectWrapper::Bind(JavascriptObject^ object, const CefRefPtr& v8Value, JavascriptCallbackRegistry^ callbackRegistry) + { + _objectId = object->Id; + + //Create property handler for get and set of Properties of this object + _jsPropertyHandler = new JavascriptPropertyHandler( + gcnew Func(this, &JavascriptObjectWrapper::GetProperty), + gcnew Func(this, &JavascriptObjectWrapper::SetProperty) + ); + + //V8Value that represents this javascript object - only one per complex type + auto javascriptObject = CefV8Value::CreateObject(_jsPropertyHandler.get(), nullptr); + auto objectName = StringUtils::ToNative(object->JavascriptName); + v8Value->SetValue(objectName, javascriptObject, V8_PROPERTY_ATTRIBUTE_NONE); + + for each (JavascriptMethod ^ method in Enumerable::OfType(object->Methods)) + { + auto wrappedMethod = gcnew JavascriptMethodWrapper(object->Id, _browserProcess, callbackRegistry); + wrappedMethod->Bind(method, javascriptObject); + + _wrappedMethods->Add(wrappedMethod); + } + + for each (JavascriptProperty ^ prop in Enumerable::OfType(object->Properties)) + { + auto wrappedproperty = gcnew JavascriptPropertyWrapper(object->Id, _browserProcess); + wrappedproperty->Bind(prop, javascriptObject, callbackRegistry); + + _wrappedProperties->Add(wrappedproperty); + } + } + + BrowserProcessResponse^ JavascriptObjectWrapper::GetProperty(String^ memberName) + { + return _browserProcess->GetProperty(_objectId, memberName); + }; + + BrowserProcessResponse^ JavascriptObjectWrapper::SetProperty(String^ memberName, Object^ value) + { + return _browserProcess->SetProperty(_objectId, memberName, value); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptObjectWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptObjectWrapper.h new file mode 100644 index 0000000..785df10 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptObjectWrapper.h @@ -0,0 +1,64 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_v8.h" + +#include "JavascriptMethodWrapper.h" +#include "JavascriptPropertyWrapper.h" +#include "JavascriptPropertyHandler.h" + +using namespace System::Runtime::Serialization; +using namespace System::Linq; +using namespace System::Collections::Generic; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class JavascriptObjectWrapper + { + private: + List^ _wrappedMethods; + List^ _wrappedProperties; + IBrowserProcess^ _browserProcess; + MCefRefPtr _jsPropertyHandler; + int64 _objectId; + + public: + JavascriptObjectWrapper(IBrowserProcess^ browserProcess) + { + _browserProcess = browserProcess; + + _wrappedMethods = gcnew List(); + _wrappedProperties = gcnew List(); + } + + !JavascriptObjectWrapper() + { + _jsPropertyHandler = nullptr; + } + + ~JavascriptObjectWrapper() + { + this->!JavascriptObjectWrapper(); + + for each (JavascriptMethodWrapper ^ var in _wrappedMethods) + { + delete var; + } + for each (JavascriptPropertyWrapper ^ var in _wrappedProperties) + { + delete var; + } + } + + void Bind(JavascriptObject^ object, const CefRefPtr& v8Value, JavascriptCallbackRegistry^ callbackRegistry); + BrowserProcessResponse^ GetProperty(String^ memberName); + BrowserProcessResponse^ SetProperty(String^ memberName, Object^ value); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h new file mode 100644 index 0000000..9274c0a --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPostMessageHandler.h @@ -0,0 +1,94 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" +#include "Serialization\V8Serialization.h" + +using namespace System; +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::BrowserSubprocess::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + const CefString kPostMessage = CefString("PostMessage"); + const CefString kPostMessageCamelCase = CefString("postMessage"); + + private class JavascriptPostMessageHandler : public CefV8Handler + { + private: + gcroot _javascriptCallbackRegistry; + + public: + JavascriptPostMessageHandler(JavascriptCallbackRegistry^ javascriptCallbackRegistry) + { + _javascriptCallbackRegistry = javascriptCallbackRegistry; + } + + bool Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception) override + { + if (arguments.size() == 0 || arguments.size() > 1) + { + //TODO: Improve error message + exception = "Only a single param is accepted"; + + return true; + } + + auto context = CefV8Context::GetCurrentContext(); + if (context.get()) + { + auto frame = context->GetFrame(); + + if (frame.get() && frame->IsValid() && context->Enter()) + { + try + { + auto global = context->GetGlobal(); + + auto request = CefProcessMessage::Create(kJavascriptMessageReceived); + auto argList = request->GetArgumentList(); + + auto params = CefListValue::Create(); + SerializeV8Object(arguments[0], params, 0, _javascriptCallbackRegistry); + + //We're only interested in the first param + if (params->GetSize() > 0) + { + argList->SetValue(0, params->GetValue(0)); + } + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, request); + + retval = CefV8Value::CreateNull(); + } + finally + { + context->Exit(); + } + } + else + { + exception = "Unable to Enter Context"; + } + } + else + { + exception = "Unable to get current context"; + } + + return true; + } + + IMPLEMENT_REFCOUNTINGM(JavascriptPostMessageHandler); + }; + } +} + + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h new file mode 100644 index 0000000..24b7bcd --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseHandler.h @@ -0,0 +1,89 @@ +// Copyright © 2020 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" +#include "Serialization\V8Serialization.h" + +using namespace System; +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::BrowserSubprocess::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + const CefString kSendEvalScriptResponse = CefString("SendEvalScriptResponse"); + const CefString kSendEvalScriptResponseCamelCase = CefString("sendEvalScriptResponse"); + + private class JavascriptPromiseHandler : public CefV8Handler + { + public: + + virtual bool Execute(const CefString& name, + CefRefPtr object, + const CefV8ValueList& arguments, + CefRefPtr& retval, + CefString& exception) + { + if (arguments.size() < 2) + { + //TODO: Improve error message + exception = "Must specify a callback Id and then/catch."; + + return true; + } + + auto callbackId = arguments[0]->GetIntValue(); + + if (callbackId == 0) + { + exception = "Invalid callback Id"; + + return true; + } + + auto success = arguments[1]->GetBoolValue(); + auto javascriptCallback = arguments.size() < 4 ? false : arguments[3]->GetBoolValue(); + + auto response = CefProcessMessage::Create(javascriptCallback ? kJavascriptCallbackResponse : kEvaluateJavascriptResponse); + + auto responseArgList = response->GetArgumentList(); + //Success + responseArgList->SetBool(0, success); + //Callback Id + SetInt64(responseArgList, 1, callbackId); + if (exception == "") + { + if (success) + { + SerializeV8Object(arguments[2], responseArgList, 2, nullptr); + } + else + { + auto reason = arguments[2]; + responseArgList->SetString(2, reason->GetStringValue()); + } + } + else + { + responseArgList->SetString(2, exception); + } + + auto context = CefV8Context::GetCurrentContext(); + + auto frame = context->GetFrame(); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, response); + + return false; + } + + IMPLEMENT_REFCOUNTINGM(JavascriptPromiseHandler); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseResolverCatch.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseResolverCatch.h new file mode 100644 index 0000000..c3dbdda --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseResolverCatch.h @@ -0,0 +1,71 @@ +// Copyright © 2022 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" + +using namespace System; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private class JavascriptPromiseResolverCatch : public CefV8Handler + { + int64 _callbackId; + bool _isJsCallback; + + public: + JavascriptPromiseResolverCatch(int64 callbackId, bool isJsCallback) : _callbackId(callbackId), _isJsCallback(isJsCallback) + { + + } + + virtual bool Execute(const CefString& name, + CefRefPtr object, + const CefV8ValueList& arguments, + CefRefPtr& retval, + CefString& exception) + { + auto context = CefV8Context::GetCurrentContext(); + + auto reason = arguments[0]; + CefString reasonString; + + if (reason->IsString()) + { + reasonString = reason->GetStringValue(); + } + else + { + //Convert value to String + auto strFunc = context->GetGlobal()->GetValue("String"); + CefV8ValueList args; + args.push_back(reason); + auto strVal = strFunc->ExecuteFunction(nullptr, args); + + reasonString = strVal->GetStringValue(); + } + + auto response = CefProcessMessage::Create(_isJsCallback ? kJavascriptCallbackResponse : kEvaluateJavascriptResponse); + auto responseArgList = response->GetArgumentList(); + + //Success + responseArgList->SetBool(0, false); + //Callback Id + SetInt64(responseArgList, 1, _callbackId); + responseArgList->SetString(2, reasonString); + + auto frame = context->GetFrame(); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, response); + + return true; + } + + IMPLEMENT_REFCOUNTINGM(JavascriptPromiseResolverCatch); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseResolverThen.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseResolverThen.h new file mode 100644 index 0000000..e2fa337 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPromiseResolverThen.h @@ -0,0 +1,59 @@ +// Copyright © 2022 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" +#include "Serialization\V8Serialization.h" + +using namespace System; +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::BrowserSubprocess::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private class JavascriptPromiseResolverThen : public CefV8Handler + { + int64 _callbackId; + bool _isJsCallback; + + public: + JavascriptPromiseResolverThen(int64 callbackId, bool isJsCallback) : _callbackId(callbackId), _isJsCallback(isJsCallback) + { + + } + + virtual bool Execute(const CefString& name, + CefRefPtr object, + const CefV8ValueList& arguments, + CefRefPtr& retval, + CefString& exception) + { + auto response = CefProcessMessage::Create(_isJsCallback ? kJavascriptCallbackResponse : kEvaluateJavascriptResponse); + + auto responseArgList = response->GetArgumentList(); + + //Success + responseArgList->SetBool(0, true); + //Callback Id + SetInt64(responseArgList, 1, _callbackId); + SerializeV8Object(arguments[0], responseArgList, 2, nullptr); + + auto context = CefV8Context::GetCurrentContext(); + + auto frame = context->GetFrame(); + + frame->SendProcessMessage(CefProcessId::PID_BROWSER, response); + + return true; + } + + IMPLEMENT_REFCOUNTINGM(JavascriptPromiseResolverThen); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyHandler.h new file mode 100644 index 0000000..1de2931 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyHandler.h @@ -0,0 +1,68 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include/cef_v8.h" +#include "TypeUtils.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private class JavascriptPropertyHandler : public CefV8Accessor + { + gcroot^> _getter; + gcroot^> _setter; + + public: + JavascriptPropertyHandler(Func^ getter, Func^ setter) + { + _getter = getter; + _setter = setter; + } + + ~JavascriptPropertyHandler() + { + delete _getter; + delete _setter; + } + + + virtual bool Get(const CefString& name, const CefRefPtr object, CefRefPtr& retval, + CefString& exception) override + { + //System::Diagnostics::Debugger::Break(); + auto propertyName = StringUtils::ToClr(name); + auto response = _getter->Invoke(propertyName); + retval = TypeUtils::ConvertToCef(response->Result, nullptr); + if (!response->Success) + { + exception = StringUtils::ToNative(response->Message); + } + //NOTE: Return true otherwise exception is ignored + return true; + } + + virtual bool Set(const CefString& name, const CefRefPtr object, const CefRefPtr value, + CefString& exception) override + { + //System::Diagnostics::Debugger::Break(); + auto propertyName = StringUtils::ToClr(name); + auto managedValue = TypeUtils::ConvertFromCef(value, nullptr); + auto response = _setter->Invoke(propertyName, managedValue); + if (!response->Success) + { + exception = StringUtils::ToNative(response->Message); + } + //NOTE: Return true otherwise exception is ignored + return true; + } + + IMPLEMENT_REFCOUNTINGM(JavascriptPropertyHandler); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyWrapper.cpp new file mode 100644 index 0000000..0325cd3 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyWrapper.cpp @@ -0,0 +1,38 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "JavascriptPropertyWrapper.h" +#include "JavascriptObjectWrapper.h" + +using namespace System; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + void JavascriptPropertyWrapper::Bind(JavascriptProperty^ javascriptProperty, const CefRefPtr& v8Value, JavascriptCallbackRegistry^ callbackRegistry) + { + auto propertyName = StringUtils::ToNative(javascriptProperty->JavascriptName); + auto clrPropertyName = javascriptProperty->JavascriptName; + + if (javascriptProperty->IsComplexType) + { + auto javascriptObjectWrapper = gcnew JavascriptObjectWrapper(_browserProcess); + javascriptObjectWrapper->Bind(javascriptProperty->JsObject, v8Value, callbackRegistry); + + _javascriptObjectWrapper = javascriptObjectWrapper; + } + else + { + auto propertyAttribute = javascriptProperty->IsReadOnly ? V8_PROPERTY_ATTRIBUTE_READONLY : V8_PROPERTY_ATTRIBUTE_NONE; + + v8Value->SetValue(propertyName, V8_ACCESS_CONTROL_DEFAULT, propertyAttribute); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyWrapper.h new file mode 100644 index 0000000..7b3abda --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptPropertyWrapper.h @@ -0,0 +1,45 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_v8.h" +#include "JavascriptCallbackRegistry.h" + +using namespace CefSharp::Internals::Wcf; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class JavascriptPropertyWrapper + { + private: + int64 _ownerId; + IBrowserProcess^ _browserProcess; + //TODO: Strongly type this variable - currently trying to include JavascriptObjectWrapper.h creates a circular reference, so won't compile + Object^ _javascriptObjectWrapper; + + public: + JavascriptPropertyWrapper(int64 ownerId, IBrowserProcess^ browserProcess) + { + _ownerId = ownerId; + _browserProcess = browserProcess; + _javascriptObjectWrapper = nullptr; + } + + ~JavascriptPropertyWrapper() + { + if (_javascriptObjectWrapper != nullptr) + { + delete _javascriptObjectWrapper; + _javascriptObjectWrapper = nullptr; + } + } + + void Bind(JavascriptProperty^ javascriptProperty, const CefRefPtr& v8Value, JavascriptCallbackRegistry^ callbackRegistry); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptRootObjectWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptRootObjectWrapper.cpp new file mode 100644 index 0000000..af73c6e --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptRootObjectWrapper.cpp @@ -0,0 +1,74 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "JavascriptRootObjectWrapper.h" +#include "CefAppUnmanagedWrapper.h" + +using namespace System::Threading; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + void JavascriptRootObjectWrapper::Bind(ICollection^ objects, const CefRefPtr& v8Value) + { + if (objects->Count > 0) + { + auto saveMethod = gcnew Func(this, &JavascriptRootObjectWrapper::SaveMethodCallback); + + for each (JavascriptObject ^ obj in Enumerable::OfType(objects)) + { + if (obj->IsAsync) + { + auto wrapperObject = gcnew JavascriptAsyncObjectWrapper(_callbackRegistry, saveMethod); + wrapperObject->Bind(obj, v8Value); + + _wrappedAsyncObjects->Add(wrapperObject); + } +#ifndef NETCOREAPP + else + { + if (_browserProcess == nullptr) + { + LOG(ERROR) << StringUtils::ToNative("IBrowserProcess is null, unable to bind object " + obj->JavascriptName).ToString(); + + continue; + } + + auto wrapperObject = gcnew JavascriptObjectWrapper(_browserProcess); + wrapperObject->Bind(obj, v8Value, _callbackRegistry); + + _wrappedObjects->Add(wrapperObject); + } +#endif + } + } + } + + JavascriptCallbackRegistry^ JavascriptRootObjectWrapper::CallbackRegistry::get() + { + return _callbackRegistry; + } + + int64 JavascriptRootObjectWrapper::SaveMethodCallback(JavascriptAsyncMethodCallback^ callback) + { + auto callbackId = Interlocked::Increment(_lastCallback); + _methodCallbacks->Add(callbackId, callback); + return callbackId; + } + + bool JavascriptRootObjectWrapper::TryGetAndRemoveMethodCallback(int64 id, JavascriptAsyncMethodCallback^% callback) + { + bool result = false; + if (result = _methodCallbacks->TryGetValue(id, callback)) + { + _methodCallbacks->Remove(id); + } + return result; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptRootObjectWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptRootObjectWrapper.h new file mode 100644 index 0000000..ca2879b --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/JavascriptRootObjectWrapper.h @@ -0,0 +1,110 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "JavascriptCallbackRegistry.h" +#ifndef NETCOREAPP +#include "JavascriptObjectWrapper.h" +#endif +#include "Async/JavascriptAsyncObjectWrapper.h" + +using namespace System::Runtime::Serialization; +using namespace System::Linq; +using namespace System::Collections::Generic; + +using namespace CefSharp::BrowserSubprocess::Async; +#ifndef NETCOREAPP +using namespace CefSharp::Internals::Wcf; +#endif + +namespace CefSharp +{ + namespace BrowserSubprocess + { + // This wraps the transmitted registered objects + // by binding the meta-data to V8 JavaScript objects + // and installing callbacks for changes to those + // objects. + private ref class JavascriptRootObjectWrapper + { + private: + //Only access through Interlocked::Increment - used to generate unique callback Id's + //Is static so ids are unique to this process https://github.com/cefsharp/CefSharp/issues/2792 + static int64 _lastCallback; + +#ifndef NETCOREAPP + initonly List^ _wrappedObjects; +#endif + initonly List^ _wrappedAsyncObjects; + initonly Dictionary^ _methodCallbacks; +#ifndef NETCOREAPP + IBrowserProcess^ _browserProcess; +#endif + // The entire set of possible JavaScript functions to + // call directly into. + JavascriptCallbackRegistry^ _callbackRegistry; + + int64 SaveMethodCallback(JavascriptAsyncMethodCallback^ callback); + + internal: + property JavascriptCallbackRegistry^ CallbackRegistry + { + JavascriptCallbackRegistry^ get(); + } + + public: +#ifdef NETCOREAPP + JavascriptRootObjectWrapper(int browserId) +#else + JavascriptRootObjectWrapper(int browserId, IBrowserProcess^ browserProcess) +#endif + { +#ifndef NETCOREAPP + _browserProcess = browserProcess; + _wrappedObjects = gcnew List(); +#endif + _wrappedAsyncObjects = gcnew List(); + _callbackRegistry = gcnew JavascriptCallbackRegistry(browserId); + _methodCallbacks = gcnew Dictionary(); + } + + ~JavascriptRootObjectWrapper() + { + if (_callbackRegistry != nullptr) + { + delete _callbackRegistry; + _callbackRegistry = nullptr; + } + +#ifndef NETCOREAPP + for each (JavascriptObjectWrapper ^ var in _wrappedObjects) + { + delete var; + } + _wrappedObjects->Clear(); + +#endif + + for each (JavascriptAsyncObjectWrapper ^ var in _wrappedAsyncObjects) + { + delete var; + } + _wrappedAsyncObjects->Clear(); + + for each (JavascriptAsyncMethodCallback ^ var in _methodCallbacks->Values) + { + delete var; + } + _methodCallbacks->Clear(); + } + + bool TryGetAndRemoveMethodCallback(int64 id, JavascriptAsyncMethodCallback^% callback); + + void Bind(ICollection^ objects, const CefRefPtr& v8Value); + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h new file mode 100644 index 0000000..525bf19 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectHandler.h @@ -0,0 +1,129 @@ +// Copyright © 2018 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "RegisterBoundObjectRegistry.h" +#include "..\CefSharp.Core.Runtime\Internals\Messaging\Messages.h" +#include "..\CefSharp.Core.Runtime\Internals\Serialization\Primitives.h" + +using namespace System; +using namespace CefSharp::Internals::Messaging; +using namespace CefSharp::Internals::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + const CefString kIsObjectCached = CefString("IsObjectCached"); + const CefString kIsObjectCachedCamelCase = CefString("isObjectCached"); + const CefString kRemoveObjectFromCache = CefString("RemoveObjectFromCache"); + const CefString kRemoveObjectFromCacheCamelCase = CefString("removeObjectFromCache"); + const CefString kDeleteBoundObject = CefString("DeleteBoundObject"); + const CefString kDeleteBoundObjectCamelCase = CefString("deleteBoundObject"); + + private class RegisterBoundObjectHandler : public CefV8Handler + { + private: + gcroot^> _javascriptObjects; + + public: + RegisterBoundObjectHandler(Dictionary^ javascriptObjects) + { + _javascriptObjects = javascriptObjects; + } + + bool Execute(const CefString& name, CefRefPtr object, const CefV8ValueList& arguments, CefRefPtr& retval, CefString& exception) override + { + auto context = CefV8Context::GetCurrentContext(); + if (context.get()) + { + if (context.get() && context->Enter()) + { + try + { + if (name == kIsObjectCached || name == kIsObjectCachedCamelCase) + { + if (arguments.size() == 0 || arguments.size() > 1) + { + //TODO: Improve error message + exception = "Must specify the name of a single bound object to check the cache for"; + + return true; + } + + auto objectName = arguments[0]->GetStringValue(); + auto managedObjectName = StringUtils::ToClr(objectName); + + //Check to see if the object name is within the cache + retval = CefV8Value::CreateBool(_javascriptObjects->ContainsKey(managedObjectName)); + } + else if (name == kRemoveObjectFromCache || name == kRemoveObjectFromCacheCamelCase) + { + if (arguments.size() == 0 || arguments.size() > 1) + { + //TODO: Improve error message + exception = "Must specify the name of a single bound object to remove from cache"; + + return true; + } + + auto objectName = arguments[0]->GetStringValue(); + auto managedObjectName = StringUtils::ToClr(objectName); + + if (_javascriptObjects->ContainsKey(managedObjectName)) + { + //Remove object from cache + retval = CefV8Value::CreateBool(_javascriptObjects->Remove(managedObjectName)); + } + else + { + retval = CefV8Value::CreateBool(false); + } + } + //TODO: Better name for this function + else if (name == kDeleteBoundObject || name == kDeleteBoundObjectCamelCase) + { + if (arguments.size() == 0 || arguments.size() > 1) + { + //TODO: Improve error message + exception = "Must specify the name of a bound object to unbind, one object at a time."; + + return true; + } + + auto objectName = arguments[0]->GetStringValue(); + + auto global = context->GetGlobal(); + + auto success = global->DeleteValue(objectName); + + retval = CefV8Value::CreateBool(success); + } + } + finally + { + context->Exit(); + } + } + else + { + exception = "Unable to Enter Context"; + } + } + else + { + exception = "Unable to get current context"; + } + + + return true; + } + + IMPLEMENT_REFCOUNTINGM(RegisterBoundObjectHandler); + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectRegistry.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectRegistry.h new file mode 100644 index 0000000..c9602da --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/RegisterBoundObjectRegistry.h @@ -0,0 +1,64 @@ +// Copyright © 2018 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" + +#include "Async/JavascriptAsyncMethodCallback.h" + +using namespace System::Runtime::Serialization; +using namespace System::Linq; +using namespace System::Threading; +using namespace System::Collections::Generic; +using namespace CefSharp::BrowserSubprocess::Async; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + //TODO: JSB Fix naming of this class, it's pretty horrible currently + private ref class RegisterBoundObjectRegistry + { + private: + //Only access through Interlocked::Increment - used to generate unique callback Id's + //Is static so ids are unique to this process https://github.com/cefsharp/CefSharp/issues/2792 + static int64 _lastCallback; + + initonly Dictionary^ _methodCallbacks; + + public: + RegisterBoundObjectRegistry() + { + _methodCallbacks = gcnew Dictionary(); + } + + ~RegisterBoundObjectRegistry() + { + for each (JavascriptAsyncMethodCallback ^ var in _methodCallbacks->Values) + { + delete var; + } + _methodCallbacks->Clear(); + } + + int64 SaveMethodCallback(JavascriptAsyncMethodCallback^ callback) + { + auto callbackId = Interlocked::Increment(_lastCallback); + _methodCallbacks->Add(callbackId, callback); + return callbackId; + } + + bool TryGetAndRemoveMethodCallback(int64 id, JavascriptAsyncMethodCallback^% callback) + { + bool result = false; + if (result = _methodCallbacks->TryGetValue(id, callback)) + { + _methodCallbacks->Remove(id); + } + return result; + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp new file mode 100644 index 0000000..15ff56d --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.cpp @@ -0,0 +1,84 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "stdafx.h" +#include "JsObjectsSerialization.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/Primitives.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/ObjectsSerialization.h" + +using namespace CefSharp::Internals::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Serialization + { + JavascriptObject^ DeserializeJsObject(const CefRefPtr& rootList, int index) + { + if (rootList->GetType(index) == VTYPE_INVALID || + rootList->GetType(index) == VTYPE_NULL) + { + return nullptr; + } + + auto list = rootList->GetList(index); + auto jsObject = gcnew JavascriptObject(); + jsObject->Id = GetInt64(list, 0); + jsObject->Name = StringUtils::ToClr(list->GetString(1)); + jsObject->JavascriptName = StringUtils::ToClr(list->GetString(2)); + jsObject->IsAsync = list->GetBool(3); + + auto methodList = list->GetList(4); + auto methodCount = methodList->GetInt(0); + auto k = 1; + for (auto j = 0; j < methodCount; j++) + { + auto jsMethod = gcnew JavascriptMethod(); + + jsMethod->Id = GetInt64(methodList, k++); + jsMethod->ManagedName = StringUtils::ToClr(methodList->GetString(k++)); + jsMethod->JavascriptName = StringUtils::ToClr(methodList->GetString(k++)); + jsMethod->ParameterCount = methodList->GetInt(k++); + + jsObject->Methods->Add(jsMethod); + } + + auto propertyList = list->GetList(5); + auto propertyCount = propertyList->GetInt(0); + k = 1; + for (auto j = 0; j < propertyCount; j++) + { + auto jsProperty = gcnew JavascriptProperty(); + + jsProperty->Id = GetInt64(propertyList, k++); + jsProperty->ManagedName = StringUtils::ToClr(propertyList->GetString(k++)); + jsProperty->JavascriptName = StringUtils::ToClr(propertyList->GetString(k++)); + jsProperty->IsComplexType = propertyList->GetBool(k++); + jsProperty->IsReadOnly = propertyList->GetBool(k++); + + jsProperty->JsObject = DeserializeJsObject(propertyList, k++); + jsProperty->PropertyValue = DeserializeObject(propertyList, k++, nullptr); + + jsObject->Properties->Add(jsProperty); + } + return jsObject; + } + + List^ DeserializeJsObjects(const CefRefPtr& list, int index) + { + auto result = gcnew List(); + auto subList = list->GetList(index); + auto size = static_cast(subList->GetSize()); + + for (int i = 0; i < size; i++) + { + result->Add(DeserializeJsObject(subList, i)); + } + + return result; + } + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.h new file mode 100644 index 0000000..8e64309 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/JsObjectsSerialization.h @@ -0,0 +1,19 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_values.h" + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Serialization + { + JavascriptObject^ DeserializeJsObject(const CefRefPtr& list, int index); + List^ DeserializeJsObjects(const CefRefPtr& list, int index); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp new file mode 100644 index 0000000..19cfa35 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.cpp @@ -0,0 +1,203 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" +#include "V8Serialization.h" +#include "JavascriptCallbackRegistry.h" +#include "../CefSharp.Core.Runtime/Internals/Serialization/Primitives.h" + +#include + +using namespace std; +using namespace CefSharp::Internals::Serialization; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Serialization + { + typedef deque> value_deque; + + template + void SerializeV8Object(const CefRefPtr &obj, const CefRefPtr& list, const TIndex& index, JavascriptCallbackRegistry^ callbackRegistry, value_deque &seen) + { + for (value_deque::const_iterator it = seen.begin(); it != seen.end(); ++it) + { + if (obj->IsSame(*it)) + { + throw exception("Cycle found"); + } + } + seen.push_back(obj); + + if (obj->IsNull() || obj->IsUndefined()) + { + list->SetNull(index); + } + else if (obj->IsBool()) + { + list->SetBool(index, obj->GetBoolValue()); + } + else if (obj->IsInt()) + { + // CEF doesn't differentiate between UINT and INT + // so we have to do some additional bounds checking + // To make sure the correct value is returned + // CEF IPC doesn't support UINT so we can only + // support int and double. + // https://github.com/cefsharp/CefSharp/issues/3858 + auto dValue = obj->GetDoubleValue(); + + if (dValue < INT_MIN || dValue > INT_MAX) + { + list->SetDouble(index, dValue); + } + else + { + list->SetInt(index, obj->GetIntValue()); + } + } + else if (obj->IsDouble()) + { + list->SetDouble(index, obj->GetDoubleValue()); + } + else if (obj->IsString()) + { + list->SetString(index, obj->GetStringValue()); + } + else if (obj->IsDate()) + { + SetCefTime(list, index, obj->GetDateValue().val); + } + else if (obj->IsArray()) + { + int arrLength = obj->GetArrayLength(); + auto array = CefListValue::Create(); + if (arrLength > 0) + { + for (int i = 0; i < arrLength; i++) + { + SerializeV8Object(obj->GetValue(i), array, i, callbackRegistry, seen); + } + } + + list->SetList(index, array); + } + else if (obj->IsFunction()) + { + auto context = CefV8Context::GetCurrentContext(); + auto jsCallback = callbackRegistry->Register(context, obj); + SetJsCallback(list, index, jsCallback); + } + else if (obj->IsObject()) + { + std::vector keys; + if (obj->GetKeys(keys) && keys.size() > 0) + { + auto result = CefDictionaryValue::Create(); + for (size_t i = 0; i < keys.size(); i++) + { + auto p_keyStr = StringUtils::ToClr(keys[i].ToString()); + if ((obj->HasValue(keys[i])) && (!p_keyStr->StartsWith("__"))) + { + SerializeV8Object(obj->GetValue(keys[i]), result, keys[i], callbackRegistry, seen); + } + } + list->SetDictionary(index, result); + } + } + else + { + list->SetNull(index); + } + seen.pop_back(); + } + + template + void SerializeV8Object(const CefRefPtr &obj, const CefRefPtr& list, const TIndex& index, JavascriptCallbackRegistry^ callbackRegistry) + { + try + { + value_deque seen; + SerializeV8Object(obj, list, index, callbackRegistry, seen); + } + catch (const exception&) + { + list->SetNull(index); + } + } + + template + CefRefPtr DeserializeV8Object(const CefRefPtr& list, const TIndex& index) + { + auto type = list->GetType(index); + + if (type == VTYPE_BOOL) + { + return CefV8Value::CreateBool(list->GetBool(index)); + } + + if (type == VTYPE_INT) + { + return CefV8Value::CreateInt(list->GetInt(index)); + } + + if (type == VTYPE_DOUBLE) + { + return CefV8Value::CreateDouble(list->GetDouble(index)); + } + + if (type == VTYPE_STRING) + { + return CefV8Value::CreateString(list->GetString(index)); + } + + if (IsCefTime(list, index)) + { + auto time = GetCefTime(list, index); + return CefV8Value::CreateDate(time); + } + + if (type == VTYPE_LIST) + { + auto subList = list->GetList(index); + auto size = static_cast(subList->GetSize()); + auto result = CefV8Value::CreateArray(size); + for (int i = 0; i < size; i++) + { + result->SetValue(i, DeserializeV8Object(subList, i)); + } + + return result; + } + + if (type == VTYPE_DICTIONARY) + { + auto subDict = list->GetDictionary(index); + auto size = subDict->GetSize(); + std::vector keys; + subDict->GetKeys(keys); + auto result = CefV8Value::CreateObject(nullptr, nullptr); + for (size_t i = 0; i < size; i++) + { + result->SetValue(keys[i], DeserializeV8Object(subDict, keys[i]), V8_PROPERTY_ATTRIBUTE_NONE); + } + + return result; + } + + return CefV8Value::CreateNull(); + } + + template void SerializeV8Object(const CefRefPtr &value, const CefRefPtr& list, const int& index, JavascriptCallbackRegistry^ callbackRegistry); + template void SerializeV8Object(const CefRefPtr &value, const CefRefPtr& list, const size_t& index, JavascriptCallbackRegistry^ callbackRegistry); + template void SerializeV8Object(const CefRefPtr &value, const CefRefPtr& list, const CefString& index, JavascriptCallbackRegistry^ callbackRegistry); + template void SerializeV8Object(const CefRefPtr &value, const CefRefPtr& list, const size_t& index, JavascriptCallbackRegistry^ callbackRegistry, value_deque &visited); + template void SerializeV8Object(const CefRefPtr &value, const CefRefPtr& list, const CefString& index, JavascriptCallbackRegistry^ callbackRegistry, value_deque &visited); + template CefRefPtr DeserializeV8Object(const CefRefPtr& list, const int& index); + template CefRefPtr DeserializeV8Object(const CefRefPtr& list, const CefString& index); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.h new file mode 100644 index 0000000..9c0bc4c --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Serialization/V8Serialization.h @@ -0,0 +1,30 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "include/cef_v8.h" +#include "JavascriptCallbackRegistry.h" + +using namespace CefSharp::Internals; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + namespace Serialization + { + //Functions to serialize/deserialize data sent to/received from the browser process. + + //Serializes a V8 structure into a given index of a CefListValue or CefDictionaryValue + //JavascriptCallbackRegistry should be passed to save V8Values with function types + template + void SerializeV8Object(const CefRefPtr &value, const CefRefPtr& list, const TIndex& index, JavascriptCallbackRegistry^ callbackRegistry); + + //Deserializes data from a given index of a CefListValue or a CefDictionaryValue + template + CefRefPtr DeserializeV8Object(const CefRefPtr& list, const TIndex& index); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Stdafx.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Stdafx.cpp new file mode 100644 index 0000000..232e9db --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Stdafx.cpp @@ -0,0 +1,3 @@ +#pragma once + +#include "Stdafx.h" diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Stdafx.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Stdafx.h new file mode 100644 index 0000000..f080d84 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Stdafx.h @@ -0,0 +1,24 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#ifdef EXPORT +#define DECL __declspec(dllexport) +#else +#define DECL __declspec(dllimport) +#endif + +#include + +#include + +#include ".\..\CefSharp.Core.Runtime\Internals\CefRefCountManaged.h" +#include ".\..\CefSharp.Core.Runtime\Internals\MCefRefPtr.h" +#include ".\..\CefSharp.Core.Runtime\Internals\StringUtils.h" +#include "vcclr_local.h" + +using namespace System; +using namespace CefSharp; +using namespace CefSharp::Internals; diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/SubProcess.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/SubProcess.h new file mode 100644 index 0000000..8f988f5 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/SubProcess.h @@ -0,0 +1,84 @@ +// Copyright © 2016 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_app.h" + +#include "SubProcessApp.h" +#include "CefBrowserWrapper.h" +#include "CefAppUnmanagedWrapper.h" +#include "Cef.h" + +using namespace System::Collections::Generic; +using namespace System::Linq; +using namespace CefSharp::Internals; +using namespace CefSharp::RenderProcess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + // Wrap CefAppUnmangedWrapper in a nice managed wrapper + public ref class SubProcess + { + private: + MCefRefPtr _cefApp; + + public: + SubProcess(IRenderProcessHandler^ handler, IEnumerable^ args) + { + auto onBrowserCreated = gcnew Action(this, &SubProcess::OnBrowserCreated); + auto onBrowserDestroyed = gcnew Action(this, &SubProcess::OnBrowserDestroyed); + auto schemes = CefCustomScheme::ParseCommandLineArguments(args); + auto enableFocusedNodeChanged = CommandLineArgsParser::HasArgument(args, CefSharpArguments::FocusedNodeChangedEnabledArgument); + + _cefApp = new CefAppUnmanagedWrapper(handler, schemes, enableFocusedNodeChanged, onBrowserCreated, onBrowserDestroyed); + } + + !SubProcess() + { + _cefApp = nullptr; + } + + ~SubProcess() + { + this->!SubProcess(); + } + + int Run() + { + auto hInstance = Process::GetCurrentProcess()->Handle; + + CefMainArgs cefMainArgs((HINSTANCE)hInstance.ToPointer()); + + return CefExecuteProcess(cefMainArgs, (CefApp*)_cefApp.get(), nullptr); + } + + virtual void OnBrowserCreated(CefBrowserWrapper^ cefBrowserWrapper) + { + + } + + virtual void OnBrowserDestroyed(CefBrowserWrapper^ cefBrowserWrapper) + { + + } + + static int ExecuteProcess(IEnumerable^ args) + { + auto hInstance = Process::GetCurrentProcess()->Handle; + + CefMainArgs cefMainArgs((HINSTANCE)hInstance.ToPointer()); + + auto schemes = CefCustomScheme::ParseCommandLineArguments(args); + + CefRefPtr app = new SubProcessApp(schemes); + + return CefExecuteProcess(cefMainArgs, app, nullptr); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/SubProcessApp.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/SubProcessApp.h new file mode 100644 index 0000000..b3e4c9b --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/SubProcessApp.h @@ -0,0 +1,50 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_app.h" + +using namespace System::Collections::Generic; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + // CefApp implementation that's common across all subprocess types + public class SubProcessApp : public CefApp + { + private: + gcroot^> _schemes; + + public: + SubProcessApp(List^ schemes) + { + _schemes = schemes; + } + + ~SubProcessApp() + { + delete _schemes; + _schemes = nullptr; + } + + void OnRegisterCustomSchemes(CefRawPtr registrar) override + { + for each (CefCustomScheme ^ scheme in _schemes->AsReadOnly()) + { + auto schemeName = StringUtils::ToNative(scheme->SchemeName); + auto schemeOptions = (int)scheme->Options; + if (!registrar->AddCustomScheme(schemeName, schemeOptions)) + { + LOG(ERROR) << "SubProcessApp::OnRegisterCustomSchemes failed for schemeName:" << schemeName; + } + } + } + + IMPLEMENT_REFCOUNTINGM(SubProcessApp); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp new file mode 100644 index 0000000..1d0afe4 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/TypeUtils.cpp @@ -0,0 +1,260 @@ +// Copyright © 2010 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include ".\..\CefSharp.Core.Runtime\Internals\StringUtils.h" +#include "TypeUtils.h" + +using namespace System::Collections::Generic; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + CefRefPtr TypeUtils::ConvertToCef(Object^ obj, Type^ type) + { + if (type == Void::typeid) + { + return CefV8Value::CreateUndefined(); + } + if (obj == nullptr) + { + return CefV8Value::CreateNull(); + } + + if (type == nullptr) + { + type = obj->GetType(); + } + + Type^ underlyingType = Nullable::GetUnderlyingType(type); + if (underlyingType != nullptr) type = underlyingType; + + if (type == Boolean::typeid) + { + return CefV8Value::CreateBool(safe_cast(obj)); + } + if (type == Int32::typeid) + { + return CefV8Value::CreateInt(safe_cast(obj)); + } + if (type == String::typeid) + { + CefString str = StringUtils::ToNative(safe_cast(obj)); + return CefV8Value::CreateString(str); + } + if (type == Double::typeid) + { + return CefV8Value::CreateDouble(safe_cast(obj)); + } + if (type == Decimal::typeid) + { + return CefV8Value::CreateDouble(Convert::ToDouble(obj)); + } + if (type == SByte::typeid) + { + return CefV8Value::CreateInt(Convert::ToInt32(obj)); + } + if (type == Int16::typeid) + { + return CefV8Value::CreateInt(Convert::ToInt32(obj)); + } + if (type == Int64::typeid) + { + return CefV8Value::CreateDouble(Convert::ToDouble(obj)); + } + if (type == Byte::typeid) + { + return CefV8Value::CreateInt(Convert::ToInt32(obj)); + } + if (type == UInt16::typeid) + { + return CefV8Value::CreateInt(Convert::ToInt32(obj)); + } + if (type == UInt32::typeid) + { + return CefV8Value::CreateDouble(Convert::ToDouble(obj)); + } + if (type == UInt64::typeid) + { + return CefV8Value::CreateDouble(Convert::ToDouble(obj)); + } + if (type == Single::typeid) + { + return CefV8Value::CreateDouble(Convert::ToDouble(obj)); + } + if (type == Char::typeid) + { + return CefV8Value::CreateInt(Convert::ToInt32(obj)); + } + if (type == DateTime::typeid) + { + CefBaseTime baseTime; + baseTime.val = CefTimeUtils::FromDateTimeToBaseTime(safe_cast(obj)); + return CefV8Value::CreateDate(baseTime); + } + if (type->IsArray) + { + Array^ managedArray = (Array^)obj; + CefRefPtr cefArray = CefV8Value::CreateArray(managedArray->Length); + + for (int i = 0; i < managedArray->Length; i++) + { + Object^ arrObj; + + arrObj = managedArray->GetValue(i); + + if (arrObj != nullptr) + { + CefRefPtr cefObj = TypeUtils::ConvertToCef(arrObj, arrObj->GetType()); + + cefArray->SetValue(i, cefObj); + } + else + { + cefArray->SetValue(i, CefV8Value::CreateNull()); + } + } + + return cefArray; + } + if (type->IsValueType && !type->IsPrimitive && !type->IsEnum) + { + cli::array^ fields = type->GetFields(); + CefRefPtr cefArray = CefV8Value::CreateArray(fields->Length); + + for (int i = 0; i < fields->Length; i++) + { + String^ fieldName = fields[i]->Name; + + CefString strFieldName = StringUtils::ToNative(safe_cast(fieldName)); + + Object^ fieldVal = fields[i]->GetValue(obj); + + if (fieldVal != nullptr) + { + CefRefPtr cefVal = TypeUtils::ConvertToCef(fieldVal, fieldVal->GetType()); + + cefArray->SetValue(strFieldName, cefVal, V8_PROPERTY_ATTRIBUTE_NONE); + } + else + { + cefArray->SetValue(strFieldName, CefV8Value::CreateNull(), V8_PROPERTY_ATTRIBUTE_NONE); + } + } + + return cefArray; + } + //TODO: What exception type? + throw gcnew Exception(String::Format("Cannot convert '{0}' object from CLR to CEF.", type->FullName)); + } + + Object^ TypeUtils::ConvertFromCef(CefRefPtr obj, JavascriptCallbackRegistry^ callbackRegistry) + { + if (obj->IsNull() || obj->IsUndefined()) + { + return nullptr; + } + + if (obj->IsBool()) + { + return gcnew System::Boolean(obj->GetBoolValue()); + } + if (obj->IsInt()) + { + return gcnew System::Int32(obj->GetIntValue()); + } + if (obj->IsDouble()) + { + return gcnew System::Double(obj->GetDoubleValue()); + } + if (obj->IsString()) + { + return StringUtils::ToClr(obj->GetStringValue()); + } + if (obj->IsDate()) + { + return CefTimeUtils::FromBaseTimeToDateTime(obj->GetDateValue().val); + } + + if (obj->IsArray()) + { + int arrLength = obj->GetArrayLength(); + + if (arrLength > 0) + { + std::vector keys; + if (obj->GetKeys(keys)) + { + auto array = gcnew List(); + + //TODO: This can likely be simplified to just call GetValue(i) rather than accessing the keys + for (int i = 0; i < arrLength; i++) + { + auto data = obj->GetValue(keys[i]); + if (data != nullptr) + { + auto p_data = TypeUtils::ConvertFromCef(data, callbackRegistry); + + array->Add(p_data); + } + } + + return array->ToArray(); + } + } + + return nullptr; + } + + if (obj->IsFunction()) + { + if (callbackRegistry == nullptr) + { + return nullptr; + } + + return callbackRegistry->Register(CefV8Context::GetCurrentContext(), obj); + } + + if (obj->IsObject()) + { + std::vector keys; + if (obj->GetKeys(keys)) + { + size_t objLength = keys.size(); + if (objLength > 0) + { + auto result = gcnew Dictionary(); + + for (size_t i = 0; i < objLength; i++) + { + String^ p_keyStr = StringUtils::ToClr(keys[i].ToString()); + + if ((obj->HasValue(keys[i])) && (!p_keyStr->StartsWith("__"))) + { + CefRefPtr data = obj->GetValue(keys[i]); + if (data != nullptr) + { + Object^ p_data = TypeUtils::ConvertFromCef(data, callbackRegistry); + + result->Add(p_keyStr, p_data); + } + } + } + + return result; + } + } + + return nullptr; + } + + //TODO: What exception type? + throw gcnew Exception("Cannot convert object from Cef to CLR."); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/TypeUtils.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/TypeUtils.h new file mode 100644 index 0000000..b7392e9 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/TypeUtils.h @@ -0,0 +1,55 @@ +// Copyright © 2012 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_v8.h" +#include "JavascriptCallbackRegistry.h" + +using namespace System; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private class TypeUtils + { + public: + /// + /// Converts a .NET object to an (unmanaged) Chromium V8 object. + /// + /// The .NET object that should be converted. + /// The type of the source object. If this parameter is a null reference, the type will be determined + /// automatically. + /// A corresponding V8 value. + static CefRefPtr ConvertToCef(Object^ obj, Type^ type); + + /// + /// Converts a Chromium V8 value to a (managed) .NET object + /// using a JavascriptCallbackRegistry param to convert any + /// anonymous function to IJavascriptCallback, if callbackRegistry + /// is nullptr will use nullptr to each anonymous function instead. + /// + /// The V8 value that should be converted. + /// Instance of JavascriptCallbackRegistry to manage IJavascriptCallback instances. + /// A corresponding .NET object. + static Object^ ConvertFromCef(CefRefPtr obj, JavascriptCallbackRegistry^ callbackRegistry); + + /// + /// Converts a Chromium V8 CefBaseTime (Date) to a (managed) .NET DateTime. + /// + /// The CefTime value that should be converted. + /// A corresponding .NET DateTime. + static DateTime ConvertCefTimeToDateTime(CefBaseTime time); + + /// + /// Converts a a (managed) .NET DateTime to Chromium V8 CefBaseTime (Date). + /// + /// The DateTime value that should be converted. + /// A corresponding CefTime (epoch). + static CefBaseTime ConvertDateTimeToCefTime(DateTime dateTime); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfBrowserSubprocessExecutable.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfBrowserSubprocessExecutable.h new file mode 100644 index 0000000..761e534 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfBrowserSubprocessExecutable.h @@ -0,0 +1,46 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "SubProcess.h" +#include "WcfEnabledSubProcess.h" +#include "BrowserSubprocessExecutable.h" + +using namespace System; +using namespace CefSharp::Internals; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + /// + /// WcfBrowserSubprocessExecutable provides the fundimental browser process handling for + /// CefSharp.BrowserSubprocess.exe and can be used to self host the BrowserSubProcess in your + /// existing application (preferred approach for .Net Core). + /// If the command line argument is + /// present then the WcfEnabledSubProcess implementation is used. + /// + public ref class WcfBrowserSubprocessExecutable : BrowserSubprocessExecutable + { + public: + WcfBrowserSubprocessExecutable() + { + + } + protected: + SubProcess^ GetSubprocess(IEnumerable^ args, int parentProcessId, IRenderProcessHandler^ handler) override + { + auto wcfEnabled = CommandLineArgsParser::HasArgument(args, CefSharpArguments::WcfEnabledArgument); + if (wcfEnabled) + { + return gcnew WcfEnabledSubProcess(parentProcessId, handler, args); + } + return gcnew SubProcess(handler, args); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfEnabledSubProcess.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfEnabledSubProcess.cpp new file mode 100644 index 0000000..ced1f83 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfEnabledSubProcess.cpp @@ -0,0 +1,103 @@ +// Copyright © 2016 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "WcfEnabledSubProcess.h" + +using namespace System::ServiceModel; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + void WcfEnabledSubProcess::OnBrowserCreated(CefBrowserWrapper^ browser) + { + if (!_parentBrowserId.HasValue) + { + _parentBrowserId = browser->BrowserId; + } + + if (!_parentBrowserId.HasValue) + { + return; + } + + //TODO: This can likely be simplified as both values are likely equal + auto browserId = browser->IsPopup ? _parentBrowserId.Value : browser->BrowserId; + + auto serviceName = RenderprocessClientFactory::GetServiceName(_parentProcessId, browserId); + + auto binding = BrowserProcessServiceHost::CreateBinding(); + + auto channelFactory = gcnew ChannelFactory( + binding, + gcnew EndpointAddress(serviceName) + ); + + channelFactory->Open(); + + auto browserProcess = channelFactory->CreateChannel(); + auto clientChannel = ((IClientChannel^)browserProcess); + + try + { + clientChannel->Open(); + + browser->ChannelFactory = channelFactory; + browser->BrowserProcess = browserProcess; + } + catch (Exception^) + { + } + } + + void WcfEnabledSubProcess::OnBrowserDestroyed(CefBrowserWrapper^ browser) + { + auto channelFactory = browser->ChannelFactory; + + //Add null check for issue https://github.com/cefsharp/CefSharp/issues/2839 + if (channelFactory == nullptr) + { + LOG(ERROR) << "WcfEnabledSubProcess::OnBrowserDestroyed - browser->ChannelFactory was unexpectedly null, see https://github.com/cefsharp/CefSharp/issues/2839 for some debugging tips."; + } + else + { + try + { + if (channelFactory->State == CommunicationState::Opened) + { + channelFactory->Close(); + } + } + catch (Exception^) + { + channelFactory->Abort(); + } + } + + //Add null check for issue https://github.com/cefsharp/CefSharp/issues/2839 + if (browser->BrowserProcess != nullptr) + { + auto clientChannel = ((IClientChannel^)browser->BrowserProcess); + + try + { + if (clientChannel->State == CommunicationState::Opened) + { + clientChannel->Close(); + } + } + catch (Exception^) + { + clientChannel->Abort(); + } + } + + browser->ChannelFactory = nullptr; + browser->BrowserProcess = nullptr; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfEnabledSubProcess.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfEnabledSubProcess.h new file mode 100644 index 0000000..ffd3ea4 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/WcfEnabledSubProcess.h @@ -0,0 +1,38 @@ +// Copyright © 2016 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "SubProcess.h" +#include "CefBrowserWrapper.h" + +using namespace System; +using namespace CefSharp::RenderProcess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + public ref class WcfEnabledSubProcess : SubProcess + { + private: + Nullable _parentBrowserId; + + /// + /// The PID for the parent (browser) process + /// + int _parentProcessId; + + public: + WcfEnabledSubProcess(int parentProcessId, IRenderProcessHandler^ handler, IEnumerable^ args) : SubProcess(handler,args) + { + _parentProcessId = parentProcessId; + } + + void OnBrowserCreated(CefBrowserWrapper^ browser) override; + void OnBrowserDestroyed(CefBrowserWrapper^ browser) override; + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Browser.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Browser.cpp new file mode 100644 index 0000000..3f1f985 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Browser.cpp @@ -0,0 +1,226 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" + +#include "Frame.h" +#include "Browser.h" + +using namespace CefSharp::BrowserSubprocess; + +bool Browser::IsValid::get() +{ + return _browser->IsValid(); +} + +/// +// Returns the browser host object. This method can only be called in the +// browser process. +/// +/*--cef()--*/ +IBrowserHost^ Browser::GetHost() +{ + throw gcnew NotImplementedException("Browser process only"); +} + +/// +// Returns true if the browser can navigate backwards. +/// +/*--cef()--*/ +bool Browser::CanGoBack::get() +{ + return _browser->CanGoBack(); +} + +/// +// Navigate backwards. +/// +/*--cef()--*/ +void Browser::GoBack() +{ + _browser->GoBack(); +} + +/// +// Returns true if the browser can navigate forwards. +/// +/*--cef()--*/ +bool Browser::CanGoForward::get() +{ + return _browser->CanGoForward(); +} + +/// +// Navigate forwards. +/// +/*--cef()--*/ +void Browser::GoForward() +{ + _browser->GoForward(); +} + +/// +// Returns true if the browser is currently loading. +/// +/*--cef()--*/ +bool Browser::IsLoading::get() +{ + return _browser->IsLoading(); +} + +void Browser::CloseBrowser(bool forceClose) +{ + throw gcnew NotImplementedException("Browser process only"); +} + +/// +// Reload the current page. +/// +/*--cef()--*/ +void Browser::Reload(bool ignoreCache) +{ + if (ignoreCache) + { + _browser->ReloadIgnoreCache(); + } + else + { + _browser->Reload(); + } +} + +/// +// Stop loading the page. +/// +/*--cef()--*/ +void Browser::StopLoad() +{ + _browser->StopLoad(); +} + +/// +// Returns the globally unique identifier for this browser. +/// +/*--cef()--*/ +int Browser::Identifier::get() +{ + return _browser->GetIdentifier(); +} + +/// +// Returns true if this object is pointing to the same handle as |that| +// object. +/// +/*--cef()--*/ +bool Browser::IsSame(IBrowser^ that) +{ + return _browser->IsSame(dynamic_cast(that)->_browser.get()); +} + +/// +// Returns true if the window is a popup window. +/// +/*--cef()--*/ +bool Browser::IsPopup::get() +{ + return _browser->IsPopup(); +} + +/// +// Returns true if a document has been loaded in the browser. +/// +/*--cef()--*/ +bool Browser::HasDocument::get() +{ + return _browser->HasDocument(); +} + +IFrame^ Browser::MainFrame::get() +{ + auto frame = _browser->GetMainFrame(); + return gcnew Frame(frame); +} + +/// +// Returns the focused frame for the browser window. +/// +/*--cef()--*/ +IFrame^ Browser::FocusedFrame::get() +{ + return gcnew Frame(_browser->GetFocusedFrame()); +} + +/// +// Returns the frame with the specified identifier, or NULL if not found. +/// +/*--cef(capi_name=get_frame_byident)--*/ +IFrame^ Browser::GetFrame(Int64 identifier) +{ + auto frame = _browser->GetFrame(identifier); + + if (frame.get()) + { + return gcnew Frame(frame); + } + + return nullptr; +} + +/// +// Returns the frame with the specified name, or NULL if not found. +/// +/*--cef(optional_param=name)--*/ +IFrame^ Browser::GetFrame(String^ name) +{ + auto frame = _browser->GetFrame(StringUtils::ToNative(name)); + + if (frame.get()) + { + return gcnew Frame(frame); + } + + return nullptr; +} + +/// +// Returns the number of frames that currently exist. +/// +/*--cef()--*/ +int Browser::GetFrameCount() +{ + return static_cast(_browser->GetFrameCount()); +} + +/// +// Returns the identifiers of all existing frames. +/// +/*--cef(count_func=identifiers:GetFrameCount)--*/ +List^ Browser::GetFrameIdentifiers() +{ + std::vector identifiers; + _browser->GetFrameIdentifiers(identifiers); + List^ results = gcnew List(static_cast(identifiers.size())); + for (UINT i = 0; i < identifiers.size(); i++) + { + results->Add(identifiers[i]); + } + return results; +} + +/// +// Returns the names of all existing frames. +/// +/*--cef()--*/ +List^ Browser::GetFrameNames() +{ + std::vector names; + + _browser->GetFrameNames(names); + return StringUtils::ToClr(names); +} + +bool Browser::IsDisposed::get() +{ + return _disposed; +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Browser.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Browser.h new file mode 100644 index 0000000..c58e23f --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Browser.h @@ -0,0 +1,193 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class Browser : public IBrowser + { + private: + MCefRefPtr _browser; + bool _disposed; + + internal: + Browser(CefRefPtr &browser) + : _browser(browser) + { + } + + !Browser() + { + // Release the reference. + _browser = nullptr; + } + + ~Browser() + { + this->!Browser(); + _disposed = true; + } + + public: + virtual property bool IsValid + { + bool get(); + } + + /// + // Returns the browser host object. This method can only be called in the + // browser process. + /// + /*--cef()--*/ + virtual IBrowserHost^ GetHost(); + + /// + // Returns true if the browser can navigate backwards. + /// + /*--cef()--*/ + virtual property bool CanGoBack + { + bool get(); + } + + /// + // Navigate backwards. + /// + /*--cef()--*/ + virtual void GoBack(); + + /// + // Returns true if the browser can navigate forwards. + /// + /*--cef()--*/ + virtual property bool CanGoForward + { + bool get(); + } + + /// + // Navigate forwards. + /// + /*--cef()--*/ + virtual void GoForward(); + + /// + // Returns true if the browser is currently loading. + /// + /*--cef()--*/ + virtual property bool IsLoading + { + bool get(); + } + + virtual void CloseBrowser(bool forceClose); + + /// + // Reload the current page. + /// + /*--cef()--*/ + virtual void Reload(bool ignoreCache); + + /// + // Stop loading the page. + /// + /*--cef()--*/ + virtual void StopLoad(); + + /// + // Returns the globally unique identifier for this browser. + /// + /*--cef()--*/ + virtual property int Identifier + { + int get(); + } + + /// + // Returns true if this object is pointing to the same handle as |that| + // object. + /// + /*--cef()--*/ + virtual bool IsSame(IBrowser^ that); + + /// + // Returns true if the window is a popup window. + /// + /*--cef()--*/ + virtual property bool IsPopup + { + bool get(); + } + + /// + // Returns true if a document has been loaded in the browser. + /// + /*--cef()--*/ + virtual property bool HasDocument + { + bool get(); + } + + /// + // Returns the main (top-level) frame for the browser window. + /// + /*--cef()--*/ + virtual property IFrame^ MainFrame + { + IFrame^ get(); + } + + /// + // Returns the focused frame for the browser window. + /// + /*--cef()--*/ + virtual property IFrame^ FocusedFrame + { + IFrame^ get(); + } + + /// + // Returns the frame with the specified identifier, or NULL if not found. + /// + /*--cef(capi_name=get_frame_byident)--*/ + virtual IFrame^ GetFrame(Int64 identifier); + + /// + // Returns the frame with the specified name, or NULL if not found. + /// + /*--cef(optional_param=name)--*/ + virtual IFrame^ GetFrame(String^ name); + + /// + // Returns the number of frames that currently exist. + /// + /*--cef()--*/ + virtual int GetFrameCount(); + + /// + // Returns the identifiers of all existing frames. + /// + /*--cef(count_func=identifiers:GetFrameCount)--*/ + virtual List^ GetFrameIdentifiers(); + + /// + // Returns the names of all existing frames. + /// + /*--cef()--*/ + virtual List^ GetFrameNames(); + + virtual property bool IsDisposed + { + bool get(); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Frame.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Frame.cpp new file mode 100644 index 0000000..09bfb02 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Frame.cpp @@ -0,0 +1,290 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" +#include + +#include "Frame.h" +#include "Browser.h" + +using namespace CefSharp::BrowserSubprocess; + +/// +// True if this object is currently attached to a valid frame. +/// +/*--cef()--*/ +bool Frame::IsValid::get() +{ + return _frame->IsValid(); +} + +/// +// Execute undo in this frame. +/// +/*--cef()--*/ +void Frame::Undo() +{ + _frame->Undo(); +} + +/// +// Execute redo in this frame. +/// +/*--cef()--*/ +void Frame::Redo() +{ + _frame->Redo(); +} + +/// +// Execute cut in this frame. +/// +/*--cef()--*/ +void Frame::Cut() +{ + _frame->Cut(); +} + +/// +// Execute copy in this frame. +/// +/*--cef()--*/ +void Frame::Copy() +{ + _frame->Copy(); +} + +/// +// Execute paste in this frame. +/// +/*--cef()--*/ +void Frame::Paste() +{ + _frame->Paste(); +} + +/// +// Execute delete in this frame. +/// +/*--cef(capi_name=del)--*/ +void Frame::Delete() +{ + _frame->Delete(); +} + +/// +// Execute select all in this frame. +/// +/*--cef()--*/ +void Frame::SelectAll() +{ + _frame->SelectAll(); +} + +/// +// Save this frame's HTML source to a temporary file and open it in the +// default text viewing application. This method can only be called from the +// browser process. +/// +/*--cef()--*/ +void Frame::ViewSource() +{ + throw gcnew NotImplementedException("Browser process only"); +} + +/// +// Retrieve this frame's HTML source as a string sent to the specified +// visitor. +/// +/*--cef()--*/ +Task^ Frame::GetSourceAsync() +{ + throw gcnew NotImplementedException(); +} + +/// +// Retrieve this frame's HTML source as a string sent to the specified +// visitor. +/// +/*--cef()--*/ +void Frame::GetSource(IStringVisitor^ visitor) +{ + throw gcnew NotImplementedException(); +} + +/// +// Retrieve this frame's display text as a string sent to the specified +// visitor. +/// +/*--cef()--*/ +Task^ Frame::GetTextAsync() +{ + throw gcnew NotImplementedException(); +} + +/// +// Retrieve this frame's display text as a string sent to the specified +// visitor. +/// +/*--cef()--*/ +void Frame::GetText(IStringVisitor^ visitor) +{ + throw gcnew NotImplementedException(); +} + + +/// +// Load the request represented by the |request| object. +/// +/*--cef()--*/ +void Frame::LoadRequest(IRequest^ request) +{ + throw gcnew NotImplementedException(); +} + +/// +// Load the specified |url|. +/// +/*--cef()--*/ +void Frame::LoadUrl(String^ url) +{ + _frame->LoadURL(StringUtils::ToNative(url)); +} + +/// +// Execute a string of JavaScript code in this frame. The |script_url| +// parameter is the URL where the script in question can be found, if any. +// The renderer may request this URL to show the developer the source of the +// error. The |start_line| parameter is the base line number to use for error +// reporting. +/// +/*--cef(optional_param=script_url)--*/ +void Frame::ExecuteJavaScriptAsync(String^ code, String^ scriptUrl, int startLine) +{ + _frame->ExecuteJavaScript(StringUtils::ToNative(code), StringUtils::ToNative(scriptUrl), startLine); +} + +Task^ Frame::EvaluateScriptAsync(String^ script, String^ scriptUrl, int startLine, Nullable timeout, bool useImmediatelyInvokedFuncExpression) +{ + throw gcnew NotImplementedException(); +} + +/// +// Returns true if this is the main (top-level) frame. +/// +/*--cef()--*/ +bool Frame::IsMain::get() +{ + return _frame->IsMain(); +} + +/// +// Returns true if this is the focused frame. +/// +/*--cef()--*/ +bool Frame::IsFocused::get() +{ + return _frame->IsFocused(); +} + +/// +// Returns the name for this frame. If the frame has an assigned name (for +// example, set via the iframe "name" attribute) then that value will be +// returned. Otherwise a unique name will be constructed based on the frame +// parent hierarchy. The main (top-level) frame will always have an empty name +// value. +/// +/*--cef()--*/ +String^ Frame::Name::get() +{ + return StringUtils::ToClr(_frame->GetName()); +} + +/// +// Returns the globally unique identifier for this frame. +/// +/*--cef()--*/ +Int64 Frame::Identifier::get() +{ + return _frame->GetIdentifier(); +} + +/// +// Returns the parent of this frame or NULL if this is the main (top-level) +// frame. +/// +/*--cef()--*/ +IFrame^ Frame::Parent::get() +{ + if (_parentFrame != nullptr) + { + return _parentFrame; + } + + // Be paranoid about creating the cached IFrame. + msclr::lock sync(_syncRoot); + + if (_parentFrame != nullptr) + { + return _parentFrame; + } + + auto parent = _frame->GetParent(); + + if (parent == nullptr) + { + return nullptr; + } + + _parentFrame = gcnew Frame(parent); + + return _parentFrame; +} + +/// +// Returns the URL currently loaded in this frame. +/// +/*--cef()--*/ +String^ Frame::Url::get() +{ + return StringUtils::ToClr(_frame->GetURL()); +} + +/// +// Returns the browser that this frame belongs to. +/// +/*--cef()--*/ +IBrowser^ Frame::Browser::get() +{ + if (_owningBrowser != nullptr) + { + return _owningBrowser; + } + + // Be paranoid about creating the cached IBrowser. + msclr::lock sync(_syncRoot); + + if (_owningBrowser != nullptr) + { + return _owningBrowser; + } + + _owningBrowser = gcnew CefSharp::BrowserSubprocess::Browser(_frame->GetBrowser()); + return _owningBrowser; +} + +IRequest^ Frame::CreateRequest(bool initializePostData) +{ + throw gcnew NotImplementedException(); +} + +IUrlRequest^ Frame::CreateUrlRequest(IRequest^ request, IUrlRequestClient^ client) +{ + throw gcnew NotImplementedException(); +} + +bool Frame::IsDisposed::get() +{ + return _disposed; +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Frame.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Frame.h new file mode 100644 index 0000000..bae5264 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/Frame.h @@ -0,0 +1,247 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_frame.h" + +using namespace System::Threading::Tasks; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + /// + // Class used to represent a frame in the browser window. When used in the + // browser process the methods of this class may be called on any thread unless + // otherwise indicated in the comments. When used in the render process the + // methods of this class may only be called on the main thread. + /// + /*--cef(source=library)--*/ + private ref class Frame : public IFrame + { + private: + MCefRefPtr _frame; + IFrame^ _parentFrame; + IBrowser^ _owningBrowser; + Object^ _syncRoot; + bool _disposed; + + internal: + Frame(CefRefPtr &frame) + : _frame(frame), _parentFrame(nullptr), + _owningBrowser(nullptr), _syncRoot(gcnew Object()) + { + } + + !Frame() + { + _frame = nullptr; + } + + ~Frame() + { + this->!Frame(); + + delete _parentFrame; + delete _owningBrowser; + _parentFrame = nullptr; + _owningBrowser = nullptr; + _syncRoot = nullptr; + _disposed = true; + } + + public: + /// + // True if this object is currently attached to a valid frame. + /// + /*--cef()--*/ + virtual property bool IsValid + { + bool get(); + } + + /// + // Execute undo in this frame. + /// + /*--cef()--*/ + virtual void Undo(); + + /// + // Execute redo in this frame. + /// + /*--cef()--*/ + virtual void Redo(); + + /// + // Execute cut in this frame. + /// + /*--cef()--*/ + virtual void Cut(); + + /// + // Execute copy in this frame. + /// + /*--cef()--*/ + virtual void Copy(); + + /// + // Execute paste in this frame. + /// + /*--cef()--*/ + virtual void Paste(); + + /// + // Execute delete in this frame. + /// + /*--cef(capi_name=del)--*/ + virtual void Delete(); + + /// + // Execute select all in this frame. + /// + /*--cef()--*/ + virtual void SelectAll(); + + /// + // Save this frame's HTML source to a temporary file and open it in the + // default text viewing application. This method can only be called from the + // browser process. + /// + /*--cef()--*/ + virtual void ViewSource(); + + /// + // Retrieve this frame's HTML source as a string sent to the specified + // visitor. + /// + /*--cef()--*/ + virtual Task^ GetSourceAsync(); + + /// + // Retrieve this frame's HTML source as a string sent to the specified + // visitor. + /// + /*--cef()--*/ + virtual void GetSource(IStringVisitor^ visitor); + + /// + // Retrieve this frame's display text as a string sent to the specified + // visitor. + /// + /*--cef()--*/ + virtual Task^ GetTextAsync(); + + /// + // Retrieve this frame's display text as a string sent to the specified + // visitor. + /// + /*--cef()--*/ + virtual void GetText(IStringVisitor^ visitor); + + /// + /// Load the request represented by the |request| object. + /// + /*--cef()--*/ + virtual void LoadRequest(IRequest^ request); + + /// + // Load the specified |url|. + /// + /*--cef()--*/ + virtual void LoadUrl(String^ url); + + /// + // Execute a string of JavaScript code in this frame. The |script_url| + // parameter is the URL where the script in question can be found, if any. + // The renderer may request this URL to show the developer the source of the + // error. The |start_line| parameter is the base line number to use for error + // reporting. + /// + /*--cef(optional_param=script_url)--*/ + virtual void ExecuteJavaScriptAsync(String^ code, String^ scriptUrl, int startLine); + + virtual Task^ EvaluateScriptAsync(String^ script, String^ scriptUrl, int startLine, Nullable timeout, bool useImmediatelyInvokedFuncExpression); + + /// + // Returns true if this is the main (top-level) frame. + /// + /*--cef()--*/ + virtual property bool IsMain + { + bool get(); + } + + /// + // Returns true if this is the focused frame. + /// + /*--cef()--*/ + virtual property bool IsFocused + { + bool get(); + } + + /// + // Returns the name for this frame. If the frame has an assigned name (for + // example, set via the iframe "name" attribute) then that value will be + // returned. Otherwise a unique name will be constructed based on the frame + // parent hierarchy. The main (top-level) frame will always have an empty name + // value. + /// + /*--cef()--*/ + virtual property String^ Name + { + String^ get(); + } + + /// + // Returns the globally unique identifier for this frame. + /// + /*--cef()--*/ + virtual property Int64 Identifier + { + Int64 get(); + } + + /// + // Returns the parent of this frame or NULL if this is the main (top-level) + // frame. + /// + /*--cef()--*/ + virtual property IFrame^ Parent + { + IFrame^ get(); + } + + /// + // Returns the URL currently loaded in this frame. + /// + /*--cef()--*/ + virtual property String^ Url + { + String^ get(); + } + + /// + // Returns the browser that this frame belongs to. + /// + /*--cef()--*/ + virtual property IBrowser^ Browser + { + IBrowser^ get(); + } + + virtual IRequest^ CreateRequest(bool initializePostData); + + virtual IUrlRequest^ CreateUrlRequest(IRequest^ request, IUrlRequestClient^ client); + + virtual property bool IsDisposed + { + bool get(); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/V8Context.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/V8Context.h new file mode 100644 index 0000000..d9fcf65 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/Wrapper/V8Context.h @@ -0,0 +1,66 @@ +// Copyright © 2019 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_v8.h" + +using namespace System::Runtime::InteropServices; +using namespace CefSharp::RenderProcess; + +namespace CefSharp +{ + namespace BrowserSubprocess + { + private ref class V8Context : public IV8Context + { + private: + MCefRefPtr _context; + + public: + V8Context(CefRefPtr &context) + : _context(context) + { + } + + !V8Context() + { + _context = nullptr; + } + + ~V8Context() + { + this->!V8Context(); + } + + virtual bool Execute(String^ code, String^ scriptUrl, int startLine, [Out] V8Exception^ %exception) + { + exception = nullptr; + + CefRefPtr result; + CefRefPtr ex; + + if (_context->Eval(StringUtils::ToNative(code), StringUtils::ToNative(scriptUrl), startLine, result, ex)) + { + return true; + } + + exception = gcnew V8Exception(ex->GetEndColumn(), + ex->GetEndPosition(), + ex->GetLineNumber(), + StringUtils::ToClr(ex->GetMessage()), + StringUtils::ToClr(ex->GetScriptResourceName()), + StringUtils::ToClr(ex->GetSourceLine()), + ex->GetStartColumn(), + ex->GetStartPosition()); + + return false; + } + }; + } +} + + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/obj/Win32/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/obj/Win32/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cpp new file mode 100644 index 0000000..cba273b --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/obj/Win32/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cpp @@ -0,0 +1,2 @@ +#using +[assembly: System::Runtime::Versioning::TargetFrameworkAttribute(L".NETFramework,Version=v4.5.2", FrameworkDisplayName=L".NET Framework 4.5.2")]; diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/obj/x64/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/obj/x64/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cpp new file mode 100644 index 0000000..cba273b --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/obj/x64/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cpp @@ -0,0 +1,2 @@ +#using +[assembly: System::Runtime::Versioning::TargetFrameworkAttribute(L".NETFramework,Version=v4.5.2", FrameworkDisplayName=L".NET Framework 4.5.2")]; diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/resource.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/resource.h new file mode 100644 index 0000000..7ca31da --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/resource.h @@ -0,0 +1,14 @@ +//{{NO_DEPENDENCIES}} +// Microsoft Visual C++ generated include file. +// Used by Resource.rc + +// Next default values for new objects +// +#ifdef APSTUDIO_INVOKED +#ifndef APSTUDIO_READONLY_SYMBOLS +#define _APS_NEXT_RESOURCE_VALUE 101 +#define _APS_NEXT_COMMAND_VALUE 40001 +#define _APS_NEXT_CONTROL_VALUE 1001 +#define _APS_NEXT_SYMED_VALUE 101 +#endif +#endif diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/vcclr_local.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/vcclr_local.h new file mode 100644 index 0000000..1d5bbae --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess.Core/vcclr_local.h @@ -0,0 +1,60 @@ +// +// vcclr_local.h - modified version of vcclr.h from c:\Program Files (x86)\Microsoft Visual Studio 11.0\VC\include\vcclr.h. +// Modifications indicated below. +// +// Copyright (C) Microsoft Corporation +// All rights reserved. +// + +#if _MSC_VER > 1000 +#pragma once +#endif + +#if !defined(_INC_VCCLR) +#define _INC_VCCLR +#ifndef RC_INVOKED + +// Deliberately disabled, since this causes mscorlib.dll to be referenced twice from two different locations, breaking +// IntelliSense whenever this header file is included. +//#using +#include + +#pragma warning(push) +#pragma warning(disable:4400) + +#ifdef __cplusplus_cli +typedef cli::interior_ptr __const_Char_ptr; +typedef cli::interior_ptr __const_Byte_ptr; +typedef cli::interior_ptr _Byte_ptr; +typedef const System::String^ __const_String_handle; +#define _NULLPTR nullptr +#else +typedef const System::Char* __const_Char_ptr; +typedef const System::Byte* __const_Byte_ptr; +typedef System::Byte* _Byte_ptr; +typedef const System::String* __const_String_handle; +#define _NULLPTR 0 +#endif + + +// +// get an interior gc pointer to the first character contained in a System::String object +// +inline __const_Char_ptr PtrToStringChars(__const_String_handle s) +{ + + _Byte_ptr bp = const_cast<_Byte_ptr>(reinterpret_cast<__const_Byte_ptr>(s)); + if (bp != _NULLPTR) + { + unsigned offset = System::Runtime::CompilerServices::RuntimeHelpers::OffsetToStringData; + bp += offset; + } + return reinterpret_cast<__const_Char_ptr>(bp); +} + +#pragma warning(pop) + +#undef _NULLPTR + +#endif /* RC_INVOKED */ +#endif //_INC_VCCLR diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Program.cs b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Program.cs new file mode 100644 index 0000000..6c6a754 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Program.cs @@ -0,0 +1,38 @@ +// Copyright © 2013 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +using System.Diagnostics; +using CefSharp.RenderProcess; + +namespace CefSharp.BrowserSubprocess +{ + /// + /// When implementing your own BrowserSubprocess + /// - For Full .Net use + /// - For .Net Core use (No WCF Support) + /// - Include an app.manifest with the dpi/compatability sections, this is required (this project contains the relevant). + /// - If you are targeting x86/Win32 then you should set /LargeAddressAware (https://docs.microsoft.com/en-us/cpp/build/reference/largeaddressaware?view=vs-2017) + /// + public class Program + { + public static int Main(string[] args) + { + Debug.WriteLine("BrowserSubprocess starting up with command line: " + string.Join("\n", args)); + + //Add your own custom implementation of IRenderProcessHandler here + IRenderProcessHandler handler = null; + + //The WcfBrowserSubprocessExecutable provides BrowserSubProcess functionality + //specific to CefSharp, WCF support (required for Sync JSB) will optionally be + //enabled if the CefSharpArguments.WcfEnabledArgument command line arg is present + //For .Net Core use BrowserSubprocessExecutable as there is no WCF support + var browserProcessExe = new WcfBrowserSubprocessExecutable(); + var result = browserProcessExe.Main(args, handler); + + Debug.WriteLine("BrowserSubprocess shutting down."); + + return result; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Program.netcore.cs b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Program.netcore.cs new file mode 100644 index 0000000..e3ad8ad --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Program.netcore.cs @@ -0,0 +1,35 @@ +// Copyright © 2020 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +using System.Diagnostics; +using CefSharp.RenderProcess; + +namespace CefSharp.BrowserSubprocess +{ + /// + /// When implementing your own BrowserSubprocess + /// - For .Net Core use (No WCF Support) + /// - Include an app.manifest with the dpi/compatability sections, this is required (this project contains the relevant). + /// - If you are targeting x86/Win32 then you should set /LargeAddressAware (https://docs.microsoft.com/en-us/cpp/build/reference/largeaddressaware?view=vs-2017) + /// + public class Program + { + public static int Main(string[] args) + { + Debug.WriteLine("BrowserSubprocess starting up with command line: " + string.Join("\n", args)); + + //Add your own custom implementation of IRenderProcessHandler here + IRenderProcessHandler handler = null; + + //The BrowserSubprocessExecutable provides BrowserSubProcess functionality + //specific to CefSharp there is no WCF support used for the sync JSB feature. + var browserProcessExe = new BrowserSubprocessExecutable(); + var result = browserProcessExe.Main(args, handler); + + Debug.WriteLine("BrowserSubprocess shutting down."); + + return result; + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Properties/AssemblyInfo.cs b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..63a61e0 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/Properties/AssemblyInfo.cs @@ -0,0 +1,18 @@ +using System; +using System.Reflection; +using System.Runtime.InteropServices; +using CefSharp; + +[assembly: AssemblyTitle("CefSharp.BrowserSubprocess")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +[assembly: AssemblyCompany(AssemblyInfo.AssemblyCompany)] +[assembly: AssemblyProduct(AssemblyInfo.AssemblyProduct)] +[assembly: AssemblyCopyright(AssemblyInfo.AssemblyCopyright)] +[assembly: ComVisible(AssemblyInfo.ComVisible)] +[assembly: AssemblyVersion(AssemblyInfo.AssemblyVersion)] +[assembly: AssemblyFileVersion(AssemblyInfo.AssemblyFileVersion)] +[assembly: CLSCompliant(AssemblyInfo.ClsCompliant)] diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/obj/x64/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cs b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/obj/x64/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cs new file mode 100644 index 0000000..f1a77a1 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/obj/x64/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETFramework,Version=v4.5.2", FrameworkDisplayName = ".NET Framework 4.5.2")] diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/obj/x86/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cs b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/obj/x86/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cs new file mode 100644 index 0000000..f1a77a1 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.BrowserSubprocess/obj/x86/Release/.NETFramework,Version=v4.5.2.AssemblyAttributes.cs @@ -0,0 +1,4 @@ +// +using System; +using System.Reflection; +[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETFramework,Version=v4.5.2", FrameworkDisplayName = ".NET Framework 4.5.2")] diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/AssemblyInfo.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/AssemblyInfo.cpp new file mode 100644 index 0000000..faebb78 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/AssemblyInfo.cpp @@ -0,0 +1,30 @@ +// Copyright © 2010 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" + +using namespace System; +using namespace System::Reflection; +using namespace System::Runtime::CompilerServices; +using namespace System::Runtime::InteropServices; +using namespace System::Security::Permissions; +using namespace CefSharp; + +[assembly:AssemblyTitle("CefSharp.Core.Runtime")]; +[assembly:AssemblyDescription("CefSharp Core Runtime Library (VC++)")]; +[assembly:AssemblyCompany(AssemblyInfo::AssemblyCompany)]; +[assembly:AssemblyProduct(AssemblyInfo::AssemblyProduct)]; +[assembly:AssemblyCopyright(AssemblyInfo::AssemblyCopyright)]; + +[assembly:AssemblyVersion(AssemblyInfo::AssemblyVersion)]; +[assembly:ComVisible(AssemblyInfo::ComVisible)]; +[assembly:CLSCompliant(AssemblyInfo::ClsCompliant)]; + +[assembly:AssemblyConfiguration("")]; +[assembly:AssemblyTrademark("")]; +[assembly:AssemblyCulture("")]; + +[assembly:InternalsVisibleTo(AssemblyInfo::CefSharpBrowserSubprocessCoreProject)]; +[assembly:InternalsVisibleTo(AssemblyInfo::CefSharpBrowserSubprocessProject)]; +[assembly:InternalsVisibleTo(AssemblyInfo::CefSharpTestProject)]; diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/BrowserSettings.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/BrowserSettings.h new file mode 100644 index 0000000..132c714 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/BrowserSettings.h @@ -0,0 +1,366 @@ +// Copyright © 2010 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\internal\cef_types_wrappers.h" + +namespace CefSharp +{ + namespace Core + { + /// + /// Browser initialization settings. Specify NULL or 0 to get the recommended + /// default values. The consequences of using custom values may not be well + /// tested. Many of these and other settings can also configured using command- + /// line switches. + /// + [System::ComponentModel::EditorBrowsableAttribute(System::ComponentModel::EditorBrowsableState::Never)] + public ref class BrowserSettings : IBrowserSettings + { + private: + bool _isDisposed = false; + bool _ownsPointer = false; + bool _autoDispose = false; + internal: + CefBrowserSettings* _browserSettings; + + /// + /// Internal Constructor + /// + BrowserSettings(CefBrowserSettings* browserSettings) + { + _browserSettings = browserSettings; + } + + public: + /// + /// Default Constructor + /// + BrowserSettings() : _browserSettings(new CefBrowserSettings()) + { + _ownsPointer = true; + } + + BrowserSettings(bool autoDispose) : _browserSettings(new CefBrowserSettings()) + { + _ownsPointer = true; + _autoDispose = autoDispose; + } + + /// + /// Finalizer. + /// + !BrowserSettings() + { + if (_ownsPointer) + { + delete _browserSettings; + } + + _browserSettings = nullptr; + _isDisposed = true; + } + + /// + /// Destructor. + /// + ~BrowserSettings() + { + this->!BrowserSettings(); + } + + /// + /// StandardFontFamily + /// + virtual property String^ StandardFontFamily + { + String^ get() { return StringUtils::ToClr(_browserSettings->standard_font_family); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->standard_font_family, value); } + } + + /// + /// FixedFontFamily + /// + virtual property String^ FixedFontFamily + { + String^ get() { return StringUtils::ToClr(_browserSettings->fixed_font_family); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->fixed_font_family, value); } + } + + /// + /// SerifFontFamily + /// + virtual property String^ SerifFontFamily + { + String^ get() { return StringUtils::ToClr(_browserSettings->serif_font_family); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->serif_font_family, value); } + } + + /// + /// SansSerifFontFamily + /// + virtual property String^ SansSerifFontFamily + { + String^ get() { return StringUtils::ToClr(_browserSettings->sans_serif_font_family); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->sans_serif_font_family, value); } + } + + /// + /// CursiveFontFamily + /// + virtual property String^ CursiveFontFamily + { + String^ get() { return StringUtils::ToClr(_browserSettings->cursive_font_family); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->cursive_font_family, value); } + } + + /// + /// FantasyFontFamily + /// + virtual property String^ FantasyFontFamily + { + String^ get() { return StringUtils::ToClr(_browserSettings->fantasy_font_family); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->fantasy_font_family, value); } + } + + /// + /// DefaultFontSize + /// + virtual property int DefaultFontSize + { + int get() { return _browserSettings->default_font_size; } + void set(int value) { _browserSettings->default_font_size = value; } + } + + /// + /// DefaultFixedFontSize + /// + virtual property int DefaultFixedFontSize + { + int get() { return _browserSettings->default_fixed_font_size; } + void set(int value) { _browserSettings->default_fixed_font_size = value; } + } + + /// + /// MinimumFontSize + /// + virtual property int MinimumFontSize + { + int get() { return _browserSettings->minimum_font_size; } + void set(int value) { _browserSettings->minimum_font_size = value; } + } + + /// + /// MinimumLogicalFontSize + /// + virtual property int MinimumLogicalFontSize + { + int get() { return _browserSettings->minimum_logical_font_size; } + void set(int value) { _browserSettings->minimum_logical_font_size = value; } + } + + /// + /// Default encoding for Web content. If empty "ISO-8859-1" will be used. Also + /// configurable using the "default-encoding" command-line switch. + /// + virtual property String^ DefaultEncoding + { + String^ get() { return StringUtils::ToClr(_browserSettings->default_encoding); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->default_encoding, value); } + } + + /// + /// Controls the loading of fonts from remote sources. Also configurable using + /// the "disable-remote-fonts" command-line switch. + /// + virtual property CefState RemoteFonts + { + CefState get() { return (CefState)_browserSettings->remote_fonts; } + void set(CefState value) { _browserSettings->remote_fonts = (cef_state_t)value; } + } + + /// + /// Controls whether JavaScript can be executed. (Used to Enable/Disable javascript) + /// Also configurable using the "disable-javascript" command-line switch. + /// + virtual property CefState Javascript + { + CefState get() { return (CefState)_browserSettings->javascript; } + void set(CefState value) { _browserSettings->javascript = (cef_state_t)value; } + } + + /// + /// Controls whether JavaScript can be used to close windows that were not + /// opened via JavaScript. JavaScript can still be used to close windows that + /// were opened via JavaScript. Also configurable using the + /// "disable-javascript-close-windows" command-line switch. + /// + virtual property CefState JavascriptCloseWindows + { + CefState get() { return (CefState)_browserSettings->javascript_close_windows; } + void set(CefState value) { _browserSettings->javascript_close_windows = (cef_state_t)value; } + } + + /// + /// Controls whether JavaScript can access the clipboard. Also configurable + /// using the "disable-javascript-access-clipboard" command-line switch. + /// + virtual property CefState JavascriptAccessClipboard + { + CefState get() { return (CefState)_browserSettings->javascript_access_clipboard; } + void set(CefState value) { _browserSettings->javascript_access_clipboard = (cef_state_t)value; } + } + + /// + /// Controls whether DOM pasting is supported in the editor via + /// execCommand("paste"). The |javascript_access_clipboard| setting must also + /// be enabled. Also configurable using the "disable-javascript-dom-paste" + /// command-line switch. + /// + virtual property CefState JavascriptDomPaste + { + CefState get() { return (CefState)_browserSettings->javascript_dom_paste; } + void set(CefState value) { _browserSettings->javascript_dom_paste = (cef_state_t)value; } + } + + /// + /// Controls whether image URLs will be loaded from the network. A cached image + /// will still be rendered if requested. Also configurable using the + /// "disable-image-loading" command-line switch. + /// + virtual property CefState ImageLoading + { + CefState get() { return (CefState)_browserSettings->image_loading; } + void set(CefState value) { _browserSettings->image_loading = (cef_state_t)value; } + } + + /// + /// Controls whether standalone images will be shrunk to fit the page. Also + /// configurable using the "image-shrink-standalone-to-fit" command-line + /// switch. + /// + virtual property CefState ImageShrinkStandaloneToFit + { + CefState get() { return (CefState)_browserSettings->image_shrink_standalone_to_fit; } + void set(CefState value) { _browserSettings->image_shrink_standalone_to_fit = (cef_state_t)value; } + } + + /// + /// Controls whether text areas can be resized. Also configurable using the + /// "disable-text-area-resize" command-line switch. + /// + virtual property CefState TextAreaResize + { + CefState get() { return (CefState)_browserSettings->text_area_resize; } + void set(CefState value) { _browserSettings->text_area_resize = (cef_state_t)value; } + } + + /// + /// Controls whether the tab key can advance focus to links. Also configurable + /// using the "disable-tab-to-links" command-line switch. + /// + virtual property CefState TabToLinks + { + CefState get() { return (CefState)_browserSettings->tab_to_links; } + void set(CefState value) { _browserSettings->tab_to_links = (cef_state_t)value; } + } + + /// + /// Controls whether local storage can be used. Also configurable using the + /// "disable-local-storage" command-line switch. + /// + virtual property CefState LocalStorage + { + CefState get() { return (CefState)_browserSettings->local_storage; } + void set(CefState value) { _browserSettings->local_storage = (cef_state_t)value; } + } + + /// + /// Controls whether databases can be used. Also configurable using the + /// "disable-databases" command-line switch. + /// + virtual property CefState Databases + { + CefState get() { return (CefState)_browserSettings->databases; } + void set(CefState value) { _browserSettings->databases = (cef_state_t)value; } + } + + /// + /// Controls whether WebGL can be used. Note that WebGL requires hardware + /// support and may not work on all systems even when enabled. Also + /// configurable using the "disable-webgl" command-line switch. + /// + virtual property CefState WebGl + { + CefState get() { return (CefState)_browserSettings->webgl; } + void set(CefState value) { _browserSettings->webgl = (cef_state_t)value; } + } + + /// + /// Background color used for the browser before a document is loaded and when no document color + /// is specified. The alpha component must be either fully opaque (0xFF) or fully transparent (0x00). + /// If the alpha component is fully opaque then the RGB components will be used as the background + /// color. If the alpha component is fully transparent for a WinForms browser then the + /// CefSettings.BackgroundColor value will be used. If the alpha component is fully transparent + /// for a windowless (WPF/OffScreen) browser then transparent painting will be enabled. + /// + virtual property uint32 BackgroundColor + { + uint32 get() { return _browserSettings->background_color; } + void set(uint32 value) { _browserSettings->background_color = value; } + } + + /// + /// Comma delimited ordered list of language codes without any whitespace that + /// will be used in the "Accept-Language" HTTP header. May be overridden on a + /// per-browser basis using the CefBrowserSettings.AcceptLanguageList value. + /// If both values are empty then "en-US,en" will be used. Can be overridden + /// for individual RequestContext instances via the + /// RequestContextSettings.AcceptLanguageList value. + /// + virtual property String^ AcceptLanguageList + { + String^ get() { return StringUtils::ToClr(_browserSettings->accept_language_list); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_browserSettings->accept_language_list, value); } + } + + /// + /// The maximum rate in frames per second (fps) that CefRenderHandler::OnPaint + /// will be called for a windowless browser. The actual fps may be lower if + /// the browser cannot generate frames at the requested rate. The minimum + /// value is 1 and the maximum value is 60 (default 30). This value can also be + /// changed dynamically via IBrowserHost.SetWindowlessFrameRate. + /// + virtual property int WindowlessFrameRate + { + int get() { return _browserSettings->windowless_frame_rate; } + void set(int value) { _browserSettings->windowless_frame_rate = value; } + } + + /// + /// Gets a value indicating if the browser settings has been disposed. + /// + virtual property bool IsDisposed + { + bool get() { return _isDisposed; } + } + + /// + /// True if dispose should be called after this object is used + /// + virtual property bool AutoDispose + { + bool get() { return _autoDispose; } + } + + virtual IBrowserSettings^ UnWrap() + { + return this; + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Cef.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Cef.h new file mode 100644 index 0000000..1040f1c --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Cef.h @@ -0,0 +1,909 @@ +// Copyright © 2013 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#ifndef CEFSHARP_CORE_CEF_H_ +#define CEFSHARP_CORE_CEF_H_ + +#pragma once + +#include "Stdafx.h" + +#include +#include +#include +#include +#include +#include +#include +#include + +#include "Internals/CefSharpApp.h" +#include "Internals/CefTaskScheduler.h" +#include "Internals/CefTaskDelegate.h" +#include "CookieManager.h" +#include "CefSettingsBase.h" +#include "RequestContext.h" + +using namespace System::Collections::Generic; +using namespace System::Linq; +using namespace System::Reflection; +using namespace msclr::interop; + +namespace CefSharp +{ + namespace Core + { + /// + /// Global CEF methods are exposed through this class. e.g. CefInitalize maps to Cef.Initialize + /// CEF API Doc https://magpcss.org/ceforum/apidocs3/projects/(default)/(_globals).html + /// This class cannot be inherited. + /// + [System::ComponentModel::EditorBrowsableAttribute(System::ComponentModel::EditorBrowsableState::Never)] + public ref class Cef sealed + { + private: + static Object^ _sync; + + static bool _initialized = false; + static bool _hasShutdown = false; + static HashSet^ _disposables; + static int _initializedThreadId; + static bool _multiThreadedMessageLoop = true; + static bool _waitForBrowsersToCloseEnabled = false; + + static Cef() + { + _sync = gcnew Object(); + _disposables = gcnew HashSet(); + } + + static bool CurrentOnUiThread() + { + return CefCurrentlyOn(CefThreadId::TID_UI); + } + + public: + + static property TaskFactory^ UIThreadTaskFactory; + static property TaskFactory^ IOThreadTaskFactory; + static property TaskFactory^ FileThreadTaskFactory; + + static void AddDisposable(IDisposable^ item) + { + msclr::lock l(_sync); + + _disposables->Add(item); + } + + static void RemoveDisposable(IDisposable^ item) + { + msclr::lock l(_sync); + + _disposables->Remove(item); + } + + /// Gets a value that indicates whether CefSharp is initialized. + /// true if CefSharp is initialized; otherwise, false. + static property bool IsInitialized + { + bool get() + { + return _initialized; + } + } + + /// Gets a value that indicates whether CefSharp was shutdown. + /// true if CefSharp was shutdown; otherwise, false. + static property bool IsShutdown + { + bool get() + { + return _hasShutdown; + } + } + + /// Gets a value that indicates the version of CefSharp currently being used. + /// The CefSharp version. + static property String^ CefSharpVersion + { + String^ get() + { + Assembly^ assembly = Assembly::GetAssembly(Cef::typeid); + return assembly->GetName()->Version->ToString(); + } + } + + /// Gets a value that indicates the CEF version currently being used. + /// The CEF Version + static property String^ CefVersion + { + String^ get() + { + return String::Format("r{0}", CEF_VERSION); + } + } + + /// Gets a value that indicates the Chromium version currently being used. + /// The Chromium version. + static property String^ ChromiumVersion + { + String^ get() + { + // Need explicit cast here to avoid C4965 warning when the minor version is zero. + return String::Format("{0}.{1}.{2}.{3}", + CHROME_VERSION_MAJOR, (Object^)CHROME_VERSION_MINOR, + CHROME_VERSION_BUILD, CHROME_VERSION_PATCH); + } + } + + /// + /// Gets a value that indicates the Git Hash for CEF version currently being used. + /// + /// The Git Commit Hash + static property String^ CefCommitHash + { + String^ get() + { + return CEF_COMMIT_HASH; + } + } + + /// + /// Parse the specified url into its component parts. + /// Uses a GURL to parse the Url. GURL is Google's URL parsing library. + /// + /// url + /// Returns null if the URL is empty or invalid. + static UrlParts^ ParseUrl(String^ url) + { + if (String::IsNullOrEmpty(url)) + { + return nullptr; + } + + CefURLParts parts; + + if (CefParseURL(StringUtils::ToNative(url), parts)) + { + auto url = gcnew UrlParts(); + url->Fragment = StringUtils::ToClr(parts.fragment); + url->Host = StringUtils::ToClr(parts.host); + url->Origin = StringUtils::ToClr(parts.origin); + url->Password = StringUtils::ToClr(parts.password); + url->Path = StringUtils::ToClr(parts.path); + url->Query = StringUtils::ToClr(parts.query); + url->Scheme = StringUtils::ToClr(parts.scheme); + url->Spec = StringUtils::ToClr(parts.spec); + url->Username = StringUtils::ToClr(parts.username); + + auto portString = StringUtils::ToClr(parts.port); + if (!String::IsNullOrEmpty(portString)) + { + int port = 0; + + if (int::TryParse(portString, port)) + { + url->Port = port; + } + } + + return url; + } + + return nullptr; + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize and Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// true if successful; otherwise, false. + static bool Initialize(CefSettingsBase^ cefSettings) + { + auto cefApp = gcnew DefaultApp(nullptr, cefSettings->CefCustomSchemes); + + return Initialize(cefSettings, false, cefApp); + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize/Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// Check that all relevant dependencies avaliable, throws exception if any are missing + /// true if successful; otherwise, false. + static bool Initialize(CefSettingsBase^ cefSettings, bool performDependencyCheck) + { + auto cefApp = gcnew DefaultApp(nullptr, cefSettings->CefCustomSchemes); + + return Initialize(cefSettings, performDependencyCheck, cefApp); + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize/Shutdown MUST be called on your main + /// applicaiton thread (Typically the UI thead). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// Check that all relevant dependencies avaliable, throws exception if any are missing + /// The handler for functionality specific to the browser process. Null if you don't wish to handle these events + /// true if successful; otherwise, false. + static bool Initialize(CefSettingsBase^ cefSettings, bool performDependencyCheck, IBrowserProcessHandler^ browserProcessHandler) + { + auto cefApp = gcnew DefaultApp(browserProcessHandler, cefSettings->CefCustomSchemes); + + return Initialize(cefSettings, performDependencyCheck, cefApp); + } + + /// + /// Initializes CefSharp with user-provided settings. + /// It's important to note that Initialize/Shutdown MUST be called on your main + /// application thread (typically the UI thread). If you call them on different + /// threads, your application will hang. See the documentation for Cef.Shutdown() for more details. + /// + /// CefSharp configuration settings. + /// Check that all relevant dependencies avaliable, throws exception if any are missing + /// Implement this interface to provide handler implementations. Null if you don't wish to handle these events + /// true if successful; otherwise, false. + static bool Initialize(CefSettingsBase^ cefSettings, bool performDependencyCheck, IApp^ cefApp) + { + if (_initialized) + { + // NOTE: Can only initialize Cef once, to make this explicitly clear throw exception on subsiquent attempts + throw gcnew Exception("Cef.Initialize can only be called once per process. This is a limitation of the underlying " + + "CEF/Chromium framework. You can change many (not all) settings at runtime through RequestContext.SetPreference. " + + "See https://github.com/cefsharp/CefSharp/wiki/General-Usage#request-context-browser-isolation " + + "Use Cef.IsInitialized to check if Cef.Initialize has already been called to avoid this exception. " + + "If you are seeing this unexpectedly then you are likely " + + "calling Cef.Initialize after you've created an instance of ChromiumWebBrowser, it must be called before the first instance is created."); + } + + if (_hasShutdown) + { + // NOTE: CefShutdown has already been called. + throw gcnew Exception("Cef.Shutdown has already been called. Cef.Initialize can only be called once per process. " + + "This is a limitation of the underlying CEF/Chromium framework. Calling Cef.Initialize after Cef.Shutdown is not supported. " + "You can change many (not all) settings at runtime through RequestContext.SetPreference." + + "See https://github.com/cefsharp/CefSharp/wiki/General-Usage#request-context-browser-isolation"); + } + + //Empty string is acceptable, the main application executable will be used + if (cefSettings->BrowserSubprocessPath == nullptr) + { + throw gcnew Exception("CefSettings BrowserSubprocessPath cannot be null."); + } + + PathCheck::AssertAbsolute(cefSettings->RootCachePath, "CefSettings.RootCachePath"); + PathCheck::AssertAbsolute(cefSettings->CachePath, "CefSettings.CachePath"); + PathCheck::AssertAbsolute(cefSettings->LocalesDirPath, "CefSettings.LocalesDirPath"); + PathCheck::AssertAbsolute(cefSettings->BrowserSubprocessPath, "CefSettings.BrowserSubprocessPath"); + + + if (performDependencyCheck) + { + DependencyChecker::AssertAllDependenciesPresent(cefSettings->Locale, cefSettings->LocalesDirPath, cefSettings->ResourcesDirPath, cefSettings->PackLoadingDisabled, cefSettings->BrowserSubprocessPath); + } + else if (!File::Exists(cefSettings->BrowserSubprocessPath)) + { + throw gcnew FileNotFoundException("CefSettings.BrowserSubprocessPath not found.", cefSettings->BrowserSubprocessPath); + } + + UIThreadTaskFactory = gcnew TaskFactory(gcnew CefTaskScheduler(TID_UI)); + IOThreadTaskFactory = gcnew TaskFactory(gcnew CefTaskScheduler(TID_IO)); + FileThreadTaskFactory = gcnew TaskFactory(gcnew CefTaskScheduler(TID_FILE_BACKGROUND)); + + //Allows us to execute Tasks on the CEF UI thread in CefSharp.dll + CefThread::Initialize(UIThreadTaskFactory, gcnew Func(&CurrentOnUiThread)); + + //To allow FolderSchemeHandlerFactory to access GetMimeType we pass in a Func + CefSharp::SchemeHandler::FolderSchemeHandlerFactory::GetMimeTypeDelegate = gcnew Func(&GetMimeType); + + CefRefPtr app(new CefSharpApp(cefSettings->ExternalMessagePump, + cefSettings->CommandLineArgsDisabled, + cefSettings->CefCommandLineArgs, + cefSettings->CefCustomSchemes, + cefApp)); + CefMainArgs main_args; + CefSettings settings = *(cefSettings->_cefSettings); + + auto success = CefInitialize(main_args, settings, app.get(), nullptr); + + if (!success) + { + CefSharp::Internals::GlobalContextInitialized::SetResult(false); + } + + _initialized = success; + _multiThreadedMessageLoop = cefSettings->MultiThreadedMessageLoop; + + _initializedThreadId = Thread::CurrentThread->ManagedThreadId; + + //We took a copy of CefSettings earlier, now we set our pointer to nullptr + delete cefSettings; + + return success; + } + + /// + /// Run the CEF message loop. Use this function instead of an application- + /// provided message loop to get the best balance between performance and CPU + /// usage. This function should only be called on the main application thread and + /// only if Cef.Initialize() is called with a + /// CefSettings.MultiThreadedMessageLoop value of false. This function will + /// block until a quit message is received by the system. + /// + static void RunMessageLoop() + { + CefRunMessageLoop(); + } + + /// + /// Quit the CEF message loop that was started by calling Cef.RunMessageLoop(). + /// This function should only be called on the main application thread and only + /// if Cef.RunMessageLoop() was used. + /// + static void QuitMessageLoop() + { + CefQuitMessageLoop(); + } + + /// + /// Perform a single iteration of CEF message loop processing.This function is + /// provided for cases where the CEF message loop must be integrated into an + /// existing application message loop. Use of this function is not recommended + /// for most users; use CefSettings.MultiThreadedMessageLoop if possible (the default). + /// When using this function care must be taken to balance performance + /// against excessive CPU usage. It is recommended to enable the + /// CefSettings.ExternalMessagePump option when using + /// this function so that IBrowserProcessHandler.OnScheduleMessagePumpWork() + /// callbacks can facilitate the scheduling process. This function should only be + /// called on the main application thread and only if Cef.Initialize() is called + /// with a CefSettings.MultiThreadedMessageLoop value of false. This function + /// will not block. + /// + static void DoMessageLoopWork() + { + CefDoMessageLoopWork(); + } + + /// + /// This function should be called from the application entry point function to execute a secondary process. + /// It can be used to run secondary processes from the browser client executable (default behavior) or + /// from a separate executable specified by the CefSettings.browser_subprocess_path value. + /// If called for the browser process (identified by no "type" command-line value) it will return immediately with a value of -1. + /// If called for a recognized secondary process it will block until the process should exit and then return the process exit code. + /// The |application| parameter may be empty. The |windows_sandbox_info| parameter is only used on Windows and may be NULL (see cef_sandbox_win.h for details). + /// + static int ExecuteProcess() + { + auto hInstance = Process::GetCurrentProcess()->Handle; + + CefMainArgs cefMainArgs((HINSTANCE)hInstance.ToPointer()); + //TODO: Look at ways to expose an instance of CefApp + //CefRefPtr app(new CefSharpApp(nullptr, nullptr)); + + return CefExecuteProcess(cefMainArgs, nullptr, nullptr); + } + + /// Add an entry to the cross-origin whitelist. + /// The origin allowed to be accessed by the target protocol/domain. + /// The target protocol allowed to access the source origin. + /// The optional target domain allowed to access the source origin. + /// If set to true would allow a blah.example.com if the + /// was set to example.com + /// + /// Returns false if is invalid or the whitelist cannot be accessed. + /// + /// The same-origin policy restricts how scripts hosted from different origins + /// (scheme + domain + port) can communicate. By default, scripts can only access + /// resources with the same origin. Scripts hosted on the HTTP and HTTPS schemes + /// (but no other schemes) can use the "Access-Control-Allow-Origin" header to + /// allow cross-origin requests. For example, https://source.example.com can make + /// XMLHttpRequest requests on http://target.example.com if the + /// http://target.example.com request returns an "Access-Control-Allow-Origin: + /// https://source.example.com" response header. + // + /// Scripts in separate frames or iframes and hosted from the same protocol and + /// domain suffix can execute cross-origin JavaScript if both pages set the + /// document.domain value to the same domain suffix. For example, + /// scheme://foo.example.com and scheme://bar.example.com can communicate using + /// JavaScript if both domains set document.domain="example.com". + // + /// This method is used to allow access to origins that would otherwise violate + /// the same-origin policy. Scripts hosted underneath the fully qualified + /// URL (like http://www.example.com) will be allowed access to + /// all resources hosted on the specified and . + /// If is non-empty and if false only + /// exact domain matches will be allowed. If contains a top- + /// level domain component (like "example.com") and is + /// true sub-domain matches will be allowed. If is empty and + /// if true all domains and IP addresses will be + /// allowed. + // + /// This method cannot be used to bypass the restrictions on local or display + /// isolated schemes. See the comments on for more + /// information. + /// + /// This function may be called on any thread. Returns false if + /// is invalid or the whitelist cannot be accessed. + /// + static bool AddCrossOriginWhitelistEntry( + String^ sourceOrigin, + String^ targetProtocol, + String^ targetDomain, + bool allowTargetSubdomains) + { + return CefAddCrossOriginWhitelistEntry( + StringUtils::ToNative(sourceOrigin), + StringUtils::ToNative(targetProtocol), + StringUtils::ToNative(targetDomain), + allowTargetSubdomains); + } + + /// Remove entry from cross-origin whitelist + /// The origin allowed to be accessed by the target protocol/domain. + /// The target protocol allowed to access the source origin. + /// The optional target domain allowed to access the source origin. + /// If set to true would allow a blah.example.com if the + /// was set to example.com + /// + /// + /// Remove an entry from the cross-origin access whitelist. Returns false if + /// is invalid or the whitelist cannot be accessed. + /// + static bool RemoveCrossOriginWhitelistEntry(String^ sourceOrigin, + String^ targetProtocol, + String^ targetDomain, + bool allowTargetSubdomains) + + { + return CefRemoveCrossOriginWhitelistEntry( + StringUtils::ToNative(sourceOrigin), + StringUtils::ToNative(targetProtocol), + StringUtils::ToNative(targetDomain), + allowTargetSubdomains); + } + + /// Remove all entries from the cross-origin access whitelist. + /// + /// Remove all entries from the cross-origin access whitelist. Returns false if + /// the whitelist cannot be accessed. + /// + static bool ClearCrossOriginWhitelist() + { + return CefClearCrossOriginWhitelist(); + } + + /// + /// Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. + /// Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() + /// The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, + /// there may be a short delay before you can Get/Write cookies. + /// To be sure the cookie manager has been initialized use one of the following + /// - Use the GetGlobalCookieManager(ICompletionCallback) overload and access the ICookieManager after + /// ICompletionCallback.OnComplete has been called. + /// - Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. + /// - Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + /// + /// A the global cookie manager or null if the RequestContext has not yet been initialized. + static ICookieManager^ GetGlobalCookieManager() + { + return GetGlobalCookieManager(nullptr); + } + + /// + /// Returns the global cookie manager. By default data will be stored at CefSettings.CachePath if specified or in memory otherwise. + /// Using this method is equivalent to calling Cef.GetGlobalRequestContext().GetCookieManager() + /// The cookie managers storage is created in an async fashion, whilst this method may return a cookie manager instance, + /// there may be a short delay before you can Get/Write cookies. + /// To be sure the cookie manager has been initialized use one of the following + /// - Access the ICookieManager after ICompletionCallback.OnComplete has been called + /// - Access the ICookieManager instance in IBrowserProcessHandler.OnContextInitialized. + /// - Use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + /// + /// If non-NULL it will be executed asnychronously on the CEF UI thread after the manager's storage has been initialized. + /// A the global cookie manager or null if the RequestContext has not yet been initialized. + static ICookieManager^ GetGlobalCookieManager(ICompletionCallback^ callback) + { + CefRefPtr c = callback == nullptr ? nullptr : new CefCompletionCallbackAdapter(callback); + + auto cookieManager = CefCookieManager::GetGlobalManager(c); + if (cookieManager.get()) + { + return gcnew CookieManager(cookieManager); + } + + return nullptr; + } + + /// + /// Called prior to calling Cef.Shutdown, this diposes of any remaning + /// ChromiumWebBrowser instances. In WPF this is used from Dispatcher.ShutdownStarted + /// to release the unmanaged resources held by the ChromiumWebBrowser instances. + /// Generally speaking you don't need to call this yourself. + /// + static void PreShutdown() + { + msclr::lock l(_sync); + + for each(IDisposable^ diposable in Enumerable::ToList(_disposables)) + { + delete diposable; + } + + _disposables->Clear(); + + GC::Collect(); + GC::WaitForPendingFinalizers(); + } + + /// + /// Shuts down CefSharp and the underlying CEF infrastructure. This method is safe to call multiple times; it will only + /// shut down CEF on the first call (all subsequent calls will be ignored). + /// This method should be called on the main application thread to shut down the CEF browser process before the application exits. + /// If you are Using CefSharp.OffScreen then you must call this explicitly before your application exits or it will hang. + /// This method must be called on the same thread as Initialize. If you don't call Shutdown explicitly then CefSharp.Wpf and CefSharp.WinForms + /// versions will do their best to call Shutdown for you, if your application is having trouble closing then call thus explicitly. + /// + static void Shutdown() + { + if (_initialized) + { + msclr::lock l(_sync); + + if (_initialized) + { + if (_initializedThreadId != Thread::CurrentThread->ManagedThreadId) + { + throw gcnew Exception("Cef.Shutdown must be called on the same thread that Cef.Initialize was called - typically your UI thread. " + + "If you called Cef.Initialize on a Thread other than the UI thread then you will need to call Cef.Shutdown on the same thread. " + + "Cef.Initialize was called on ManagedThreadId: " + _initializedThreadId + " where Cef.Shutdown is being called on " + + "ManagedThreadId: " + Thread::CurrentThread->ManagedThreadId); + } + + UIThreadTaskFactory = nullptr; + IOThreadTaskFactory = nullptr; + FileThreadTaskFactory = nullptr; + + CefThread::Shutdown(); + + for each(IDisposable^ diposable in Enumerable::ToList(_disposables)) + { + delete diposable; + } + + GC::Collect(); + GC::WaitForPendingFinalizers(); + + if (!_multiThreadedMessageLoop) + { + // We need to run the message pump until it is idle. However we don't have + // that information here so we run the message loop "for a while". + // See https://github.com/cztomczak/cefpython/issues/245 for an excellent description + for (int i = 0; i < 10; i++) + { + DoMessageLoopWork(); + + // Sleep to allow the CEF proc to do work. + Sleep(50); + } + } + + CefShutdown(); + _initialized = false; + _hasShutdown = true; + } + } + } + + /// + /// This method should only be used by advanced users, if you're unsure then use Cef.Shutdown(). + /// This function should be called on the main application thread to shut down + /// the CEF browser process before the application exits. This method simply obtains a lock + /// and calls the native CefShutdown method, only IsInitialized is checked. All ChromiumWebBrowser + /// instances MUST be Disposed of before calling this method. If calling this method results in a crash + /// or hangs then you're likely hanging on to some unmanaged resources or haven't closed all of your browser + /// instances + /// + static void ShutdownWithoutChecks() + { + if (_initialized) + { + msclr::lock l(_sync); + + if (_initialized) + { + CefShutdown(); + _initialized = false; + _hasShutdown = true; + } + } + } + + /// + /// Clear all scheme handler factories registered with the global request context. + /// Returns false on error. This function may be called on any thread in the browser process. + /// Using this function is equivalent to calling Cef.GetGlobalRequestContext().ClearSchemeHandlerFactories(). + /// + /// Returns false on error. + static bool ClearSchemeHandlerFactories() + { + return CefClearSchemeHandlerFactories(); + } + + /// + /// Returns true if called on the specified CEF thread. + /// + /// Returns true if called on the specified thread. + static bool CurrentlyOnThread(CefThreadIds threadId) + { + return CefCurrentlyOn((CefThreadId)threadId); + } + + /// + /// Gets the Global Request Context. Make sure to Dispose of this object when finished. + /// The earlier possible place to access the IRequestContext is in IBrowserProcessHandler.OnContextInitialized. + /// Alternative use the ChromiumWebBrowser BrowserInitialized (OffScreen) or IsBrowserInitializedChanged (WinForms/WPF) events. + /// + /// Returns the global request context or null if the RequestContext has not been initialized yet. + static IRequestContext^ GetGlobalRequestContext() + { + auto context = CefRequestContext::GetGlobalContext(); + + if (context.get()) + { + return gcnew RequestContext(context); + } + + return nullptr; + } + + /// + /// Helper function (wrapper around the CefColorSetARGB macro) which combines + /// the 4 color components into an uint32 for use with BackgroundColor property + /// + /// Alpha + /// Red + /// Green + /// Blue + /// Returns the color. + static uint32 ColorSetARGB(uint32 a, uint32 r, uint32 g, uint32 b) + { + return CefColorSetARGB(a, r, g, b); + } + + /// + /// Crash reporting is configured using an INI-style config file named + /// crash_reporter.cfg. This file must be placed next to + /// the main application executable. File contents are as follows: + /// + /// # Comments start with a hash character and must be on their own line. + /// + /// [Config] + /// ProductName=<Value of the "prod" crash key; defaults to "cef"> + /// ProductVersion=<Value of the "ver" crash key; defaults to the CEF version> + /// AppName=<Windows only; App-specific folder name component for storing crash + /// information; default to "CEF"> + /// ExternalHandler=<Windows only; Name of the external handler exe to use + /// instead of re-launching the main exe; default to empty> + /// ServerURL=<crash server URL; default to empty> + /// RateLimitEnabled=<True if uploads should be rate limited; default to true> + /// MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; + /// default to 5> + /// MaxDatabaseSizeInMb=<Total crash report disk usage greater than this value + /// will cause older reports to be deleted; default to 20> + /// MaxDatabaseAgeInDays=<Crash reports older than this value will be deleted; + /// default to 5> + /// + /// [CrashKeys] + /// my_key1=<small|medium|large> + /// my_key2=<small|medium|large> + /// + /// Config section: + /// + /// If "ProductName" and/or "ProductVersion" are set then the specified values + /// will be included in the crash dump metadata. + /// + /// If "AppName" is set on Windows then crash report information (metrics, + /// database and dumps) will be stored locally on disk under the + /// "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. + /// + /// If "ExternalHandler" is set on Windows then the specified exe will be + /// launched as the crashpad-handler instead of re-launching the main process + /// exe. The value can be an absolute path or a path relative to the main exe + /// directory. + /// + /// If "ServerURL" is set then crashes will be uploaded as a multi-part POST + /// request to the specified URL. Otherwise, reports will only be stored locally + /// on disk. + /// + /// If "RateLimitEnabled" is set to true then crash report uploads will be rate + /// limited as follows: + /// 1. If "MaxUploadsPerDay" is set to a positive value then at most the + /// specified number of crashes will be uploaded in each 24 hour period. + /// 2. If crash upload fails due to a network or server error then an + /// incremental backoff delay up to a maximum of 24 hours will be applied for + /// retries. + /// 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the + /// "MaxUploadsPerDay" value will be reduced to 1 until the client is + /// restarted. This helps to avoid an upload flood when the network or + /// server error is resolved. + /// + /// If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage + /// on disk will be limited to that size in megabytes. For example, on Windows + /// each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to + /// about 34 crash reports stored on disk. + /// + /// If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older + /// than the specified age in days will be deleted. + /// + /// CrashKeys section: + /// + /// Any number of crash keys can be specified for use by the application. Crash + /// key values will be truncated based on the specified size (small = 63 bytes, + /// medium = 252 bytes, large = 1008 bytes). The value of crash keys can be set + /// from any thread or process using the Cef.SetCrashKeyValue function. These + /// key/value pairs will be sent to the crash server along with the crash dump + /// file. Medium and large values will be chunked for submission. For example, + /// if your key is named "mykey" then the value will be broken into ordered + /// chunks and submitted using keys named "mykey-1", "mykey-2", etc. + /// + /// Returns true if crash reporting is enabled. + static property bool CrashReportingEnabled + { + bool get() + { + return CefCrashReportingEnabled(); + } + } + + /// + /// Sets or clears a specific key-value pair from the crash metadata. + /// + static void SetCrashKeyValue(String^ key, String^ value) + { + CefSetCrashKeyValue(StringUtils::ToNative(key), StringUtils::ToNative(value)); + } + + static int GetMinLogLevel() + { + return cef_get_min_log_level(); + } + + /// + /// Returns the mime type for the specified file extension or an empty string if unknown. + /// + /// file extension + /// Returns the mime type for the specified file extension or an empty string if unknown. + static String^ GetMimeType(String^ extension) + { + if (extension == nullptr) + { + throw gcnew ArgumentNullException("extension"); + } + + if (extension->StartsWith(".")) + { + extension = extension->Substring(1, extension->Length - 1); + } + + auto mimeType = StringUtils::ToClr(CefGetMimeType(StringUtils::ToNative(extension))); + + //Lookup to see if we have a custom mapping + //MimeTypeMapping::GetCustomMapping will Fallback + //to application/octet-stream if no mapping found + if (String::IsNullOrEmpty(mimeType)) + { + return MimeTypeMapping::GetCustomMapping(extension); + } + + return mimeType; + } + + /// + /// WaitForBrowsersToClose is not enabled by default, call this method + /// before Cef.Initialize to enable. If you aren't calling Cef.Initialize + /// explicitly then this should be called before creating your first + /// ChromiumWebBrowser instance. + /// + static void EnableWaitForBrowsersToClose() + { + if (_waitForBrowsersToCloseEnabled) + { + return; + } + + if (_initialized) + { + throw gcnew Exception("Must be enabled before Cef.Initialize is called. "); + } + + _waitForBrowsersToCloseEnabled = true; + + BrowserRefCounter::Instance = gcnew BrowserRefCounter(); + } + + /// + /// Helper method to ensure all ChromiumWebBrowser instances have been + /// closed/disposed, should be called before Cef.Shutdown. + /// Disposes all remaning ChromiumWebBrowser instances + /// then waits for CEF to release it's remaning CefBrowser instances. + /// Finally a small delay of 50ms to allow for CEF to finish it's cleanup. + /// Should only be called when MultiThreadedMessageLoop = true; + /// (Hasn't been tested when when CEF integrates into main message loop). + /// + static void WaitForBrowsersToClose() + { + WaitForBrowsersToClose(750); + } + + /// + /// Helper method to ensure all ChromiumWebBrowser instances have been + /// closed/disposed, should be called before Cef.Shutdown. + /// Disposes all remaning ChromiumWebBrowser instances + /// then waits for CEF to release it's remaning CefBrowser instances. + /// Finally a small delay of 50ms to allow for CEF to finish it's cleanup. + /// Should only be called when MultiThreadedMessageLoop = true; + /// (Hasn't been tested when when CEF integrates into main message loop). + /// + /// The timeout in miliseconds. + static void WaitForBrowsersToClose(int timeoutInMiliseconds) + { + if (!_waitForBrowsersToCloseEnabled) + { + throw gcnew Exception("This feature is currently disabled. Call Cef.EnableWaitForBrowsersToClose before calling Cef.Initialize to enable."); + } + + //Dispose of any remaining browser instances + for each(IDisposable^ diposable in Enumerable::ToList(_disposables)) + { + delete diposable; + } + + //Clear the list as we've disposed of them all now. + _disposables->Clear(); + + //Wait for the browsers to close + BrowserRefCounter::Instance->WaitForBrowsersToClose(timeoutInMiliseconds); + + //A few extra ms to allow for CEF to finish + Thread::Sleep(50); + } + + /// + /// Post an action for delayed execution on the specified thread. + /// + /// thread id + /// action to execute + /// delay in ms + /// bool + static bool PostDelayedAction(CefThreadIds threadId, Action^ action, int delayInMs) + { + auto task = new CefTaskDelegate(action); + + return CefPostDelayedTask((cef_thread_id_t)threadId, task, delayInMs); + } + + /// + /// Post an action for execution on the specified thread. + /// + /// thread id + /// action to execute + /// bool + static bool PostAction(CefThreadIds threadId, Action^ action) + { + auto task = new CefTaskDelegate(action); + + return CefPostTask((cef_thread_id_t)threadId, task); + } + }; + } +} +#endif // CEFSHARP_CORE_CEF_H_ diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CefSettingsBase.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CefSettingsBase.h new file mode 100644 index 0000000..b083bdf --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CefSettingsBase.h @@ -0,0 +1,407 @@ +// Copyright © 2010 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +using namespace System::Collections::Generic; +using namespace System::IO; + +namespace CefSharp +{ + namespace Core + { + /// + /// Initialization settings. Many of these and other settings can also configured using command-line switches. + /// WPF/WinForms/OffScreen each have their own CefSettings implementation that sets + /// relevant settings e.g. OffScreen starts with audio muted. + /// + [System::ComponentModel::EditorBrowsableAttribute(System::ComponentModel::EditorBrowsableState::Never)] + public ref class CefSettingsBase sealed + { + private: + /// + /// Command Line Arguments Dictionary. + /// + CommandLineArgDictionary^ _cefCommandLineArgs; + + internal: + /// + /// CefSettings unmanaged pointer + /// + ::CefSettings* _cefSettings; + /// + /// CefCustomScheme collection + /// + List^ _cefCustomSchemes; + + public: + /// + /// Default Constructor. + /// + CefSettingsBase() : _cefSettings(new ::CefSettings()) + { + _cefSettings->multi_threaded_message_loop = true; + _cefSettings->no_sandbox = true; + BrowserSubprocessPath = Path::Combine(Path::GetDirectoryName(CefSettingsBase::typeid->Assembly->Location), "CefSharp.BrowserSubprocess.exe"); + _cefCustomSchemes = gcnew List(); + _cefCommandLineArgs = gcnew CommandLineArgDictionary(); + } + + /// + /// Finalizer. + /// + !CefSettingsBase() + { + _cefSettings = nullptr; + } + + /// + /// Destructor. + /// + ~CefSettingsBase() + { + this->!CefSettingsBase(); + } + + /// + /// Add Customs schemes to this collection. + /// + property IEnumerable^ CefCustomSchemes + { + IEnumerable^ get() { return _cefCustomSchemes; } + } + + /// + /// Add custom command line argumens to this collection, they will be added in OnBeforeCommandLineProcessing. The + /// CefSettings.CommandLineArgsDisabled value can be used to start with an empty command-line object. Any values specified in + /// CefSettings that equate to command-line arguments will be set before this method is called. + /// + property CommandLineArgDictionary^ CefCommandLineArgs + { + CommandLineArgDictionary^ get() { return _cefCommandLineArgs; } + } + + /// + /// **Experimental** + /// Set to true to enable use of the Chrome runtime in CEF. This feature is + /// considered experimental and is not recommended for most users at this time. + /// See issue https://github.com/chromiumembedded/cef/issues/2969 + /// + property bool ChromeRuntime + { + bool get() { return _cefSettings->chrome_runtime == 1; } + void set(bool value) { _cefSettings->chrome_runtime = value; } + } + + /// + /// Set to true to disable configuration of browser process features using standard CEF and Chromium command-line arguments. + /// Configuration can still be specified using CEF data structures or by adding to CefCommandLineArgs. + /// + property bool CommandLineArgsDisabled + { + bool get() { return _cefSettings->command_line_args_disabled == 1; } + void set(bool value) { _cefSettings->command_line_args_disabled = value; } + } + + /// + /// Set to true to control browser process main (UI) thread message pump scheduling via the + /// IBrowserProcessHandler.OnScheduleMessagePumpWork callback. This option is recommended for use in combination with the + /// Cef.DoMessageLoopWork() function in cases where the CEF message loop must be integrated into an existing application message + /// loop (see additional comments and warnings on Cef.DoMessageLoopWork). Enabling this option is not recommended for most users; + /// leave this option disabled and use either MultiThreadedMessageLoop (the default) if possible. + /// + property bool ExternalMessagePump + { + bool get() { return _cefSettings->external_message_pump == 1; } + void set(bool value) { _cefSettings->external_message_pump = value; } + } + + /// + /// Set to true to have the browser process message loop run in a separate thread. If false than the CefDoMessageLoopWork() + /// function must be called from your application message loop. This option is only supported on Windows. The default value is + /// true. + /// + property bool MultiThreadedMessageLoop + { + bool get() { return _cefSettings->multi_threaded_message_loop == 1; } + void set(bool value) { _cefSettings->multi_threaded_message_loop = value; } + } + + /// + /// The path to a separate executable that will be launched for sub-processes. By default the browser process executable is used. + /// See the comments on Cef.ExecuteProcess() for details. If this value is non-empty then it must be an absolute path. + /// Also configurable using the "browser-subprocess-path" command-line switch. + /// Defaults to using the provided CefSharp.BrowserSubprocess.exe instance + /// + property String^ BrowserSubprocessPath + { + String^ get() { return StringUtils::ToClr(_cefSettings->browser_subprocess_path); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->browser_subprocess_path, value); } + } + + /// + /// The location where data for the global browser cache will be stored on disk. In this value is non-empty then it must be + /// an absolute path that is must be either equal to or a child directory of CefSettings.RootCachePath (if RootCachePath is + /// empty it will default to this value). If the value is empty then browsers will be created in "incognito mode" where + /// in-memory caches are used for storage and no data is persisted to disk. HTML5 databases such as localStorage will only + /// persist across sessions if a cache path is specified. Can be overridden for individual RequestContext instances via the + /// RequestContextSettings.CachePath value. + /// + property String^ CachePath + { + String^ get() { return StringUtils::ToClr(_cefSettings->cache_path); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->cache_path, value); } + } + + /// + /// The root directory that all CefSettings.CachePath and RequestContextSettings.CachePath values must have in common. If this + /// value is empty and CefSettings.CachePath is non-empty then it will default to the CefSettings.CachePath value. + /// If this value is non-empty then it must be an absolute path. Failure to set this value correctly may result in the sandbox + /// blocking read/write access to the CachePath directory. NOTE: CefSharp does not implement the CHROMIUM SANDBOX. A non-empty + /// RootCachePath can be used in conjuncation with an empty CefSettings.CachePath in instances where you would like browsers + /// attached to the Global RequestContext (the default) created in "incognito mode" and instances created with a custom + /// RequestContext using a disk based cache. + /// + property String^ RootCachePath + { + String^ get() { return StringUtils::ToClr(_cefSettings->root_cache_path); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->root_cache_path, value); } + } + + /// + /// The location where user data such as the Widevine CDM module and spell checking dictionary files will be stored on disk. + /// If this value is empty then "Local Settings\Application Data\CEF\User Data" directory under the user profile directory + /// will be used. If this value is non-empty then it must be an absolute path. + /// + property String^ UserDataPath + { + String^ get() { return StringUtils::ToClr(_cefSettings->user_data_path); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->user_data_path, value); } + } + + /// + /// The locale string that will be passed to WebKit. If empty the default locale of "en-US" will be used. Also configurable using + /// the "lang" command-line switch. + /// + property String^ Locale + { + String^ get() { return StringUtils::ToClr(_cefSettings->locale); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->locale, value); } + } + + /// + /// The fully qualified path for the locales directory. If this value is empty the locales directory must be located in the + /// module directory. If this value is non-empty then it must be an absolute path. Also configurable using the "locales-dir-path" + /// command-line switch. + /// + property String^ LocalesDirPath + { + String^ get() { return StringUtils::ToClr(_cefSettings->locales_dir_path); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->locales_dir_path, value); } + } + + /// + /// The fully qualified path for the resources directory. If this value is empty the cef.pak and/or devtools_resources.pak files + /// must be located in the module directory. Also configurable using the "resources-dir-path" command-line switch. + /// + property String^ ResourcesDirPath + { + String^ get() { return StringUtils::ToClr(_cefSettings->resources_dir_path); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->resources_dir_path, value); } + } + + /// + /// The directory and file name to use for the debug log. If empty a default log file name and location will be used. On Windows + /// a "debug.log" file will be written in the main executable directory. Also configurable using the"log-file" command- line + /// switch. + /// + property String^ LogFile + { + String^ get() { return StringUtils::ToClr(_cefSettings->log_file); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->log_file, value); } + } + + /// + /// The log severity. Only messages of this severity level or higher will be logged. When set to + /// no messages will be written to the log file, but Fatal messages will still be + /// output to stderr. Also configurable using the "log-severity" command-line switch with a value of "verbose", "info", "warning", + /// "error", "fatal", "error-report" or "disable". + /// + property CefSharp::LogSeverity LogSeverity + { + CefSharp::LogSeverity get() { return (CefSharp::LogSeverity)_cefSettings->log_severity; } + void set(CefSharp::LogSeverity value) { _cefSettings->log_severity = (cef_log_severity_t)value; } + } + + /// + /// Custom flags that will be used when initializing the V8 JavaScript engine. The consequences of using custom flags may not be + /// well tested. Also configurable using the "js-flags" command-line switch. + /// + property String^ JavascriptFlags + { + String^ get() { return StringUtils::ToClr(_cefSettings->javascript_flags); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->javascript_flags, value); } + } + + /// + /// Set to true to disable loading of pack files for resources and locales. A resource bundle handler must be provided for the + /// browser and render processes via CefApp::GetResourceBundleHandler() if loading of pack files is disabled. Also configurable + /// using the "disable-pack-loading" command- line switch. + /// + property bool PackLoadingDisabled + { + bool get() { return _cefSettings->pack_loading_disabled == 1; } + void set(bool value) { _cefSettings->pack_loading_disabled = value; } + } + + /// + /// Value that will be inserted as the product portion of the default User-Agent string. If empty the Chromium product version + /// will be used. If UserAgent is specified this value will be ignored. Also configurable using the "user-agent-product" command- + /// line switch. + /// + property String^ UserAgentProduct + { + String^ get() { return StringUtils::ToClr(_cefSettings->user_agent_product); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->user_agent_product, value); } + } + + /// + /// Set to a value between 1024 and 65535 to enable remote debugging on the specified port. For example, if 8080 is specified the + /// remote debugging URL will be http://localhost:8080. CEF can be remotely debugged from any CEF or Chrome browser window. Also + /// configurable using the "remote-debugging-port" command-line switch. + /// + property int RemoteDebuggingPort + { + int get() { return _cefSettings->remote_debugging_port; } + void set(int value) { _cefSettings->remote_debugging_port = value; } + } + + /// + /// The number of stack trace frames to capture for uncaught exceptions. Specify a positive value to enable the + /// CefRenderProcessHandler:: OnUncaughtException() callback. Specify 0 (default value) and OnUncaughtException() will not be + /// called. Also configurable using the "uncaught-exception-stack-size" command-line switch. + /// + property int UncaughtExceptionStackSize + { + int get() { return _cefSettings->uncaught_exception_stack_size; } + void set(int value) { _cefSettings->uncaught_exception_stack_size = value; } + } + + /// + /// Value that will be returned as the User-Agent HTTP header. If empty the default User-Agent string will be used. Also + /// configurable using the "user-agent" command-line switch. + /// + property String^ UserAgent + { + String^ get() { return StringUtils::ToClr(_cefSettings->user_agent); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->user_agent, value); } + } + + /// + /// Set to true (1) to enable windowless (off-screen) rendering support. Do not enable this value if the application does not use + /// windowless rendering as it may reduce rendering performance on some systems. + /// + property bool WindowlessRenderingEnabled + { + bool get() { return _cefSettings->windowless_rendering_enabled == 1; } + void set(bool value) { _cefSettings->windowless_rendering_enabled = value; } + } + + /// + /// To persist session cookies (cookies without an expiry date or validity interval) by default when using the global cookie + /// manager set this value to true. Session cookies are generally intended to be transient and most Web browsers do not persist + /// them. A CachePath value must also be specified to enable this feature. Also configurable using the "persist-session-cookies" + /// command-line switch. Can be overridden for individual RequestContext instances via the + /// RequestContextSettings.PersistSessionCookies value. + /// + property bool PersistSessionCookies + { + bool get() { return _cefSettings->persist_session_cookies == 1; } + void set(bool value) { _cefSettings->persist_session_cookies = value; } + } + + /// + /// To persist user preferences as a JSON file in the cache path directory set this value to true. A CachePath value must also be + /// specified to enable this feature. Also configurable using the "persist-user-preferences" command-line switch. Can be + /// overridden for individual RequestContext instances via the RequestContextSettings.PersistUserPreferences value. + /// + property bool PersistUserPreferences + { + bool get() { return _cefSettings->persist_user_preferences == 1; } + void set(bool value) { _cefSettings->persist_user_preferences = value; } + } + + /// + /// Comma delimited ordered list of language codes without any whitespace that will be used in the "Accept-Language" HTTP header. + /// May be set globally using the CefSettings.AcceptLanguageList value. If both values are empty then "en-US,en" will be used. + /// + /// + property String^ AcceptLanguageList + { + String^ get() { return StringUtils::ToClr(_cefSettings->accept_language_list); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->accept_language_list, value); } + } + + /// + /// Background color used for the browser before a document is loaded and when no document color is specified. The alpha + /// component must be either fully opaque (0xFF) or fully transparent (0x00). If the alpha component is fully opaque then the RGB + /// components will be used as the background color. If the alpha component is fully transparent for a WinForms browser then the + /// default value of opaque white be used. If the alpha component is fully transparent for a windowless (WPF/OffScreen) browser + /// then transparent painting will be enabled. + /// + property uint32 BackgroundColor + { + uint32 get() { return _cefSettings->background_color; } + void set(uint32 value) { _cefSettings->background_color = value; } + } + + /// + /// Comma delimited list of schemes supported by the associated + /// ICookieManager. If CookieableSchemesExcludeDefaults is false the + /// default schemes ("http", "https", "ws" and "wss") will also be supported. + /// Specifying a CookieableSchemesList value and setting + /// CookieableSchemesExcludeDefaults to true will disable all loading + /// and saving of cookies for this manager. Can be overridden + /// for individual RequestContext instances via the + /// RequestContextSettings.CookieableSchemesList and + /// RequestContextSettings.CookieableSchemesExcludeDefaults values. + /// + property String^ CookieableSchemesList + { + String^ get() { return StringUtils::ToClr(_cefSettings->cookieable_schemes_list); } + void set(String^ value) { StringUtils::AssignNativeFromClr(_cefSettings->cookieable_schemes_list, value); } + } + + /// + /// If CookieableSchemesExcludeDefaults is false the + /// default schemes ("http", "https", "ws" and "wss") will also be supported. + /// Specifying a CookieableSchemesList value and setting + /// CookieableSchemesExcludeDefaults to true will disable all loading + /// and saving of cookies for this manager. Can be overridden + /// for individual RequestContext instances via the + /// RequestContextSettings.CookieableSchemesList and + /// RequestContextSettings.CookieableSchemesExcludeDefaults values. + /// + property bool CookieableSchemesExcludeDefaults + { + bool get() { return _cefSettings->cookieable_schemes_exclude_defaults == 1; } + void set(bool value) { _cefSettings->cookieable_schemes_exclude_defaults = value; } + } + + /// + /// Registers a custom scheme using the provided settings. + /// + /// The CefCustomScheme which provides the details about the scheme. + void RegisterScheme(CefCustomScheme^ cefCustomScheme) + { + //Scheme names are converted to lowercase + cefCustomScheme->SchemeName = cefCustomScheme->SchemeName->ToLower(); + + _cefCustomSchemes->Add(cefCustomScheme); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CookieManager.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CookieManager.cpp new file mode 100644 index 0000000..e227396 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CookieManager.cpp @@ -0,0 +1,91 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" +#include "CookieManager.h" + +#include "Internals\CefCookieVisitorAdapter.h" +#include "Internals\CefCompletionCallbackAdapter.h" +#include "Internals\CefSetCookieCallbackAdapter.h" +#include "Internals\CefDeleteCookiesCallbackAdapter.h" + +using namespace CefSharp::Internals; + +namespace CefSharp +{ + void CookieManager::ThrowIfDisposed() + { + if (_cookieManager.get() == nullptr) + { + throw gcnew ObjectDisposedException("CookieManager"); + } + } + + bool CookieManager::DeleteCookies(String^ url, String^ name, IDeleteCookiesCallback^ callback) + { + ThrowIfDisposed(); + + CefRefPtr wrapper = callback == nullptr ? nullptr : new CefDeleteCookiesCallbackAdapter(callback); + + return _cookieManager->DeleteCookies(StringUtils::ToNative(url), StringUtils::ToNative(name), wrapper); + } + + bool CookieManager::SetCookie(String^ url, Cookie^ cookie, ISetCookieCallback^ callback) + { + ThrowIfDisposed(); + + CefRefPtr wrapper = callback == nullptr ? nullptr : new CefSetCookieCallbackAdapter(callback); + + CefCookie c; + StringUtils::AssignNativeFromClr(c.name, cookie->Name); + StringUtils::AssignNativeFromClr(c.value, cookie->Value); + StringUtils::AssignNativeFromClr(c.domain, cookie->Domain); + StringUtils::AssignNativeFromClr(c.path, cookie->Path); + c.secure = cookie->Secure; + c.httponly = cookie->HttpOnly; + c.has_expires = cookie->Expires.HasValue; + + if (cookie->Expires.HasValue) + { + c.expires.val = CefTimeUtils::FromDateTimeToBaseTime(cookie->Expires.Value); + } + + // creation/last_access are basically readonly (assigned by Chromium when the cookie is created) + // So I don't think we actually need to set them. The other option is to assign them to DateTime.Now + // Issue #4234 + //c.creation.val = CefTimeUtils::FromDateTimeToBaseTime(cookie->Creation); + //c.last_access.val = CefTimeUtils::FromDateTimeToBaseTime(cookie->LastAccess); + c.same_site = (cef_cookie_same_site_t)cookie->SameSite; + c.priority = (cef_cookie_priority_t)cookie->Priority; + + return _cookieManager->SetCookie(StringUtils::ToNative(url), c, wrapper); + } + + bool CookieManager::VisitAllCookies(ICookieVisitor^ visitor) + { + ThrowIfDisposed(); + + CefRefPtr cookieVisitor = new CefCookieVisitorAdapter(visitor); + + return _cookieManager->VisitAllCookies(cookieVisitor); + } + + bool CookieManager::VisitUrlCookies(String^ url, bool includeHttpOnly, ICookieVisitor^ visitor) + { + ThrowIfDisposed(); + + CefRefPtr cookieVisitor = new CefCookieVisitorAdapter(visitor); + + return _cookieManager->VisitUrlCookies(StringUtils::ToNative(url), includeHttpOnly, cookieVisitor); + } + + bool CookieManager::FlushStore(ICompletionCallback^ callback) + { + ThrowIfDisposed(); + + CefRefPtr wrapper = callback == nullptr ? nullptr : new CefCompletionCallbackAdapter(callback); + + return _cookieManager->FlushStore(wrapper); + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CookieManager.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CookieManager.h new file mode 100644 index 0000000..fc3d856 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/CookieManager.h @@ -0,0 +1,64 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include/cef_cookie.h" +#include "internals\CefCompletionCallbackAdapter.h" + +namespace CefSharp +{ + //TODO: No longer possible for users to create a CookieManager, can be made private now + /// + private ref class CookieManager : public ICookieManager + { + private: + MCefRefPtr _cookieManager; + + void ThrowIfDisposed(); + + internal: + CookieManager(const CefRefPtr &cookieManager) + :_cookieManager(cookieManager.get()) + { + + } + + operator CefRefPtr() + { + if (this == nullptr) + { + return nullptr; + } + return _cookieManager.get(); + } + + public: + !CookieManager() + { + this->_cookieManager = nullptr; + } + + ~CookieManager() + { + this->!CookieManager(); + } + + virtual bool DeleteCookies(String^ url, String^ name, IDeleteCookiesCallback^ callback); + virtual bool SetCookie(String^ url, Cookie^ cookie, ISetCookieCallback^ callback); + virtual bool VisitAllCookies(ICookieVisitor^ visitor); + virtual bool VisitUrlCookies(String^ url, bool includeHttpOnly, ICookieVisitor^ visitor); + virtual bool FlushStore(ICompletionCallback^ callback); + + virtual property bool IsDisposed + { + bool get() + { + return !_cookieManager.get(); + } + } + }; +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/DragData.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/DragData.h new file mode 100644 index 0000000..ea9b679 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/DragData.h @@ -0,0 +1,229 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include/cef_drag_data.h" + +#include "Internals\CefWrapper.h" +#include "Internals\CefImageWrapper.h" +#include "Internals\CefWriteHandlerWrapper.h" + +using namespace std; +using namespace System::IO; + +namespace CefSharp +{ + namespace Core + { + [System::ComponentModel::EditorBrowsableAttribute(System::ComponentModel::EditorBrowsableState::Never)] + public ref class DragData : public IDragData, public CefWrapper + { + private: + MCefRefPtr _wrappedDragData; + + internal: + DragData(CefRefPtr &dragData) : + _wrappedDragData(dragData) + { + IsReadOnly = dragData->IsReadOnly(); + FileName = StringUtils::ToClr(dragData->GetFileName()); + IsFile = dragData->IsFile(); + IsFragment = dragData->IsFragment(); + IsLink = dragData->IsLink(); + } + + !DragData() + { + _wrappedDragData = nullptr; + } + + ~DragData() + { + this->!DragData(); + + _disposed = true; + } + + operator CefRefPtr() + { + if (this == nullptr) + { + return nullptr; + } + return _wrappedDragData.get(); + } + + public: + virtual property bool IsReadOnly; + virtual property String^ FileName; + virtual property bool IsFile; + virtual property bool IsFragment; + virtual property bool IsLink; + + virtual IDragData^ Clone() + { + return gcnew DragData(_wrappedDragData->Clone()); + } + + /// + // Create a new CefDragData object. + /// + /*--cef()--*/ + static IDragData^ Create() + { + return gcnew DragData(CefDragData::Create()); + } + + //TODO: Vector is a pointer, so can potentially be updated (items may be possibly removed) + virtual property IList^ FileNames + { + IList^ get() + { + auto names = vector(); + _wrappedDragData->GetFileNames(names); + + return StringUtils::ToClr(names); + } + } + + virtual property String^ FragmentBaseUrl + { + String^ get() + { + return StringUtils::ToClr(_wrappedDragData->GetFragmentBaseURL()); + } + void set(String^ fragmentBaseUrl) + { + _wrappedDragData->SetFragmentBaseURL(StringUtils::ToNative(fragmentBaseUrl)); + } + } + + virtual property String^ FragmentHtml + { + String^ get() + { + return StringUtils::ToClr(_wrappedDragData->GetFragmentHtml()); + } + void set(String^ fragmentHtml) + { + _wrappedDragData->SetFragmentHtml(StringUtils::ToNative(fragmentHtml)); + } + } + + virtual property String^ FragmentText + { + String^ get() + { + return StringUtils::ToClr(_wrappedDragData->GetFragmentText()); + } + void set(String^ fragmentText) + { + _wrappedDragData->SetFragmentText(StringUtils::ToNative(fragmentText)); + } + } + + virtual property bool HasImage + { + bool get() + { + return _wrappedDragData->HasImage(); + } + } + + /// + /// Get the image representation of drag data. + /// May return NULL if no image representation is available. + /// + virtual property IImage^ Image + { + IImage^ get() + { + if (_wrappedDragData->HasImage()) + { + return gcnew CefImageWrapper(_wrappedDragData->GetImage()); + } + return nullptr; + } + } + + /// + /// Get the image hotspot (drag start location relative to image dimensions). + /// + virtual property CefSharp::Structs::Point ImageHotspot + { + CefSharp::Structs::Point get() + { + return CefSharp::Structs::Point(0, 0); + } + } + + virtual property String^ LinkMetaData + { + String^ get() + { + return StringUtils::ToClr(_wrappedDragData->GetLinkMetadata()); + } + void set(String^ linkMetaData) + { + _wrappedDragData->SetLinkMetadata(StringUtils::ToNative(linkMetaData)); + } + } + + virtual property String^ LinkTitle + { + String^ get() + { + return StringUtils::ToClr(_wrappedDragData->GetLinkTitle()); + } + void set(String^ linkTitle) + { + _wrappedDragData->SetLinkTitle(StringUtils::ToNative(linkTitle)); + } + } + + virtual property String^ LinkUrl + { + String^ get() + { + return StringUtils::ToClr(_wrappedDragData->GetLinkURL()); + } + void set(String^ linkUrl) + { + _wrappedDragData->SetLinkURL(StringUtils::ToNative(linkUrl)); + } + } + + virtual void AddFile(String^ path, String^ displayName) + { + _wrappedDragData->AddFile(StringUtils::ToNative(path), StringUtils::ToNative(displayName)); + } + + virtual void ResetFileContents() + { + _wrappedDragData->ResetFileContents(); + } + + virtual void ClearFilenames() + { + _wrappedDragData->ClearFilenames(); + } + + virtual Int64 GetFileContents(Stream^ stream) + { + if (stream == nullptr) + { + return (Int64)_wrappedDragData->GetFileContents(nullptr); + } + + auto writeHandler = new CefWriteHandlerWrapper(stream); + + auto writer = CefStreamWriter::CreateForHandler(writeHandler); + return (Int64)_wrappedDragData->GetFileContents(writer); + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefAuthCallbackWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefAuthCallbackWrapper.h new file mode 100644 index 0000000..65b5aa2 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefAuthCallbackWrapper.h @@ -0,0 +1,59 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_auth_callback.h" +#include "CefWrapper.h" + +namespace CefSharp +{ + namespace Internals + { + private ref class CefAuthCallbackWrapper : public IAuthCallback, public CefWrapper + { + private: + MCefRefPtr _callback; + + public: + CefAuthCallbackWrapper(CefRefPtr &callback) + : _callback(callback) + { + + } + + !CefAuthCallbackWrapper() + { + _callback = nullptr; + } + + ~CefAuthCallbackWrapper() + { + this->!CefAuthCallbackWrapper(); + + _disposed = true; + } + + virtual void Cancel() + { + ThrowIfDisposed(); + + _callback->Cancel(); + + delete this; + } + + virtual void Continue(String^ username, String^ password) + { + ThrowIfDisposed(); + + _callback->Continue(StringUtils::ToNative(username), StringUtils::ToNative(password)); + + delete this; + } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBeforeDownloadCallbackWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBeforeDownloadCallbackWrapper.h new file mode 100644 index 0000000..53e490a --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBeforeDownloadCallbackWrapper.h @@ -0,0 +1,51 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_download_handler.h" +#include "CefWrapper.h" + +namespace CefSharp +{ + namespace Internals + { + private ref class CefBeforeDownloadCallbackWrapper : public IBeforeDownloadCallback, public CefWrapper + { + private: + MCefRefPtr _callback; + + public: + CefBeforeDownloadCallbackWrapper(CefRefPtr &callback) + : _callback(callback) + { + + } + + !CefBeforeDownloadCallbackWrapper() + { + _callback = nullptr; + } + + ~CefBeforeDownloadCallbackWrapper() + { + this->!CefBeforeDownloadCallbackWrapper(); + + _disposed = true; + } + + virtual void Continue(String^ downloadPath, bool showDialog) + { + ThrowIfDisposed(); + + _callback->Continue(StringUtils::ToNative(downloadPath), showDialog); + + delete this; + } + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserHostWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserHostWrapper.cpp new file mode 100644 index 0000000..143f278 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserHostWrapper.cpp @@ -0,0 +1,787 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" +#include "CefBrowserHostWrapper.h" + +#include "include\cef_client.h" +#include "include\cef_parser.h" + +#include "Cef.h" +#include "CefExtensionWrapper.h" +#include "CefTaskScheduler.h" +#include "DragData.h" +#include "CefRunFileDialogCallbackAdapter.h" +#include "CefPdfPrintCallbackWrapper.h" +#include "CefNavigationEntryVisitorAdapter.h" +#include "CefRegistrationWrapper.h" +#include "CefDevToolsMessageObserverAdapter.h" +#include "RequestContext.h" +#include "WindowInfo.h" + +using namespace CefSharp::Core; + +void CefBrowserHostWrapper::DragTargetDragEnter(IDragData^ dragData, MouseEvent mouseEvent, DragOperationsMask allowedOperations) +{ + ThrowIfDisposed(); + + auto dragDataWrapper = static_cast(dragData); + dragDataWrapper->ResetFileContents(); // Recommended by documentation to reset before calling DragEnter + _browserHost->DragTargetDragEnter(static_cast>(dragDataWrapper), GetCefMouseEvent(mouseEvent), (CefBrowserHost::DragOperationsMask) allowedOperations); +} + +void CefBrowserHostWrapper::DragTargetDragOver(MouseEvent mouseEvent, DragOperationsMask allowedOperations) +{ + ThrowIfDisposed(); + + _browserHost->DragTargetDragOver(GetCefMouseEvent(mouseEvent), (CefBrowserHost::DragOperationsMask) allowedOperations); +} + +void CefBrowserHostWrapper::DragTargetDragDrop(MouseEvent mouseEvent) +{ + ThrowIfDisposed(); + + _browserHost->DragTargetDrop(GetCefMouseEvent(mouseEvent)); +} + +void CefBrowserHostWrapper::DragSourceEndedAt(int x, int y, DragOperationsMask op) +{ + ThrowIfDisposed(); + + _browserHost->DragSourceEndedAt(x, y, (CefBrowserHost::DragOperationsMask)op); +} + +void CefBrowserHostWrapper::DragTargetDragLeave() +{ + ThrowIfDisposed(); + + _browserHost->DragTargetDragLeave(); +} + +void CefBrowserHostWrapper::DragSourceSystemDragEnded() +{ + ThrowIfDisposed(); + + _browserHost->DragSourceSystemDragEnded(); +} + +void CefBrowserHostWrapper::StartDownload(String^ url) +{ + ThrowIfDisposed(); + + _browserHost->StartDownload(StringUtils::ToNative(url)); +} + +void CefBrowserHostWrapper::Print() +{ + ThrowIfDisposed(); + + _browserHost->Print(); +} + +void CefBrowserHostWrapper::PrintToPdf(String^ path, PdfPrintSettings^ settings, IPrintToPdfCallback^ callback) +{ + ThrowIfDisposed(); + + CefPdfPrintSettings nativeSettings; + if (settings != nullptr) + { + nativeSettings.landscape = settings->Landscape ? 1 : 0; + nativeSettings.print_background = settings->PrintBackground ? 1 : 0; + nativeSettings.scale = settings->Scale; + nativeSettings.paper_height = settings->PaperHeight; + nativeSettings.paper_width = settings->PaperWidth; + nativeSettings.prefer_css_page_size = settings->PreferCssPageSize ? 1 : 0; + nativeSettings.margin_type = static_cast(settings->MarginType); + nativeSettings.margin_bottom = settings->MarginBottom; + nativeSettings.margin_top = settings->MarginTop; + nativeSettings.margin_left = settings->MarginLeft; + nativeSettings.margin_right = settings->MarginRight; + StringUtils::AssignNativeFromClr(nativeSettings.page_ranges, settings->PageRanges); + nativeSettings.display_header_footer = settings->DisplayHeaderFooter ? 1 : 0; + StringUtils::AssignNativeFromClr(nativeSettings.header_template, settings->HeaderTemplate); + StringUtils::AssignNativeFromClr(nativeSettings.footer_template, settings->FooterTemplate); + } + + _browserHost->PrintToPDF(StringUtils::ToNative(path), nativeSettings, new CefPdfPrintCallbackWrapper(callback)); +} + +void CefBrowserHostWrapper::SetZoomLevel(double zoomLevel) +{ + ThrowIfDisposed(); + + _browserHost->SetZoomLevel(zoomLevel); +} + +double CefBrowserHostWrapper::GetZoomLevel() +{ + ThrowIfDisposed(); + + if (CefCurrentlyOn(TID_UI)) + { + + return _browserHost->GetZoomLevel(); + } + + throw gcnew InvalidOperationException("This method can only be called directly on the CEF UI Thread. Use GetZoomLevelAsync or use Cef.UIThreadTaskFactory to marshal the call onto the CEF UI Thread."); + +} + +Task^ CefBrowserHostWrapper::GetZoomLevelAsync() +{ + ThrowIfDisposed(); + + if (CefCurrentlyOn(TID_UI)) + { + auto taskSource = gcnew TaskCompletionSource(); + + CefSharp::Internals::TaskExtensions::TrySetResultAsync(taskSource, GetZoomLevelOnUI()); + return taskSource->Task; + } + return Cef::UIThreadTaskFactory->StartNew(gcnew Func(this, &CefBrowserHostWrapper::GetZoomLevelOnUI)); +} + +IntPtr CefBrowserHostWrapper::GetWindowHandle() +{ + ThrowIfDisposed(); + + return IntPtr(_browserHost->GetWindowHandle()); +} + +void CefBrowserHostWrapper::CloseBrowser(bool forceClose) +{ + ThrowIfDisposed(); + + _browserHost->CloseBrowser(forceClose); +} + +bool CefBrowserHostWrapper::TryCloseBrowser() +{ + ThrowIfDisposed(); + ThrowIfExecutedOnNonCefUiThread(); + + return _browserHost->TryCloseBrowser(); +} + +void CefBrowserHostWrapper::ShowDevTools(IWindowInfo^ windowInfo, int inspectElementAtX, int inspectElementAtY) +{ + ThrowIfDisposed(); + + CefBrowserSettings settings; + CefWindowInfo nativeWindowInfo; + + if (windowInfo == nullptr) + { + nativeWindowInfo.SetAsPopup(NULL, "DevTools"); + } + else + { + //Get the inner instance then case that + auto cefWindowInfoWrapper = static_cast(windowInfo->UnWrap()); + + nativeWindowInfo = *cefWindowInfoWrapper->GetWindowInfo(); + } + + _browserHost->ShowDevTools(nativeWindowInfo, _browserHost->GetClient(), settings, CefPoint(inspectElementAtX, inspectElementAtY)); +} + +void CefBrowserHostWrapper::CloseDevTools() +{ + ThrowIfDisposed(); + + _browserHost->CloseDevTools(); +} + +bool CefBrowserHostWrapper::HasDevTools::get() +{ + ThrowIfDisposed(); + + return _browserHost->HasDevTools(); +} + +bool CefBrowserHostWrapper::SendDevToolsMessage(String^ messageAsJson) +{ + ThrowIfDisposed(); + + ThrowIfExecutedOnNonCefUiThread(); + + if (String::IsNullOrEmpty(messageAsJson)) + { + throw gcnew ArgumentNullException("messageAsJson"); + } + + //NOTE: Prefix with cli:: namespace as VS2015 gets confused with std::array + cli::array^ buffer = System::Text::Encoding::UTF8->GetBytes(messageAsJson); + pin_ptr src = &buffer[0]; + + return _browserHost->SendDevToolsMessage(static_cast(src), buffer->Length); +} + +int CefBrowserHostWrapper::ExecuteDevToolsMethod(int messageId, String^ method, IDictionary^ paramaters) +{ + ThrowIfDisposed(); + + ThrowIfExecutedOnNonCefUiThread(); + + if (paramaters == nullptr) + { + return _browserHost->ExecuteDevToolsMethod(messageId, StringUtils::ToNative(method), nullptr); + } + + auto val = TypeConversion::ToNative(paramaters); + + if (val && val->GetType() == VTYPE_DICTIONARY) + { + return _browserHost->ExecuteDevToolsMethod(messageId, StringUtils::ToNative(method), val->GetDictionary()); + } + + throw gcnew Exception("Unable to convert paramaters to CefDictionaryValue."); +} + + + +int CefBrowserHostWrapper::ExecuteDevToolsMethod(int messageId, String^ method, String^ paramsAsJson) +{ + ThrowIfDisposed(); + + ThrowIfExecutedOnNonCefUiThread(); + + if (String::IsNullOrEmpty(paramsAsJson)) + { + return _browserHost->ExecuteDevToolsMethod(messageId, StringUtils::ToNative(method), nullptr); + } + + auto val = CefParseJSON(StringUtils::ToNative(paramsAsJson), cef_json_parser_options_t::JSON_PARSER_RFC); + + if (val && val->GetType() == VTYPE_DICTIONARY) + { + return _browserHost->ExecuteDevToolsMethod(messageId, StringUtils::ToNative(method), val->GetDictionary()); + } + + throw gcnew Exception("Unable to parse paramsAsJson with CefParseJSON method"); +} + +IRegistration^ CefBrowserHostWrapper::AddDevToolsMessageObserver(IDevToolsMessageObserver^ observer) +{ + ThrowIfDisposed(); + + auto registration = _browserHost->AddDevToolsMessageObserver(new CefDevToolsMessageObserverAdapter(observer)); + + return gcnew CefRegistrationWrapper(registration); +} + +int CefBrowserHostWrapper::GetNextDevToolsMessageId() +{ + return Interlocked::Increment(_lastDevToolsMessageId); +} + +void CefBrowserHostWrapper::AddWordToDictionary(String^ word) +{ + ThrowIfDisposed(); + + _browserHost->AddWordToDictionary(StringUtils::ToNative(word)); +} + +void CefBrowserHostWrapper::ReplaceMisspelling(String^ word) +{ + ThrowIfDisposed(); + + _browserHost->ReplaceMisspelling(StringUtils::ToNative(word)); +} + +IExtension^ CefBrowserHostWrapper::Extension::get() +{ + ThrowIfDisposed(); + + auto extension = _browserHost->GetExtension(); + + if (extension.get()) + { + return gcnew CefExtensionWrapper(_browserHost->GetExtension()); + } + + return nullptr; +} + +void CefBrowserHostWrapper::RunFileDialog(CefFileDialogMode mode, String^ title, String^ defaultFilePath, IList^ acceptFilters, IRunFileDialogCallback^ callback) +{ + ThrowIfDisposed(); + + _browserHost->RunFileDialog((CefBrowserHost::FileDialogMode)mode, + StringUtils::ToNative(title), + StringUtils::ToNative(defaultFilePath), + StringUtils::ToNative(acceptFilters), + new CefRunFileDialogCallbackAdapter(callback)); +} + +void CefBrowserHostWrapper::Find(String^ searchText, bool forward, bool matchCase, bool findNext) +{ + ThrowIfDisposed(); + + _browserHost->Find(StringUtils::ToNative(searchText), forward, matchCase, findNext); +} + +void CefBrowserHostWrapper::StopFinding(bool clearSelection) +{ + ThrowIfDisposed(); + + _browserHost->StopFinding(clearSelection); +} + +void CefBrowserHostWrapper::SetFocus(bool focus) +{ + ThrowIfDisposed(); + + _browserHost->SetFocus(focus); +} + +void CefBrowserHostWrapper::SendFocusEvent(bool setFocus) +{ + ThrowIfDisposed(); + + _browserHost->SetFocus(setFocus); +} + +void CefBrowserHostWrapper::SendKeyEvent(KeyEvent keyEvent) +{ + ThrowIfDisposed(); + + CefKeyEvent nativeKeyEvent; + nativeKeyEvent.focus_on_editable_field = keyEvent.FocusOnEditableField == 1; + nativeKeyEvent.is_system_key = keyEvent.IsSystemKey == 1; + nativeKeyEvent.modifiers = (uint32)keyEvent.Modifiers; + nativeKeyEvent.type = (cef_key_event_type_t)keyEvent.Type; + nativeKeyEvent.native_key_code = keyEvent.NativeKeyCode; + nativeKeyEvent.windows_key_code = keyEvent.WindowsKeyCode; + + _browserHost->SendKeyEvent(nativeKeyEvent); +} + +void CefBrowserHostWrapper::SendKeyEvent(int message, int wParam, int lParam) +{ + ThrowIfDisposed(); + + CefKeyEvent keyEvent; + keyEvent.windows_key_code = wParam; + keyEvent.native_key_code = lParam; + keyEvent.is_system_key = message == WM_SYSCHAR || + message == WM_SYSKEYDOWN || + message == WM_SYSKEYUP; + keyEvent.modifiers = GetCefKeyboardModifiers(wParam, lParam); + + if (message == WM_KEYDOWN || message == WM_SYSKEYDOWN) + { + keyEvent.type = KEYEVENT_RAWKEYDOWN; + } + else if (message == WM_KEYUP || message == WM_SYSKEYUP) + { + keyEvent.type = KEYEVENT_KEYUP; + } + else + { + keyEvent.type = KEYEVENT_CHAR; + + // mimic alt-gr check behaviour from + // src/ui/events/win/events_win_utils.cc: GetModifiersFromKeyState + if (IsKeyDown(VK_MENU)) + { + // reverse AltGr detection taken from PlatformKeyMap::UsesAltGraph + // instead of checking all combination for ctrl-alt, just check current char + HKL current_layout = ::GetKeyboardLayout(0); + + // https://docs.microsoft.com/en-gb/windows/win32/api/winuser/nf-winuser-vkkeyscanexw + // ... high-order byte contains the shift state, + // which can be a combination of the following flag bits. + // 1 Either SHIFT key is pressed. + // 2 Either CTRL key is pressed. + // 4 Either ALT key is pressed. + SHORT scan_res = ::VkKeyScanExW(wParam, current_layout); + constexpr auto ctrlAlt = (2 | 4); + if (((scan_res >> 8) & ctrlAlt) == ctrlAlt) // ctrl-alt pressed + { + keyEvent.modifiers &= ~(EVENTFLAG_CONTROL_DOWN | EVENTFLAG_ALT_DOWN); + keyEvent.modifiers |= EVENTFLAG_ALTGR_DOWN; + } + } + } + + _browserHost->SendKeyEvent(keyEvent); +} + +double CefBrowserHostWrapper::GetZoomLevelOnUI() +{ + if (_disposed) + { + return 0.0; + } + + CefTaskScheduler::EnsureOn(TID_UI, "CefBrowserHostWrapper::GetZoomLevel"); + + //Don't throw exception if no browser host here as it's not easy to handle + if (_browserHost.get()) + { + return _browserHost->GetZoomLevel(); + } + + return 0.0; +} + +void CefBrowserHostWrapper::SendMouseWheelEvent(MouseEvent mouseEvent, int deltaX, int deltaY) +{ + ThrowIfDisposed(); + + if (_browserHost.get()) + { + CefMouseEvent m; + m.x = mouseEvent.X; + m.y = mouseEvent.Y; + m.modifiers = (uint32)mouseEvent.Modifiers; + + _browserHost->SendMouseWheelEvent(m, deltaX, deltaY); + } +} + +void CefBrowserHostWrapper::SendTouchEvent(TouchEvent evt) +{ + ThrowIfDisposed(); + + if (_browserHost.get()) + { + CefTouchEvent e; + e.id = evt.Id; + e.modifiers = (uint32)evt.Modifiers; + e.pointer_type = (cef_pointer_type_t)evt.PointerType; + e.pressure = evt.Pressure; + e.radius_x = evt.RadiusX; + e.radius_y = evt.RadiusY; + e.rotation_angle = evt.RotationAngle; + e.type = (cef_touch_event_type_t)evt.Type; + e.x = evt.X; + e.y = evt.Y; + + _browserHost->SendTouchEvent(e); + } +} + +void CefBrowserHostWrapper::SetAccessibilityState(CefState accessibilityState) +{ + ThrowIfDisposed(); + + _browserHost->SetAccessibilityState((cef_state_t)accessibilityState); +} + +void CefBrowserHostWrapper::SetAutoResizeEnabled(bool enabled, Size minSize, Size maxSize) +{ + ThrowIfDisposed(); + + _browserHost->SetAutoResizeEnabled(enabled, CefSize(minSize.Width, minSize.Height), CefSize(maxSize.Width, maxSize.Height)); +} + +void CefBrowserHostWrapper::Invalidate(PaintElementType type) +{ + ThrowIfDisposed(); + + _browserHost->Invalidate((CefBrowserHost::PaintElementType)type); +} + +bool CefBrowserHostWrapper::IsBackgroundHost::get() +{ + ThrowIfDisposed(); + + return _browserHost->IsBackgroundHost(); +} + +void CefBrowserHostWrapper::ImeSetComposition(String^ text, cli::array^ underlines, Nullable replacementRange, Nullable selectionRange) +{ + ThrowIfDisposed(); + + std::vector underlinesVector = std::vector(); + CefRange repRange; + CefRange selRange; + + if (underlines != nullptr && underlines->Length > 0) + { + for each (CompositionUnderline underline in underlines) + { + auto c = CefCompositionUnderline(); + c.range = CefRange(underline.Range.From, underline.Range.To); + c.color = underline.Color; + c.background_color = underline.BackgroundColor; + c.thick = (int)underline.Thick; + c.style = (cef_composition_underline_style_t)underline.Style; + underlinesVector.push_back(c); + } + } + + if (replacementRange.HasValue) + { + repRange = CefRange(replacementRange.Value.From, replacementRange.Value.To); + } + + if (selectionRange.HasValue) + { + selRange = CefRange(selectionRange.Value.From, selectionRange.Value.To); + } + + _browserHost->ImeSetComposition(StringUtils::ToNative(text), underlinesVector, repRange, selRange); +} + +void CefBrowserHostWrapper::ImeCommitText(String^ text, Nullable replacementRange, int relativeCursorPos) +{ + ThrowIfDisposed(); + + CefRange repRange; + + if (replacementRange.HasValue) + { + repRange = CefRange(replacementRange.Value.From, replacementRange.Value.To); + } + + _browserHost->ImeCommitText(StringUtils::ToNative(text), repRange, relativeCursorPos); +} + +void CefBrowserHostWrapper::ImeFinishComposingText(bool keepSelection) +{ + ThrowIfDisposed(); + + _browserHost->ImeFinishComposingText(keepSelection); +} + +void CefBrowserHostWrapper::ImeCancelComposition() +{ + ThrowIfDisposed(); + + _browserHost->ImeCancelComposition(); +} + +void CefBrowserHostWrapper::SendMouseClickEvent(MouseEvent mouseEvent, MouseButtonType mouseButtonType, bool mouseUp, int clickCount) +{ + ThrowIfDisposed(); + + CefMouseEvent m; + m.x = mouseEvent.X; + m.y = mouseEvent.Y; + m.modifiers = (uint32)mouseEvent.Modifiers; + + _browserHost->SendMouseClickEvent(m, (CefBrowserHost::MouseButtonType) mouseButtonType, mouseUp, clickCount); +} + +void CefBrowserHostWrapper::SendMouseMoveEvent(MouseEvent mouseEvent, bool mouseLeave) +{ + ThrowIfDisposed(); + + CefMouseEvent m; + m.x = mouseEvent.X; + m.y = mouseEvent.Y; + m.modifiers = (uint32)mouseEvent.Modifiers; + + _browserHost->SendMouseMoveEvent(m, mouseLeave); +} + +void CefBrowserHostWrapper::WasResized() +{ + ThrowIfDisposed(); + + _browserHost->WasResized(); +} + +void CefBrowserHostWrapper::WasHidden(bool hidden) +{ + ThrowIfDisposed(); + + _browserHost->WasHidden(hidden); +} + +void CefBrowserHostWrapper::GetNavigationEntries(INavigationEntryVisitor^ visitor, bool currentOnly) +{ + ThrowIfDisposed(); + + auto navEntryVisitor = new CefNavigationEntryVisitorAdapter(visitor); + + _browserHost->GetNavigationEntries(navEntryVisitor, currentOnly); +} + +NavigationEntry^ CefBrowserHostWrapper::GetVisibleNavigationEntry() +{ + ThrowIfDisposed(); + + ThrowIfExecutedOnNonCefUiThread(); + + auto entry = _browserHost->GetVisibleNavigationEntry(); + + return TypeConversion::FromNative(entry, true); +} + +void CefBrowserHostWrapper::NotifyMoveOrResizeStarted() +{ + ThrowIfDisposed(); + + _browserHost->NotifyMoveOrResizeStarted(); +} + +void CefBrowserHostWrapper::NotifyScreenInfoChanged() +{ + ThrowIfDisposed(); + + _browserHost->NotifyScreenInfoChanged(); +} + +int CefBrowserHostWrapper::WindowlessFrameRate::get() +{ + ThrowIfDisposed(); + + return _browserHost->GetWindowlessFrameRate(); +} + +void CefBrowserHostWrapper::WindowlessFrameRate::set(int val) +{ + ThrowIfDisposed(); + + _browserHost->SetWindowlessFrameRate(val); +} + +bool CefBrowserHostWrapper::WindowRenderingDisabled::get() +{ + ThrowIfDisposed(); + + return _browserHost->IsWindowRenderingDisabled(); +} + +bool CefBrowserHostWrapper::IsAudioMuted::get() +{ + ThrowIfDisposed(); + + ThrowIfExecutedOnNonCefUiThread(); + + return _browserHost->IsAudioMuted(); +} + +void CefBrowserHostWrapper::SetAudioMuted(bool mute) +{ + ThrowIfDisposed(); + + _browserHost->SetAudioMuted(mute); +} + +IntPtr CefBrowserHostWrapper::GetOpenerWindowHandle() +{ + ThrowIfDisposed(); + + return IntPtr(_browserHost->GetOpenerWindowHandle()); +} + +void CefBrowserHostWrapper::SendExternalBeginFrame() +{ + ThrowIfDisposed(); + + _browserHost->SendExternalBeginFrame(); +} + +void CefBrowserHostWrapper::SendCaptureLostEvent() +{ + ThrowIfDisposed(); + + _browserHost->SendCaptureLostEvent(); +} + + +IRequestContext^ CefBrowserHostWrapper::RequestContext::get() +{ + ThrowIfDisposed(); + + return gcnew CefSharp::Core::RequestContext(_browserHost->GetRequestContext()); +} + +CefMouseEvent CefBrowserHostWrapper::GetCefMouseEvent(MouseEvent mouseEvent) +{ + CefMouseEvent cefMouseEvent; + cefMouseEvent.x = mouseEvent.X; + cefMouseEvent.y = mouseEvent.Y; + cefMouseEvent.modifiers = (uint32)mouseEvent.Modifiers; + return cefMouseEvent; +} + +//Code imported from +//https://bitbucket.org/chromiumembedded/branches-2062-cef3/src/a073e92426b3967f1fc2f1d3fd7711d809eeb03a/tests/cefclient/cefclient_osr_widget_win.cpp?at=master#cl-361 +int CefBrowserHostWrapper::GetCefKeyboardModifiers(WPARAM wparam, LPARAM lparam) +{ + int modifiers = 0; + if (IsKeyDown(VK_SHIFT)) + modifiers |= EVENTFLAG_SHIFT_DOWN; + if (IsKeyDown(VK_CONTROL)) + modifiers |= EVENTFLAG_CONTROL_DOWN; + if (IsKeyDown(VK_MENU)) + modifiers |= EVENTFLAG_ALT_DOWN; + + // Low bit set from GetKeyState indicates "toggled". + if (::GetKeyState(VK_NUMLOCK) & 1) + modifiers |= EVENTFLAG_NUM_LOCK_ON; + if (::GetKeyState(VK_CAPITAL) & 1) + modifiers |= EVENTFLAG_CAPS_LOCK_ON; + + switch (wparam) + { + case VK_RETURN: + if ((lparam >> 16) & KF_EXTENDED) + modifiers |= EVENTFLAG_IS_KEY_PAD; + break; + case VK_INSERT: + case VK_DELETE: + case VK_HOME: + case VK_END: + case VK_PRIOR: + case VK_NEXT: + case VK_UP: + case VK_DOWN: + case VK_LEFT: + case VK_RIGHT: + if (!((lparam >> 16) & KF_EXTENDED)) + modifiers |= EVENTFLAG_IS_KEY_PAD; + break; + case VK_NUMLOCK: + case VK_NUMPAD0: + case VK_NUMPAD1: + case VK_NUMPAD2: + case VK_NUMPAD3: + case VK_NUMPAD4: + case VK_NUMPAD5: + case VK_NUMPAD6: + case VK_NUMPAD7: + case VK_NUMPAD8: + case VK_NUMPAD9: + case VK_DIVIDE: + case VK_MULTIPLY: + case VK_SUBTRACT: + case VK_ADD: + case VK_DECIMAL: + case VK_CLEAR: + modifiers |= EVENTFLAG_IS_KEY_PAD; + break; + case VK_SHIFT: + if (IsKeyDown(VK_LSHIFT)) + modifiers |= EVENTFLAG_IS_LEFT; + else if (IsKeyDown(VK_RSHIFT)) + modifiers |= EVENTFLAG_IS_RIGHT; + break; + case VK_CONTROL: + if (IsKeyDown(VK_LCONTROL)) + modifiers |= EVENTFLAG_IS_LEFT; + else if (IsKeyDown(VK_RCONTROL)) + modifiers |= EVENTFLAG_IS_RIGHT; + break; + case VK_MENU: + if (IsKeyDown(VK_LMENU)) + modifiers |= EVENTFLAG_IS_LEFT; + else if (IsKeyDown(VK_RMENU)) + modifiers |= EVENTFLAG_IS_RIGHT; + break; + case VK_LWIN: + modifiers |= EVENTFLAG_IS_LEFT; + break; + case VK_RWIN: + modifiers |= EVENTFLAG_IS_RIGHT; + break; + } + return modifiers; +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserHostWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserHostWrapper.h new file mode 100644 index 0000000..2f2cd09 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserHostWrapper.h @@ -0,0 +1,176 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "CefWrapper.h" + +using namespace System::Threading::Tasks; +using namespace CefSharp::Structs; +using namespace CefSharp::Enums; +using namespace CefSharp::Callback; + +namespace CefSharp +{ + namespace Internals + { + private ref class CefBrowserHostWrapper : public IBrowserHost, public CefWrapper + { + private: + MCefRefPtr _browserHost; + int _lastDevToolsMessageId = 0; + + double GetZoomLevelOnUI(); + + internal: + CefBrowserHostWrapper(CefRefPtr &browserHost) : _browserHost(browserHost) + { + } + + !CefBrowserHostWrapper() + { + _browserHost = nullptr; + } + + ~CefBrowserHostWrapper() + { + this->!CefBrowserHostWrapper(); + + _disposed = true; + } + + public: + virtual void StartDownload(String^ url); + virtual void Print(); + virtual void PrintToPdf(String^ path, PdfPrintSettings^ settings, IPrintToPdfCallback^ callback); + virtual void SetZoomLevel(double zoomLevel); + virtual double GetZoomLevel(); + virtual Task^ GetZoomLevelAsync(); + virtual IntPtr GetWindowHandle(); + virtual void CloseBrowser(bool forceClose); + virtual bool TryCloseBrowser(); + + virtual void DragTargetDragEnter(IDragData^ dragData, MouseEvent mouseEvent, DragOperationsMask allowedOperations); + virtual void DragTargetDragOver(MouseEvent mouseEvent, DragOperationsMask allowedOperations); + virtual void DragTargetDragDrop(MouseEvent mouseEvent); + virtual void DragSourceEndedAt(int x, int y, DragOperationsMask op); + virtual void DragTargetDragLeave(); + virtual void DragSourceSystemDragEnded(); + + virtual void ShowDevTools(IWindowInfo^ windowInfo, int inspectElementAtX, int inspectElementAtY); + virtual void CloseDevTools(); + /// + // Returns true if this browser currently has an associated DevTools browser. + // Must be called on the browser process UI thread. + /// + /*--cef()--*/ + virtual property bool HasDevTools + { + bool get(); + } + + virtual bool SendDevToolsMessage(String^ messageAsJson); + virtual int ExecuteDevToolsMethod(int messageId, String^ method, String^ paramsAsJson); + virtual int ExecuteDevToolsMethod(int messageId, String^ method, IDictionary^ paramaters); + virtual IRegistration^ AddDevToolsMessageObserver(IDevToolsMessageObserver^ observer); + virtual int GetNextDevToolsMessageId(); + + virtual void AddWordToDictionary(String^ word); + virtual void ReplaceMisspelling(String^ word); + + virtual property IExtension^ Extension + { + IExtension^ get(); + } + + virtual void RunFileDialog(CefFileDialogMode mode, String^ title, String^ defaultFilePath, IList^ acceptFilters, IRunFileDialogCallback^ callback); + + virtual void Find(String^ searchText, bool forward, bool matchCase, bool findNext); + virtual void StopFinding(bool clearSelection); + + virtual void SetFocus(bool focus); + virtual void SendFocusEvent(bool setFocus); + virtual void SendKeyEvent(KeyEvent keyEvent); + virtual void SendKeyEvent(int message, int wParam, int lParam); + + virtual void SendMouseWheelEvent(MouseEvent mouseEvent, int deltaX, int deltaY); + + virtual void SendTouchEvent(TouchEvent evt); + + virtual void Invalidate(PaintElementType type); + + virtual property bool IsBackgroundHost + { + bool get(); + } + + virtual void ImeSetComposition(String^ text, cli::array^ underlines, Nullable replacementRange, Nullable selectionRange); + virtual void ImeCommitText(String^ text, Nullable replacementRange, int relativeCursorPos); + virtual void ImeFinishComposingText(bool keepSelection); + virtual void ImeCancelComposition(); + + virtual void SendMouseClickEvent(MouseEvent mouseEvent, MouseButtonType mouseButtonType, bool mouseUp, int clickCount); + + virtual void SendMouseMoveEvent(MouseEvent mouseEvent, bool mouseLeave); + + virtual void SetAccessibilityState(CefState accessibilityState); + + virtual void SetAutoResizeEnabled(bool enabled, Size minSize, Size maxSize); + + virtual void NotifyMoveOrResizeStarted(); + + virtual void NotifyScreenInfoChanged(); + + virtual void WasResized(); + + virtual void WasHidden(bool hidden); + + virtual void GetNavigationEntries(INavigationEntryVisitor^ visitor, bool currentOnly); + + virtual NavigationEntry^ GetVisibleNavigationEntry(); + + virtual property int WindowlessFrameRate + { + int get(); + void set(int val); + } + + virtual property bool WindowRenderingDisabled + { + bool get(); + } + + virtual property bool IsAudioMuted + { + bool get(); + } + + virtual void SetAudioMuted(bool mute); + + virtual IntPtr GetOpenerWindowHandle(); + + virtual void SendExternalBeginFrame(); + + virtual void SendCaptureLostEvent(); + + virtual property IRequestContext^ RequestContext + { + IRequestContext^ get(); + } + + // Misc. private functions: + CefMouseEvent GetCefMouseEvent(MouseEvent mouseEvent); + int GetCefKeyboardModifiers(WPARAM wparam, LPARAM lparam); + + // Private keyboard functions: + bool IsKeyDown(WPARAM wparam) + { + return (GetKeyState(wparam) & 0x8000) != 0; + } + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserWrapper.cpp new file mode 100644 index 0000000..db2d802 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserWrapper.cpp @@ -0,0 +1,272 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" + +#include "Internals\CefFrameWrapper.h" +#include "Internals\CefBrowserWrapper.h" +#include "Internals\CefBrowserHostWrapper.h" + +bool CefBrowserWrapper::IsValid::get() +{ + ThrowIfDisposed(); + return _browser->IsValid(); +} + +/// +// Returns the browser host object. This method can only be called in the +// browser process. +/// +/*--cef()--*/ +IBrowserHost^ CefBrowserWrapper::GetHost() +{ + ThrowIfDisposed(); + + if (_browserHost == nullptr) + { + _browserHost = gcnew CefBrowserHostWrapper(_browser->GetHost()); + } + + return _browserHost; +} + +/// +// Returns true if the browser can navigate backwards. +/// +/*--cef()--*/ +bool CefBrowserWrapper::CanGoBack::get() +{ + ThrowIfDisposed(); + return _browser->CanGoBack(); +} + +/// +// Navigate backwards. +/// +/*--cef()--*/ +void CefBrowserWrapper::GoBack() +{ + ThrowIfDisposed(); + _browser->GoBack(); +} + +/// +// Returns true if the browser can navigate forwards. +/// +/*--cef()--*/ +bool CefBrowserWrapper::CanGoForward::get() +{ + ThrowIfDisposed(); + return _browser->CanGoForward(); +} + +/// +// Navigate forwards. +/// +/*--cef()--*/ +void CefBrowserWrapper::GoForward() +{ + ThrowIfDisposed(); + _browser->GoForward(); +} + +/// +// Returns true if the browser is currently loading. +/// +/*--cef()--*/ +bool CefBrowserWrapper::IsLoading::get() +{ + ThrowIfDisposed(); + return _browser->IsLoading(); +} + +void CefBrowserWrapper::CloseBrowser(bool forceClose) +{ + ThrowIfDisposed(); + _browser->GetHost()->CloseBrowser(forceClose); +} + +/// +// Reload the current page. +/// +/*--cef()--*/ +void CefBrowserWrapper::Reload(bool ignoreCache) +{ + ThrowIfDisposed(); + + if (ignoreCache) + { + _browser->ReloadIgnoreCache(); + } + else + { + _browser->Reload(); + } +} + +/// +// Stop loading the page. +/// +/*--cef()--*/ +void CefBrowserWrapper::StopLoad() +{ + ThrowIfDisposed(); + _browser->StopLoad(); +} + +/// +// Returns the globally unique identifier for this browser. +/// +/*--cef()--*/ +int CefBrowserWrapper::Identifier::get() +{ + ThrowIfDisposed(); + return _browser->GetIdentifier(); +} + +/// +// Returns true if this object is pointing to the same handle as |that| +// object. +/// +/*--cef()--*/ +bool CefBrowserWrapper::IsSame(IBrowser^ that) +{ + ThrowIfDisposed(); + return _browser->IsSame(dynamic_cast(that)->_browser.get()); +} + +/// +// Returns true if the window is a popup window. +/// +/*--cef()--*/ +bool CefBrowserWrapper::IsPopup::get() +{ + ThrowIfDisposed(); + return _browser->IsPopup(); +} + +/// +// Returns true if a document has been loaded in the browser. +/// +/*--cef()--*/ +bool CefBrowserWrapper::HasDocument::get() +{ + ThrowIfDisposed(); + return _browser->HasDocument(); +} + +IFrame^ CefBrowserWrapper::MainFrame::get() +{ + ThrowIfDisposed(); + + auto frame = _browser->GetMainFrame(); + + if (frame.get()) + { + return gcnew CefFrameWrapper(frame); + } + + return nullptr; +} + +/// +// Returns the focused frame for the browser window. +/// +/*--cef()--*/ +IFrame^ CefBrowserWrapper::FocusedFrame::get() +{ + ThrowIfDisposed(); + + auto frame = _browser->GetFocusedFrame(); + + if (frame.get()) + { + return gcnew CefFrameWrapper(frame); + } + + return nullptr; +} + +/// +// Returns the frame with the specified identifier, or NULL if not found. +/// +/*--cef(capi_name=get_frame_byident)--*/ +IFrame^ CefBrowserWrapper::GetFrame(Int64 identifier) +{ + ThrowIfDisposed(); + + auto frame = _browser->GetFrame(identifier); + + if (frame.get()) + { + return gcnew CefFrameWrapper(frame); + } + + return nullptr; +} + +/// +// Returns the frame with the specified name, or NULL if not found. +/// +/*--cef(optional_param=name)--*/ +IFrame^ CefBrowserWrapper::GetFrame(String^ name) +{ + ThrowIfDisposed(); + + auto frame = _browser->GetFrame(StringUtils::ToNative(name)); + + if (frame.get()) + { + return gcnew CefFrameWrapper(frame); + } + + return nullptr; +} + +/// +// Returns the number of frames that currently exist. +/// +/*--cef()--*/ +int CefBrowserWrapper::GetFrameCount() +{ + ThrowIfDisposed(); + return static_cast(_browser->GetFrameCount()); +} + +/// +// Returns the identifiers of all existing frames. +/// +/*--cef(count_func=identifiers:GetFrameCount)--*/ +List^ CefBrowserWrapper::GetFrameIdentifiers() +{ + ThrowIfDisposed(); + + std::vector identifiers; + _browser->GetFrameIdentifiers(identifiers); + List^ results = gcnew List(static_cast(identifiers.size())); + for (UINT i = 0; i < identifiers.size(); i++) + { + results->Add(identifiers[i]); + } + return results; +} + +/// +// Returns the names of all existing frames. +/// +/*--cef()--*/ +List^ CefBrowserWrapper::GetFrameNames() +{ + ThrowIfDisposed(); + + std::vector names; + + _browser->GetFrameNames(names); + return StringUtils::ToClr(names); +} + +MCefRefPtr CefBrowserWrapper::Browser::get() +{ + return _browser; +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserWrapper.h new file mode 100644 index 0000000..0d0fd89 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefBrowserWrapper.h @@ -0,0 +1,196 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include +#include "CefWrapper.h" + +namespace CefSharp +{ + namespace Internals + { + private ref class CefBrowserWrapper : public IBrowser, public CefWrapper + { + private: + MCefRefPtr _browser; + IBrowserHost^ _browserHost; + + internal: + CefBrowserWrapper::CefBrowserWrapper(CefRefPtr &browser) + : _browser(browser), _browserHost(nullptr) + { + } + + !CefBrowserWrapper() + { + // Release the reference. + _browser = nullptr; + } + + ~CefBrowserWrapper() + { + this->!CefBrowserWrapper(); + delete _browserHost; + _browserHost = nullptr; + _disposed = true; + } + + virtual property MCefRefPtr Browser + { + MCefRefPtr get(); + } + + public: + virtual property bool IsValid + { + bool get(); + } + + /// + // Returns the browser host object. This method can only be called in the + // browser process. + /// + /*--cef()--*/ + virtual IBrowserHost^ GetHost(); + + /// + // Returns true if the browser can navigate backwards. + /// + /*--cef()--*/ + virtual property bool CanGoBack + { + bool get(); + } + + /// + // Navigate backwards. + /// + /*--cef()--*/ + virtual void GoBack(); + + /// + // Returns true if the browser can navigate forwards. + /// + /*--cef()--*/ + virtual property bool CanGoForward + { + bool get(); + } + + /// + // Navigate forwards. + /// + /*--cef()--*/ + virtual void GoForward(); + + /// + // Returns true if the browser is currently loading. + /// + /*--cef()--*/ + virtual property bool IsLoading + { + bool get(); + } + + virtual void CloseBrowser(bool forceClose); + + /// + // Reload the current page. + /// + /*--cef()--*/ + virtual void Reload(bool ignoreCache); + + /// + // Stop loading the page. + /// + /*--cef()--*/ + virtual void StopLoad(); + + /// + // Returns the globally unique identifier for this browser. + /// + /*--cef()--*/ + virtual property int Identifier + { + int get(); + } + + /// + // Returns true if this object is pointing to the same handle as |that| + // object. + /// + /*--cef()--*/ + virtual bool IsSame(IBrowser^ that); + + /// + // Returns true if the window is a popup window. + /// + /*--cef()--*/ + virtual property bool IsPopup + { + bool get(); + } + + /// + // Returns true if a document has been loaded in the browser. + /// + /*--cef()--*/ + virtual property bool HasDocument + { + bool get(); + } + + /// + // Returns the main (top-level) frame for the browser window. + /// + /*--cef()--*/ + virtual property IFrame^ MainFrame + { + IFrame^ get(); + } + + /// + // Returns the focused frame for the browser window. + /// + /*--cef()--*/ + virtual property IFrame^ FocusedFrame + { + IFrame^ get(); + } + + /// + // Returns the frame with the specified identifier, or NULL if not found. + /// + /*--cef(capi_name=get_frame_byident)--*/ + virtual IFrame^ GetFrame(Int64 identifier); + + /// + // Returns the frame with the specified name, or NULL if not found. + /// + /*--cef(optional_param=name)--*/ + virtual IFrame^ GetFrame(String^ name); + + /// + // Returns the number of frames that currently exist. + /// + /*--cef()--*/ + virtual int GetFrameCount(); + + /// + // Returns the identifiers of all existing frames. + /// + /*--cef(count_func=identifiers:GetFrameCount)--*/ + virtual List^ GetFrameIdentifiers(); + + /// + // Returns the names of all existing frames. + /// + /*--cef()--*/ + virtual List^ GetFrameNames(); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCallbackWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCallbackWrapper.h new file mode 100644 index 0000000..7587f82 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCallbackWrapper.h @@ -0,0 +1,59 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_callback.h" +#include "CefWrapper.h" + +namespace CefSharp +{ + namespace Internals + { + private ref class CefCallbackWrapper : public ICallback, public CefWrapper + { + private: + MCefRefPtr _callback; + + public: + CefCallbackWrapper(CefRefPtr &callback) : + _callback(callback) + { + + } + + !CefCallbackWrapper() + { + _callback = nullptr; + } + + ~CefCallbackWrapper() + { + this->!CefCallbackWrapper(); + + _disposed = true; + } + + virtual void Cancel() + { + ThrowIfDisposed(); + + _callback->Cancel(); + + delete this; + } + + virtual void Continue() + { + ThrowIfDisposed(); + + _callback->Continue(); + + delete this; + } + }; + } +} \ No newline at end of file diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCertificateCallbackWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCertificateCallbackWrapper.h new file mode 100644 index 0000000..ef8940f --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCertificateCallbackWrapper.h @@ -0,0 +1,98 @@ +// Copyright © 2016 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_request_handler.h" +#include "CefWrapper.h" + +using namespace System::Security::Cryptography::X509Certificates; + +namespace CefSharp +{ + namespace Internals + { + private ref class CefCertificateCallbackWrapper : public ISelectClientCertificateCallback, public CefWrapper + { + private: + MCefRefPtr _callback; + const CefRequestHandler::X509CertificateList& _certificateList; + + public: + CefCertificateCallbackWrapper(CefRefPtr& callback, const CefRequestHandler::X509CertificateList& certificates) + : _callback(callback), _certificateList(certificates) + { + + } + + !CefCertificateCallbackWrapper() + { + _callback = nullptr; + } + + ~CefCertificateCallbackWrapper() + { + this->!CefCertificateCallbackWrapper(); + + _disposed = true; + } + + virtual void Select(X509Certificate2^ cert) + { + ThrowIfDisposed(); + + if (cert == nullptr) + { + _callback->Select(nullptr); + } + else + { + auto certSerial = cert->SerialNumber; + + std::vector>::const_iterator it = + _certificateList.begin(); + for (; it != _certificateList.end(); ++it) + { + + // TODO: Need to make this logic of comparing serial number of the certificate (*it) + // with the selected certificate returned by the user selection (cert). + // Better and more performant way would be to read the serial number from + // (*it) and convert it into System::String, so that it can directly compared + // with certSerial. This is how I tried it but the Encoding class garbled up + // the string when converting it from CefRefPtr to System::String + // Try to find a better way to do this + // + //auto serialNum((*it)->GetSerialNumber()); + //auto byteSize = serialNum->GetSize(); + //auto bufferByte = gcnew cli::array(byteSize); + //pin_ptr src = &bufferByte[0]; // pin pointer to first element in arr + //serialNum->GetData(static_cast(src), byteSize, 0); + //UTF8Encoding^ encoding = gcnew UTF8Encoding; + //auto serialStr(encoding->GetString(bufferByte)); + + auto bytes((*it)->GetDEREncoded()); + auto byteSize = bytes->GetSize(); + + auto bufferByte = gcnew cli::array(byteSize); + pin_ptr src = &bufferByte[0]; // pin pointer to first element in arr + + bytes->GetData(static_cast(src), byteSize, 0); + auto newcert = gcnew System::Security::Cryptography::X509Certificates::X509Certificate2(bufferByte); + auto serialStr = newcert->SerialNumber; + + if (certSerial == serialStr) + { + _callback->Select(*it); + break; + } + } + } + + delete this; + } + }; + } +} \ No newline at end of file diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCompletionCallbackAdapter.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCompletionCallbackAdapter.h new file mode 100644 index 0000000..410d11c --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCompletionCallbackAdapter.h @@ -0,0 +1,39 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include\cef_callback.h" + +namespace CefSharp +{ + namespace Internals + { + private class CefCompletionCallbackAdapter : public CefCompletionCallback + { + private: + gcroot _handler; + + public: + CefCompletionCallbackAdapter(ICompletionCallback^ handler) + { + _handler = handler; + } + + ~CefCompletionCallbackAdapter() + { + delete _handler; + _handler = nullptr; + } + + void OnComplete() override + { + _handler->OnComplete(); + } + + IMPLEMENT_REFCOUNTINGM(CefCompletionCallbackAdapter); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefContextMenuParamsWrapper.cpp b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefContextMenuParamsWrapper.cpp new file mode 100644 index 0000000..7259b17 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefContextMenuParamsWrapper.cpp @@ -0,0 +1,148 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#include "Stdafx.h" +#include "CefContextMenuParamsWrapper.h" + +namespace CefSharp +{ + namespace Internals + { + int CefContextMenuParamsWrapper::YCoord::get() + { + ThrowIfDisposed(); + + return _wrappedInfo->GetYCoord(); + } + + int CefContextMenuParamsWrapper::XCoord::get() + { + ThrowIfDisposed(); + + return _wrappedInfo->GetXCoord(); + } + + ContextMenuType CefContextMenuParamsWrapper::TypeFlags::get() + { + ThrowIfDisposed(); + + return (ContextMenuType)_wrappedInfo->GetTypeFlags(); + } + + String^ CefContextMenuParamsWrapper::LinkUrl::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetLinkUrl()); + } + + String^ CefContextMenuParamsWrapper::UnfilteredLinkUrl::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetUnfilteredLinkUrl()); + } + + String^ CefContextMenuParamsWrapper::SourceUrl::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetSourceUrl()); + } + + bool CefContextMenuParamsWrapper::HasImageContents::get() + { + ThrowIfDisposed(); + + return _wrappedInfo->HasImageContents(); + } + + String^ CefContextMenuParamsWrapper::PageUrl::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetPageUrl()); + } + + String^ CefContextMenuParamsWrapper::FrameUrl::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetFrameUrl()); + } + + String^ CefContextMenuParamsWrapper::FrameCharset::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetFrameCharset()); + } + + ContextMenuMediaType CefContextMenuParamsWrapper::MediaType::get() + { + ThrowIfDisposed(); + + return (ContextMenuMediaType)_wrappedInfo->GetMediaType(); + } + + ContextMenuMediaState CefContextMenuParamsWrapper::MediaStateFlags::get() + { + ThrowIfDisposed(); + + return (ContextMenuMediaState)_wrappedInfo->GetMediaStateFlags(); + } + + String^ CefContextMenuParamsWrapper::SelectionText::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetSelectionText()); + } + + String^ CefContextMenuParamsWrapper::MisspelledWord::get() + { + ThrowIfDisposed(); + + return StringUtils::ToClr(_wrappedInfo->GetMisspelledWord()); + } + + List^ CefContextMenuParamsWrapper::DictionarySuggestions::get() + { + ThrowIfDisposed(); + + std::vector& dictionarySuggestions = std::vector(); + bool result = _wrappedInfo->GetDictionarySuggestions(dictionarySuggestions); + + return StringUtils::ToClr(dictionarySuggestions); + } + + bool CefContextMenuParamsWrapper::IsEditable::get() + { + ThrowIfDisposed(); + + return _wrappedInfo->IsEditable(); + } + + bool CefContextMenuParamsWrapper::IsSpellCheckEnabled::get() + { + ThrowIfDisposed(); + + return _wrappedInfo->IsSpellCheckEnabled(); + } + + ContextMenuEditState CefContextMenuParamsWrapper::EditStateFlags::get() + { + ThrowIfDisposed(); + + return (ContextMenuEditState)_wrappedInfo->GetEditStateFlags(); + } + + bool CefContextMenuParamsWrapper::IsCustomMenu::get() + { + ThrowIfDisposed(); + + return _wrappedInfo->IsCustomMenu(); + } + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefContextMenuParamsWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefContextMenuParamsWrapper.h new file mode 100644 index 0000000..0ac01ee --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefContextMenuParamsWrapper.h @@ -0,0 +1,62 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "CefWrapper.h" + +#include "include\cef_context_menu_handler.h" + +using namespace System::Collections::Generic; + +namespace CefSharp +{ + namespace Internals + { + private ref class CefContextMenuParamsWrapper : public IContextMenuParams, public CefWrapper + { + MCefRefPtr _wrappedInfo; + + internal: + CefContextMenuParamsWrapper(CefRefPtr &cefParams) : + _wrappedInfo(cefParams) + { + } + + !CefContextMenuParamsWrapper() + { + _wrappedInfo = nullptr; + } + + ~CefContextMenuParamsWrapper() + { + this->!CefContextMenuParamsWrapper(); + + _disposed = true; + } + + public: + virtual property int YCoord { int get(); } + virtual property int XCoord { int get(); } + virtual property ContextMenuType TypeFlags { ContextMenuType get(); } + virtual property String^ LinkUrl { String^ get(); } + virtual property String^ UnfilteredLinkUrl { String^ get(); } + virtual property String^ SourceUrl { String^ get(); } + virtual property bool HasImageContents { bool get(); } + virtual property String^ PageUrl { String^ get(); } + virtual property String^ FrameUrl { String^ get(); } + virtual property String^ FrameCharset { String^ get(); } + virtual property ContextMenuMediaType MediaType { ContextMenuMediaType get(); } + virtual property ContextMenuMediaState MediaStateFlags { ContextMenuMediaState get(); } + virtual property String^ SelectionText { String^ get(); } + virtual property String^ MisspelledWord { String^ get(); } + virtual property List^ DictionarySuggestions { List^ get(); } + virtual property bool IsEditable { bool get(); } + virtual property bool IsSpellCheckEnabled { bool get(); } + virtual property ContextMenuEditState EditStateFlags { ContextMenuEditState get(); } + virtual property bool IsCustomMenu { bool get(); } + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCookieAccessFilterAdapter.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCookieAccessFilterAdapter.h new file mode 100644 index 0000000..943902e --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCookieAccessFilterAdapter.h @@ -0,0 +1,82 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include\cef_resource_request_handler.h" + +#include "CefResponseWrapper.h" +#include "Request.h" +#include "CefFrameWrapper.h" +#include "CefBrowserWrapper.h" + +using namespace CefSharp::Core; + +namespace CefSharp +{ + namespace Internals + { + private class CefCookieAccessFilterAdapter : public CefCookieAccessFilter + { + private: + gcroot _handler; + gcroot _browserControl; + + public: + CefCookieAccessFilterAdapter(ICookieAccessFilter^ handler, IWebBrowser^ browserControl) + { + _handler = handler; + _browserControl = browserControl; + } + + ~CefCookieAccessFilterAdapter() + { + delete _handler; + _handler = nullptr; + _browserControl = nullptr; + } + + + bool CanSendCookie(CefRefPtr browser, CefRefPtr frame, CefRefPtr request, const CefCookie& cookie) override + { + Request requestWrapper(request); + auto managedCookie = TypeConversion::FromNative(cookie); + + //For ServiceWorker browser and frame will be null + if (browser.get() && frame.get()) + { + + CefBrowserWrapper browserWrapper(browser); + CefFrameWrapper frameWrapper(frame); + + return _handler->CanSendCookie(_browserControl, %browserWrapper, %frameWrapper, %requestWrapper, managedCookie); + } + + return _handler->CanSendCookie(_browserControl, nullptr, nullptr, %requestWrapper, managedCookie); + } + + bool CanSaveCookie(CefRefPtr browser, CefRefPtr frame, CefRefPtr request, CefRefPtr response, const CefCookie& cookie) override + { + Request requestWrapper(request); + CefResponseWrapper responseWrapper(response); + auto managedCookie = TypeConversion::FromNative(cookie); + + //For ServiceWorker browser and frame will be null + if (browser.get() && frame.get()) + { + + CefBrowserWrapper browserWrapper(browser); + CefFrameWrapper frameWrapper(frame); + + return _handler->CanSaveCookie(_browserControl, %browserWrapper, %frameWrapper, %requestWrapper, %responseWrapper, managedCookie); + } + + return _handler->CanSaveCookie(_browserControl, nullptr, nullptr, %requestWrapper, %responseWrapper, managedCookie); + } + + IMPLEMENT_REFCOUNTINGM(CefCookieAccessFilterAdapter); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCookieVisitorAdapter.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCookieVisitorAdapter.h new file mode 100644 index 0000000..0a4af57 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefCookieVisitorAdapter.h @@ -0,0 +1,43 @@ +// Copyright © 2012 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "TypeConversion.h" +#include "include/cef_cookie.h" + + +namespace CefSharp +{ + namespace Internals + { + private class CefCookieVisitorAdapter : public CefCookieVisitor + { + private: + gcroot _visitor; + + public: + CefCookieVisitorAdapter(ICookieVisitor^ visitor) : + _visitor(visitor) + { + } + + ~CefCookieVisitorAdapter() + { + delete _visitor; + _visitor = nullptr; + } + + virtual bool Visit(const CefCookie& cefCookie, int count, int total, bool& deleteCookie) override + { + auto cookie = TypeConversion::FromNative(cefCookie); + + return _visitor->Visit(cookie, count, total, deleteCookie); + } + + IMPLEMENT_REFCOUNTINGM(CefCookieVisitorAdapter); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDeleteCookiesCallbackAdapter.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDeleteCookiesCallbackAdapter.h new file mode 100644 index 0000000..bf0d2d9 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDeleteCookiesCallbackAdapter.h @@ -0,0 +1,40 @@ +// Copyright © 2017 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include/cef_cookie.h" + +namespace CefSharp +{ + namespace Internals + { + private class CefDeleteCookiesCallbackAdapter : public CefDeleteCookiesCallback + { + private: + gcroot _handler; + + public: + CefDeleteCookiesCallbackAdapter(IDeleteCookiesCallback^ handler) + { + _handler = handler; + } + + ~CefDeleteCookiesCallbackAdapter() + { + delete _handler; + _handler = nullptr; + } + + void OnComplete(int numDeleted) override + { + _handler->OnComplete(numDeleted); + } + + IMPLEMENT_REFCOUNTINGM(CefDeleteCookiesCallbackAdapter); + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDevToolsMessageObserverAdapter.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDevToolsMessageObserverAdapter.h new file mode 100644 index 0000000..fea1ff5 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDevToolsMessageObserverAdapter.h @@ -0,0 +1,82 @@ +// Copyright © 2014 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" +#include "include\cef_callback.h" + +#include "CefBrowserWrapper.h" +#include "StringUtils.h" + +using namespace CefSharp::Callback; +using namespace System::IO; + +namespace CefSharp +{ + namespace Internals + { + private class CefDevToolsMessageObserverAdapter : public CefDevToolsMessageObserver + { + private: + gcroot _handler; + + public: + CefDevToolsMessageObserverAdapter(IDevToolsMessageObserver^ handler) + { + _handler = handler; + } + + ~CefDevToolsMessageObserverAdapter() + { + delete _handler; + _handler = nullptr; + } + + virtual bool OnDevToolsMessage(CefRefPtr browser, const void* message, size_t message_size) + { + CefBrowserWrapper browserWrapper(browser); + UnmanagedMemoryStream messageStream((Byte*)message, (Int64)message_size, (Int64)message_size, FileAccess::Read); + + return _handler->OnDevToolsMessage(%browserWrapper, %messageStream); + } + + virtual void OnDevToolsMethodResult(CefRefPtr browser, + int message_id, + bool success, + const void* result, + size_t result_size) override + { + CefBrowserWrapper browserWrapper(browser); + UnmanagedMemoryStream resultStream((Byte*)result, (Int64)result_size, (Int64)result_size, FileAccess::Read); + + _handler->OnDevToolsMethodResult(%browserWrapper, message_id, success, %resultStream); + } + + virtual void OnDevToolsEvent(CefRefPtr browser, const CefString& method, const void* params, size_t params_size) override + { + CefBrowserWrapper browserWrapper(browser); + UnmanagedMemoryStream paramsStream((Byte*)params, (Int64)params_size, (Int64)params_size, FileAccess::Read); + + _handler->OnDevToolsEvent(%browserWrapper, StringUtils::ToClr(method), %paramsStream); + } + + void OnDevToolsAgentAttached(CefRefPtr browser) override + { + CefBrowserWrapper browserWrapper(browser); + + _handler->OnDevToolsAgentAttached(%browserWrapper); + } + + void OnDevToolsAgentDetached(CefRefPtr browser) override + { + CefBrowserWrapper browserWrapper(browser); + + _handler->OnDevToolsAgentDetached(%browserWrapper); + } + + IMPLEMENT_REFCOUNTINGM(CefDevToolsMessageObserverAdapter); + }; + } +} diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDownloadItemCallbackWrapper.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDownloadItemCallbackWrapper.h new file mode 100644 index 0000000..6a6e594 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefDownloadItemCallbackWrapper.h @@ -0,0 +1,69 @@ +// Copyright © 2015 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_download_handler.h" + +#include "CefWrapper.h" + +namespace CefSharp +{ + namespace Internals + { + private ref class CefDownloadItemCallbackWrapper : public IDownloadItemCallback, public CefWrapper + { + private: + MCefRefPtr _callback; + + public: + CefDownloadItemCallbackWrapper(CefRefPtr &callback) + : _callback(callback) + { + } + + !CefDownloadItemCallbackWrapper() + { + _callback = nullptr; + } + + ~CefDownloadItemCallbackWrapper() + { + this->!CefDownloadItemCallbackWrapper(); + + _disposed = true; + } + + virtual void Cancel() + { + ThrowIfDisposed(); + + _callback->Cancel(); + + delete this; + } + + virtual void Pause() + { + ThrowIfDisposed(); + + //Only free the callback when cancel called + //Need to be able to pause/resume #3145 + _callback->Pause(); + } + + virtual void Resume() + { + ThrowIfDisposed(); + + //Only free the callback when cancel called + //Need to be able to pause/resume #3145 + _callback->Resume(); + } + }; + } +} + diff --git a/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefExtensionHandlerAdapter.h b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefExtensionHandlerAdapter.h new file mode 100644 index 0000000..14fa527 --- /dev/null +++ b/packages/CefSharp.Common.113.1.40/src/CefSharp.Core.Runtime/Internals/CefExtensionHandlerAdapter.h @@ -0,0 +1,214 @@ +// Copyright © 2018 The CefSharp Authors. All rights reserved. +// +// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. + +#pragma once + +#include "Stdafx.h" + +#include "include\cef_extension.h" +#include "include\cef_extension_handler.h" +#include "BrowserSettings.h" +#include "CefExtensionWrapper.h" +#include "CefBrowserWrapper.h" +#include "CefGetExtensionResourceCallbackWrapper.h" +#include "WindowInfo.h" + +using namespace CefSharp; + +namespace CefSharp +{ + namespace Internals + { + private class CefExtensionHandlerAdapter : public CefExtensionHandler + { + gcroot _handler; + + public: + CefExtensionHandlerAdapter(IExtensionHandler^ handler) + : _handler(handler) + { + } + + ~CefExtensionHandlerAdapter() + { + delete _handler; + _handler = nullptr; + } + + /// + // Called if the CefRequestContext::LoadExtension request fails. |result| will + // be the error code. + /// + /*--cef()--*/ + void OnExtensionLoadFailed(cef_errorcode_t result) override + { + _handler->OnExtensionLoadFailed((CefErrorCode)result); + } + + /// + // Called if the CefRequestContext::LoadExtension request succeeds. + // |extension| is the loaded extension. + /// + /*--cef()--*/ + void OnExtensionLoaded(CefRefPtr extension) override + { + //TODO: Should this be auto disposed? + _handler->OnExtensionLoaded(gcnew CefExtensionWrapper(extension)); + } + + /// + // Called after the CefExtension::Unload request has completed. + /// + /*--cef()--*/ + void OnExtensionUnloaded(CefRefPtr extension) override + { + //TODO: Add comment to interface saying extension is only valid within the scope + //of this method as it's auto disposed + CefExtensionWrapper wrapper(extension); + _handler->OnExtensionUnloaded(%wrapper); + } + + /// + // Called when an extension needs a browser to host a background script + // specified via the "background" manifest key. The browser will have no + // visible window and cannot be displayed. |extension| is the extension that + // is loading the background script. |url| is an internally generated + // reference to an HTML page that will be used to load the background script + // via a