From c858eb27653fe2d26cd99b228707693d61adfc5f Mon Sep 17 00:00:00 2001
From: snianu <45411397+snianu@users.noreply.github.com>
Date: Tue, 13 Feb 2024 16:00:42 -0800
Subject: [PATCH] Add non-normative and optional texts. (#208)
* Add non-normative and optional texts.
* Address PR comments.
---
index.bs | 33 ++++++++++++++++++++-------------
1 file changed, 20 insertions(+), 13 deletions(-)
diff --git a/index.bs b/index.bs
index e322d5b..841ca01 100644
--- a/index.bs
+++ b/index.bs
@@ -543,18 +543,23 @@ url: https://w3c.github.io/permissions/#permissions-task-source; type: dfn;
and suffix (after stripping out `"web "`) passes the [=parsing a MIME type=] check.
Unsanitized data types
+ This section is non-normative.
These data types MUST NOT be sanitized by UAs:
* image/png
+ These data types MAY NOT be sanitized by UAs:
+
* [=optional unsanitized data types=]
- Optional unsanitized data types are [=representation/mime type=]s specified by the web authors that MUST NOT be sanitized by the user agent.
+ Optional unsanitized data types are [=representation/mime type=]s specified by the web authors that MAY NOT be sanitized by the user agent.
The valid [=optional unsanitized data types=] are listed below:
* text/html
+ [=optional unsanitized data types=] may not be supported by a user agent due to their privacy requirements.
+
Asynchronous Clipboard API
Navigator Interface
@@ -817,6 +822,8 @@ url: https://w3c.github.io/permissions/#permissions-task-source; type: dfn;
{{ClipboardUnsanitizedFormats/unsanitized}} is a [=sequence=] of {{DOMString}}s corresponding to the [=representation/mime type=] that the author wants to be treated as [=optional unsanitized data types=].
+ The {{ClipboardUnsanitizedFormats/unsanitized}} option MAY NOT be supported by the user agent. The web authors shouldn't assume that the content for the MIME types listed in {{ClipboardUnsanitizedFormats/unsanitized}} would be unsanitized as there could be privacy modes where this option may not be allowed.
+
The clipboard task source is triggered in response to reading or writing of [=system clipboard data=].
@@ -870,13 +877,13 @@ url: https://w3c.github.io/permissions/#permissions-task-source; type: dfn;
1. If |format| is equal to [=representation/MIME type=], set |isUnsanitized| to true.
- 1. Set |representation|'s [=representation/data=] to |systemClipboardRepresentation|'s [=system clipboard representation/data=].
+ 1. Resolve |representation|'s [=representation/data=] with |systemClipboardRepresentation|'s [=system clipboard representation/data=].
Issue: It should be possible to read the data asynchronously from the system clipboard after the author calls getType, however, this set of steps implies that data will be provided at the time of read.
- 1. The user agent, MUST NOT sanitize |representation|'s [=representation/data=], if it satisfies the below conditions:
+ 1. The user agent, MAY sanitize |representation|'s [=representation/data=], unless |representation|'s [=representation/MIME type=]'s essence is "image/png", which should remain unsanitized to preserve meta data, or if it satisfies the below conditions:
- 1. |representation|'s [=representation/MIME type=] is in [=unsanitized data types=] list.
+ 1. |representation|'s [=representation/MIME type=] is in optional [=unsanitized data types=] list.
1. |isUnsanitized| is true.
@@ -885,20 +892,20 @@ url: https://w3c.github.io/permissions/#permissions-task-source; type: dfn;
1. Set |isUnsanitized| to |false|.
1. If |item|'s [=list of representations=] size is greater than 0, append |item| to |items|.
-
- If |items| has a size > 0, then:
+
+ 1. If |items| has a size > 0, then:
- 1. Let |firstItem| be |items|[0]
+ 1. Let |firstItem| be |items|[0]
+
+ 1. Run the [=read web custom format=] algorithm given |firstItem|.
- 1. Run the [=read web custom format=] algorithm given |firstItem|.
-
- Else:
+ 1. Else:
- 1. Let |customItem| be a new [=/clipboard item=].
+ 1. Let |customItem| be a new [=/clipboard item=].
- 1. Run the [=read web custom format=] algorithm given |customItem|.
+ 1. Run the [=read web custom format=] algorithm given |customItem|.
- 1. If |customItem|'s [=list of representations=] size is greater than 0, append |item| to |items|.
+ 1. If |customItem|'s [=list of representations=] size is greater than 0, append |customItem| to |items|.
1. [=Queue a global task=] on the [=clipboard task source=], given |realm|'s [=realm/global object=], to perform the below steps: