The webRequest API might be what you need. This code goes in your background page:
chrome.webRequest.onBeforeRequest.addListener(
function(details) {
if( details.url == "http://www.google.com/" )
return {redirectUrl: "http://www.google.com/?q=defaultquery" };
},
{urls: ["http://www.google.com/*"]},
["blocking"]);
This is an extremely specific rule that redirects visits to http://www.google.com/
with http://www.google.com/?q=defaultquery
, but I think you can see how to expand it to include more functionality.
Note that this will reroute all attempts to reach http://www.google.com/
, including Ajax requests and iframes.
Per the documentation, you will need to add the webRequest
and webRequestBlocking
permissions, along with host permissions for every host you plan to intercept:
"permissions": [
"webRequest",
"webRequestBlocking",
"*://*.google.com/",
...
],