From 87a5ed3fa9a504036523b65d3aad26312b8ea0f4 Mon Sep 17 00:00:00 2001 From: Ming-Ying Chung Date: Wed, 26 Jul 2023 13:56:59 +0900 Subject: [PATCH] [explainer] Add alternative approch discussions to fetchLater Also refer to #3 and whatwg/fetch#1647 --- docs/fetch-later-api.md | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/docs/fetch-later-api.md b/docs/fetch-later-api.md index 6963c79..33deb6f 100644 --- a/docs/fetch-later-api.md +++ b/docs/fetch-later-api.md @@ -138,6 +138,31 @@ class PendingBeacon { } ``` +## Alternatives Considered + +### 1. BackgroundSync API + +The [Background Synchronization API][backgroundsync-api] allows web applications to defer requests to their service worker to handle at a later time, if the device is offline. + +However, to use the API requires the control over a service worker from the top-level window open for the origin, which is impossible for 3rd party iframes that want to perform beaconing. + +Note that there are [discussions][#3] to address PendingBeacon (or fetchLater)'s privacy requirements by reusing BackgroundSync's access permission. + +[backgroundsync-api]: https://github.com/WICG/background-sync/blob/main/explainers/sync-explainer.md#the-api +[#3]: https://github.com/WICG/pending-beacon/issues/3#issuecomment-1531639163 + +### 2. BackgroundFetch API + +The [Background Fetch API][backgroundfetch-api] provides a way for service workers to defer processing until a user is connected. + +Similar to [BackgroundSync API](#1-backgroundsync-api), using BackGroundFetch also requires the control over a service worker, which is impossible for 3rd party iframes that want to perform beaconing. + +[backgroundfetch-api]: https://wicg.github.io/background-fetch/ + +### 3. Other Alternatives + +See also PendingBeacon's [Alternative Approaches](docs/alternative-approaches.md). + ## Open Discussions See [Deferred fetching PR](https://github.com/whatwg/fetch/pull/1647).