windows10/Brave 1.76.74 Chromium: 134.0.6998.89
chrome.contentSettings.javascript.set({
prinamaryPattern: “https://brave.com/*”, // any
value: “block”
});
- このコードは、primaryPatternにマッチしたサイトのjsを無効にします。
- コードを実行 & primaryPatternにマッチするサイト(この場合 https://brave.com)のShildsをOffにする。
- ShieldsはOffになるが、chrome extensionsによって、サイトのjsを無効にしたはずが、有効になってしまう(jsがリクエストされる)。
このバグを至急改善して欲しいです。
@anpanchi こんにちは。
担当部署に調査依頼するにあたって以下の情報をご提供いただけますでしょうか。
- 再現操作手順
- 実際の操作結果
- 想定していた操作結果
- 再現頻度
- エビデンス的なもの(スクリーンショット)など
以上、よろしくお願いいたします。
再現操作手順
- フォルダの作成: フォルダ名: test
- test配下に2つのファイルを作成する
ファイル名: manifest.json
テキスト:
{
“name”: “test”,
“manifest_version”: 3,
“version”: “0”,
“permissions”: [
“contentSettings”
],
“background”: {
“service_worker”: “bg.js”
}
}
ファイル名: bg.js
// 前回の質問のコードに不備があるため、訂正します
テキスト:
chrome.contentSettings.javascript.set({
primaryPattern: “https://brave.com/*”,
setting: “block”
});
- brave://extensions/ からデベロッパーモードを有効にする。
- パッケージ化されいない拡張機能を読み込むをクリックし、1で作成したフォルダを選択する。
- 新しいタブを開いて、F12で開発者ツール起動後,Networkをクリックする。
- https://brave.comにアクセスする。
- 開発者ツールのNetworkを見たとき、拡張機能によってjavascriptが無効化されているため、.jsファイルにリクエストがされないことを確認してください。この動作はアドレスバーのBrave Shieldsが有効であることが条件です。これは正常な動作であり問題ありません。
- brave.comを開いている状態で、アドレスバーの最も右にあるBrave Shieldsから"次のサイトでシールドオン"をオフにする。
- 開発者ツールを起動してある状態で、F5で再度brave.comにアクセスする。
- 開発者ツールのNetworkを見たとき、拡張機能によってjavascriptが無効にされているはずが、.jsファイルにリクエストしてため、正常な動作ではありません。期待する動作は.jsファイルにリクエストしません。
補足:
アドレスバーの最も左にあるボタンから、拡張機能によるjsが有効かどうか確認できます。primaryPatternはhttps://brave.com/* としましたが、ここは、有効なURLPatternなら何でも構いません。またsettingの値は"block"から"allow”にして、拡張機能を再読み込みすれば、javascriptを有効にすることができます
@anpanchi こんにちは。
詳細を追記いただき、まことにありがとうございます。まず、このスクリプト自体はBraveでも動作しますが、Braveにおいては Shieldsの設定をカスタマイズするスクリプトとして動作します。
- Brave Shieldsはデフォルトではスクリプトブロックは無効です。
- ご提示の拡張機能が無効のままbrave.comにアクセスをした際に、スクリプトブロックが無効になっていることを確認します。
- 拡張機能を有効にします。
- 再度brave.comをリロードすると設定変更はしていないにも関わらず、スクリプトブロックが有効になっていることが確認できます。この設定変更が、スクリプトによって制御されたものになります。
- スクリプトはあくまでもShieldsの設定の制御として機能しているため、Shieldsを無効にするとスクリプトブロック自体も無効になります。
- Shields有効の状態で拡張機能を無効にすると、スクリプトブロックは無効の状態に戻ります。
参考までに、Shieldsとは別に拡張機能によってスクリプトブロックを行う必要がある理由があれば教えていただけますでしょうか。ユーザーフィードバックとして担当部署に共有させていただきます。