मेनिफ़ेस्ट V3 में नेटवर्क अनुरोधों में बदलाव करना
मेनिफ़ेस्ट V3, एक्सटेंशन के नेटवर्क अनुरोधों में बदलाव करने के तरीके में बदलाव करता है. आपका एक्सटेंशन, नेटवर्क अनुरोधों को इंटरसेप्ट करने और chrome.webRequest
की मदद से रनटाइम पर उनमें बदलाव करने के बजाय, ऐसे नियम तय करता है जिनमें बताई गई शर्तें पूरी होने पर की जाने वाली कार्रवाइयों के बारे में बताया जाता है. इसके लिए, नेटवर्क अनुरोध को मैनेज करने के लिए, निर्देश के बजाय सुझाव देने की अनुमति देने वाले एपीआई का इस्तेमाल करें.
वेब अनुरोध एपीआई और नेटवर्क अनुरोध को मैनेज करने के लिए, निर्देश के बजाय सुझाव देने की अनुमति देने वाले एपीआई काफ़ी अलग हैं. एक फ़ंक्शन कॉल को दूसरे से बदलने के बजाय, आपको इस्तेमाल के उदाहरणों के हिसाब से अपना कोड फिर से लिखना होगा. इस सेक्शन में, इस प्रोसेस के बारे में बताया गया है.
मेनिफ़ेस्ट V2 में, वेब अनुरोधों को ब्लॉक करने से, एक्सटेंशन और उन पेजों की परफ़ॉर्मेंस पर काफ़ी असर पड़ सकता है जिन पर वे काम करते हैं. webRequest
नेमस्पेस, संभावित रूप से ब्लॉक करने वाले नौ इवेंट के साथ काम करता है. इनमें से हर इवेंट में अनलिमिटेड इवेंट हैंडलर होते हैं. इससे भी बुरा यह है कि हर वेब पेज को कई एक्सटेंशन ब्लॉक कर सकते हैं. इसके लिए, ऐसी अनुमतियां चाहिए जो आपके निजता अधिकारों का उल्लंघन करती हैं. मेनिफ़ेस्ट V3, कॉलबैक को एलान वाले नियमों से बदलकर इस समस्या से बचाता है.
यह तीन सेक्शन में से दूसरा सेक्शन है. इसमें, एक्सटेंशन सेवा वर्कर का हिस्सा नहीं होने वाले कोड में किए जाने वाले ज़रूरी बदलावों के बारे में बताया गया है. इसमें, मेनिफ़ेस्ट V2 में इस्तेमाल होने वाले, वेब को ब्लॉक करने वाले अनुरोधों को, मेनिफ़ेस्ट V3 में इस्तेमाल होने वाले, एलान वाले नेट अनुरोधों में बदलने के बारे में बताया गया है. दूसरे दो सेक्शन में, मेनिफ़ेस्ट V3 पर माइग्रेट करने और सुरक्षा को बेहतर बनाने के लिए, अपने कोड को अपडेट करने के बारे में बताया गया है.
अनुमतियां अपडेट करें
अपने manifest.json
में "permissions"
फ़ील्ड में ये बदलाव करें.
- अगर आपको अब नेटवर्क अनुरोधों को मॉनिटर करने की ज़रूरत नहीं है, तो
"webRequest"
अनुमति हटाएं. - मैच पैटर्न को
"permissions"
से"host_permissions"
पर ले जाएं.
आपको इस्तेमाल के उदाहरण के आधार पर, अन्य अनुमतियां जोड़नी होंगी. इन अनुमतियों के बारे में, इस्तेमाल के उदाहरण के साथ बताया जाता है.
नेटवर्क अनुरोध को मैनेज करने के लिए, निर्देश के बजाय सुझाव देने की अनुमति वाले नियम बनाना
डेक्लेरेटिव नेट रिक्वेस्ट के नियम बनाने के लिए, आपको अपने manifest.json
में "declarative_net_request"
ऑब्जेक्ट जोड़ना होगा. "declarative_net_request"
ब्लॉक में "rule_resource"
ऑब्जेक्ट की कैटगरी होती है, जो किसी नियम फ़ाइल पर ले जाती है. नियम फ़ाइल में, किसी कार्रवाई और उन शर्तों के बारे में बताने वाले ऑब्जेक्ट का कलेक्शन होता है जिनमें वे कार्रवाइयां लागू होती हैं.
इस्तेमाल के सामान्य उदाहरण
यहां दिए गए सेक्शन में, डेक्लेरेटिव नेट रिक्वेस्ट के सामान्य इस्तेमाल के उदाहरणों के बारे में बताया गया है. यहां दिए गए निर्देशों में सिर्फ़ खास जानकारी दी गई है. यहां दी गई सभी जानकारी के बारे में ज़्यादा जानकारी, chrome.declarativeNetRequest
में एपीआई रेफ़रंस में दी गई है
किसी एक यूआरएल को ब्लॉक करना
मेनिफ़ेस्ट V2 में, बैकग्राउंड स्क्रिप्ट में onBeforeRequest
इवेंट का इस्तेमाल करके, वेब अनुरोधों को ब्लॉक करना एक सामान्य इस्तेमाल का उदाहरण था.
chrome.webRequest.onBeforeRequest.addListener((e) => {
return { cancel: true };
}, { urls: ["https://www.example.com/*"] }, ["blocking"]);
मेनिफ़ेस्ट V3 के लिए, "block"
ऐक्शन टाइप का इस्तेमाल करके नया declarativeNetRequest
नियम बनाएं. उदाहरण के तौर पर दिए गए नियम में "condition"
ऑब्जेक्ट पर ध्यान दें. इसका "urlFilter"
, webRequest
लिसनर को दिए गए urls
विकल्प की जगह ले लेता है. "resourceTypes"
कलेक्शन से, ब्लॉक किए जाने वाले रिसॉर्स की कैटगरी के बारे में पता चलता है. इस उदाहरण में, सिर्फ़ मुख्य एचटीएमएल पेज को ब्लॉक किया गया है. हालांकि, सिर्फ़ फ़ॉन्ट को भी ब्लॉक किया जा सकता है.
[
{
"id" : 1,
"priority": 1,
"action" : { "type" : "block" },
"condition" : {
"urlFilter" : "||example.com",
"resourceTypes" : ["main_frame"]
}
}
]
इसे काम करने के लिए, आपको एक्सटेंशन की अनुमतियों को अपडेट करना होगा. manifest.json
में, "webRequestBlocking"
अनुमति को "declarativeNetRequest"
अनुमति से बदलें. ध्यान दें कि यूआरएल को "permissions"
फ़ील्ड से हटा दिया गया है, क्योंकि कॉन्टेंट को ब्लॉक करने के लिए, होस्ट की अनुमतियों की ज़रूरत नहीं होती. जैसा कि ऊपर दिखाया गया है, नियम फ़ाइल में उस होस्ट या होस्ट के बारे में बताया गया है जिस पर एलान वाला नेट अनुरोध लागू होता है.
अगर आपको इसे आज़माना है, तो नीचे दिया गया कोड हमारे सैंपल रिपॉज़िटरी में उपलब्ध है.
"permissions": [
"webRequestBlocking",
"https://*.example.com/*"
]
"permissions": [
"declarativeNetRequest",
]
एक से ज़्यादा यूआरएल रीडायरेक्ट करना
मेनिफ़ेस्ट V2 में, वेब अनुरोधों को रीडायरेक्ट करने के लिए BeforeRequest
इवेंट का इस्तेमाल करना एक आम उदाहरण था.
chrome.webRequest.onBeforeRequest.addListener((e) => {
console.log(e);
return { redirectUrl: "https://developer.chrome.com/docs/extensions/mv3/intro/" };
}, {
urls: [
"https://developer.chrome.com/docs/extensions/mv2/"
]
},
["blocking"]
);
मेनिफ़ेस्ट V3 के लिए, "redirect"
ऐक्शन टाइप का इस्तेमाल करें. पहले की तरह, "urlFilter"
, webRequest
लिसनर को दिए गए url
विकल्प की जगह ले लेता है. ध्यान दें कि इस उदाहरण में, नियम फ़ाइल के "action"
ऑब्जेक्ट में एक "redirect"
फ़ील्ड है. इसमें फ़िल्टर किए गए यूआरएल के बजाय, वह यूआरएल होता है जिसे दिखाना है.
[
{
"id" : 1,
"priority": 1,
"action": {
"type": "redirect",
"redirect": { "url": "https://developer.chrome.com/docs/extensions/mv3/intro/" }
},
"condition": {
"urlFilter": "https://developer.chrome.com/docs/extensions/mv2/",
"resourceTypes": ["main_frame"]
}
}
इस स्थिति में, एक्सटेंशन की अनुमतियों में भी बदलाव करने होंगे. पहले की तरह, "webRequestBlocking"
अनुमति को "declarativeNetRequest"
अनुमति से बदलें. यूआरएल को फिर से manifest.json
से नियम फ़ाइल में ले जाया जाता है. ध्यान दें कि रीडायरेक्ट करने के लिए, होस्ट की अनुमति के साथ-साथ "declarativeNetRequestWithHostAccess"
की अनुमति भी ज़रूरी है.
अगर आपको इसे आज़माना है, तो नीचे दिया गया कोड हमारे सैंपल रिपॉज़िटरी में उपलब्ध है.
"permissions": [
"webRequestBlocking",
"https://developer.chrome.com/docs/extensions/*",
"https://developer.chrome.com/docs/extensions/reference"
]
"permissions": [
"declarativeNetRequestWithHostAccess"
],
"host_permissions": [
"https://developer.chrome.com/*"
]
कुकी ब्लॉक करना
मेनिफ़ेस्ट V2 में, कुकी को ब्लॉक करने के लिए, वेब अनुरोध हेडर को भेजे जाने से पहले उन्हें इंटरसेप्ट करना और किसी खास हेडर को हटाना ज़रूरी है.
chrome.webRequest.onBeforeSendHeaders.addListener(
function(details) {
removeHeader(details.requestHeaders, 'cookie');
return {requestHeaders: details.requestHeaders};
},
// filters
{urls: ['https://*/*', 'http://*/*']},
// extraInfoSpec
['blocking', 'requestHeaders', 'extraHeaders']);
मेनिफ़ेस्ट V3, नियम फ़ाइल में मौजूद नियम की मदद से भी ऐसा करता है. इस बार कार्रवाई का टाइप "modifyHeaders"
है. यह फ़ाइल, "requestHeaders"
ऑब्जेक्ट का एक कलेक्शन लेती है. इसमें, उन हेडर के बारे में बताया जाता है जिनमें बदलाव करना है और उन्हें कैसे बदलना है. ध्यान दें कि "condition"
ऑब्जेक्ट में सिर्फ़ "resourceTypes"
कलेक्शन है. यह पिछले उदाहरणों की तरह ही वैल्यू के साथ काम करता है.
अगर आपको इसे आज़माना है, तो नीचे दिया गया कोड हमारे सैंपल रिपॉज़िटरी में उपलब्ध है.
[
{
"id": 1,
"priority": 1,
"action": {
"type": "modifyHeaders",
"requestHeaders": [
{ "header": "cookie", "operation": "remove" }
]
},
"condition": {
"urlFilter": "|*?no-cookies=1",
"resourceTypes": ["main_frame"]
}
}
]
इस स्थिति में, एक्सटेंशन की अनुमतियों में भी बदलाव करना होगा. पहले की तरह, "webRequestBlocking"
अनुमति को "declarativeNetRequest"
अनुमति से बदलें.
"permissions": [
"webRequest",
"webRequestBlocking",
"https://*/*",
"http://*/*"
],
"permissions": [
"declarativeNetRequest",
],
"host_permissions": [
"