mirror of
https://gitlab.alpinelinux.org/alpine/abuild.git
synced 2025-01-13 10:33:35 +00:00
17cb68e9fb
Symbolic links might point to files outside of the chroot and thus might delete files outside the chroot. This allows deletion of arbitrary directories on the host from a malicious APKBUILD. Following hard links shouldn't be a problem since hard links (usually) cannot refer to directories and since remove(3) removes the link, not the file it points to it shouldn't cause a problem. I noticed this because alpine-baselayout creates /var/run as a symlink to /run. Therefore causing /run to be deleted on the host when using abuild-rmtemp which in turn causes a bunch of software to no longer function properly (including OpenRC).
51 lines
1.0 KiB
C
51 lines
1.0 KiB
C
/*
|
|
* abuild-rmtemp
|
|
* Copyright (c) 2017 Kaarle Ritvanen
|
|
* Distributed under GPL-2
|
|
*/
|
|
|
|
#define _XOPEN_SOURCE 700
|
|
#include <err.h>
|
|
#include <errno.h>
|
|
#include <ftw.h>
|
|
#include <pwd.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <sys/stat.h>
|
|
#include <sys/types.h>
|
|
#include <unistd.h>
|
|
|
|
#define PREFIX "/var/tmp/abuild."
|
|
|
|
static void fail() {
|
|
errx(1, "%s", strerror(errno));
|
|
}
|
|
|
|
static int handler(const char *fpath, const struct stat *sb, int typeflag, struct FTW *ftwbuf) {
|
|
return remove(fpath);
|
|
}
|
|
|
|
int main(int argc, char **argv) {
|
|
if (argc < 2) return 0;
|
|
|
|
if (getuid()) {
|
|
argv[0] = "-abuild-rmtemp";
|
|
execv("/usr/bin/abuild-sudo", argv);
|
|
}
|
|
|
|
if (strncmp(argv[1], PREFIX, strlen(PREFIX)) || \
|
|
strchr(argv[1] + strlen(PREFIX), '/'))
|
|
errx(1, "Invalid path: %s", argv[1]);
|
|
|
|
struct stat s;
|
|
if (lstat(argv[1], &s)) fail();
|
|
struct passwd *p = getpwnam(getenv("USER"));
|
|
if (!p) errx(1, "Incorrect user");
|
|
if (s.st_uid != p->pw_uid) errx(1, "Permission denied");
|
|
|
|
if (nftw(argv[1], handler, 512, FTW_DEPTH|FTW_PHYS)) fail();
|
|
|
|
return 0;
|
|
}
|