diff options
author | David Shaw <[email protected]> | 2004-10-13 18:30:29 +0000 |
---|---|---|
committer | David Shaw <[email protected]> | 2004-10-13 18:30:29 +0000 |
commit | d603b7c3a16d4dfdbd26fa0ca28adf7ee850016e (patch) | |
tree | de899dab667bd80a7afa4cae558387db1682144c /keyserver/ksutil.c | |
parent | Added SELInux hacks and did some cleanups. (diff) | |
download | gnupg-d603b7c3a16d4dfdbd26fa0ca28adf7ee850016e.tar.gz gnupg-d603b7c3a16d4dfdbd26fa0ca28adf7ee850016e.zip |
* gpgkeys_ldap.c (main), gpgkeys_hkp.c (main), gpgkeys_http.c (main),
gpgkeys_finger.c (main): Call timeout functions before performing an
action that could block for a long time.
* ksutil.h, ksutil.c: New. Right now just contains timeout functions.
Diffstat (limited to 'keyserver/ksutil.c')
-rw-r--r-- | keyserver/ksutil.c | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/keyserver/ksutil.c b/keyserver/ksutil.c new file mode 100644 index 000000000..51e527d7b --- /dev/null +++ b/keyserver/ksutil.c @@ -0,0 +1,63 @@ +/* ksutil.c - general keyserver utility functions + * Copyright (C) 2004 Free Software Foundation, Inc. + * + * This file is part of GnuPG. + * + * GnuPG is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * GnuPG is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA + */ + +#include <config.h> +#include <signal.h> +#include <unistd.h> +#include "keyserver.h" +#include "ksutil.h" + +static void +catch_alarm(int foo) +{ + _exit(KEYSERVER_TIMEOUT); +} + +unsigned int +set_timeout(unsigned int seconds) +{ +#ifdef HAVE_DOSISH_SYSTEM + return 0; +#else + return alarm(seconds); +#endif +} + +int +register_timeout(void) +{ +#ifdef HAVE_DOSISH_SYSTEM + return 0; +#else +#if defined(HAVE_SIGACTION) && defined(HAVE_STRUCT_SIGACTION) + struct sigaction act; + + act.sa_handler=catch_alarm; + sigemptyset(&act.sa_mask); + act.sa_flags=0; + return sigaction(SIGALRM,&act,NULL); +#else + if(signal(SIGALRM,catch_alarm)==SIG_ERR) + return -1; + else + return 0; +#endif +#endif +} |