From: Jay Freeman (saurik) Date: Fri, 13 Jun 2014 08:31:54 +0000 (-0700) Subject: Fix permissions of _.* containers on new stashes. X-Git-Tag: v1.1.12~3 X-Git-Url: https://git.saurik.com/cydia.git/commitdiff_plain/b132a9721b0c0bc21158e5d33445e0bf700f97b0?hp=cd701a7b2beb7bf3e60047c65c8445df12e30d09 Fix permissions of _.* containers on new stashes. --- diff --git a/Library/move.sh b/Library/move.sh index c0fc10cd..98d9986f 100755 --- a/Library/move.sh +++ b/Library/move.sh @@ -24,6 +24,9 @@ function mv_() { tmp=$(mktemp -d /var/stash/_.XXXXXX) dst=${tmp}/${src##*/} + chmod 755 "${tmp}" + chown root.admin "${tmp}" + mkdir -- "${dst}" || { rmdir -- "${tmp}" exit 1 diff --git a/postinst.mm b/postinst.mm index a3269117..405b3176 100644 --- a/postinst.mm +++ b/postinst.mm @@ -24,6 +24,33 @@ void Finish(const char *finish) { fclose(fout); } +static void FixPermissions() { + DIR *stash(opendir("/var/stash")); + if (stash == NULL) + return; + + while (dirent *entry = readdir(stash)) { + const char *folder(entry->d_name); + if (strlen(folder) != 8) + continue; + if (strncmp(folder, "_.", 2) != 0) + continue; + + char path[1024]; + sprintf(path, "/var/stash/%s", folder); + + struct stat stat; + if (lstat(path, &stat) == -1) + continue; + if (!S_ISDIR(stat.st_mode)) + continue; + + chmod(path, 0755); + } + + closedir(stash); +} + #define APPLICATIONS "/Applications" static bool FixApplications() { char target[1024]; @@ -126,6 +153,8 @@ int main(int argc, const char *argv[]) { CydiaWriteSources(); + FixPermissions(); + if (FixApplications()) Finish("restart");