]> git.saurik.com Git - cydia.git/commitdiff
Restrict DYLD_ launchd injection in cydo's parent.
authorJay Freeman (saurik) <saurik@saurik.com>
Fri, 3 Jul 2015 20:37:03 +0000 (13:37 -0700)
committerJay Freeman (saurik) <saurik@saurik.com>
Fri, 3 Jul 2015 20:37:03 +0000 (13:37 -0700)
cydo.cpp

index 6fcde151cb6438afd3d61c716733077d4dfccbdc..6d33f94800655da9bf118240e7f69b7310fe3ced 100644 (file)
--- a/cydo.cpp
+++ b/cydo.cpp
@@ -68,6 +68,19 @@ int main(int argc, char *argv[]) {
         if (pid != parent)
             return;
 
+        auto variables(launch_data_dict_lookup(value, LAUNCH_JOBKEY_ENVIRONMENTVARIABLES));
+        if (variables != NULL && launch_data_get_type(variables) == LAUNCH_DATA_DICTIONARY) {
+            bool dyld(false);
+
+            launch_data_dict_iterate(variables, [&dyld](const char *name, launch_data_t value) {
+                if (strncmp(name, "DYLD_", 5) == 0)
+                    dyld = true;
+            });
+
+            if (dyld)
+                return;
+        }
+
         auto string(launch_data_dict_lookup(value, LAUNCH_JOBKEY_PROGRAM));
         if (string == NULL || launch_data_get_type(string) != LAUNCH_DATA_STRING) {
             auto array(launch_data_dict_lookup(value, LAUNCH_JOBKEY_PROGRAMARGUMENTS));