بهبود فیلتر کردن محتوا در Manifest V3

در طول سال گذشته، ما به طور فعال در بحث با فروشندگان پشت چندین افزونه مسدودکننده محتوا پیرامون راه‌های بهبود پلتفرم افزونه‌های MV3 شرکت کرده‌ایم. بر اساس این بحث ها، که بسیاری از آنها در گروه انجمن WebExtensions ( WECG ) با همکاری سایر مرورگرها انجام شد، ما توانسته ایم پیشرفت های قابل توجهی را ارائه دهیم.

قوانین ایستا بیشتر

مجموعه ای از قوانین فیلتر معمولاً در لیست ها گروه بندی می شوند. به عنوان مثال، یک لیست عمومی تر می تواند حاوی قوانین قابل اجرا برای همه کاربران باشد، در حالی که یک لیست خاص تر ممکن است محتوای خاص مکان را پنهان کند که فقط برخی از کاربران مایل به مسدود کردن آن هستند. تا همین اواخر، ما به هر برنامه افزودنی اجازه می دادیم تا انتخابی از بین 50 لیست (یا "مجموعه قوانین ثابت") را به کاربران ارائه دهد و 10 مورد از آنها را به طور همزمان فعال کنند. در بحث با جامعه، توسعه‌دهندگان برنامه‌های افزودنی شواهد قانع‌کننده‌ای ارائه کردند که نشان می‌دهد این برای موارد استفاده خاص بسیار کم است. پس از بررسی عملکرد API در کروم با در نظر گرفتن این بحث ها، اکنون اجازه می دهیم تا حداکثر 50 به طور همزمان فعال شوند. (به طور قابل توجهی، این به طور قابل توجهی بالاتر از حد 20 درخواست شده در WECG است.) ما همچنین در مجموع به 100 مجموعه قانون اجازه می دهیم. این در Chrome 120 ارسال می‌شود و افزایش محدودیت‌ها توسط فایرفاکس و سافاری پشتیبانی می‌شود که هر دو ورودی اولیه را در مورد این پیشنهاد ارائه کردند.

قوانین پویا تر

اکثر قوانین "ایستا" هستند و با هر به روز رسانی به یک برنامه افزودنی ارسال می شوند. با این حال، برای پشتیبانی از به‌روزرسانی‌های مکرر و قوانین تعریف‌شده توسط کاربر، برنامه‌های افزودنی می‌توانند قوانین را به صورت پویا نیز اضافه کنند، بدون اینکه برنامه‌نویسان مجبور باشند نسخه جدیدی از برنامه افزودنی را در فروشگاه وب Chrome آپلود کنند.

وقتی یک برنامه افزودنی می‌تواند به‌طور پویا درخواست‌ها را به روش‌هایی تغییر دهد که در بررسی فروشگاه وب Chrome بررسی نشده‌اند، این کار کاربران را در معرض خطرات فیشینگ یا سرقت داده‌ها قرار می‌دهد. به عنوان مثال، یک قانون تغییر مسیر ممکن است برای تزریق پیوندهای وابسته بدون رضایت مورد سوء استفاده قرار گیرد.

در نتیجه، ما فقط به برنامه‌های افزودنی اجازه دادیم تا حداکثر 5000 قانون را اضافه کنند که استفاده کم از این عملکرد را تشویق می‌کند و تشخیص سوءاستفاده را برای ما آسان‌تر می‌کند.

با این حال، توسعه‌دهندگان برنامه‌های افزودنی از جمله AdGuard و Adblock Plus تجزیه و تحلیل خود را انجام دادند و داده‌هایی را به اشتراک گذاشتند که محدودیت‌های بالاتر باعث می‌شود قوانین به‌روزتر و کاربرانی که تعداد فهرست‌های سفارشی بیشتری دارند به Manifest V3 مهاجرت کنند. در واقع، AdGuard گزارش داد که هر هفته بیش از 2600 تغییر در لیست‌های محبوب ایجاد می‌شود و از پنج درصد کاربرانی که از لیست‌های فیلتر سفارشی استفاده می‌کنند، از هر چهار کاربر یک نفر مجموعاً بیش از 5000 قانون پویا در سراسر آنها دارد ( منبع ). AdGuard این را به عنوان یک چالش مهم برای انتقال برنامه افزودنی خود به Manifest V3 ذکر کرد و ما بازخوردهای مشابهی را از سایر مسدود کننده های محتوا شنیدیم.

ما تشخیص دادیم که برخی از قوانین فیلتر، مانند مواردی که دارای عملکرد block یا allow هستند، بسیار ایمن‌تر هستند و کمتر مورد سوء استفاده قرار می‌گیرند. آنها همچنین اکثریت بزرگی از قوانین فیلتر بلوک تبلیغات را تشکیل می دهند. بر این اساس، من پیش‌نویسی را برای تعریف مجموعه‌ای از قوانین که ریسک کمتری در نظر می‌گیریم و حداکثر 30000 مورد از این موارد را مجاز می‌دانیم، در گروه جامعه برنامه‌های افزودنی وب به اشتراک گذاشتم . ما همچنان یک حد بالایی را برای جلوگیری از رگرسیون عملکرد حفظ می کنیم.

این پیشنهاد در گروه انجمن برنامه های افزودنی وب پشتیبانی شد، بنابراین ما آن را اجرا کردیم. با شروع Chrome 121، محدودیت بالاتر 30000 قانون برای قوانین DNR ایمن اعمال می‌شود، که ما آن‌ها را به‌عنوان قوانینی با عملکرد block ، allow ، allowAllRequests یا upgradeScheme تعریف می‌کنیم.

بر اساس داده های به اشتراک گذاشته شده توسط AdGuard، بین 98 تا 99 درصد از قوانین آنها باید از این حد بالاتر بهره مند شوند. قوانین باقی مانده همچنان پشتیبانی می شوند و می توانند در محدوده موجود اضافه شوند.

این در Chrome به عنوان ثابت MAX_NUMBER_OF_DYNAMIC_RULES در دسترس است. محدودیت قانون برای سایر قوانین درخواست خالص پویا 5000 باقی می ماند.

کاهش اندازه مجموعه قوانین

در Chrome 118، مقدار پیش‌فرض فیلد isUrlFilterCaseSensitive را بر اساس بازخورد انجمن به false تغییر دادیم . این فیلد کنترل می‌کند که آیا قاعده‌ای که بر اساس URL فیلتر می‌شود به حروف کوچک و بزرگ حساس است یا خیر، و ما متوجه شدیم که اکثر توسعه‌دهندگان پیش‌فرض متفاوتی در پسوند خود دارند. در نتیجه، مقدار باید چندین بار تنظیم شود. با ایجاد این تغییر، توسعه دهندگان قادر به کاهش اندازه قابل توجهی در مجموعه قوانین خود هستند.

بعدش چی؟

ما متعهد هستیم که به سرمایه گذاری در DeclarativeNetRequest API ادامه دهیم تا بتوانیم تا حد امکان از موارد استفاده پشتیبانی کنیم و مشتاقانه منتظر ادامه همکاری با جامعه هستیم. به طور خاص، مایلیم از اعضای WECG به خاطر مشارکتشان، از جمله AdGuard برای به اشتراک گذاشتن مقدار قابل توجهی از داده‌هایی که این کار را به انجام رساندند، و همه فروشندگان مرورگر که همگی بخش عمده‌ای در طراحی این API بوده‌اند، تشکر کنیم.

ما به بررسی محدودیت‌هایی که داریم ادامه می‌دهیم تا در صورت نیاز تنظیمات را انجام دهیم. برای حمایت از این امر، قصد داریم در آینده نزدیک برخی از داده هایی را که به عنوان بخشی از این کار جمع آوری کرده ایم به اشتراک بگذاریم. علاوه بر این، ما در حال کار بر روی افزودن قابلیت‌های اضافی مانند توانایی تطبیق با سرصفحه‌های پاسخ هستیم، که درخواست رایجی است که از پسوندهای نمایشگر PDF دیده‌ایم. در همه موارد، ما به برقراری ارتباط با کار خود ادامه می‌دهیم و از گروه انجمن افزونه‌های وب به‌عنوان مکانی برای بحث در مورد ایده‌ها و هماهنگی با آنچه که می‌خواهیم در آینده به آن نگاه کنیم، استفاده می‌کنیم.