ম্যানিফেস্ট V3-এ নেটওয়ার্ক অনুরোধগুলি পরিবর্তন করা হচ্ছে
ম্যানিফেস্ট V3 কীভাবে এক্সটেনশনগুলি নেটওয়ার্ক অনুরোধগুলির পরিবর্তন পরিচালনা করে তা পরিবর্তন করে। chrome.webRequest
এর সাথে নেটওয়ার্ক অনুরোধগুলিকে বাধা দেওয়ার এবং রানটাইমে সেগুলিকে পরিবর্তন করার পরিবর্তে, আপনার এক্সটেনশন এমন নিয়মগুলি নির্দিষ্ট করে যা নির্দিষ্ট শর্তগুলির একটি সেট পূরণ করার সময় সম্পাদন করার জন্য ক্রিয়াগুলি বর্ণনা করে৷ ঘোষণামূলক নেট অনুরোধ API ব্যবহার করে এটি করুন।
ওয়েব রিকোয়েস্ট এপিআই এবং ডিক্লারেটিভ নেট রিকোয়েস্ট এপিআই উল্লেখযোগ্যভাবে আলাদা। একটি ফাংশন কল অন্যটির সাথে প্রতিস্থাপন করার পরিবর্তে, ব্যবহারের ক্ষেত্রে আপনাকে আপনার কোডটি পুনরায় লিখতে হবে। এই বিভাগটি আপনাকে সেই প্রক্রিয়ার মধ্য দিয়ে নিয়ে যায়।
ম্যানিফেস্ট 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
এর অধীনে API রেফারেন্সে বর্ণিত হয়েছে
একটি একক URL ব্লক করুন
ম্যানিফেস্ট V2-এ একটি সাধারণ ব্যবহারের ক্ষেত্রে ছিল ব্যাকগ্রাউন্ড স্ক্রিপ্টে onBeforeRequest
ইভেন্ট ব্যবহার করে ওয়েব অনুরোধগুলি ব্লক করা।
chrome.webRequest.onBeforeRequest.addListener((e) => { return { cancel: true }; }, { urls: ["https://www.example.com/*"] }, ["blocking"]);
ম্যানিফেস্ট V3 এর জন্য, "block"
অ্যাকশন টাইপ ব্যবহার করে একটি নতুন declarativeNetRequest
নিয়ম তৈরি করুন। উদাহরণ নিয়মে "condition"
বস্তুটি লক্ষ্য করুন। এর "urlFilter"
webRequest
শ্রোতার কাছে পাস করা urls
বিকল্পটিকে প্রতিস্থাপন করে। একটি "resourceTypes"
অ্যারে ব্লক করার জন্য রিসোর্সের বিভাগ নির্দিষ্ট করে। এই উদাহরণটি শুধুমাত্র প্রধান HTML পৃষ্ঠাকে ব্লক করে, কিন্তু আপনি, উদাহরণস্বরূপ, শুধুমাত্র ফন্টগুলি ব্লক করতে পারেন।
[ { "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", ]
একাধিক URL পুনর্নির্দেশ করুন
ম্যানিফেস্ট 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"
ক্ষেত্র রয়েছে যেখানে URL ফিল্টার করার পরিবর্তে ফিরে আসার জন্য URL রয়েছে৷
[ { "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"
অনুমতি দিয়ে প্রতিস্থাপন করুন। URLগুলি আবার 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": [ "" ]