Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!
Bug 702460 - [QA] Tree policy for acct-* UID/GID assignment
Summary: [QA] Tree policy for acct-* UID/GID assignment
Status: RESOLVED FIXED
Alias: None
Product: Quality Assurance
Classification: Unclassified
Component: Policies (show other bugs)
Hardware: All Linux
: Normal normal
Assignee: Gentoo Quality Assurance Team
URL:
Whiteboard: vote [y/n/a]: 7/0/0
Keywords:
Depends on:
Blocks:
 
Reported: 2019-12-10 13:57 UTC by Michał Górny
Modified: 2021-11-14 17:23 UTC (History)
0 users

See Also:
Package list:
Runtime testing required: ---


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Michał Górny archtester Gentoo Infrastructure gentoo-dev Security 2019-12-10 13:57:39 UTC
Following the discussion [1], I'd like to remove the policy part of GLEP 81 [2] and replace it with a tree policy.  In this bug, I'd like to propose this policy for discussion/vote by the QA team.  This is roughly a nicely worded version of the policy proposed in the RFC.


===
All new user/group accounts must be created via GLEP 81 packages.  The existing packages should be migrated on the next version bump or major update.  CI system will remind developers to perform the migration.

Existing and historical fixed UIDs/GIDs in range 0..999 (used in baselayout or via user.eclass) as listed in uid-gid.txt can be reused as-is in acct-* packages.

UIDs and GIDs in range 0..100 are reserved for important system accounts.  New assignments in that range need to be explicitly approved by the QA lead, in response to a justified request from the developer.

The range 101..500 is provided for regular use by packages.  The assignments from this range follow the following rules:

1. A developer can select an arbitrary free UID/GID from this range.  If in doubt, it is recommended to select successive numbers from 500 downwards.

2. Unless there is a very good reason not to, matching users and groups should use the same number.  It is acceptable to leave gaps in assignments as a result of that.

3. Before pushing the new acct-* packages, the developer *must* push an update to uid-gid.txt adding the 'acct' entry for the desired UID/GID.  This serves as a synchronization primitive to prevent collisions.

Further UID/GID ranges will be open in the future as the need arises.
===


[1] https://archives.gentoo.org/gentoo-dev/message/9601d9904bf97d88349d41ab7d3a4eb7
[2] https://archives.gentoo.org/gentoo-dev/message/7e2197c632d42900df525141ae328913
Comment 1 Ulrich Müller gentoo-dev 2019-12-10 14:10:36 UTC
(In reply to Michał Górny from comment #0)
> Existing and historical fixed UIDs/GIDs in range 0..999 (used in baselayout
> or via user.eclass) as listed in uid-gid.txt can be reused as-is in acct-*
> packages.

It doesn't make a difference, but shouldn't we say 0..499 here, because there are no existing assignments above that range?

> UIDs and GIDs in range 0..100 are reserved for important system accounts. 
> New assignments in that range need to be explicitly approved by the QA lead,
> in response to a justified request from the developer.
> 
> The range 101..500 is provided for regular use by packages.  The assignments
> from this range follow the following rules:

Again, why 101..500 and not 101..499?

> 1. A developer can select an arbitrary free UID/GID from this range.  If in
> doubt, it is recommended to select successive numbers from 500 downwards.

s/500/499/

> 2. Unless there is a very good reason not to, matching users and groups
> should use the same number.  It is acceptable to leave gaps in assignments
> as a result of that.
> 
> 3. Before pushing the new acct-* packages, the developer *must* push an
> update to uid-gid.txt adding the 'acct' entry for the desired UID/GID.  This
> serves as a synchronization primitive to prevent collisions.
> 
> Further UID/GID ranges will be open in the future as the need arises.
Comment 2 Michał Górny archtester Gentoo Infrastructure gentoo-dev Security 2019-12-10 14:32:30 UTC
My mistake.  Repaste with ->499:

===
All new user/group accounts must be created via GLEP 81 packages.  The existing packages should be migrated on the next version bump or major update.  CI system will remind developers to perform the migration.

Existing and historical fixed UIDs/GIDs in range 0..499 (used in baselayout or via user.eclass) as listed in uid-gid.txt can be reused as-is in acct-* packages.

UIDs and GIDs in range 0..100 are reserved for important system accounts.  New assignments in that range need to be explicitly approved by the QA lead, in response to a justified request from the developer.

The range 101..499 is provided for regular use by packages.  The assignments from this range follow the following rules:

1. A developer can select an arbitrary free UID/GID from this range.  If in doubt, it is recommended to select successive numbers from 499 downwards.

2. Unless there is a very good reason not to, matching users and groups should use the same number.  It is acceptable to leave gaps in assignments as a result of that.

3. Before pushing the new acct-* packages, the developer *must* push an update to uid-gid.txt adding the 'acct' entry for the desired UID/GID.  This serves as a synchronization primitive to prevent collisions.

Further UID/GID ranges will be open in the future as the need arises.
===
Comment 3 Thomas Deutschmann (RETIRED) gentoo-dev 2019-12-10 15:19:18 UTC
(In reply to Michał Górny from comment #2)
> The range 101..499 is provided for regular use by packages.  The assignments
> from this range follow the following rules:
> 
> 1. A developer can select an arbitrary free UID/GID from this range.  If in
> doubt, it is recommended to select successive numbers from 499 downwards.

Have you seen my comment from https://archives.gentoo.org/gentoo-dev/message/03a592fa4695bfa9075ec4b1e066d6b9 (the last part)? We should go upwards, not downwards.
Comment 4 Michał Górny archtester Gentoo Infrastructure gentoo-dev Security 2019-12-10 15:52:52 UTC
(In reply to Thomas Deutschmann from comment #3)
> Have you seen my comment from
> https://archives.gentoo.org/gentoo-dev/message/
> 03a592fa4695bfa9075ec4b1e066d6b9 (the last part)? We should go upwards, not
> downwards.

No, I've stopped reading at the initial noise.  Still, there are so many twists in that (last) part, I'm lost what is the exact reason you want to reverse practice already in use.
Comment 5 Michał Górny archtester Gentoo Infrastructure gentoo-dev Security 2019-12-13 21:21:06 UTC
@qa, given no further comments, please vote on the policy as outlined in #c2.
Comment 6 Michał Górny archtester Gentoo Infrastructure gentoo-dev Security 2019-12-13 21:22:11 UTC
(note that the policy won't start applying until Council approves GLEP 81 changes)
Comment 7 Ulrich Müller gentoo-dev 2019-12-14 13:43:59 UTC
I vote yes.
Comment 8 Sergey Popov (RETIRED) gentoo-dev 2019-12-18 08:08:08 UTC
I vote yes
Comment 9 Amy Liffey gentoo-dev 2019-12-18 16:20:33 UTC
Yes
Comment 10 Andreas K. Hüttel archtester gentoo-dev 2019-12-18 17:28:54 UTC
I vote yes. 

[Had to re-read policies and threads first...]
Comment 11 Mikle Kolyada (RETIRED) archtester Gentoo Infrastructure gentoo-dev Security 2019-12-18 19:56:45 UTC
Yes.
Comment 12 David Seifert gentoo-dev 2019-12-18 20:48:56 UTC
Yes
Comment 13 Michał Górny archtester Gentoo Infrastructure gentoo-dev Security 2019-12-18 20:59:01 UTC
Yes.

Unanimously approved.  I've filed the request to approve GLEP update already (see 'See also').