-
Notifications
You must be signed in to change notification settings - Fork 181
Security & privacy self review: WebAuthn Large Blob Extension
TAG review requires filling a Security and Privacy questionnaire.
-
What information might this feature expose to Web sites or other parties, and for what purposes is that exposure necessary?
The large blob extension will expose the following information to relying parties (i.e. websites):
- On registration, whether the authenticator selected by the user supports large blobs or not. This lets relying parties decide e.g. to show an error to the user or to disable whichever feature would have made use of large blobs.
- On assertion, the large blob that was previously stored by the same relying party. This is the point of the feature. The blob will only ever be revealed to the relying party after the user consents to asserting a credential.
-
Do features in your specification expose the minimum amount of information necessary to enable their intended uses?
Correct. No other information is revealed by the use of the extension.
-
How do the features in your specification deal with personal information, personally-identifiable information (PII), or information derived from them?
By design, this feature lets sites store and retrieve arbitrary data. It's up to the site to define what data this is. The data is protected the same way as regular discoverable credentials, which by nature of being for authentication can usually be considered PII. See the webauthn privacy considerations.
-
How do the features in your specification deal with sensitive information?
See #3.
-
Do the features in your specification introduce new state for an origin that persists across browsing sessions?
WebAuthn discoverable credentials already persist between browsing sessions. Large blob lets websites add arbitrary data to these credentials.
-
Do the features in your specification expose information about the underlying platform to origins?
Somewhat. After creating or asserting a credential, the browser will indicate support of the feature. Support depends on the browser, platform (on Windows, large blob is only supported for versions >= 11), and authenticator. For example, a relying party that knows a user is on Windows can infer that they are on a fairly recent version if large blob registration succeeds.
This information is not very practical to use for fingerprinting the user since it requires the user to go through a registration or assertion ceremony.
-
Does this specification allow an origin to send data to the underlying platform?
Yes. If the large blob is stored on a platform credential, by definition the platform would store that blob.
-
Do features in this specification enable access to device sensors?
No.
-
What data do the features in this specification expose to an origin? Please also document what data is identical to data exposed by other features, in the same or different contexts.
See #1. Large blobs that were previously stored by the same origin, and whether they are supported by the given authenticator & platform. This data is new.
-
Do features in this specification enable new script execution/loading mechanisms?
No.
-
Do features in this specification allow an origin to access other devices?
WebAuthn by definition exposes an API to use devices for authentication. The large blob extension does not add new devices that can be used.
-
Do features in this specification allow an origin some measure of control over a user agent’s native UI?
A user agent may choose to inform the user large blob is required for the request, but other than that, no.
-
What temporary identifiers do the features in this specification create or expose to the web?
None.
-
How does this specification distinguish between behavior in first-party and third-party contexts?
Large blobs does not change how WebAuthn treats first-party vs third-party contexts. For specific guidance on webauthn & iframes, see Using Web Authentication within iframe elements.
-
How do the features in this specification work in the context of a browser’s Private Browsing or Incognito mode?
Similar to how discoverable credentials already work, it is not possible for a relying party to know if the authenticator does not support the feature, or the user agent (or user) denied consent. It should not be possible then to infer the user is in a private session from this extension.
Storing a large blob will leave information that outlasts the incognito session. This matches the existing behaviour for discoverable credentials. Chrome already has a warning for incognito mode when storing a discoverable credential (which is effectively a requirement for large blobs) and tells the user of this fact.
-
Does this specification have both "Security Considerations" and "Privacy Considerations" sections?
-
Do features in your specification enable origins to downgrade default security protections?
No.
-
How does your feature handle non-"fully active" documents?
No information is shared with the website until the user consents, so that can't happen if the document is not fully active. In practice, a
navigator.credentials.get()
/navigator.credentials.create()
request will be paused with the promise remaining unresolved, and may be resumed if the document becomes fully active again.