X-Git-Url: https://git.saurik.com/cydia.git/blobdiff_plain/e4d9a4f2fdc098e3447d4a81bc4dbb2f9acd5e53..f4f6714a329bf399840b3f9991b310bd17f7bed6:/postinst.mm?ds=sidebyside diff --git a/postinst.mm b/postinst.mm index c67cce5c..f826f4ff 100644 --- a/postinst.mm +++ b/postinst.mm @@ -1,3 +1,5 @@ +#include "CyteKit/UCPlatform.h" + #include #include @@ -28,14 +30,62 @@ static bool setnsfpn(const char *path) { return system([[NSString stringWithFormat:@"/usr/libexec/cydia/setnsfpn %s", path] UTF8String]) == 0; } +enum StashStatus { + StashDone, + StashFail, + StashGood, +}; + +static StashStatus MoveStash() { + struct stat stat; + + if (lstat("/var/stash", &stat) == -1) + return errno == ENOENT ? StashGood : StashFail; + else if (S_ISLNK(stat.st_mode)) + return StashGood; + else if (!S_ISDIR(stat.st_mode)) + return StashFail; + + if (lstat("/var/db/stash", &stat) == -1) { + if (errno == ENOENT) + goto move; + else return StashFail; + } else if (S_ISLNK(stat.st_mode)) + // XXX: this is fixable + return StashFail; + else if (!S_ISDIR(stat.st_mode)) + return StashFail; + else { + if (!setnsfpn("/var/db/stash")) + return StashFail; + if (system("mv -t /var/stash /var/db/stash/*") != 0) + return StashFail; + if (rmdir("/var/db/stash") == -1) + return StashFail; + } move: + + if (!setnsfpn("/var/stash")) + return StashFail; + + if (rename("/var/stash", "/var/db/stash") == -1) + return StashFail; + if (symlink("/var/db/stash", "/var/stash") != -1) + return StashDone; + if (rename("/var/db/stash", "/var/stash") != -1) + return StashFail; + + fprintf(stderr, "/var/stash misplaced -- DO NOT REBOOT\n"); + return StashFail; +} + static bool FixProtections() { - for (const char *path : (const char *[]) {"/var/lib", "/var/cache", "/var/stash"}) { - mkdir(path, 0755); - if (!setnsfpn(path)) { - fprintf(stderr, "failed to setnsfpn %s\n", path); - return false; - } + const char *path("/var/lib"); + mkdir(path, 0755); + if (!setnsfpn(path)) { + fprintf(stderr, "failed to setnsfpn %s\n", path); + return false; } + return true; } @@ -129,60 +179,38 @@ static bool FixApplications() { } } -_H Sources_; -bool Changed_; - -_H System_; - int main(int argc, const char *argv[]) { if (argc < 2 || strcmp(argv[1], "configure") != 0) return 0; NSAutoreleasePool *pool([[NSAutoreleasePool alloc] init]); - if (kCFCoreFoundationVersionNumber >= 1000) + bool restart(false); + + if (kCFCoreFoundationVersionNumber >= 1000) { if (!FixProtections()) return 1; - - size_t size; - sysctlbyname("kern.osversion", NULL, &size, NULL, 0); - char *osversion = new char[size]; - if (sysctlbyname("kern.osversion", osversion, &size, NULL, 0) != -1) - System_ = [NSString stringWithUTF8String:osversion]; - - NSDictionary *metadata([[[NSMutableDictionary alloc] initWithContentsOfFile:@"/var/lib/cydia/metadata.plist"] autorelease]); - NSUInteger version(0); - - if (metadata != nil) { - Sources_ = [metadata objectForKey:@"Sources"]; - - if (NSNumber *number = [metadata objectForKey:@"Version"]) - version = [number unsignedIntValue]; - } - - if (Sources_ == nil) - Sources_ = [NSMutableDictionary dictionaryWithCapacity:8]; - - if (version == 0) { - CydiaAddSource(@"http://apt.thebigboss.org/repofiles/cydia/", @"stable", [NSMutableArray arrayWithObject:@"main"]); - CydiaAddSource(@"http://apt.modmyi.com/", @"stable", [NSMutableArray arrayWithObject:@"main"]); - CydiaAddSource(@"http://cydia.zodttd.com/repo/cydia/", @"stable", [NSMutableArray arrayWithObject:@"main"]); - CydiaAddSource(@"http://repo666.ultrasn0w.com/", @"./"); + switch (MoveStash()) { + case StashDone: + restart = true; + break; + case StashFail: + fprintf(stderr, "failed to move stash\n"); + return 1; + case StashGood: + break; + } } - CydiaWriteSources(); - #define OldCache_ "/var/root/Library/Caches/com.saurik.Cydia" if (access(OldCache_, F_OK) == 0) system("rm -rf " OldCache_); #define NewCache_ "/var/mobile/Library/Caches/com.saurik.Cydia" system("cd /; su -c 'mkdir -p " NewCache_ "' mobile"); - - if (access(NewCache_ "/lists", F_OK) != 0 && errno == ENOENT) { + if (access(NewCache_ "/lists", F_OK) != 0 && errno == ENOENT) system("cp -at " NewCache_ " /var/lib/apt/lists"); - system("chown -R 501.501 " NewCache_ "/lists"); - } + system("chown -R 501.501 " NewCache_); #define OldLibrary_ "/var/lib/cydia" @@ -191,6 +219,15 @@ int main(int argc, const char *argv[]) { #define Cytore_ "/metadata.cb0" + #define CYDIA_LIST "/etc/apt/sources.list.d/cydia.list" + unlink(CYDIA_LIST); + [[NSString stringWithFormat:@ + "deb http://apt.saurik.com/ ios/%.2f main\n" + "deb http://apt.thebigboss.org/repofiles/cydia/ stable main\n" + "deb http://cydia.zodttd.com/repo/cydia/ stable main\n" + "deb http://apt.modmyi.com/ stable main\n" + , kCFCoreFoundationVersionNumber] writeToFile:@ CYDIA_LIST atomically:YES]; + if (access(NewLibrary_ Cytore_, F_OK) != 0 && errno == ENOENT) { if (access(NewCache_ Cytore_, F_OK) == 0) system("mv -f " NewCache_ Cytore_ " " NewLibrary_); @@ -201,7 +238,9 @@ int main(int argc, const char *argv[]) { FixPermissions(); - if (FixApplications()) + restart |= FixApplications(); + + if (restart) Finish("restart"); [pool release];