Chromium 中chrome.webRequest扩展接口定义c++

打印 上一主题 下一主题

主题 828|帖子 828|积分 2484

一、chrome.webRequest

留意:从 Manifest V3 开始,"webRequestBlocking"权限不再适用于大多数扩展程序。以"declarativeNetRequest"为例,它答应利用declarativeNetRequest API。除了"webRequestBlocking"之外,webRequest API 保持稳固,仍可正常利用。通过政策安装的扩展程序可以继承利用"webRequestBlocking"。
利用chrome.webRequestAPI 可观察和分析流量,以及拦截、阻止或修改传输中的请求。
权限

webRequest
您必须在扩展程序清单中声明"webRequest"权限,才气利用 Web 请求 API 以及必要的主机权限。要拦截子资源请求, 扩展程序必须同时有权访问请求的网址及其发起者。例如:
  1. {
  2.   "name": "My extension",
  3.   ...
  4.   "permissions": [
  5.     "webRequest"
  6.   ],
  7.   "host_permissions": [
  8.     "*://*.google.com/*"
  9.   ],
  10.   ...
  11. }
复制代码
webRequestBlocking
必须填写此字段,才气注册屏蔽事件处理惩罚脚本。从 Manifest V3 开始, 适用于通过政策安装的扩展程序
webRequestAuthProvider
利用onAuthRequired方法的必须条件。请参阅处理惩罚身份验证。
请求的生命周期

Web 请求 API 定义了一组遵照 Web 请求生命周期的事件。您可以利用 来观察和分析流量。某些同步事件答应您拦截、 屏蔽或修改请求
乐成请求的事件生命周期如下所示,其后是事件定义:

更多参考chrome.webRequest ?|? API ?|? Chrome for Developers
二、chrome.webRequest c++接口定义:

1、web_request.json接口描述文件:

extensionscommonapiweb_request.json
  1. // Copyright 2012 The Chromium Authors
  2. // Use of this source code is governed by a BSD-style license that can be
  3. // found in the LICENSE file.
  4. [
  5.   {
  6.     "namespace": "webRequest",
  7.     "description": "Use the <code>chrome.webRequest</code> API to observe and analyze traffic and to intercept, block, or modify requests in-flight.",
  8.     "properties": {
  9.       "MAX_HANDLER_BEHAVIOR_CHANGED_CALLS_PER_10_MINUTES": {
  10.         "value": 20,
  11.         "description": "The maximum number of times that <code>handlerBehaviorChanged</code> can be called per 10 minute sustained interval. <code>handlerBehaviorChanged</code> is an expensive function call that shouldn't be called often."
  12.       }
  13.     },
  14.     "types": [
  15.       {
  16.         "id": "ResourceType",
  17.         "type": "string",
  18.         "enum": [
  19.           {"name": "main_frame", "description": "Specifies the resource as the main frame."},
  20.           {"name": "sub_frame", "description": "Specifies the resource as a sub frame."},
  21.           {"name":  "stylesheet", "description": "Specifies the resource as a stylesheet."},
  22.           {"name": "script", "description": "Specifies the resource as a script."},
  23.           {"name": "image", "description": "Specifies the resource as an image."},
  24.           {"name": "font", "description": "Specifies the resource as a font."},
  25.           {"name": "object", "description": "Specifies the resource as an object."},
  26.           {"name": "xmlhttprequest",
  27.            "description": "Specifies the resource as an XMLHttpRequest."},
  28.           {"name": "ping",
  29.            "description": "Specifies the resource as a ping."},
  30.           {"name": "csp_report",
  31.           "description": "Specifies the resource as a Content Security Policy (CSP) report."},
  32.           {"name": "media", "description": "Specifies the resource as a media object."},
  33.           {"name": "websocket", "description": "Specifies the resource as a WebSocket."},
  34.           {"name": "webbundle", "description": "Specifies the resource as a WebBundle."},
  35.           {"name": "other", "description": "Specifies the resource as a type not included in the listed types."}
  36.         ]
  37.       },
  38.       {
  39.         "id": "OnBeforeRequestOptions",
  40.         "type": "string",
  41.         "enum": [
  42.           {"name": "blocking", "description": "Specifies the request is blocked until the callback function returns."},
  43.           {"name": "requestBody", "description": "Specifies that the request body should be included in the event."},
  44.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  45.         ]
  46.       },
  47.       {
  48.         "id": "OnBeforeSendHeadersOptions",
  49.         "type": "string",
  50.         "enum": [
  51.           {"name": "requestHeaders", "description": "Specifies that the request header should be included in the event."},
  52.           {"name": "blocking", "description": "Specifies the request is blocked until the callback function returns."},
  53.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  54.         ]
  55.       },
  56.       {
  57.         "id": "OnSendHeadersOptions",
  58.         "type": "string",
  59.         "enum": [
  60.           {"name": "requestHeaders", "description": "Specifies that the request header should be included in the event."},
  61.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  62.         ]
  63.       },
  64.       {
  65.         "id": "OnHeadersReceivedOptions",
  66.         "type": "string",
  67.         "enum": [
  68.           {"name": "blocking", "description": "Specifies the request is blocked until the callback function returns."},
  69.           {"name": "responseHeaders", "description": "Specifies that the response headers should be included in the event."},
  70.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  71.         ]
  72.       },
  73.       {
  74.         "id": "OnAuthRequiredOptions",
  75.         "type": "string",
  76.         "enum": [
  77.           {"name": "responseHeaders", "description": "Specifies that the response headers should be included in the event."},
  78.           {"name": "blocking", "description": "Specifies the request is blocked until the callback function returns."},
  79.           {"name": "asyncBlocking", "description": "Specifies that the callback function is handled asynchronously."},
  80.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  81.         ]
  82.       },
  83.       {
  84.         "id": "OnResponseStartedOptions",
  85.         "type": "string",
  86.         "enum": [
  87.           {"name": "responseHeaders", "description": "Specifies that the response headers should be included in the event."},
  88.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  89.         ]
  90.       },
  91.       {
  92.         "id": "OnBeforeRedirectOptions",
  93.         "type": "string",
  94.         "enum": [
  95.           {"name": "responseHeaders", "description": "Specifies that the response headers should be included in the event."},
  96.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  97.         ]
  98.       },
  99.       {
  100.         "id": "OnCompletedOptions",
  101.         "type": "string",
  102.         "enum": [
  103.           {"name": "responseHeaders", "description": "Specifies that the response headers should be included in the event."},
  104.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  105.         ]
  106.       },
  107.       {
  108.         "id": "OnErrorOccurredOptions",
  109.         "type": "string",
  110.         "enum": [
  111.           {"name": "extraHeaders", "description": "Specifies that headers can violate Cross-Origin Resource Sharing (CORS)."}
  112.         ]
  113.       },
  114.       {
  115.         "id": "RequestFilter",
  116.         "type": "object",
  117.         "description": "An object describing filters to apply to webRequest events.",
  118.         "properties": {
  119.           "urls": {
  120.             "type": "array",
  121.             "description": "A list of URLs or URL patterns. Requests that cannot match any of the URLs will be filtered out.",
  122.             "items": { "type": "string" }
  123.           },
  124.           "types": {
  125.             "type": "array",
  126.             "optional": true,
  127.             "description": "A list of request types. Requests that cannot match any of the types will be filtered out.",
  128.             "items": { "$ref": "ResourceType" }
  129.           },
  130.           "tabId": { "type": "integer", "optional": true },
  131.           "windowId": { "type": "integer", "optional": true }
  132.         }
  133.       },
  134.       {
  135.         "id": "HttpHeaders",
  136.         "nocompile": true,
  137.         "type": "array",
  138.         "description": "An array of HTTP headers. Each header is represented as a dictionary containing the keys <code>name</code> and either <code>value</code> or <code>binaryValue</code>.",
  139.         "items": {
  140.           "type": "object",
  141.           "properties": {
  142.             "name": {"type": "string", "description": "Name of the HTTP header."},
  143.             "value": {"type": "string", "optional": true, "description": "Value of the HTTP header if it can be represented by UTF-8."},
  144.             "binaryValue": {
  145.               "type": "array",
  146.               "optional": true,
  147.               "description": "Value of the HTTP header if it cannot be represented by UTF-8, stored as individual byte values (0..255).",
  148.               "items": {"type": "integer"}
  149.             }
  150.           }
  151.         }
  152.       },
  153.       {
  154.         "id": "BlockingResponse",
  155.         "nocompile": true,
  156.         "type": "object",
  157.         "description": "Returns value for event handlers that have the 'blocking' extraInfoSpec applied. Allows the event handler to modify network requests.",
  158.         "properties": {
  159.           "cancel": {
  160.             "type": "boolean",
  161.             "optional": true,
  162.             "description": "If true, the request is cancelled. This prevents the request from being sent. This can be used as a response to the onBeforeRequest, onBeforeSendHeaders, onHeadersReceived and onAuthRequired events."
  163.           },
  164.           "redirectUrl": {
  165.             "type": "string",
  166.             "optional": true,
  167.             "description": "Only used as a response to the onBeforeRequest and onHeadersReceived events. If set, the original request is prevented from being sent/completed and is instead redirected to the given URL. Redirections to non-HTTP schemes such as <code>data:</code> are allowed. Redirects initiated by a redirect action use the original request method for the redirect, with one exception: If the redirect is initiated at the onHeadersReceived stage, then the redirect will be issued using the GET method. Redirects from URLs with <code>ws://</code> and <code>wss://</code> schemes are <b>ignored</b>."
  168.           },
  169.           "requestHeaders": {
  170.             "$ref": "HttpHeaders",
  171.             "optional": true,
  172.             "description": "Only used as a response to the onBeforeSendHeaders event. If set, the request is made with these request headers instead."
  173.           },
  174.           "responseHeaders": {
  175.             "$ref": "HttpHeaders",
  176.             "optional": true,
  177.             "description": "Only used as a response to the onHeadersReceived event. If set, the server is assumed to have responded with these response headers instead. Only return <code>responseHeaders</code> if you really want to modify the headers in order to limit the number of conflicts (only one extension may modify <code>responseHeaders</code> for each request)."
  178.           },
  179.           "authCredentials": {
  180.             "type": "object",
  181.             "description": "Only used as a response to the onAuthRequired event. If set, the request is made using the supplied credentials.",
  182.             "optional": true,
  183.             "properties": {
  184.               "username": {"type": "string"},
  185.               "password": {"type": "string"}
  186.             }
  187.           }
  188.         }
  189.       },
  190.       {
  191.         "id": "UploadData",
  192.         "type": "object",
  193.         "properties": {
  194.           "bytes": {
  195.             "type": "any",
  196.             "optional": true,
  197.             "description": "An ArrayBuffer with a copy of the data."
  198.           },
  199.           "file": {
  200.             "type": "string",
  201.             "optional": true,
  202.             "description": "A string with the file's path and name."
  203.           }
  204.         },
  205.         "description": "Contains data uploaded in a URL request."
  206.       },
  207.       {
  208.         "id": "FormDataItem",
  209.         "choices": [
  210.           { "type": "binary" },
  211.           { "type": "string" }
  212.         ],
  213.         "description": "Contains data passed within form data. For urlencoded form it is stored as string if data is utf-8 string and as ArrayBuffer otherwise. For form-data it is ArrayBuffer. If form-data represents uploading file, it is string with filename, if the filename is provided."
  214.       },
  215.       {
  216.         "id": "IgnoredActionType",
  217.         "decription": "Denotes the extension proposed action which was ignored.",
  218.         "type": "string",
  219.         "enum": ["redirect", "request_headers", "response_headers", "auth_credentials"]
  220.       }
  221.     ],
  222.     "functions": [
  223.       {
  224.         "name": "handlerBehaviorChanged",
  225.         "type": "function",
  226.         "description": "Needs to be called when the behavior of the webRequest handlers has changed to prevent incorrect handling due to caching. This function call is expensive. Don't call it often.",
  227.         "parameters": [],
  228.         "returns_async": {"name": "callback", "optional": true, "parameters": []}
  229.       }
  230.     ],
  231.     "events": [
  232.       {
  233.         "name": "onBeforeRequest",
  234.         "type": "function",
  235.         "description": "Fired when a request is about to occur.",
  236.         "parameters": [
  237.           {
  238.             "type": "object",
  239.             "name": "details",
  240.             "properties": {
  241.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  242.               "url": {"type": "string"},
  243.               "method": {"type": "string", "description": "Standard HTTP method."},
  244.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  245.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  246.               "documentId": {"type": "string", "optional": true, "description": "The UUID of the document making the request."},
  247.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  248.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "optional": true, "description": "The lifecycle the document is in."},
  249.               "frameType": {"$ref": "extensionTypes.FrameType", "optional": true, "description": "The type of frame the request occurred in."},
  250.               "requestBody": {
  251.                 "type": "object",
  252.                 "optional": true,
  253.                 "description": "Contains the HTTP request body data. Only provided if extraInfoSpec contains 'requestBody'.",
  254.                 "properties": {
  255.                   "error": {"type": "string", "optional": true, "description": "Errors when obtaining request body data."},
  256.                   "formData": {
  257.                     "type": "object",
  258.                     "optional": true,
  259.                     "description": "If the request method is POST and the body is a sequence of key-value pairs encoded in UTF8, encoded as either multipart/form-data, or application/x-www-form-urlencoded, this dictionary is present and for each key contains the list of all values for that key. If the data is of another media type, or if it is malformed, the dictionary is not present. An example value of this dictionary is {'key': ['value1', 'value2']}.",
  260.                     "properties": {},
  261.                     "additionalProperties": {
  262.                       "type": "array",
  263.                       "items": { "$ref": "FormDataItem" }
  264.                     }
  265.                   },
  266.                   "raw" : {
  267.                     "type": "array",
  268.                     "optional": true,
  269.                     "items": {"$ref": "UploadData"},
  270.                     "description": "If the request method is PUT or POST, and the body is not already parsed in formData, then the unparsed request body elements are contained in this array."
  271.                   }
  272.                 }
  273.               },
  274.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  275.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  276.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  277.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."}
  278.             }
  279.           }
  280.         ],
  281.         "extraParameters": [
  282.           {
  283.             "$ref": "RequestFilter",
  284.             "name": "filter",
  285.             "description": "A set of filters that restricts the events that will be sent to this listener."
  286.           },
  287.           {
  288.             "type": "array",
  289.             "optional": true,
  290.             "name": "extraInfoSpec",
  291.             "description": "Array of extra information that should be passed to the listener function.",
  292.             "items": {
  293.               "$ref": "OnBeforeRequestOptions"
  294.             }
  295.           }
  296.         ],
  297.         "returns": {
  298.           "$ref": "BlockingResponse",
  299.           "description": "If "blocking" is specified in the "extraInfoSpec" parameter, the event listener should return an object of this type.",
  300.           "optional": true
  301.         }
  302.       },
  303.       {
  304.         "name": "onBeforeSendHeaders",
  305.         "nocompile": true,
  306.         "type": "function",
  307.         "description": "Fired before sending an HTTP request, once the request headers are available. This may occur after a TCP connection is made to the server, but before any HTTP data is sent. ",
  308.         "parameters": [
  309.           {
  310.             "type": "object",
  311.             "name": "details",
  312.             "properties": {
  313.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  314.               "url": {"type": "string"},
  315.               "method": {"type": "string", "description": "Standard HTTP method."},
  316.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  317.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  318.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  319.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  320.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  321.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  322.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  323.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  324.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  325.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  326.               "requestHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP request headers that are going to be sent out with this request."}
  327.             }
  328.           }
  329.         ],
  330.         "extraParameters": [
  331.           {
  332.             "$ref": "RequestFilter",
  333.             "name": "filter",
  334.             "description": "A set of filters that restricts the events that will be sent to this listener."
  335.           },
  336.           {
  337.             "type": "array",
  338.             "optional": true,
  339.             "name": "extraInfoSpec",
  340.             "description": "Array of extra information that should be passed to the listener function.",
  341.             "items": {
  342.               "$ref": "OnBeforeSendHeadersOptions"
  343.             }
  344.           }
  345.         ],
  346.         "returns": {
  347.           "$ref": "BlockingResponse",
  348.           "description": "If "blocking" is specified in the "extraInfoSpec" parameter, the event listener should return an object of this type.",
  349.           "optional": true
  350.         }
  351.       },
  352.       {
  353.         "name": "onSendHeaders",
  354.         "nocompile": true,
  355.         "type": "function",
  356.         "description": "Fired just before a request is going to be sent to the server (modifications of previous onBeforeSendHeaders callbacks are visible by the time onSendHeaders is fired).",
  357.         "parameters": [
  358.           {
  359.             "type": "object",
  360.             "name": "details",
  361.             "properties": {
  362.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  363.               "url": {"type": "string"},
  364.               "method": {"type": "string", "description": "Standard HTTP method."},
  365.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  366.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  367.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  368.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  369.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  370.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  371.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  372.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  373.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  374.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  375.               "requestHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP request headers that have been sent out with this request."}
  376.             }
  377.           }
  378.         ],
  379.         "extraParameters": [
  380.           {
  381.             "$ref": "RequestFilter",
  382.             "name": "filter",
  383.             "description": "A set of filters that restricts the events that will be sent to this listener."
  384.           },
  385.           {
  386.             "type": "array",
  387.             "optional": true,
  388.             "name": "extraInfoSpec",
  389.             "description": "Array of extra information that should be passed to the listener function.",
  390.             "items": {
  391.               "$ref": "OnSendHeadersOptions"
  392.             }
  393.           }
  394.         ]
  395.       },
  396.       {
  397.         "name": "onHeadersReceived",
  398.         "nocompile": true,
  399.         "type": "function",
  400.         "description": "Fired when HTTP response headers of a request have been received.",
  401.         "parameters": [
  402.           {
  403.             "type": "object",
  404.             "name": "details",
  405.             "properties": {
  406.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  407.               "url": {"type": "string"},
  408.               "method": {"type": "string", "description": "Standard HTTP method."},
  409.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  410.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  411.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  412.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  413.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  414.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  415.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  416.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  417.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  418.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  419.               "statusLine": {"type": "string", "description": "HTTP status line of the response or the 'HTTP/0.9 200 OK' string for HTTP/0.9 responses (i.e., responses that lack a status line)."},
  420.               "responseHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP response headers that have been received with this response."},
  421.               "statusCode": {"type": "integer", "description": "Standard HTTP status code returned by the server."}
  422.              }
  423.           }
  424.         ],
  425.         "extraParameters": [
  426.           {
  427.             "$ref": "RequestFilter",
  428.             "name": "filter",
  429.             "description": "A set of filters that restricts the events that will be sent to this listener."
  430.           },
  431.           {
  432.             "type": "array",
  433.             "optional": true,
  434.             "name": "extraInfoSpec",
  435.             "description": "Array of extra information that should be passed to the listener function.",
  436.             "items": {
  437.               "$ref": "OnHeadersReceivedOptions"
  438.             }
  439.           }
  440.         ],
  441.         "returns": {
  442.           "$ref": "BlockingResponse",
  443.           "description": "If "blocking" is specified in the "extraInfoSpec" parameter, the event listener should return an object of this type.",
  444.           "optional": true
  445.         }
  446.       },
  447.       {
  448.         "name": "onAuthRequired",
  449.         "nocompile": true,
  450.         "type": "function",
  451.         "description": "Fired when an authentication failure is received. The listener has three options: it can provide authentication credentials, it can cancel the request and display the error page, or it can take no action on the challenge. If bad user credentials are provided, this may be called multiple times for the same request. Note, only one of <code>'blocking'</code> or <code>'asyncBlocking'</code> modes must be specified in the <code>extraInfoSpec</code> parameter.",
  452.         "parameters": [
  453.           {
  454.             "type": "object",
  455.             "name": "details",
  456.             "properties": {
  457.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  458.               "url": {"type": "string"},
  459.               "method": {"type": "string", "description": "Standard HTTP method."},
  460.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  461.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  462.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  463.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  464.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  465.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  466.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  467.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  468.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  469.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  470.               "scheme": {"type": "string", "description": "The authentication scheme, e.g. Basic or Digest."},
  471.               "realm": {"type": "string", "description": "The authentication realm provided by the server, if there is one.", "optional": true},
  472.               "challenger": {"type": "object", "description": "The server requesting authentication.", "properties": {"host": {"type": "string"}, "port": {"type": "integer"}}},
  473.               "isProxy": {"type": "boolean", "description": "True for Proxy-Authenticate, false for WWW-Authenticate."},
  474.               "responseHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP response headers that were received along with this response."},
  475.               "statusLine": {"type": "string", "description": "HTTP status line of the response or the 'HTTP/0.9 200 OK' string for HTTP/0.9 responses (i.e., responses that lack a status line) or an empty string if there are no headers."},
  476.               "statusCode": {"type": "integer", "description": "Standard HTTP status code returned by the server."}
  477.             }
  478.           },
  479.           {
  480.             "type": "function",
  481.             "optional": true,
  482.             "description" : "Only valid if <code>'asyncBlocking'</code> is specified as one of the <code>OnAuthRequiredOptions</code>.",
  483.             "name": "asyncCallback",
  484.             "parameters": [
  485.               {"name": "response", "$ref": "BlockingResponse"}
  486.             ]
  487.           }
  488.         ],
  489.         "extraParameters": [
  490.           {
  491.             "$ref": "RequestFilter",
  492.             "name": "filter",
  493.             "description": "A set of filters that restricts the events that will be sent to this listener."
  494.           },
  495.           {
  496.             "type": "array",
  497.             "optional": true,
  498.             "name": "extraInfoSpec",
  499.             "description": "Array of extra information that should be passed to the listener function.",
  500.             "items": {
  501.               "$ref": "OnAuthRequiredOptions"
  502.             }
  503.           }
  504.         ],
  505.         "returns": {
  506.           "$ref": "BlockingResponse",
  507.           "description": "If "blocking" is specified in the "extraInfoSpec" parameter, the event listener should return an object of this type.",
  508.           "optional": true
  509.         }
  510.       },
  511.       {
  512.         "name": "onResponseStarted",
  513.         "nocompile": true,
  514.         "type": "function",
  515.         "description": "Fired when the first byte of the response body is received. For HTTP requests, this means that the status line and response headers are available.",
  516.         "parameters": [
  517.           {
  518.             "type": "object",
  519.             "name": "details",
  520.             "properties": {
  521.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  522.               "url": {"type": "string"},
  523.               "method": {"type": "string", "description": "Standard HTTP method."},
  524.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  525.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  526.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  527.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  528.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  529.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  530.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  531.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  532.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  533.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  534.               "ip": {"type": "string", "optional": true, "description": "The server IP address that the request was actually sent to. Note that it may be a literal IPv6 address."},
  535.               "fromCache": {"type": "boolean", "description": "Indicates if this response was fetched from disk cache."},
  536.               "statusCode": {"type": "integer", "description": "Standard HTTP status code returned by the server."},
  537.               "responseHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP response headers that were received along with this response."},
  538.               "statusLine": {"type": "string", "description": "HTTP status line of the response or the 'HTTP/0.9 200 OK' string for HTTP/0.9 responses (i.e., responses that lack a status line) or an empty string if there are no headers."}
  539.             }
  540.           }
  541.         ],
  542.         "extraParameters": [
  543.           {
  544.             "$ref": "RequestFilter",
  545.             "name": "filter",
  546.             "description": "A set of filters that restricts the events that will be sent to this listener."
  547.           },
  548.           {
  549.             "type": "array",
  550.             "optional": true,
  551.             "name": "extraInfoSpec",
  552.             "description": "Array of extra information that should be passed to the listener function.",
  553.             "items": {
  554.               "$ref": "OnResponseStartedOptions"
  555.             }
  556.           }
  557.         ]
  558.       },
  559.       {
  560.         "name": "onBeforeRedirect",
  561.         "type": "function",
  562.         "nocompile": true,
  563.         "description": "Fired when a server-initiated redirect is about to occur.",
  564.         "parameters": [
  565.           {
  566.             "type": "object",
  567.             "name": "details",
  568.             "properties": {
  569.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  570.               "url": {"type": "string"},
  571.               "method": {"type": "string", "description": "Standard HTTP method."},
  572.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  573.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  574.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  575.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  576.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  577.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  578.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  579.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  580.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  581.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  582.               "ip": {"type": "string", "optional": true, "description": "The server IP address that the request was actually sent to. Note that it may be a literal IPv6 address."},
  583.               "fromCache": {"type": "boolean", "description": "Indicates if this response was fetched from disk cache."},
  584.               "statusCode": {"type": "integer", "description": "Standard HTTP status code returned by the server."},
  585.               "redirectUrl": {"type": "string", "description": "The new URL."},
  586.               "responseHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP response headers that were received along with this redirect."},
  587.               "statusLine": {"type": "string", "description": "HTTP status line of the response or the 'HTTP/0.9 200 OK' string for HTTP/0.9 responses (i.e., responses that lack a status line) or an empty string if there are no headers."}
  588.             }
  589.           }
  590.         ],
  591.         "extraParameters": [
  592.           {
  593.             "$ref": "RequestFilter",
  594.             "name": "filter",
  595.             "description": "A set of filters that restricts the events that will be sent to this listener."
  596.           },
  597.           {
  598.             "type": "array",
  599.             "optional": true,
  600.             "name": "extraInfoSpec",
  601.             "description": "Array of extra information that should be passed to the listener function.",
  602.             "items": {
  603.               "$ref": "OnBeforeRedirectOptions"
  604.             }
  605.           }
  606.         ]
  607.       },
  608.       {
  609.         "name": "onCompleted",
  610.         "type": "function",
  611.         "nocompile": true,
  612.         "description": "Fired when a request is completed.",
  613.         "parameters": [
  614.           {
  615.             "type": "object",
  616.             "name": "details",
  617.             "properties": {
  618.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  619.               "url": {"type": "string"},
  620.               "method": {"type": "string", "description": "Standard HTTP method."},
  621.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  622.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  623.               "documentId": {"type": "string", "description": "The UUID of the document making the request."},
  624.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  625.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  626.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  627.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  628.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  629.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  630.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  631.               "ip": {"type": "string", "optional": true, "description": "The server IP address that the request was actually sent to. Note that it may be a literal IPv6 address."},
  632.               "fromCache": {"type": "boolean", "description": "Indicates if this response was fetched from disk cache."},
  633.               "statusCode": {"type": "integer", "description": "Standard HTTP status code returned by the server."},
  634.               "responseHeaders": {"$ref": "HttpHeaders", "optional": true, "description": "The HTTP response headers that were received along with this response."},
  635.               "statusLine": {"type": "string", "description": "HTTP status line of the response or the 'HTTP/0.9 200 OK' string for HTTP/0.9 responses (i.e., responses that lack a status line) or an empty string if there are no headers."}
  636.             }
  637.           }
  638.         ],
  639.         "extraParameters": [
  640.           {
  641.             "$ref": "RequestFilter",
  642.             "name": "filter",
  643.             "description": "A set of filters that restricts the events that will be sent to this listener."
  644.           },
  645.           {
  646.             "type": "array",
  647.             "optional": true,
  648.             "name": "extraInfoSpec",
  649.             "description": "Array of extra information that should be passed to the listener function.",
  650.             "items": {
  651.               "$ref": "OnCompletedOptions"
  652.             }
  653.           }
  654.         ]
  655.       },
  656.       {
  657.         "name": "onErrorOccurred",
  658.         "type": "function",
  659.         "description": "Fired when an error occurs.",
  660.         "parameters": [
  661.           {
  662.             "type": "object",
  663.             "name": "details",
  664.             "properties": {
  665.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  666.               "url": {"type": "string"},
  667.               "method": {"type": "string", "description": "Standard HTTP method."},
  668.               "frameId": {"type": "integer", "description": "The value 0 indicates that the request happens in the main frame; a positive value indicates the ID of a subframe in which the request happens. If the document of a (sub-)frame is loaded (<code>type</code> is <code>main_frame</code> or <code>sub_frame</code>), <code>frameId</code> indicates the ID of this frame, not the ID of the outer frame. Frame IDs are unique within a tab."},
  669.               "parentFrameId": {"type": "integer", "description": "ID of frame that wraps the frame which sent the request. Set to -1 if no parent frame exists."},
  670.               "documentId": {"type": "string", "description": "The UUID of the document making the request. This value is not present if the request is a navigation of a frame."},
  671.               "parentDocumentId": {"type": "string", "optional": true, "description": "The UUID of the parent document owning this frame. This is not set if there is no parent."},
  672.               "documentLifecycle": {"$ref": "extensionTypes.DocumentLifecycle", "description": "The lifecycle the document is in."},
  673.               "frameType": {"$ref": "extensionTypes.FrameType", "description": "The type of frame the request occurred in."},
  674.               "tabId": {"type": "integer", "description": "The ID of the tab in which the request takes place. Set to -1 if the request isn't related to a tab."},
  675.               "type": {"$ref": "ResourceType", "description": "How the requested resource will be used."},
  676.               "initiator": {"type": "string", "optional": true, "description": "The origin where the request was initiated. This does not change through redirects. If this is an opaque origin, the string 'null' will be used."},
  677.               "timeStamp": {"type": "number", "description": "The time when this signal is triggered, in milliseconds since the epoch."},
  678.               "ip": {"type": "string", "optional": true, "description": "The server IP address that the request was actually sent to. Note that it may be a literal IPv6 address."},
  679.               "fromCache": {"type": "boolean", "description": "Indicates if this response was fetched from disk cache."},
  680.               "error": {"type": "string", "description": "The error description. This string is <em>not</em> guaranteed to remain backwards compatible between releases. You must not parse and act based upon its content."}
  681.             }
  682.           }
  683.         ],
  684.         "extraParameters": [
  685.           {
  686.             "$ref": "RequestFilter",
  687.             "name": "filter",
  688.             "description": "A set of filters that restricts the events that will be sent to this listener."
  689.           },
  690.           {
  691.             "type": "array",
  692.             "optional": true,
  693.             "name": "extraInfoSpec",
  694.             "description": "Array of extra information that should be passed to the listener function.",
  695.             "items": {
  696.               "$ref": "OnErrorOccurredOptions"
  697.             }
  698.           }
  699.         ]
  700.       },
  701.       {
  702.         "name": "onActionIgnored",
  703.         "type": "function",
  704.         "description": "Fired when an extension's proposed modification to a network request is ignored. This happens in case of conflicts with other extensions.",
  705.         "parameters": [
  706.           {
  707.             "type": "object",
  708.             "name": "details",
  709.             "properties": {
  710.               "requestId": {"type": "string", "description": "The ID of the request. Request IDs are unique within a browser session. As a result, they could be used to relate different events of the same request."},
  711.               "action": {"$ref": "IgnoredActionType", "description": "The proposed action which was ignored."}
  712.             }
  713.           }
  714.         ]
  715.       }
  716.     ]
  717.   }
  718. ]
复制代码
2、web_request.json生成的c++文件:

outDebuggenextensionscommonapiweb_request.h
outDebuggenextensionscommonapiweb_request.cc
3、web_request api接口定义c++:

extensionsrowserapiweb_requestweb_request_api.h
extensionsrowserapiweb_requestweb_request_api.cc
  1. namespace extensions {
  2. // Support class for the WebRequest API. Lives on the UI thread. Most of the
  3. // work is done by ExtensionWebRequestEventRouter below. This class observes
  4. // extensions::EventRouter to deal with event listeners. There is one instance
  5. // per BrowserContext which is shared with incognito.
  6. class WebRequestAPI : public BrowserContextKeyedAPI,
  7.                       public EventRouter::Observer,
  8.                       public ExtensionRegistryObserver {
  9. public:
  10.   // A callback used to asynchronously respond to an intercepted authentication
  11.   // request. If |should_cancel| is true the request will be cancelled.
  12.   // Otherwise any supplied |credentials| will be used. If no credentials are
  13.   // supplied, default browser behavior will follow (e.g. UI prompt for login).
  14.   using AuthRequestCallback = base::OnceCallback<void(
  15.       const std::optional<net::AuthCredentials>& credentials,
  16.       bool should_cancel)>;
  17.   // An interface which is held by ProxySet defined below.
  18.   class Proxy {
  19.    public:
  20.     virtual ~Proxy() = default;
  21.     // Asks the Proxy to handle an auth request on behalf of one of its known
  22.     // in-progress network requests. If the request will *not* be handled by
  23.     // the proxy, |callback| should be invoked with |std::nullopt|.
  24.     virtual void HandleAuthRequest(
  25.         const net::AuthChallengeInfo& auth_info,
  26.         scoped_refptr<net::HttpResponseHeaders> response_headers,
  27.         int32_t request_id,
  28.         AuthRequestCallback callback);
  29.   };
  30.   // A ProxySet is a set of proxies used by WebRequestAPI: It holds Proxy
  31.   // instances, and removes all proxies when it is destroyed.
  32.   class ProxySet {
  33.    public:
  34.     ProxySet();
  35.     ProxySet(const ProxySet&) = delete;
  36.     ProxySet& operator=(const ProxySet&) = delete;
  37.     ~ProxySet();
  38.     // Add a Proxy.
  39.     void AddProxy(std::unique_ptr<Proxy> proxy);
  40.     // Remove a Proxy. The removed proxy is deleted upon this call.
  41.     void RemoveProxy(Proxy* proxy);
  42.     // Associates |proxy| with |id|. |proxy| must already be registered within
  43.     // this ProxySet.
  44.     //
  45.     // Each Proxy may be responsible for multiple requests, but any given
  46.     // request identified by |id| must be associated with only a single proxy.
  47.     void AssociateProxyWithRequestId(Proxy* proxy,
  48.                                      const content::GlobalRequestID& id);
  49.     // Disassociates |proxy| with |id|. |proxy| must already be registered
  50.     // within this ProxySet.
  51.     void DisassociateProxyWithRequestId(Proxy* proxy,
  52.                                         const content::GlobalRequestID& id);
  53.     Proxy* GetProxyFromRequestId(const content::GlobalRequestID& id);
  54.     void MaybeProxyAuthRequest(
  55.         const net::AuthChallengeInfo& auth_info,
  56.         scoped_refptr<net::HttpResponseHeaders> response_headers,
  57.         const content::GlobalRequestID& request_id,
  58.         AuthRequestCallback callback);
  59.    private:
  60.     // Although these members are initialized on the UI thread, we expect at
  61.     // least one memory barrier before actually calling Generate in the IO
  62.     // thread, so we don't protect them with a lock.
  63.     std::set<std::unique_ptr<Proxy>, base::UniquePtrComparator> proxies_;
  64.     // Bi-directional mapping between request ID and Proxy for faster lookup.
  65.     std::map<content::GlobalRequestID, Proxy*> request_id_to_proxy_map_;
  66.     std::map<Proxy*, std::set<content::GlobalRequestID>>
  67.         proxy_to_request_id_map_;
  68.   };
  69.   class RequestIDGenerator {
  70.    public:
  71.     RequestIDGenerator();
  72.     RequestIDGenerator(const RequestIDGenerator&) = delete;
  73.     RequestIDGenerator& operator=(const RequestIDGenerator&) = delete;
  74.     ~RequestIDGenerator();
  75.     // Generates a WebRequest ID. If the same (routing_id,
  76.     // network_service_request_id) pair is passed to this as was previously
  77.     // passed to SaveID(), the |request_id| passed to SaveID() will be returned.
  78.     int64_t Generate(int32_t routing_id, int32_t network_service_request_id);
  79.     // This saves a WebRequest ID mapped to the (routing_id,
  80.     // network_service_request_id) pair. Clients must call Generate() with the
  81.     // same ID pair to retrieve the |request_id|, or else there may be a memory
  82.     // leak.
  83.     void SaveID(int32_t routing_id,
  84.                 int32_t network_service_request_id,
  85.                 uint64_t request_id);
  86.    private:
  87.     int64_t id_ = 0;
  88.     std::map<std::pair<int32_t, int32_t>, uint64_t> saved_id_map_;
  89.   };
  90.   explicit WebRequestAPI(content::BrowserContext* context);
  91.   WebRequestAPI(const WebRequestAPI&) = delete;
  92.   WebRequestAPI& operator=(const WebRequestAPI&) = delete;
  93.   ~WebRequestAPI() override;
  94.   // BrowserContextKeyedAPI support:
  95.   static BrowserContextKeyedAPIFactory<WebRequestAPI>* GetFactoryInstance();
  96.   void Shutdown() override;
  97.   // EventRouter::Observer overrides:
  98.   void OnListenerRemoved(const EventListenerInfo& details) override;
  99.   // If any WebRequest event listeners are currently active for this
  100.   // BrowserContext, |*factory_request| is swapped out for a new request which
  101.   // proxies through an internal URLLoaderFactory. This supports lifetime
  102.   // observation and control on behalf of the WebRequest API.
  103.   // |frame| and |render_process_id| are the frame and render process id in
  104.   // which the URLLoaderFactory will be used. |frame| can be nullptr for
  105.   // factories proxied for service worker.
  106.   //
  107.   // |navigation_response_task_runner| is a task runner that may be non-null for
  108.   // navigation requests and can be used to run navigation request blocking
  109.   // tasks.
  110.   //
  111.   // Returns |true| if the URLLoaderFactory will be proxied; |false| otherwise.
  112.   bool MaybeProxyURLLoaderFactory(
  113.       content::BrowserContext* browser_context,
  114.       content::RenderFrameHost* frame,
  115.       int render_process_id,
  116.       content::ContentBrowserClient::URLLoaderFactoryType type,
  117.       std::optional<int64_t> navigation_id,
  118.       ukm::SourceIdObj ukm_source_id,
  119.       mojo::PendingReceiver<network::mojom::URLLoaderFactory>* factory_receiver,
  120.       mojo::PendingRemote<network::mojom::TrustedURLLoaderHeaderClient>*
  121.           header_client,
  122.       scoped_refptr<base::SequencedTaskRunner> navigation_response_task_runner,
  123.       const url::Origin& request_initiator = url::Origin());
  124.   // Any request which requires authentication to complete will be bounced
  125.   // through this method.
  126.   //
  127.   // If this returns |true|, |callback| will eventually be invoked on the UI
  128.   // thread.
  129.   bool MaybeProxyAuthRequest(
  130.       content::BrowserContext* browser_context,
  131.       const net::AuthChallengeInfo& auth_info,
  132.       scoped_refptr<net::HttpResponseHeaders> response_headers,
  133.       const content::GlobalRequestID& request_id,
  134.       bool is_main_frame,
  135.       AuthRequestCallback callback,
  136.       WebViewGuest* web_view_guest);
  137.   // Starts proxying the connection with |factory|. This function can be called
  138.   // only when MayHaveProxies() returns true.
  139.   void ProxyWebSocket(
  140.       content::RenderFrameHost* frame,
  141.       content::ContentBrowserClient::WebSocketFactory factory,
  142.       const GURL& url,
  143.       const net::SiteForCookies& site_for_cookies,
  144.       const std::optional<std::string>& user_agent,
  145.       mojo::PendingRemote<network::mojom::WebSocketHandshakeClient>
  146.           handshake_client);
  147.   // Starts proxying WebTransport handshake.
  148.   void ProxyWebTransport(
  149.       content::RenderProcessHost& render_process_host,
  150.       int frame_routing_id,
  151.       const GURL& url,
  152.       const url::Origin& initiator_origin,
  153.       mojo::PendingRemote<network::mojom::WebTransportHandshakeClient>
  154.           handshake_client,
  155.       content::ContentBrowserClient::WillCreateWebTransportCallback callback);
  156.   void ForceProxyForTesting();
  157.   // Indicates whether or not the WebRequestAPI may have one or more proxies
  158.   // installed to support the API.
  159.   bool MayHaveProxies() const;
  160.   // Indicates whether or not WebRequestAPI may have one or more proxies
  161.   // installed to support intercepting websocket connections for extension
  162.   // telemetry.
  163.   // TODO(psarouthakis): This is here for the current implementation, but
  164.   // will be refactored to live somewhere else so that we don't have to
  165.   // create a full proxy just for telemetry.
  166.   bool MayHaveWebsocketProxiesForExtensionTelemetry() const;
  167.   // Indicates whether the WebRequestAPI is available to a RenderFrameHost
  168.   // that embeds a WebView instance.
  169.   bool IsAvailableToWebViewEmbedderFrame(
  170.       content::RenderFrameHost* render_frame_host) const;
  171.   bool HasExtraHeadersListenerForTesting();
  172. private:
  173.   friend class BrowserContextKeyedAPIFactory<WebRequestAPI>;
  174.   // BrowserContextKeyedAPI support:
  175.   static const char* service_name() { return "WebRequestAPI"; }
  176.   static const bool kServiceRedirectedInIncognito = true;
  177.   static const bool kServiceIsNULLWhileTesting = true;
  178.   // Checks if |MayHaveProxies()| has changed from false to true, and resets
  179.   // URLLoaderFactories if so.
  180.   void UpdateMayHaveProxies();
  181.   // ExtensionRegistryObserver implementation.
  182.   void OnExtensionLoaded(content::BrowserContext* browser_context,
  183.                          const Extension* extension) override;
  184.   void OnExtensionUnloaded(content::BrowserContext* browser_context,
  185.                            const Extension* extension,
  186.                            UnloadedExtensionReason reason) override;
  187.   // This a proxy API for the tasks that are posted. It is either called
  188.   // when the task is run and forwards to the corresponding member function
  189.   // in ExtensionWebRequestEventRouter, or not, if the owning BrowserContext
  190.   // goes away or the WeakPtr instance bound in the callback is invalidated.
  191.   void UpdateActiveListener(
  192.       content::BrowserContext* browser_context,
  193.       WebRequestEventRouter::ListenerUpdateType update_type,
  194.       const ExtensionId& extension_id,
  195.       const std::string& sub_event_name,
  196.       int worker_thread_id,
  197.       int64_t service_worker_version_id);
  198.   // This a proxy API for the tasks that are posted. It is either called
  199.   // when the task is run and forwards to the corresponding member function
  200.   // in ExtensionWebRequestEventRouter, or not, if the owning BrowserContext
  201.   // goes away or the WeakPtr instance bound in the callback is invalidated.
  202.   void RemoveLazyListener(content::BrowserContext* browser_context,
  203.                           const ExtensionId& extension_id,
  204.                           const std::string& sub_event_name);
  205.   // A count of active extensions for this BrowserContext that use web request
  206.   // permissions.
  207.   int web_request_extension_count_ = 0;
  208.   const raw_ptr<content::BrowserContext, DanglingUntriaged> browser_context_;
  209.   RequestIDGenerator request_id_generator_;
  210.   std::unique_ptr<ProxySet> proxies_;
  211.   // Stores the last result of |MayHaveProxies()|, so it can be used in
  212.   // |UpdateMayHaveProxies()|.
  213.   bool may_have_proxies_;
  214.   base::WeakPtrFactory<WebRequestAPI> weak_factory_{this};
  215. };
  216. class WebRequestInternalFunction : public ExtensionFunction {
  217. public:
  218.   WebRequestInternalFunction() = default;
  219. protected:
  220.   ~WebRequestInternalFunction() override = default;
  221.   const std::string& extension_id_safe() const {
  222.     return extension() ? extension_id() : base::EmptyString();
  223.   }
  224. };
  225. class WebRequestInternalAddEventListenerFunction
  226.     : public WebRequestInternalFunction {
  227. public:
  228.   DECLARE_EXTENSION_FUNCTION("webRequestInternal.addEventListener",
  229.                              WEBREQUESTINTERNAL_ADDEVENTLISTENER)
  230. protected:
  231.   ~WebRequestInternalAddEventListenerFunction() override = default;
  232.   // ExtensionFunction:
  233.   ResponseAction Run() override;
  234. };
  235. class WebRequestInternalEventHandledFunction
  236.     : public WebRequestInternalFunction {
  237. public:
  238.   DECLARE_EXTENSION_FUNCTION("webRequestInternal.eventHandled",
  239.                              WEBREQUESTINTERNAL_EVENTHANDLED)
  240. protected:
  241.   ~WebRequestInternalEventHandledFunction() override = default;
  242. private:
  243.   // Unblocks the network request. Use this function when handling incorrect
  244.   // requests from the extension that cannot be detected by the schema
  245.   // validator.
  246.   void OnError(const std::string& event_name,
  247.                const std::string& sub_event_name,
  248.                uint64_t request_id,
  249.                int render_process_id,
  250.                int web_view_instance_id,
  251.                std::unique_ptr<WebRequestEventRouter::EventResponse> response);
  252.   // ExtensionFunction:
  253.   ResponseAction Run() override;
  254. };
  255. class WebRequestHandlerBehaviorChangedFunction
  256.     : public WebRequestInternalFunction {
  257. public:
  258.   DECLARE_EXTENSION_FUNCTION("webRequest.handlerBehaviorChanged",
  259.                              WEBREQUEST_HANDLERBEHAVIORCHANGED)
  260. protected:
  261.   ~WebRequestHandlerBehaviorChangedFunction() override = default;
  262.   // ExtensionFunction:
  263.   void GetQuotaLimitHeuristics(
  264.       extensions::QuotaLimitHeuristics* heuristics) const override;
  265.   // Handle quota exceeded gracefully: Only warn the user but still execute the
  266.   // function.
  267.   void OnQuotaExceeded(std::string error) override;
  268.   ResponseAction Run() override;
  269. };
  270. }  // namespace extensions
复制代码
总结:

WebRequest API 接口c++定义介绍完毕,必要调试修改逻辑的可以在以上文件处更改。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王海鱼

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表