diff options
author | Masahiro FUJIMOTO <mfujimot@gmail.com> | 2021-06-06 00:08:18 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-06 00:08:18 +0900 |
commit | a4ef7708f29bbe20f9338eaaf8c3e839cb8d4467 (patch) | |
tree | 435cf41be921b4cd4f5bcfcf43ab79de541311fd | |
parent | 55c9b90af57bf54887500ed6b250f353a9216965 (diff) | |
download | translated-content-a4ef7708f29bbe20f9338eaaf8c3e839cb8d4467.tar.gz translated-content-a4ef7708f29bbe20f9338eaaf8c3e839cb8d4467.tar.bz2 translated-content-a4ef7708f29bbe20f9338eaaf8c3e839cb8d4467.zip |
Mozilla/Add-ons/WebExtensions/manifest.json/permissions を更新 (#978)
- 英語版章題マクロを削除
- 2021/02/20 時点の英語版に同期
-rw-r--r-- | files/ja/mozilla/add-ons/webextensions/manifest.json/permissions/index.html | 144 |
1 files changed, 84 insertions, 60 deletions
diff --git a/files/ja/mozilla/add-ons/webextensions/manifest.json/permissions/index.html b/files/ja/mozilla/add-ons/webextensions/manifest.json/permissions/index.html index 097d3a4102..a139d5c23a 100644 --- a/files/ja/mozilla/add-ons/webextensions/manifest.json/permissions/index.html +++ b/files/ja/mozilla/add-ons/webextensions/manifest.json/permissions/index.html @@ -4,25 +4,28 @@ slug: Mozilla/Add-ons/WebExtensions/manifest.json/permissions tags: - Add-ons - Extensions + - Permissions + - Reference - WebExtensions + - manifest.json translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/permissions --- -<div>{{AddonSidebar}}</div> +<p>{{AddonSidebar}}</p> <table class="fullwidth-table standard-table"> <tbody> <tr> - <th scope="row" style="width: 50%;"><strong>型</strong></th> + <th scope="row" style="width: 30%;">型</th> <td><code>Array</code></td> </tr> <tr> - <th scope="row"><strong>必須項目か?</strong></th> + <th scope="row">必須項目か?</th> <td>いいえ</td> </tr> <tr> - <th scope="row"><strong>例</strong></th> + <th scope="row">例</th> <td> - <pre class="brush: json no-line-numbers"> + <pre class="brush: json; no-line-numbers"> "permissions": [ "*://developer.mozilla.org/*", "webRequest" @@ -32,51 +35,53 @@ translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/permissions </tbody> </table> -<p>拡張機能が特別な権限を必要とする際には <code>permission</code> キーを使用します。このキーには文字列の配列を指定し、各文字列がパーミッションを要求します。</p> +<p>拡張機能が特別な権限を必要とする際には <code>permissions</code> キーを使用します。このキーには文字列の配列を指定し、各文字列が権限を要求します。</p> -<p>このキーを用いてパーミッションを要求した場合、ブラウザーはインストール時に「この拡張機能はこれだけの特権を要求しています」と通知し、これらの特権を許可しても大丈夫かとユーザーに確認します。ブラウザーはまた、インストール後にユーザーがアドオンの特権を調査することも許可します。</p> +<p>このキーを使って権限を要求した場合、ブラウザーはインストール時に、拡張機能が特定の権限を要求していることをユーザーに伝え、その権限を許可してもよいかどうかを確認するよう求めることがあります。また、ブラウザーは、インストール後にユーザーが拡張機能の権限を検査できるようにすることもできます。権限付与の要求は、ユーザーが拡張機能をインストールする意欲に影響を与える可能性があるため、権限の要求は慎重に検討する必要があります。たとえば、不要な権限を要求することは避けたいもので、拡張機能のストアの説明に権限を要求する理由についての情報を提供するとよいでしょう。検討すべき事項の詳細については、 <a href="https://extensionworkshop.com/documentation/develop/request-the-right-permissions/">Request the right permissions</a> の記事にあります。</p> + +<p>許可証のテストとプレビューの方法については、 Extension Workshop サイトの <a href="https://extensionworkshop.com/documentation/develop/test-permission-requests/">Test permission requests</a> を参照してください。</p> <p>キーには以下の 3 種類があります。</p> <ul> - <li>host パーミッション</li> - <li>API パーミッション</li> - <li>activeTab パーミッション</li> + <li>host 権限</li> + <li>API 権限</li> + <li>activeTab 権限</li> </ul> -<p>{{英語版章題("Host permissions")}}</p> - -<h2 id="host_パーミッション">host パーミッション</h2> +<h2 id="Host_permissions">host 権限</h2> -<p>host パーミッションは<a href="https://developer.mozilla.org/ja/docs/Mozilla/Add-ons/WebExtensions/Match_patterns">マッチパターン</a>として指定します。それぞれのパターンによって、アドオンの要求する権限が有効となる URL の範囲を指定します。host パーミッションの例は <code>"*://developer.mozilla.org/*"</code> のようなものです。</p> +<p>host 権限は<a href="/ja/docs/Mozilla/Add-ons/WebExtensions/Match_patterns">マッチパターン</a>として指定します。それぞれのパターンによって、アドオンの要求する権限が有効となる URL の範囲を指定します。host 権限の例は <code>"*://developer.mozilla.org/*"</code> のようなものです。</p> <p>この権限には以下が含まれます。</p> <ul> - <li>そのオリジンに対して、クロス-オリジン制約なしに <a href="https://developer.mozilla.org/ja/docs/Web/API/XMLHttpRequest">XMLHttpRequest</a> アクセス、 <a href="https://developer.mozilla.org/ja/docs/Web/API/Fetch_API">fetch</a> アクセスができる権限(コンテンツスクリプトからのリクエストによるものも含みます)</li> - <li>そのオリジンによるページに(<a href="https://developer.mozilla.org/ja/docs/Mozilla/Add-ons/WebExtensions/API/tabs/executeScript">tabs.executeScript</a> を用いて)スクリプトをプログラム的に挿入できる権限</li> - <li><a href="https://developer.mozilla.org/ja/docs/Mozilla/Add-ons/WebExtensions/API/webRequest">webRequest</a> API を用いて、そのホストからのイベントを受信できる権限</li> - <li><a href="https://developer.mozilla.org/ja/Add-ons/WebExtensions/API/cookies">cookies</a> API を用いて、そのホストの Cookie にアクセスできる権限("cookies" API のパーミッションが指定されている場合)</li> - <li>ホスト名が完全修飾ドメインであり、ワイルドカードを含まない場合にトラッキング防止を回避。<code><all_urls></code> については除外。</li> + <li>そのオリジンに対して、クロス-オリジン制約なしに <a href="/ja/docs/Web/API/XMLHttpRequest">XMLHttpRequest</a> アクセス、 <a href="/ja/docs/Web/API/Fetch_API">fetch</a> アクセスができる権限 (コンテンツスクリプトからのリクエストによるものも含みます)</li> + <li>"tabs" 権限なしに、タブ固有のメタデータを読み取ることができる権限。 {{WebExtAPIRef("tabs.Tab")}} オブジェクトの <code>url</code>, <code>title</code>, <code>favIconUrl</code> などのプロパティです。</li> + <li>そのオリジンによるページに ({{webextAPIref("tabs/executeScript", "tabs.executeScript()")}} を用いて) スクリプトをプログラム的に挿入できる権限</li> + <li>{{webextAPIref("webrequest")}} API を用いて、そのホストからのイベントを受信できる権限</li> + <li>{{webextAPIref("cookies")}} API を用いて、そのホストの Cookie にアクセスできる権限("cookies" API の権限が指定されている場合)</li> + <li>ホストが完全修飾ドメインまたはワイルドカードで指定されている拡張ページのトラッキング防止機能をバイパスすることができます。しかし、コンテンツスクリプトでは、完全修飾ドメインで指定されたホストに対してのみトラッキング防止機能をバイパスすることができます。 + + ホスト名が完全修飾ドメインであり、ワイルドカードを含まない場合にトラッキング防止を回避。<code><all_urls></code> については除外。</li> </ul> -<p>Firefox では バージョン 56 以降で拡張機能は自動的に自身をオリジンとする host パーミッションを次の形式で取得します:</p> +<p>Firefox では バージョン 56 以降で拡張機能は自動的に自身をオリジンとする host 権限を次の形式で取得します。</p> <pre><code>moz-extension://60a20a9b-1ad4-af49-9b6c-c64c98c37920/</code></pre> -<p>ここで <code>60a20a9b-1ad4-af49-9b6c-c64c98c37920</code> は拡張機能の内部 ID です。拡張機能は <a href="https://developer.mozilla.org/ja/docs/Mozilla/Add-ons/WebExtensions/API/extension/getURL">extension.getURL()</a> を呼び出すことでこの URL を取得できます:</p> - -<pre class="brush: js line-numbers language-js"><code class="language-js">browser<span class="punctuation token">.</span>extension<span class="punctuation token">.</span><span class="function token">getURL</span><span class="punctuation token">(</span><span class="string token">""</span><span class="punctuation token">)</span><span class="punctuation token">;</span> -<span class="comment token">// moz-extension://60a20a9b-1ad4-af49-9b6c-c64c98c37920/</span></code></pre> +<p>ここで <code>60a20a9b-1ad4-af49-9b6c-c64c98c37920</code> は拡張機能の内部 ID です。拡張機能は {{webextAPIref("extension/getURL", "extension.getURL()")}} を呼び出すことでこの URL を取得できます。</p> -<p>{{英語版章題("API permissions")}}</p> +<pre class="brush: js">browser.extension.getURL(""); +// moz-extension://60a20a9b-1ad4-af49-9b6c-c64c98c37920/ +</pre> -<h2 id="API_パーミッション">API パーミッション</h2> +<h2 id="API_permissions">API 権限</h2> -<p>API パーミッションには、拡張機能から使用したい WebExtension API の名前をキーワードとして指定します。</p> +<p>API 権限には、拡張機能から使用したい <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API">WebExtension API</a> の名前をキーワードとして指定します。</p> <p>現時点で使用できるキーワードは以下の通りです。</p> - +<div class="threecolumns"> <ul> <li><code>activeTab</code></li> <li><code>alarms</code></li> @@ -84,11 +89,15 @@ translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/permissions <li><code>bookmarks</code></li> <li><code>browserSettings</code></li> <li><code>browsingData</code></li> + <li><code>captivePortal</code></li> + <li><code>clipboardRead</code></li> + <li><code>clipboardWrite</code></li> <li><code>contentSettings</code></li> <li><code>contextMenus</code></li> <li><code>contextualIdentities</code></li> <li><code>cookies</code></li> <li><code>debugger</code></li> + <li><code>dns</code></li> <li><code>downloads</code></li> <li><code>downloads.open</code></li> <li><code>find</code></li> @@ -98,37 +107,46 @@ translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/permissions <li><code>idle</code></li> <li><code>management</code></li> <li><code>menus</code></li> + <li><code>menus.overrideContext</code></li> <li><code>nativeMessaging</code></li> <li><code>notifications</code></li> <li><code>pageCapture</code></li> <li><code>pkcs11</code></li> <li><code>privacy</code></li> <li><code>proxy</code></li> + <li><code>search</code></li> <li><code>sessions</code></li> <li><code>storage</code></li> + <li><code>tabHide</code></li> <li><code>tabs</code></li> <li><code>theme</code></li> <li><code>topSites</code></li> + <li><code>unlimitedStorage</code></li> <li><code>webNavigation</code></li> <li><code>webRequest</code></li> <li><code>webRequestBlocking</code></li> </ul> +</div> -<p>ほとんどの場合、パーミッションはその API へのアクセス権を付与するだけですが、以下のような例外があります。</p> +<p>ほとんどの場合、権限はその API へのアクセス権を付与するだけですが、以下のような例外があります。</p> <ul> - <li><code>tabs</code> パーミッションを指定した場合、<a href="/ja/Add-ons/WebExtensions/API/tabs">特別な <code>tabs</code> API のパーツ</a> (<code>Tab.url</code> / <code>Tab.title</code> / <code>Tab.faviconUrl</code>)にアクセスすることが許可されます。 Firefox では、<code><a href="https://developer.mozilla.org/ja/docs/Mozilla/Add-ons/WebExtensions/API/tabs/query">tabs.query()</a></code> の <code>queryInfo</code> パラメーターに <code>url</code> を入れるのにも <code>tabs</code> が必要です。他の <code>tabs</code> API についてはパーミッションの要求なしで使用できます。</li> - <li><code>webRequestBlocking</code> パーミッションを指定した場合、"blocking" 引数の使用が許可されます。これによって<a href="https://developer.mozilla.org/ja/Add-ons/WebExtensions/API/WebRequest">リクエストの変更やキャンセル</a>が可能となります。</li> - <li><code>downloads.open</code> パーミッションを指定した場合、{{WebExtAPIRef("downloads.open()")}} API の利用が許可されます。</li> + <li><code>tabs</code> 権限は、 {{webextAPIref("tabs", "<code>tabs</code> API のうち特権が必要なもの")}}に対して、 <a href="/ja/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions#host_permissions">host 権限</a>なしにアクセスできます。対象は <code>Tab.url</code>, <code>Tab.title</code>, <code>Tab.faviconUrl</code> です。 + <ul> + <li>Firefox 85 以前では、 <code>tabs</code> は <code>url</code> を <code>queryInfo</code> 引数に含めて {{webextAPIref("tabs/query", "tabs.query()")}} を呼び出す際にも必要です。 <code>tabs</code> API の他の部分は、権限を要求することなく使用できます。</li> + <li>Firefox 86 および Chrome 50 では、 "tabs" 権限の代わりに matching <a href="/ja/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions#host_permissions">host 権限</a>を使用することもできます。</li> + </ul> + </li> + <li><code>webRequestBlocking</code> 権限を指定した場合、"blocking" 引数の使用が許可されます。これによって{{webextAPIref("WebRequest", "リクエストの変更やキャンセル")}}が可能となります。</li> + <li><code>downloads.open</code> 権限を指定した場合、{{WebExtAPIRef("downloads.open()")}} API の利用が許可されます。</li> + <li><code>tabHide</code> で {{WebExtAPIRef("tabs.hide()")}} API の使用が許可されます。</li> </ul> -<p>{{英語版章題("activeTab permission")}}</p> - -<h2 id="activeTab_パーミッション">activeTab パーミッション</h2> +<h2 id="activeTab_permission">activeTab 権限</h2> -<p>このパーミッションは <code>"activeTab"</code> と指定されます。拡張機能が <code>activeTab</code> パーミッションを持つなら、ユーザーが拡張機能と相互作用する時に、拡張機能はアクティブなタブ限定の特別な権限が許可されます。</p> +<p>この権限は <code>"activeTab"</code> と指定されます。拡張機能が <code>activeTab</code> 権限を持つなら、ユーザーが拡張機能と相互作用する時に、拡張機能はアクティブなタブ限定の特別な権限が許可されます。</p> -<p>"ユーザーの相互作用" とは次のようなものです:</p> +<p>"ユーザーの相互作用" とは次のようなものです。</p> <ul> <li>ブラウザーアクションやページアクションをクリック</li> @@ -136,55 +154,61 @@ translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/permissions <li>拡張機能によって定義されたキーボードショートカットをアクティベート</li> </ul> -<p>特別な権限とは:</p> +<p>特別な権限とは以下の通りです。</p> <ul> - <li><code><a href="https://developer.mozilla.org/ja/Add-ons/WebExtensions/API/tabs/executeScript">chrome.tabs.executeScript</a></code> と <code><a href="https://developer.mozilla.org/ja/Add-ons/WebExtensions/API/tabs/insertCSS">chrome.tabs.insertCSS</a></code> を用いてタブに JavaScript や CSS をプログラム的に挿入できる能力</li> + <li>{{webextAPIref("tabs/executeScript", "browser.tabs.executeScript()")}} と {{webextAPIref("tabs/insertCSS", "browser.tabs.insertCSS()")}} を用いてタブに JavaScript や CSS をプログラム的に挿入できる能力</li> <li>現在のタブに、次の一部の tabs API の権限アクセス: <code>Tab.url</code>, <code>Tab.title</code>, <code>Tab.faviconUrl</code>.</li> </ul> -<p>このパーミッションの意図は、拡張機能によくあるユースケースを、強力すぎるパーミッションを与えずに実行できるようにすることです。多くの拡張機能は「ユーザーが希望したら現在のページで何かをする」ことを希望しています。例えば、ユーザーがブラウザーアクションをクリックした時に現在のページでスクリプトを実行する拡張機能を考えます。<code>activeTab</code> パーミッションがない場合、拡張機能は <code><all_urls></code> の host パーミッションを要求する必要があります。しかし、これは拡張機能に必要以上の力を与えています: アクティブなタブで単にユーザーアクションに応答する代わりに、いかなるタブで、いかなるタイミングで、スクリプトを実行できます。</p> +<p>この権限の意図は、拡張機能によくあるユースケースを、強力すぎる権限を与えずに実行できるようにすることです。多くの拡張機能は「ユーザーが希望したら現在のページで何かをする」ことを希望しています。</p> -<p>{{英語版章題("Clipboard access")}}</p> +<p>例えば、ユーザーがブラウザーアクションをクリックした時に現在のページでスクリプトを実行する拡張機能を考えます。<code>activeTab</code> 権限がない場合、拡張機能は <code><all_urls></code> の host 権限を要求する必要があります。しかし、これは拡張機能に必要以上の力を与えています。アクティブなタブで単にユーザーアクションに応答する代わりに、<em>任意のタブ</em>で、<em>任意の時</em>に、スクリプトを実行できます。</p> -<h2 id="Clipboard_access" name="Clipboard_access">クリップボードのアクセス</h2> +<div class="notecard note"> +<p><strong>注:</strong> ユーザー操作 (例:クリック) が発生したときに存在していたタブ/データにのみアクセスできます。アクティブなタブが移動すると (例:読み込みの終了やその他のイベントにより)、権限はそのタブへのアクセスを許可しなくなります。</p> +</div> -<p>拡張機能にクリップボードとやりとりできるようにする、2つの権限があります:</p> +<p>通常、 <code>activeTab</code> が付与されるタブは、 1 つのケースを除いて、単に現在アクティブなタブです。 {{webextAPIref("menus")}} API では、ユーザーがタブをコンテキストクリックしたときに表示されるメニュー項目を作成することができます (つまり、ユーザーがあるタブから別のタブに切り替えることができるタブトリップの要素)。</p> -<ul> - <li><code>clipboardWrite</code>: <code>document.execCommand("copy")</code> か <code>document.execCommand("cut")</code> を使ったクリップボードの書き込み</li> - <li><code>clipboardRead</code>: <code>document.execCommand("paste")</code> を使ったクリップボードの読み込み</li> -</ul> +<p>ユーザーがこのような項目をクリックした場合、ユーザーがクリックしたタブが現在のアクティブなタブでなくても、activeTab 権限が付与されます (Firefox 63 以降、{{bug(1446956)}})。</p> + +<h2 id="Clipboard_access">クリップボードのアクセス</h2> + +<p>拡張機能にクリップボードとやりとりできるようにする、 2 つの権限があります。</p> + +<dl> + <dt><code>clipboardWrite</code></dt> + <dd>{{DOMxRef("Clipboard.write()")}}, {{DOMxRef("Clipboard.writeText()")}}, <code>document.execCommand("copy")</code>, <code>document.execCommand("cut")</code> を用いたクリップボードへの書き込み</dd> + <dt><code>clipboardRead</code></dt> + <dd>{{DOMxRef("Clipboard.read()")}}, {{DOMxRef("Clipboard.readText()")}}, <code>document.execCommand("paste")</code> を用いたクリップボードからの読み込み</dd> +</dl> <p>これについての詳細は<a href="/ja/docs/Mozilla/Add-ons/WebExtensions/Interact_with_the_clipboard">クリップボードと相互作用する</a>を見てください。</p> -<h2 id="Unlimited_storage" name="Unlimited_storage">Unlimited storage</h2> +<h2 id="Unlimited_storage">Unlimited storage</h2> -<p><code>unlimitedStorage</code> パーミッションは:</p> +<p><code>unlimitedStorage</code> 権限は以下の通りです。</p> <ul> <li>拡張機能に {{WebExtAPIRef("storage.local")}} API で制限する容量を超えられるようにする</li> - <li>Firefox では<a href="/ja/docs/Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria#Firefox_specifics">「永続的な」IndexedDB データベース</a>の作成を、データベース作成時にブラウザーからユーザーに許可を確認することなく、可能にする</li> + <li>Firefox では<a href="/ja/docs/Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria#firefox_specifics">「永続的な」IndexedDB データベース</a>の作成を、データベース作成時にブラウザーからユーザーに許可を確認することなく、可能にする</li> </ul> -<p>{{英語版章題("Example")}}</p> - -<h2 id="例">例</h2> +<h2 id="Example">例</h2> -<pre class="brush: json"> "permissions": ["*://developer.mozilla.org/*"]</pre> +<pre class="brush: json no-line-numbers"> "permissions": ["*://developer.mozilla.org/*"]</pre> -<p>これは developer.mozilla.org ドメイン配下のページにアクセスする権限を要求しています。</p> +<p>これは <code>developer.mozilla.org</code> ドメイン配下のページにアクセスする権限を要求しています。</p> -<pre class="brush: json"> "permissions": ["tabs"]</pre> +<pre class="brush: json no-line-numbers"> "permissions": ["tabs"]</pre> <p><code>tabs</code> API を使用する権限を要求しています。</p> -<pre class="brush: json"> "permissions": ["*://developer.mozilla.org/*", "tabs"]</pre> +<pre class="brush: json no-line-numbers"> "permissions": ["*://developer.mozilla.org/*", "tabs"]</pre> <p>上記の権限を両方ともに要求しています。</p> -<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザー実装状況</h2> - -<p class="hidden">The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p> +<h2 id="Browser_compatibility">ブラウザーの互換性</h2> <p>{{Compat("webextensions.manifest.permissions")}}</p> |