mirror of
https://github.com/SELinuxProject/selinux
synced 2025-01-09 06:59:34 +00:00
policycoreutils: restorecon: Always check return code on asprintf
Do not assume it is always a success and error gracefully when it isn't. Signed-off-by: Eric Paris <eparis@redhat.com> Acked-by: Dan Walsh <dwalsh@redhat.com>
This commit is contained in:
parent
48681bb49c
commit
9961ca6499
@ -190,7 +190,11 @@ int start() {
|
|||||||
static int local_server() {
|
static int local_server() {
|
||||||
// ! dbus, run as local service
|
// ! dbus, run as local service
|
||||||
char *ptr=NULL;
|
char *ptr=NULL;
|
||||||
asprintf(&ptr, "%s/.restorecond", homedir);
|
if (asprintf(&ptr, "%s/.restorecond", homedir) < 0) {
|
||||||
|
if (debug_mode)
|
||||||
|
perror("asprintf");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
int fd = open(ptr, O_CREAT | O_WRONLY | O_NOFOLLOW, S_IRUSR | S_IWUSR);
|
int fd = open(ptr, O_CREAT | O_WRONLY | O_NOFOLLOW, S_IRUSR | S_IWUSR);
|
||||||
if (debug_mode)
|
if (debug_mode)
|
||||||
g_warning ("Lock file: %s", ptr);
|
g_warning ("Lock file: %s", ptr);
|
||||||
|
@ -226,7 +226,9 @@ static void process_config(int fd, FILE * cfg)
|
|||||||
if (buffer[0] == '~') {
|
if (buffer[0] == '~') {
|
||||||
if (run_as_user) {
|
if (run_as_user) {
|
||||||
char *ptr=NULL;
|
char *ptr=NULL;
|
||||||
asprintf(&ptr, "%s%s", homedir, &buffer[1]);
|
if (asprintf(&ptr, "%s%s", homedir, &buffer[1]) < 0)
|
||||||
|
exitApp("Error allocating memory.");
|
||||||
|
|
||||||
watch_list_add(fd, ptr);
|
watch_list_add(fd, ptr);
|
||||||
free(ptr);
|
free(ptr);
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user