From be8b315d1522fa1c109a49435c1638bafd838b91 Mon Sep 17 00:00:00 2001 From: rsc Date: Thu, 17 Jun 2004 03:27:35 +0000 Subject: basically none of these build --- src/libauth/auth_getkey.c | 51 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 src/libauth/auth_getkey.c (limited to 'src/libauth/auth_getkey.c') diff --git a/src/libauth/auth_getkey.c b/src/libauth/auth_getkey.c new file mode 100644 index 00000000..0ae28b1e --- /dev/null +++ b/src/libauth/auth_getkey.c @@ -0,0 +1,51 @@ +#include +#include +#include + +int +auth_getkey(char *params) +{ + char *name; + Dir *d; + int pid; + Waitmsg *w; + + /* start /factotum to query for a key */ + name = "/factotum"; + d = dirstat(name); + if(d == nil){ + name = "/boot/factotum"; + d = dirstat(name); + } + if(d == nil){ + werrstr("auth_getkey: no /factotum or /boot/factotum: didn't get key %s", params); + return -1; + } +if(0) if(d->type != '/'){ + werrstr("auth_getkey: /factotum may be bad: didn't get key %s", params); + return -1; + } + switch(pid = fork()){ + case -1: + werrstr("can't fork for %s: %r", name); + return -1; + case 0: + execl(name, "getkey", "-g", params, nil); + exits(0); + default: + for(;;){ + w = wait(); + if(w == nil) + break; + if(w->pid == pid){ + if(w->msg[0] != '\0'){ + free(w); + return -1; + } + free(w); + return 0; + } + } + } + return 0; +} -- cgit v1.2.3