mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 03:25:20 +00:00
util: portably check for unchanged uid
We've already scrubbed for comparisons of 'uid_t == -1' (which fail
on platforms where uid_t is a u16), but another one snuck in.
* src/util/virutil.c (virSetUIDGIDWithCaps): Correct uid comparison.
* cfg.mk (sc_prohibit_risky_id_promotion): New rule.
(cherry picked from commit 7af86379ef
)
This commit is contained in:
parent
fe03d58621
commit
e0316039c0
6
cfg.mk
6
cfg.mk
@ -389,6 +389,12 @@ sc_prohibit_setuid:
|
||||
halt='use virSetUIDGID, not raw set*id' \
|
||||
$(_sc_search_regexp)
|
||||
|
||||
# Don't compare *id_t against raw -1.
|
||||
sc_prohibit_risky_id_promotion:
|
||||
@prohibit='\b(user|group|[ug]id) *[=!]= *-' \
|
||||
halt='cast -1 to ([ug]id_t) before comparing against id' \
|
||||
$(_sc_search_regexp)
|
||||
|
||||
# Use snprintf rather than s'printf, even if buffer is provably large enough,
|
||||
# since gnulib has more guarantees for snprintf portability
|
||||
sc_prohibit_sprintf:
|
||||
|
@ -3011,7 +3011,7 @@ virSetUIDGIDWithCaps(uid_t uid, gid_t gid, unsigned long long capBits,
|
||||
* change the capabilities bounding set.
|
||||
*/
|
||||
|
||||
if (clearExistingCaps || (uid != -1 && uid != 0))
|
||||
if (clearExistingCaps || (uid != (uid_t)-1 && uid != 0))
|
||||
capng_clear(CAPNG_SELECT_BOTH);
|
||||
|
||||
for (ii = 0; ii <= CAP_LAST_CAP; ii++) {
|
||||
|
Loading…
Reference in New Issue
Block a user