int main(int argc, char *argv[]) { int c; void (*func)(); extern int optind; int ret; (void) setlocale(LC_ALL, ""); #if !defined(TEXT_DOMAIN) /* Should be defined by cc -D */ #define TEXT_DOMAIN "SYS_TEST" #endif (void) textdomain(TEXT_DOMAIN); (void) set_prog_name(argv[0]); while ((c = getopt(argc, argv, "snio?")) != EOF) { switch (c) { case 'n': options |= PT_RENAME; break; case 'i': options |= PT_INFO_ONLY; break; case 'o': options |= PT_OVERWRITE; break; case 's': options |= PT_ODTSTREAM; break; default: usage(); return (1); } } func = signal(SIGINT, trap); if (func != SIG_DFL) (void) signal(SIGINT, func); (void) signal(SIGHUP, trap); (void) signal(SIGQUIT, trap); (void) signal(SIGTERM, trap); (void) signal(SIGPIPE, trap); (void) signal(SIGPWR, trap); if ((argc-optind) < 2) { usage(); return (1); } ret = pkgtrans(flex_device(argv[optind], 1), flex_device(argv[optind+1], 1), &argv[optind+2], options); quit(ret); /*NOTREACHED*/ }
int pkghead(char *device) { char *pt; int n; cleanup(); if (device == NULL) return (0); else if ((device[0] == '/') && !isdir(device)) { pkgdir = device; return (0); } else if ((pt = devattr(device, "pathname")) != NULL && !isdir(pt)) { pkgdir = pt; return (0); } /* check for datastream */ if (n = pkgtrans(device, (char *)0, allpkg, PT_SILENT|PT_INFO_ONLY, NULL, NULL)) { cleanup(); return (n); } /* pkgtrans has set pkgdir */ return (0); }
int main(int argc, char *argv[]) { int c; void (*func)(); extern char *optarg; extern int optind; char *keystore_alias = NULL; char *keystore_file = NULL; boolean_t create_sig = B_FALSE; char *homedir = NULL; PKG_ERR *err; int ret, len; (void) setlocale(LC_ALL, ""); #if !defined(TEXT_DOMAIN) /* Should be defined by cc -D */ #define TEXT_DOMAIN "SYS_TEST" #endif (void) textdomain(TEXT_DOMAIN); (void) set_prog_name(argv[0]); while ((c = getopt(argc, argv, "ga:P:k:snio?")) != EOF) { switch (c) { case 'n': options |= PT_RENAME; break; case 'i': options |= PT_INFO_ONLY; break; case 'o': options |= PT_OVERWRITE; break; case 's': options |= PT_ODTSTREAM; break; case 'g': /* this should eventually be a PT_ option */ create_sig = B_TRUE; break; case 'k': keystore_file = optarg; break; case 'a': keystore_alias = optarg; break; case 'P': set_passphrase_passarg(optarg); if (ci_strneq(optarg, "pass:"******"pass:<pass>"); } break; default: usage(); return (1); } } func = signal(SIGINT, trap); if (func != SIG_DFL) (void) signal(SIGINT, func); (void) signal(SIGHUP, trap); (void) signal(SIGQUIT, trap); (void) signal(SIGTERM, trap); (void) signal(SIGPIPE, trap); (void) signal(SIGPWR, trap); if ((argc-optind) < 2) { usage(); return (1); } if (create_sig) { sec_init(); err = pkgerr_new(); /* figure out which keystore to use */ if (keystore_file == NULL) { if (geteuid() == 0) { /* we are superuser, so use their keystore */ keystore_file = PKGSEC; } else if ((homedir = getenv("HOME")) == NULL) { /* * not superuser, but no home dir, so * use superuser's keystore */ keystore_file = PKGSEC; } else if (asprintf(&keystore_file, "%s/.pkg/security", homedir) < 0) { logerr(ERR_MEM); quit(1); } } logerr(gettext(KEYSTORE_OPEN), keystore_file); set_passphrase_prompt(MSG_PASSPROMPT); /* open keystore for reading */ if (open_keystore(err, keystore_file, get_prog_name(), pkg_passphrase_cb, KEYSTORE_DFLT_FLAGS, &keystore) != 0) { pkgerr(err); pkgerr_free(err); quit(1); } } else { /* no signature, so don't use a keystore */ keystore = NULL; } ret = pkgtrans(flex_device(argv[optind], 1), flex_device(argv[optind+1], 1), &argv[optind+2], options, keystore, keystore_alias); if (create_sig) { /* close keystore */ if (close_keystore(err, keystore, NULL) != 0) { pkgerr(err); pkgerr_free(err); quit(1); } keystore = NULL; } quit(ret); /*NOTREACHED*/ }