This questionnaire covers the FetchLater API
explainer, based on the W3C TAG Self-Review Questionnaire: Security and Privacy.
-
What information does this feature expose, and for what purposes?
The API intends to provide a reliable way for a document to send data to the target URL on document discard, or sometimes later after the document entering bfcache (becoming non-"fully active"), by making the user agent process the "send" requests queued by calling the API.
The user agent should not expose the queued requests to new network providers after users navigating away from the document where the requests were queued without user permission.
Users can disallow the "sending after navigating away" behavior by disabling BackgroundSync for an origin.
The API only sends requests in CORS mode with Same-Origin credentials mode.
-
What information does your spec expose to the first party that the first party cannot currently easily determine.
No extra information exposed.
-
What information does your spec expose to third parties that third parties cannot currently easily determine.
No extra information exposed.
Note that the API only sends requests in CORS mode with Same-Origin credentials mode.
-
What potentially identifying information does your spec expose to the first party that the first party can already access (i.e., what identifying information does your spec duplicate or mirror).
The API spec does not directly deal with potentially identifying information. But the API users can learn when a document is discarded or put into bfcache (becoming non-"fully active"), which is already available by using the corresponding event handlers.
-
What potentially identifying information does your spec expose to third parties that third parties can already access.
Same as above.
-
-
Do features in your specification expose the minimum amount of information necessary to enable their intended uses?
Yes. No information is directly exposed by the API itself.
-
Do the features in your specification expose personal information, personally-identifiable information (PII), or information derived from either?
No. The API itself does not expose such information. However, the API users can collect such information and send them via the API.
-
How do the features in your specification deal with sensitive information?
No. The API itself does not expose such information. However, the API users can collect such information and send them via the API.
-
Do the features in your specification introduce new state for an origin that persists across browsing sessions?
- Queued requests does NOT persist across browsing sessions if "Crash Recovery" is not supported.
- Queued requests persist across browsing session if "Crash Recovery" is supported. We are still unsure how to address privacy concern for this, so it's not specified yet.
Note: The API provides a way to queue HTTPS requests on a document which will be send by the user agent sometimes later, but before the document is discarded/browsing session ends if without "Crash Recovery".
-
Do the features in your specification expose information about the underlying platform to origins?
No. The API itself does not expose such information. However, the API users can collect such information and send them via the API.
-
Does this specification allow an origin to send data to the underlying platform?
No.
-
Do features in this specification enable access to device sensors?
No.
-
Do features in this specification enable new script execution/loading mechanisms?
No.
-
Do features in this specification allow an origin to access other devices?
No. The users can use API to send HTTP requests to a target URL which might be other devices. But the responses are discarded by user agent.
-
Do features in this specification allow an origin some measure of control over a user agent's native UI?
No.
-
What temporary identifiers do the features in this specification create or expose to the web?
No.
-
How does this specification distinguish between behavior in first-party and third-party contexts?
Both 1st party and 3rd party can use the API.
-
How do the features in this specification work in the context of a browser’s Private Browsing or Incognito mode?
The queued requests only persist in memory, i.e. whether "Crash Recovery" is supported or not is not relevant. If in a browsing mode, the document is made impossible for history navigation, i.e. it gets discarded instead of becoming non-"fully active", all queued requests will be sent right on document discard.
-
Does this specification have both "Security Considerations" and "Privacy Considerations" sections?
Yes.
-
Do features in your specification enable origins to downgrade default security protections?
No.
-
How does your feature handle non-"fully active" documents?
The API provides some mechanism for users to specify when to send the queued requests after custom time, even if the document is non-"fully active" at the specified time.
The data of the queued requests should only come from the API calls when the document is still active. If the document transits from non-"fully active" to fully active again, the API can continue to be pending, and potentially be aborted by uers from the API calls in the document.
If BackgroundSync permission is not enabled for the Origin of the document, the user agent should not allow the queued requests after the document becomes non-"fully active", i.e. they should all be sent out on navigating away.
The user agent sends out all queued requests if a non-"fully active" document gets unloaded (discard).
-
What should this questionnaire have asked?
How long can a request be queued on a document by this feature?