From 9b424db0bf6f82cb09156178ed70ab2bbc695528 Mon Sep 17 00:00:00 2001 From: "Dustin J. Mitchell" Date: Thu, 7 Mar 2024 11:42:48 -0500 Subject: [PATCH] Pluralize form-factors header/property (#358) --- README.md | 10 +++++----- index.bs | 30 +++++++++++++++--------------- 2 files changed, 20 insertions(+), 20 deletions(-) diff --git a/README.md b/README.md index 67c5bff..8736682 100644 --- a/README.md +++ b/README.md @@ -12,7 +12,7 @@ a corresponding JavaScript API: * `Sec-CH-UA-Platform` * `Sec-CH-UA-Platform-Version` * `Sec-CH-UA` -* `Sec-CH-UA-Form-Factor` +* `Sec-CH-UA-Form-Factors` * `Sec-CH-UA-Full-Version` (deprecated in favor of `Sec-CH-UA-Full-Version-List`) * `Sec-CH-UA-Full-Version-List` * `Sec-CH-UA-WoW64` @@ -203,14 +203,14 @@ accomplish this as follows: Sec-CH-UA-Bitness: "64" ``` - 1. The `Sec-CH-UA-Form-Factor` header field represents the form-factor of a device, historically + 1. The `Sec-CH-UA-Form-Factors` header field represents the form-factor of a device, historically represented as a <deviceCompat> token in the User-Agent string (e.g., "Tablet", "VR", etc.) For example: ```http - Sec-CH-UA-Form-Factor: "XR" + Sec-CH-UA-Form-Factors: "XR" ``` 1. The `Sec-CH-UA-Mobile` header field represents whether the user agent should receive a @@ -265,7 +265,7 @@ accomplish this as follows: boolean mobile; // true DOMString architecture; // "arm" DOMString bitness; // "64" - DOMString formFactor; // "Automotive" + DOMString formFactors; // ["Automotive"] FrozenArray fullVersionList; // [ {brand: "Google Chrome", version: "84.0.4147.0"}, {brand: "Chromium", version: "84.0.4147"} ] DOMString model; // "X644GTM" DOMString platform; // "PhoneOS" @@ -278,7 +278,7 @@ accomplish this as follows: readonly attribute FrozenArray brands; // [ {brand: "Google Chrome", version: "84"}, {brand: "Chromium", version: "84"} ] readonly attribute boolean mobile; // false readonly attribute platform; // "PhoneOS" - Promise getHighEntropyValues(sequence hints); // { architecture: "arm", bitness: "64", model: "X644GTM", platform: "PhoneOS", platformVersion: "10A", formFactor: "VR", fullVersionList: [ {brand: "Google Chrome", version: "84.1.2.3"}, {brand: "Chromium", version: "84.1.2.3"}, {brand: "Not A;Brand", version: "101.3.2.9"} ] } + Promise getHighEntropyValues(sequence hints); // { architecture: "arm", bitness: "64", model: "X644GTM", platform: "PhoneOS", platformVersion: "10A", formFactors: ["VR"], fullVersionList: [ {brand: "Google Chrome", version: "84.1.2.3"}, {brand: "Chromium", version: "84.1.2.3"}, {brand: "Not A;Brand", version: "101.3.2.9"} ] } }; interface mixin NavigatorUA { diff --git a/index.bs b/index.bs index d3bce8e..32e7902 100644 --- a/index.bs +++ b/index.bs @@ -435,7 +435,7 @@ has defined a number of properties for itself: * brand - The [=user agent=]'s commercial name (e.g., "cURL", "Edge", "The World's Best Web Browser"), which MUST be shorter than 32 [=ASCII alpha=] characters. -* form-factor - The form-factor of a device, historically +* form-factors - The form-factors of a device, historically represented as a <[=deviceCompat=]> token in the User-Agent string (e.g., "Tablet", "VR", etc.) * full version - The build version (e.g., @@ -549,24 +549,24 @@ The header's ABNF is: Sec-CH-UA-Bitness = sf-string ~~~ -The 'Sec-CH-UA-Form-Factor' Header Field {#sec-ch-ua-form-factor} +The 'Sec-CH-UA-Form-Factors' Header Field {#sec-ch-ua-form-factors} ------------------------------ -The `Sec-CH-UA-Form-Factor` request header field gives a -server information about the [=user agent=]'s [=form-factor=]. It is a +The `Sec-CH-UA-Form-Factors` request header field gives a +server information about the [=user agent=]'s [=form-factors=]. It is a [=Structured Header=] whose value MUST be a [=structured header/list=] [[!RFC8941]]. In order to avoid providing additional fingerprinting entropy, the header's values MUST be given in lexical order, and values are case-sensitive. -The header SHOULD describe the form-factor of the device using one or more of +The header SHOULD describe the form-factors of the device using one or more of the following common form-factor values: "Desktop", "Automotive", "Mobile", "Tablet", "XR", "EInk", or "Watch". All applicable form-factor values SHOULD be included.
-The form-factor of a user-agent describes how the user interacts with the +The form-factors of a user-agent describe how the user interacts with the user-agent. The meanings of the allowed values are: * "Desktop" refers to a user-agent running on a personal computer. @@ -596,7 +596,7 @@ using existing hints. The header's ABNF is: ~~~ abnf - Sec-CH-UA-Form-Factor = sf-list + Sec-CH-UA-Form-Factors = sf-list ~~~ The 'Sec-CH-UA-Full-Version' Header Field {#sec-ch-ua-full-version} @@ -780,7 +780,7 @@ The header's ABNF is: ``` Note: These client hints can be evoked with the following set of [=client hints tokens=]: -`Sec-CH-UA`, `Sec-CH-UA-Arch`, `Sec-CH-UA-Bitness`, `Sec-CH-UA-Form-Factor`, +`Sec-CH-UA`, `Sec-CH-UA-Arch`, `Sec-CH-UA-Bitness`, `Sec-CH-UA-Form-Factors`, `Sec-CH-UA-Full-Version`, `Sec-CH-UA-Full-Version-List`, `Sec-CH-UA-Mobile`, `Sec-CH-UA-Model`, `Sec-CH-UA-Platform`, `Sec-CH-UA-Platform-Version`, `Sec-CH-UA-WoW64` @@ -797,7 +797,7 @@ dictionary UADataValues { DOMString architecture; DOMString bitness; sequence<NavigatorUABrandVersion> brands; - sequence<DOMString> formFactor; + sequence<DOMString> formFactors; sequence<NavigatorUABrandVersion> fullVersionList; DOMString model; boolean mobile; @@ -990,8 +990,8 @@ ISSUE(wicg/ua-client-hints): We can improve upon when and why a UA decides to re the [=user agent=]'s [=user agent/platform architecture=]. 1. If |hints| [=list/contains=] "bitness", set |uaData|["{{UADataValues/bitness}}"] to the [=user agent=]'s [=user agent/platform bitness=]. - 1. If |hints| [=list/contains=] "formFactor", set |uaData|["{{UADataValues/formFactor}}"] to - the [=user agent=]'s [=user agent/form-factor=]. + 1. If |hints| [=list/contains=] "formFactors", set |uaData|["{{UADataValues/formFactors}}"] to + the [=user agent=]'s [=user agent/form-factors=]. 1. If |hints| [=list/contains=] "fullVersionList", set |uaData|["{{UADataValues/fullVersionList}}"] to [=this=]'s [=relevant global object=]'s [=WindowOrWorkerGlobalScope/full version list frozen array=]. @@ -1154,7 +1154,7 @@ IANA Considerations {#iana} =================== This document intends to define the `Sec-CH-UA`, `Sec-CH-UA-Arch`, `Sec-CH-UA-Bitness`, -`Sec-CH-UA-Form-Factor`, `Sec-CH-UA-Full-Version`, `Sec-CH-UA-Mobile`, `Sec-CH-UA-Model`, +`Sec-CH-UA-Form-Factors`, `Sec-CH-UA-Full-Version`, `Sec-CH-UA-Mobile`, `Sec-CH-UA-Model`, `Sec-CH-UA-Platform`, `Sec-CH-UA-Platform-Version`, `Sec-CH-UA-WoW64`, and the `Sec-CH-UA-Full-Version-List` HTTP request header fields, and register them in the permanent message header field registry ([[RFC3864]]). @@ -1200,10 +1200,10 @@ Author/Change controller: IETF Specification document: this specification ([[#sec-ch-ua-bitness]]) -'Sec-CH-UA-Form-Factor' Header Field {#iana-form-factor} +'Sec-CH-UA-Form-Factors' Header Field {#iana-form-factors} -------------------------- -Header field name: Sec-CH-UA-Form-Factor +Header field name: Sec-CH-UA-Form-Factors Applicable protocol: http @@ -1211,7 +1211,7 @@ Status: standard Author/Change controller: IETF -Specification document: this specification ([[#sec-ch-ua-form-factor]]) +Specification document: this specification ([[#sec-ch-ua-form-factors]]) 'Sec-CH-UA-Full-Version' Header Field {#iana-full-version} ----------------------------