Gentoo Archives: gentoo-commits

From: "Michał Górny" <mgorny@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: eclass/
Date: Sat, 09 Jan 2021 18:04:18
Message-Id: 1610215347.3d16edacf664782db004255b67464808c257f722.mgorny@gentoo
1 commit: 3d16edacf664782db004255b67464808c257f722
2 Author: Michał Górny <mgorny <AT> gentoo <DOT> org>
3 AuthorDate: Tue Jan 5 18:39:11 2021 +0000
4 Commit: Michał Górny <mgorny <AT> gentoo <DOT> org>
5 CommitDate: Sat Jan 9 18:02:27 2021 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3d16edac
7
8 acct-group.eclass: Support ACCT_GROUP_ID override
9
10 Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
11
12 eclass/acct-group.eclass | 39 +++++++++++++++++++++++++++++----------
13 1 file changed, 29 insertions(+), 10 deletions(-)
14
15 diff --git a/eclass/acct-group.eclass b/eclass/acct-group.eclass
16 index 9c46d3a1c21..11a9f29e625 100644
17 --- a/eclass/acct-group.eclass
18 +++ b/eclass/acct-group.eclass
19 @@ -59,7 +59,8 @@ readonly ACCT_GROUP_NAME
20 # @REQUIRED
21 # @DESCRIPTION:
22 # Preferred GID for the new group. This variable is obligatory, and its
23 -# value must be unique across all group packages.
24 +# value must be unique across all group packages. This can be overriden
25 +# in make.conf through ACCT_GROUP_<UPPERCASE_USERNAME>_ID variable.
26 #
27 # Overlays should set this to -1 to dynamically allocate GID. Using -1
28 # in ::gentoo is prohibited by policy.
29 @@ -91,25 +92,33 @@ acct-group_pkg_pretend() {
30
31 # verify ACCT_GROUP_ID
32 [[ -n ${ACCT_GROUP_ID} ]] || die "Ebuild error: ACCT_GROUP_ID must be set!"
33 - [[ ${ACCT_GROUP_ID} -eq -1 ]] && return
34 - [[ ${ACCT_GROUP_ID} -ge 0 ]] || die "Ebuild errors: ACCT_GROUP_ID=${ACCT_GROUP_ID} invalid!"
35 + [[ ${ACCT_GROUP_ID} -ge -1 ]] || die "Ebuild error: ACCT_GROUP_ID=${ACCT_GROUP_ID} invalid!"
36 + local group_id=${ACCT_GROUP_ID}
37 +
38 + # check for the override
39 + local override_name=${ACCT_GROUP_NAME^^}
40 + local override_var=ACCT_GROUP_${override_name//-/_}_ID
41 + if [[ -n ${!override_var} ]]; then
42 + group_id=${!override_var}
43 + [[ ${group_id} -ge -1 ]] || die "${override_var}=${group_id} invalid!"
44 + fi
45
46 # check for ACCT_GROUP_ID collisions early
47 - if [[ -n ${ACCT_GROUP_ENFORCE_ID} ]]; then
48 - local group_by_id=$(egetgroupname "${ACCT_GROUP_ID}")
49 + if [[ ${group_id} -ne -1 && -n ${ACCT_GROUP_ENFORCE_ID} ]]; then
50 + local group_by_id=$(egetgroupname "${group_id}")
51 local group_by_name=$(egetent group "${ACCT_GROUP_NAME}")
52 if [[ -n ${group_by_id} ]]; then
53 if [[ ${group_by_id} != ${ACCT_GROUP_NAME} ]]; then
54 eerror "The required GID is already taken by another group."
55 - eerror " GID: ${ACCT_GROUP_ID}"
56 + eerror " GID: ${group_id}"
57 eerror " needed for: ${ACCT_GROUP_NAME}"
58 eerror " current group: ${group_by_id}"
59 - die "GID ${ACCT_GROUP_ID} taken already"
60 + die "GID ${group_id} taken already"
61 fi
62 elif [[ -n ${group_by_name} ]]; then
63 eerror "The requested group exists already with wrong GID."
64 eerror " groupname: ${ACCT_GROUP_NAME}"
65 - eerror " requested GID: ${ACCT_GROUP_ID}"
66 + eerror " requested GID: ${group_id}"
67 eerror " current entry: ${group_by_name}"
68 die "Group ${ACCT_GROUP_NAME} exists with wrong GID"
69 fi
70 @@ -122,11 +131,21 @@ acct-group_pkg_pretend() {
71 acct-group_src_install() {
72 debug-print-function ${FUNCNAME} "${@}"
73
74 + # check for the override
75 + local override_name=${ACCT_GROUP_NAME^^}
76 + local override_var=ACCT_GROUP_${override_name//-/_}_ID
77 + if [[ -n ${!override_var} ]]; then
78 + ewarn "${override_var}=${!override_var} override in effect, support will not be provided."
79 + _ACCT_GROUP_ID=${!override_var}
80 + else
81 + _ACCT_GROUP_ID=${ACCT_GROUP_ID}
82 + fi
83 +
84 insinto /usr/lib/sysusers.d
85 newins - ${CATEGORY}-${ACCT_GROUP_NAME}.conf < <(
86 printf "g\t%q\t%q\n" \
87 "${ACCT_GROUP_NAME}" \
88 - "${ACCT_GROUP_ID/#-*/-}"
89 + "${_ACCT_GROUP_ID/#-*/-}"
90 )
91 }
92
93 @@ -137,7 +156,7 @@ acct-group_pkg_preinst() {
94 debug-print-function ${FUNCNAME} "${@}"
95
96 enewgroup ${ACCT_GROUP_ENFORCE_ID:+-F} "${ACCT_GROUP_NAME}" \
97 - "${ACCT_GROUP_ID}"
98 + "${_ACCT_GROUP_ID}"
99 }
100
101 fi