Block all use of getenv with syntax-check

The use of getenv is typically insecure, and we want people
to use our wrappers, to force them to think about setuid
needs.

Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
(cherry picked from commit 71b21f12bece1127b28b404f11f57b4c2d48983a)
This commit is contained in:
Daniel P. Berrange 2013-10-09 11:19:27 +01:00
parent 61fe5eebda
commit eb892701c7
2 changed files with 10 additions and 2 deletions

8
cfg.mk
View File

@ -851,6 +851,11 @@ sc_prohibit_unbounded_arrays_in_rpc:
halt='Arrays in XDR must have a upper limit set for <NNN>' \
$(_sc_search_regexp)
sc_prohibit_getenv:
@prohibit='\b(secure_)?getenv *\(' \
exclude='exempt from syntax-check' \
halt='Use virGetEnv{Allow,Block}SUID instead of getenv' \
$(_sc_search_regexp)
# We don't use this feature of maint.mk.
prev_version_file = /dev/null
@ -1020,3 +1025,6 @@ exclude_file_name_regexp--sc_prohibit_include_public_headers_brackets = \
exclude_file_name_regexp--sc_prohibit_int_ijk = \
^(src/remote_protocol-structs|src/remote/remote_protocol.x|cfg.mk|include/)$
exclude_file_name_regexp--sc_prohibit_getenv = \
^tests/.*\.[ch]$$

View File

@ -2140,7 +2140,7 @@ cleanup:
*/
const char *virGetEnvBlockSUID(const char *name)
{
return secure_getenv(name);
return secure_getenv(name); /* exempt from syntax-check-rules */
}
@ -2154,7 +2154,7 @@ const char *virGetEnvBlockSUID(const char *name)
*/
const char *virGetEnvAllowSUID(const char *name)
{
return getenv(name);
return getenv(name); /* exempt from syntax-check-rules */
}