California law is not U.S. law -- The law is absurd and frankly attempting to address it by forcing its application upon non-Californians is ridiculous. I will not be using Fedora, nor will I ever contribute to it if any attempt is made to track users' age even if it is law -- laws do not determine what our mores are and we shouldn't let them. We should not abide such an obvious over-reach.
On 3/1/26 3:00 PM, Aaron Rainbolt wrote: > Forwarding because my initial attempt to send this failed due to not > being subscribed to the list. > > Begin forwarded message: > > Date: Sun, 1 Mar 2026 14:48:00 -0500 > From: Aaron Rainbolt <[email protected]> > To: [email protected] > Cc: [email protected], [email protected], > [email protected], [email protected], > [email protected], [email protected] Subject: On the > unfortunate need for an "age verification" API for legal compliance > reasons in some U.S. states > > > Given that this is related to legal stuff, I should preface this by > saying I am not a lawyer. > > Recently, a new law was passed in California that requires OS vendors > to provide some limited info about a user's age via an API that > application distribution websites and application stores can use. [1] > Colorado seems to be working on a similar law. [2] The law will go into > effect January 1, 2027, it is no longer a draft. I do quite a bit of > work with an OS vendor (working with the Kicksecure [3] and Whonix [4] > projects), and we aren't particularly interested in blocking everyone > in California and Colorado from using our OSes, so we're currently > looking into how to implement an API that will comply with the laws > while also not being a privacy disaster. Given that other distributions > are also investigating what to do with this, and the law requires us to > make a "good faith effort to comply with [the] title, taking into > consideration available technology", I figured it would be a good idea > to bring the issue here. > > At its core, the law seems to require that an "operating system" > (I'm guessing this would correspond to a Linux distribution, not an OS > kernel or userland) request the user's age or date of birth at "account > setup". The OS is also expected to allow users to set the user's age if > they didn't already provide it (because the OS was installed before the > law went into effect), and it needs to provide an API somewhere so that > app stores and application distribution websites can ask the OS "what > age bracket does this user fall into?" Four age brackets are defined, > "< 13", ">= 13 and < 16", ">= 16 and < 18", and ">= 18". It looks like > the API also needs to not provide more information than just the age > bracket data. A bunch of stuff is left unclear (how to handle servers > and other CLI-only installs, how to handle VMs, whether the law is even > applicable if the primary user is over 18 since the law ridiculously > defines a user as "a child" while also defining "a child" as anyone > under the age of 18, etc.), but that's what we're given to deal with. > > The most intuitive place to put this functionality would be, IMO, > AccountsService. The main issue with that is that stable-release > distributions, and distributions based upon them, would be faced with > the issue of how to get an updated version of AccountsService integrated > into their software repositories, or how to backport the appropriate > code. The law goes into effect on January 1, 2027, Debian Bookworm is > going to be supported by ELTS until July 30, 2033, and we don't yet > know if Debian will care enough about California's laws to want to > backport a new feature in AccountsService into Debian Bookworm (or even > Trixie). Distributions based on Debian (such as Kicksecure and Whonix) > may still want to comply with the law though, so something using > AccountsService-specific APIs would be frustrating. Requiring a whole > separate daemon for the foreseeable future just for an age verification > API would also be annoying. > > Another place the functionality could go is xdg-desktop-portal. This > one is a bit non-ideal for a couple of reasons; for one, the easiest > place to put the call would be in the Account portal, which returns > more information than the account's age bracket. This could potentially > be considered non-compliant with the law, as it states that the > operating system shall "[s]end only the minimum amount of information > necessary to comply with this title". This also comes with the > backporting disadvantages of an AccountsService-based implementation. > > For this reason, I'd like to propose a "hybrid" approach; introduce a > new standard D-Bus interface, `org.freedesktop.AgeVerification1`, that > can be implemented by arbitrary applications as a distro sees fit. > AccountsService could implement this API so that newer versions > of distros will get the relevant features for free, while distros with > an AccountsService too old to contain the feature can implement it > themselves as a stop-gap solution. > > Taking inspiration from the File Manager D-Bus interface [5], I think > something like the following might work: > > <!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection > 1.0//EN" > "http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd"> > <node name="/org/freedesktop/AgeVerification1"> > <interface name="org.freedesktop.AgeVerification1"> > <method name="SetAge"> > <arg type="s" name="User" direction="in"/> > <arg type="u" name="YearsOfAge" direction="in"/> > </method> > <method name="SetDateOfBirth"> > <arg type="s" name="User" direction="in"/> > <arg type="s" name="Date" direction="in"/> > </method> > <method name='GetAgeBracket'> > <arg type="s" name="User" direction="in"/> > <arg type="u" name="AgeBracket" direction="out"/> > </method> > </interface> > </node> > > * The 'User' argument would, in all instances, be expected to be the > UNIX account username of the user in question. This user account must > not be a system account (i.e. its UID must fall between UID_MIN and > UID_MAX as defined by /etc/login.defs). If a user is specified that > does not exist or whose UID is out of range, these methods will > return the error 'org.freedesktop.AgeVerification1.Error.NoSuchUser'. > If the specified user is not the same as the user making the method > call, and the user making the method call is not root, these methods > will return the error > 'org.freedesktop.AgeVerification1.Error.PermissionDenied'. > * The 'YearsOfAge' argument of the 'SetAge' method should be an > unsigned integer specifying the age of the user in years at the time > of the method call. (The law specifically allows providing simply an > age value rather than a birth date if desired.) > * The 'Date' argument of the 'SetDateOfBirth' method should be a string > in ISO8601 format (i.e. YYYY-MM-DD) indicating the day on which the > user was born. If the argument is invalid, the method will return the > error 'org.freedesktop.AgeVerification1.Error.InvalidDate'. > * The 'AgeBracket' output argument of the 'GetAgeBracket' method will be > an unsigned integer between 1 and 4 inclusive, where 1 indicates that > the user is under 13 years old, 2 indicates that the user is at least > 13 and under 16 years old, 3 indicates that the user is at least 16 > and under 18 years old, and 4 indicates that the user is 18 years old > or older. If no age has been configured for the user yet, the method > will return the error > 'org.freedesktop.AgeVerification1.Error.AgeUndefined'. > > I propose that the exact way in which age information is stored by the > daemon should be left implementation-defined. For Kicksecure, the way > we implement it will almost certainly store only the age bracket and > require users to explicitly reconfigure their age once they are old > enough to move from one age bracket to another. Other implementations > may choose to store the date of birth or the age and date on which the > age was set so that they can automatically update the age bracket as > time passes. This interface will be provided *on the system bus* (NOT > the session bus!), and the D-Bus service that provides these services > should run as root. The file containing the user-to-age mappings should > be owned by root and should not be world-readable, to prevent leaking > the user's specific age to malicious applications. > > Some things I did think about when writing the above but ultimately > decided to not propose: > > * Detailed permission gating for the 'GetAgeBracket' method. The only > reason to do this would be for additional privacy, and > privacy-conscious users can simply lie about their age or the age of > the intended user. There isn't anything in the law (that I can tell) > that prevents the user from just saying "I'm 18" when the prompt > appears and going with it. This would also be really difficult to > implement outside of the context of xdg-desktop-portal, and would > probably only work with sandboxed apps if it was implemented that way. > * UX for actually requesting the age from the user. IMO this is out of > scope for FreeDesktop; individual distros should see to it that they > prompt for the user's age or birth date at "account setup" (whatever > that happens to be defined as for the distro in question), nudge the > user to provide the information later on for existing installations, > etc. Furthermore, this mechanism needs to work even on CLI-only > installs and maybe even on server installs, depending on how one > defines "general purpose computing device" (as specified by the law > in question), so defining any specific UX is likely infeasible. (If > this is required on servers, end-users will probably want to > auto-provision the age information somehow, and specifying how to do > that in a distribution-agnostic way is impossible given that Ubuntu > uses cloud-init, Fedora uses Kickstart and Ignition, etc.) > * Omitting the 'SetDateOfBirth' method. It can be lived without > legally, but without the method, it becomes difficult for software > that already records the user's date of birth to accurately implement > automatic age bracket adjustment as time passes. This isn't a feature > Kicksecure would use, but it's a feature some projects might be > interested in. > > Thanks for taking a look at this. > > -- > Aaron > > [1] > https://leginfo.legislature.ca.gov/faces/billTextClient.xhtml?bill_id=202520260AB1043 > [2] https://leg.colorado.gov/bill_files/110990/download > [3] https://www.kicksecure.com/ > [4] https://www.whonix.org/ > [5] https://www.freedesktop.org/wiki/Specifications/file-manager-interface/ > -- > _______________________________________________ > devel mailing list -- [email protected] > To unsubscribe send an email to [email protected] > Fedora Code of Conduct: > https://docs.fedoraproject.org/en-US/project/code-of-conduct/ > List Guidelines: https://fedoraproject.org/wiki/Mailing_list_guidelines > List Archives: > https://lists.fedoraproject.org/archives/list/[email protected] > Do not reply to spam, report it: > https://forge.fedoraproject.org/infra/tickets/issues/new -- _______________________________________________ devel mailing list -- [email protected] To unsubscribe send an email to [email protected] Fedora Code of Conduct: https://docs.fedoraproject.org/en-US/project/code-of-conduct/ List Guidelines: https://fedoraproject.org/wiki/Mailing_list_guidelines List Archives: https://lists.fedoraproject.org/archives/list/[email protected] Do not reply to spam, report it: https://forge.fedoraproject.org/infra/tickets/issues/new
