メニュー
日本語

MV3制約の影響でカスタムフィルタと臨時修正フィルタがなくなりました

「AdGuardブラウザ拡張機能のカスタムフィルタと臨時修正フィルタはどこに?」

Chromeの厳しいリモート実行ポリシーManifest V3の下)に準拠するため、私たちAdGuardブラウザ拡張機能側は辛い決断を迫られました。カスタムフィルタは一時的に利用不可能になり、臨時修正フィルタは恒久的に削除されました。

その理由は、Chromeのポリシーではスクリプトやリモートホストコードの挿入が禁止されているからです。このポリシーのもともとの意図は良いものですが、その文言があまりにも広範であるため、広告ブロックルールでさえもこれらの制限の対象となってしまうことがありあるのです。残念ながら、カスタムフィルタと臨時修正フィルタの両方も該当していると判断されました。

なぜこれが問題なのか

まず第一に、「臨時修正フィルタ」が実装されたこと自体も、もともとMV3(Manifest V3)の制限があったからです。

MV3対応のブラウザ拡張機能では、AdGuardのフィルタはすべて拡張機能自体にあらかじめ組み込まれており、つまりフィルタの更新もストアでの審査を経て拡張機能自体のまるごとアップデートを通じてしか配信できないということです。
となると、フィルタ更新内容がユーザーに届くまでには数日かかる可能性があります。人気のあるウェブサイトが壊れた場合、ユーザーは解決策を待たなければならず、ユーザーにとってもAdGuardにとってもストレスが溜まるシチュエーションになります。

MV2(Manifest V2)では、差分アップデート という方法でこの問題を解決し、拡張機能全体をアップデートすることなく、新しいフィルタを迅速に配信できるようになりました。
しかし、MV3ではそのような仕組みの導入が許されていないため、「臨時修正フィルタ」が、フィルタのリアルタイム更新を実現するためのAdGuardの次善策となりました。

臨時修正フィルタをMV3に準拠させるために最善を尽くしましたが(このフィルタを巡る苦悩に満ちた経緯については下記の「この問題の進展タイムライン」を参照)、最終的にはChromeのポリシーにより、同フィルタを完全に削除せざるを得なくなりました。これは大きな損失のひとつです

もうひとつの損失は「カスタムフィルタ」で、同じリモート実行ポリシーにヤられてしまいましたした。

カスタムフィルタは、URL経由でサードパーティのフィルタを追加することを可能にします。何千ものボランティアがこれらのフィルタを管理しており、広告ブロックエコシステムの成長に不可欠なものです。AdGuardは組み込みフィルタに実在するあらゆるフィルタを全部盛り込むことはでき泣いた、カスタムフィルタが、他の多種フィルタのテストおよび配布を可能にしてくれていました。

カスタムフィルタの喪失で悪影響を受けるのはユーザーだけではありません。拡張機能がユーザーに対して有効であり続けるよう私たちAdGuardが最善を尽くしておりますが、以前にもMV3関連の記事の1つで述べたように、「MV3への移行における真の犠牲者はフィルタ開発者である」のです。
そして、ついにその時がやってきました。カスタムフィルタが失われることは、広告ブロックの世界を動かしているコミュニティにとって打撃となります。

この問題をどう解決するか

ブラウザ拡張機能の機能と利便性を維持しながら、AdGuardがフィルタリングルールを処理する方法を全面的に見直し、Chromeのポリシーに準拠させます。

以下が私たちAdGuardの対策です。

  • カスタムフィルタを復活させるために、私たちは userScripts API を使用するようにします。この API を使用することで、MV3(Manifest MV3)ポリシーに準拠したスクリプトを登録することができます。

ただし、注意点があります。ユーザーはそれらを使用するために開発者モードを有効にする必要があり、余分なステップが増えます。技術に詳しくないユーザーにとっては、これが障壁となる可能性があることは承知しています。そのため、カスタムフィルタ付きのバージョンをリリースした際には、有効化とフィルタの追加方法について、わかりやすい手順を提供するようにいたします。

  • 「臨時修正フィルタ」は、もはや元の形式では存在できないため、Chromeの審査免除プロセスを利用します。これにより、拡張機能の審査を待つことなく、フィルタをより頻繁に更新できるようになります。ただし、この方法は、DNRルールセットとセーフリストの変更のみに適用されるという制限があります。

間もなく、AdGuardブラウザ拡張機能のアップデートに2つのタイプを提供開始予定です。高速アップデートは数時間ごとに自動的に行われ、フルアップデートに対してはChromeウェブストアの審査が行われます。

この、あまり理想的だとは言えない解決策にたどり着くまでは、長い道のりでした。
以下の「この問題を進展タイムライン」は、広告を効果的にブロックし、ユーザーがフィルタリングを自分好みにカスタマイズできるようにしながら、拡張機能をChromeのポリシーに準拠させるために試したことのすべてを時系列で示したものです:

この問題の進展タイムライン

  • 1回目の申請却下:リモートスクリプト実行

AdGuardブラウザ拡張機能のChromeウェブストア審査への申請は、ルールを適用するために <script> タグを使用しているという理由で拒否されました。 確かに、拡張機能がルールからスクリプトを抽出し、それを <script> タグ経由でページに適用する仕組みを使用していました。 MV3 拡張機能では、コンテンツ・セキュリティ・ポリシーの要件が MV2 よりも厳しく、スクリプトルールを挿入するだけでは不十分です。そのため、ページコンテンツを修正する際に開発者が使用できるツールが大幅に制限されてしまいます。そのため、場合によっては、<script>タグのインジェクションを強化する必要があり、それが問題となりました。

AdGuardがとった対策:

Firefoxで使用していたソリューションを採用しました。スクリプトルールを拡張機能内に保存されたローカルJavaScript関数に変換するものです。これにより、<script>タグを使用せずにネイティブのルールを適用できるようになりました。また、スクリプトを適用する前に、それが組み込みのルールの一部であることを確認するチェックも追加しました。

しかし、ユーザールールカスタムフィルタ、臨時修正フィルタについては例外とし、これらのルールには引き続き <script> タグを使用して挿入することにしました。

これらの変更を加えたバージョンは承認されました。しかし、そうではありませんでした。

  • 2度目の却下:臨時修正フィルタのダウンロード

今回は、リモートソースから臨時修正フィルタをダウンロードする仕組みが、リモート実行ポリシーの違反としてクロームにフラグ付けされました。

AdGuardの対応:

臨時修正フィルタの目的を説明する詳細なコメントを追加し、ポリシーに違反することなく MV3 の制限に対処するために設計された仕組みを明確にしました。

しかし、クロームの審査担当者はこれでも納得せず、次のような対応を行いました。

  • 3回目と4回目の却下:臨時修正フィルタ

Chrome の要件を満たすため、Quick Fixes フィルターを完全に削除し、拡張機能を再提出しました。 再び却下されたため、サポートに連絡し、臨時修正フィルタのコードとメタデータのダウンロードを完全に無効にしたバージョンを提出しました。 このバージョンは当初は承認されましたが…。

  • 5回目の却下:スクリプトレット(Scriptlets)とパラメータ

Chrome は、組み込みの JavaScript 関数であるスクリプトレットの使用が、パラメータとともに実行される可能性があるため、リモート実行ポリシーに違反していると指摘しました。

AdGuardの対応:

すべてのスクリプトレットを拡張機能に直接ハードコードしました。拡張機能エンジンは現在、ルールが事前設定のフィルターカテゴリー(広告ブロックやセキュリティなど)に一致するかどうかを検証します。一致する場合はルールが適用され、一致しない場合は破棄されます。

また、臨時修正フィルタを限定した形で再導入しましたが、<script>ベースの実行は行われません。

これらの変更にもかかわらず、AdGuardブラウザ拡張機能は依然として却下されました。

より大きく見た全体像

もちろん、私たちAdGuardはこの状況を乗り越える方法を見つけます。それが私たちの仕事だからです。

しかし、これはAdGuardだけの問題ではありません。Chromeのポリシーはすべての広告ブロッカーや拡張機能に影響を与えます。

開発者には、Chrome ウェブストアからのより明確なガイドラインと透明性が必要なのです。

今回の状況がセキュリティと機能性のバランスについてより幅広い議論を喚起することを期待しています。このような話題は、開発者とユーザーの両方に利益をもたらします。

この記事を気に入っていただけましたか?
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for Windows

AdGuard for Windowsは、単なる広告ブロッカーではなく、広告をブロックし、危険なサイトへのアクセスを制御し、ページの読み込みを高速化し、不適切なコンテンツから子供を保護する、多目的ツールです。
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for Mac

AdGuardはmacOSの仕様を念頭に設計されたユニークな広告ブロッカーです。 ブラウザやアプリで広告を取り除くだけでなく、個人情報追跡、フィッシング、詐欺から端末を守ります。
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for Android

AdGuard for Androidは、Android搭載端末に最適なソリューションです。 他のほとんどの広告ブロッカーと違って、root権限を必要とせず、アプリでのフィルタリング、アプリ管理など、幅広い機能を提供しています。
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for iOS

AdGuard はiOSに最適な広告ブロックアプリです。Safariブラウザですべての広告を削除し、プライバシー保護、ページの読み込み時間の短縮を実現します。 また、複数のフィルタを同時に使用できるようにしながら、最高のフィルタリング品質を実現する最新の広告ブロック技術を採用しています。
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuardコンテンツブロッカー

AdGuard Content Blockerは、コンテンツブロッカーテクノロジーをサポートするモバイルブラウザー(Samsung Internet、Yandex.Browser)のすべての種類の広告を排除します。 Android for AdGuardよりも制限されていますが、無料で簡単にインストールでき、広告のブロック品質も高いです。
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard ブラウザ拡張機能

AdGuardは、Webページ上のすあらゆる広告を効果的にブロックします。また最速で軽量な広告ブロック拡張機能です!是非AdGuardを使って広告のない高速で安全なブラウジングをお楽しみください。
19,548 19548件のユーザーレビュー
素晴らしい

AdGuardアシスタント

“AdGuardデスクトップアプリのお手伝い役”ブラウザー拡張機能。カスタム要素のブロック、Webサイトのホワイトリストへの登録、報告の送信などといった機能に直接ブラウザーからアクセスできるようにします。
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard Home

AdGuard Home は、広告とトラッキング(追跡)をブロックするネットワーク全体用ソフトウェアです。 セットアップを完成すると、全ての家庭内デバイスをカバーし、クライアント側のソフトウェアさえ必要ありません。 Internet-Of-Thingsや接続するデバイスの登場と伴って、ネットワーク全体を制御することがますます重要になってきています。
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard Pro for iOS

AdGuard Pro は、通常バージョンのユーザーに既に知られているSafariの優れた広告ブロック機能以外にも多くの機能を提供いたします。 カスタムDNS設定へのアクセスを提供することで、広告ブロック、アダルトコンテンツからお子様を守り、盗難からあなたの個人データを保護することができます。
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for Safari

Appleが新しいSDKの使用を開発者全員に強制し始めてから、Safari用の広告ブロック拡張機能は苦境に立たされています。AdGuard拡張機能は、Safari用の高品質な広告ブロック機能を復活させることがミッションです。
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for Android TV

AdGuard for Android TV は、広告をブロックし、プライバシーを保護し、スマートテレビのファイアウォールとして機能する唯一のアプリです。Webの脅威に関する警告を受け取り、セキュアDNSを使用し、トラフィックを暗号化しましょう。セキュリティを向上して、広告なしでお気に入りの番組をお楽しみください!
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard for Linux

AdGuard for Linux は、世界初のシステムワイドなLinux用広告ブロッカーです。デバイスレベルで広告やトラッカーをブロックしたり、プリインストールされたフィルタから選択したり、独自のフィルタを追加したりすることができます。
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard Temp Mail

匿名性とプライバシーを保護する、無料の捨てメアド(一時メールアドレス)ジェネレーター。メインのメールサービスに迷惑メールは届きません!
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard VPN

73ヵ所の世界中ロケーション

どのコンテンツも自由にアクセス

強力な暗号化

ログ一切なしポリシー

最速コネクション

年中無休サポート(日本語対応)

無料で使ってみる
ダウンロードされますと、使用許諾契約書に同意したことになります。
詳細
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard DNS

AdGuard DNSは、広告ブロック、プライバシー保護、ペアレンタルコントロールの代替ソリューションです。初期設定が簡単で、端末のプラットフォームやデバイスに関係なく、オンライン広告、トラッカー、フィッシングに対する必要最小限の保護を提供します。
19,548 19548件のユーザーレビュー
素晴らしい

AdGuard Mail β

エイリアスと使い捨てメールアドレスを使用して、個人情報を保護し、迷惑メールを回避し、受信トレイを安全に。全OS対応の無料メール転送サービス・アプリです。
AdGuardをダウンロード中です AdGuardをインストールするには、矢印が指してるファイルをクリックしてください 「開く」を選択し、「OK」をクリックして、ファイルがダウンロードされるのをお待ちください。 ダウンロードが終了し開きましたウィンドウでAdGuardを「Applications」フォルダにドラッグで移動させてください。 AdGuardをダウンロードして頂きありがとうございます! 「開く」を選択し、「OK」をクリックして、ファイルがダウンロードされるのをお待ちください。 ダウンロードが終了し開きましたウィンドウで「インストール」をクリックしてください。 AdGuardをダウンロードして頂きありがとうございます!
以下のQRコードをスキャンすることでモバイル端末にもAdGuardをインストールできます。