mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-18 10:35: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 7af86379ef4b46bcc1e07fb8bf90d46c9537e944)
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' \
|
halt='use virSetUIDGID, not raw set*id' \
|
||||||
$(_sc_search_regexp)
|
$(_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,
|
# Use snprintf rather than s'printf, even if buffer is provably large enough,
|
||||||
# since gnulib has more guarantees for snprintf portability
|
# since gnulib has more guarantees for snprintf portability
|
||||||
sc_prohibit_sprintf:
|
sc_prohibit_sprintf:
|
||||||
|
@ -3011,7 +3011,7 @@ virSetUIDGIDWithCaps(uid_t uid, gid_t gid, unsigned long long capBits,
|
|||||||
* change the capabilities bounding set.
|
* change the capabilities bounding set.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (clearExistingCaps || (uid != -1 && uid != 0))
|
if (clearExistingCaps || (uid != (uid_t)-1 && uid != 0))
|
||||||
capng_clear(CAPNG_SELECT_BOTH);
|
capng_clear(CAPNG_SELECT_BOTH);
|
||||||
|
|
||||||
for (ii = 0; ii <= CAP_LAST_CAP; ii++) {
|
for (ii = 0; ii <= CAP_LAST_CAP; ii++) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user