mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-17 14:07:03 +01:00
* configure.ac: Check for funopen and fopencookie as part of the
jnlib checks. * logging.c (writen, fun_writer, fun_closer): New. (log_set_file): Add feature to log to a socket.
This commit is contained in:
parent
56530d2c39
commit
dba63c0a0c
@ -1,3 +1,8 @@
|
|||||||
|
2003-12-16 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
* configure.ac: Check for funopen and fopencookie as part of the
|
||||||
|
jnlib checks.
|
||||||
|
|
||||||
2003-12-09 Werner Koch <wk@gnupg.org>
|
2003-12-09 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* configure.ac: Add a min_automake_version.
|
* configure.ac: Add a min_automake_version.
|
||||||
|
8
NEWS
8
NEWS
@ -2,7 +2,13 @@ Noteworthy changes in version 1.9.3 (unreleased)
|
|||||||
------------------------------------------------
|
------------------------------------------------
|
||||||
|
|
||||||
* New options --{enable,disable}-ocsp to validate keys using OCSP
|
* New options --{enable,disable}-ocsp to validate keys using OCSP
|
||||||
This requires at least DirMngr 0.5.1 to work. Default is disabled.
|
This requires a not yet released DirMngr 0.5.1. Default is
|
||||||
|
disabled.
|
||||||
|
|
||||||
|
* The --log-file may now be used to print logs to a socket. Prefix
|
||||||
|
the socket name with "socket://" to enable this. This does not
|
||||||
|
work on all systems and falls back to stderr if there is a problem
|
||||||
|
with the socket.
|
||||||
|
|
||||||
|
|
||||||
Noteworthy changes in version 1.9.2 (2003-11-17)
|
Noteworthy changes in version 1.9.2 (2003-11-17)
|
||||||
|
@ -698,7 +698,7 @@ AC_CHECK_TYPES([struct sigaction, sigset_t],,,[#include <signal.h>])
|
|||||||
# These are needed by libjnlib - fixme: we should have macros for them
|
# These are needed by libjnlib - fixme: we should have macros for them
|
||||||
AC_CHECK_FUNCS(memicmp stpcpy strlwr strtoul memmove stricmp strtol)
|
AC_CHECK_FUNCS(memicmp stpcpy strlwr strtoul memmove stricmp strtol)
|
||||||
AC_CHECK_FUNCS(getrusage setrlimit stat setlocale)
|
AC_CHECK_FUNCS(getrusage setrlimit stat setlocale)
|
||||||
AC_CHECK_FUNCS(flockfile funlockfile)
|
AC_CHECK_FUNCS(flockfile funlockfile fopencookie funopen)
|
||||||
|
|
||||||
AC_REPLACE_FUNCS(vasprintf)
|
AC_REPLACE_FUNCS(vasprintf)
|
||||||
AC_REPLACE_FUNCS(fopencookie)
|
AC_REPLACE_FUNCS(fopencookie)
|
||||||
@ -709,6 +709,7 @@ AC_REPLACE_FUNCS(putc_unlocked)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# check for gethrtime and run a testprogram to see whether
|
# check for gethrtime and run a testprogram to see whether
|
||||||
# it is broken. It has been reported that some Solaris and HP UX systems
|
# it is broken. It has been reported that some Solaris and HP UX systems
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
2003-12-16 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
* logging.c (writen, fun_writer, fun_closer): New.
|
||||||
|
(log_set_file): Add feature to log to a socket.
|
||||||
|
|
||||||
2003-11-13 Werner Koch <wk@gnupg.org>
|
2003-11-13 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* strlist.c (strlist_copy): New.
|
* strlist.c (strlist_copy): New.
|
||||||
|
161
jnlib/logging.c
161
jnlib/logging.c
@ -29,9 +29,12 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#include <stddef.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/un.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#ifdef __MINGW32__
|
#ifdef __MINGW32__
|
||||||
# include <io.h>
|
# include <io.h>
|
||||||
@ -84,13 +87,163 @@ log_inc_errorcount (void)
|
|||||||
errorcount++;
|
errorcount++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* The follwing 3 functions are used by funopen to write logs to a
|
||||||
|
socket. */
|
||||||
|
#if defined (HAVE_FOPENCOOKIE) || defined (HAVE_FUNOPEN)
|
||||||
|
struct fun_cookie_s {
|
||||||
|
int fd;
|
||||||
|
int quiet;
|
||||||
|
char name[1];
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Write NBYTES of BUF to file descriptor FD. */
|
||||||
|
static int
|
||||||
|
writen (int fd, const unsigned char *buf, size_t nbytes)
|
||||||
|
{
|
||||||
|
size_t nleft = nbytes;
|
||||||
|
int nwritten;
|
||||||
|
|
||||||
|
while (nleft > 0)
|
||||||
|
{
|
||||||
|
nwritten = write (fd, buf, nleft);
|
||||||
|
if (nwritten < 0 && errno == EINTR)
|
||||||
|
continue;
|
||||||
|
if (nwritten < 0)
|
||||||
|
return -1;
|
||||||
|
nleft -= nwritten;
|
||||||
|
buf = buf + nwritten;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
fun_writer (void *cookie_arg, const char *buffer, size_t size)
|
||||||
|
{
|
||||||
|
struct fun_cookie_s *cookie = cookie_arg;
|
||||||
|
|
||||||
|
/* Note that we always try to reconnect to the socket but print error
|
||||||
|
messages only the first time an error occured. */
|
||||||
|
if (cookie->fd == -1 )
|
||||||
|
{
|
||||||
|
/* Note yet open or meanwhile closed due to an error. */
|
||||||
|
struct sockaddr_un addr;
|
||||||
|
size_t addrlen;
|
||||||
|
|
||||||
|
cookie->fd = socket (PF_LOCAL, SOCK_STREAM, 0);
|
||||||
|
if (cookie->fd == -1)
|
||||||
|
{
|
||||||
|
if (!cookie->quiet)
|
||||||
|
fprintf (stderr, "failed to create socket for logging: %s\n",
|
||||||
|
strerror(errno));
|
||||||
|
goto failure;
|
||||||
|
}
|
||||||
|
|
||||||
|
memset (&addr, 0, sizeof addr);
|
||||||
|
addr.sun_family = PF_LOCAL;
|
||||||
|
strncpy (addr.sun_path, cookie->name, sizeof (addr.sun_path)-1);
|
||||||
|
addr.sun_path[sizeof (addr.sun_path)-1] = 0;
|
||||||
|
addrlen = (offsetof (struct sockaddr_un, sun_path)
|
||||||
|
+ strlen (addr.sun_path) + 1);
|
||||||
|
|
||||||
|
if (connect (cookie->fd, (struct sockaddr *) &addr, addrlen) == -1)
|
||||||
|
{
|
||||||
|
if (!cookie->quiet)
|
||||||
|
fprintf (stderr, "can't connect to `%s': %s\n",
|
||||||
|
cookie->name, strerror(errno));
|
||||||
|
close (cookie->fd);
|
||||||
|
cookie->fd = -1;
|
||||||
|
goto failure;
|
||||||
|
}
|
||||||
|
/* Connection established. */
|
||||||
|
cookie->quiet = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!writen (cookie->fd, buffer, size))
|
||||||
|
return size; /* Okay. */
|
||||||
|
|
||||||
|
fprintf (stderr, "error writing to `%s': %s\n",
|
||||||
|
cookie->name, strerror(errno));
|
||||||
|
close (cookie->fd);
|
||||||
|
cookie->fd = -1;
|
||||||
|
|
||||||
|
failure:
|
||||||
|
if (!cookie->quiet)
|
||||||
|
{
|
||||||
|
fputs ("switching logging to stderr\n", stderr);
|
||||||
|
cookie->quiet = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
fwrite (buffer, size, 1, stderr);
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
fun_closer (void *cookie_arg)
|
||||||
|
{
|
||||||
|
struct fun_cookie_s *cookie = cookie_arg;
|
||||||
|
|
||||||
|
if (cookie->fd != -1)
|
||||||
|
close (cookie->fd);
|
||||||
|
jnlib_free (cookie);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif /* HAVE_FOPENCOOKIE || HAVE_FUNOPEN */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Set the file to write log to. The sepcial names NULL and "_" may
|
||||||
|
be used to select stderr and names formatted like
|
||||||
|
"socket:///home/foo/mylogs" may be used to write the logging to the
|
||||||
|
socket "/home/foo/mylogs". If the connection to the socket fails
|
||||||
|
or a write error is detected, the function writes to stderr and
|
||||||
|
tries the next time again to connect the socket.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
log_set_file (const char *name)
|
log_set_file (const char *name)
|
||||||
{
|
{
|
||||||
FILE *fp = (name && strcmp(name,"-"))? fopen(name, "a") : stderr;
|
FILE *fp;
|
||||||
if( !fp ) {
|
|
||||||
|
if (name && !strncmp (name, "socket://", 9) && name[9])
|
||||||
|
{
|
||||||
|
#if defined (HAVE_FOPENCOOKIE)|| defined (HAVE_FUNOPEN)
|
||||||
|
struct fun_cookie_s *cookie;
|
||||||
|
|
||||||
|
cookie = jnlib_xmalloc (sizeof *cookie + strlen (name+9));
|
||||||
|
cookie->fd = -1;
|
||||||
|
cookie->quiet = 0;
|
||||||
|
strcpy (cookie->name, name+9);
|
||||||
|
|
||||||
|
#ifdef HAVE_FOPENCOOKIE
|
||||||
|
{
|
||||||
|
cookie_io_functions_t io = { NULL };
|
||||||
|
io.write = fun_writer;
|
||||||
|
io.close = fun_closer;
|
||||||
|
|
||||||
|
fp = fopencookie (cookie, "w", io);
|
||||||
|
}
|
||||||
|
#else /*!HAVE_FOPENCOOKIE*/
|
||||||
|
{
|
||||||
|
fp = funopen (cookie, NULL, fun_writer, NULL, fun_closer);
|
||||||
|
}
|
||||||
|
#endif /*!HAVE_FOPENCOOKIE*/
|
||||||
|
#else /* Neither fopencookie nor funopen. */
|
||||||
|
{
|
||||||
|
fprintf (stderr, "system does not support logging to a socket - "
|
||||||
|
"using stderr\n");
|
||||||
|
fp = stderr;
|
||||||
|
}
|
||||||
|
#endif /* Neither fopencookie nor funopen. */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
fp = (name && strcmp(name,"-"))? fopen (name, "a") : stderr;
|
||||||
|
if (!fp)
|
||||||
|
{
|
||||||
fprintf (stderr, "failed to open log file `%s': %s\n",
|
fprintf (stderr, "failed to open log file `%s': %s\n",
|
||||||
name, strerror(errno));
|
name? name:"[stderr]", strerror(errno));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
setvbuf (fp, NULL, _IOLBF, 0);
|
setvbuf (fp, NULL, _IOLBF, 0);
|
||||||
@ -101,6 +254,7 @@ log_set_file( const char *name )
|
|||||||
missing_lf = 0;
|
missing_lf = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
log_set_fd (int fd)
|
log_set_fd (int fd)
|
||||||
{
|
{
|
||||||
@ -221,6 +375,7 @@ do_logv( int level, const char *fmt, va_list arg_ptr )
|
|||||||
default: fprintf(logstream,"[Unknown log level %d]: ", level ); break;
|
default: fprintf(logstream,"[Unknown log level %d]: ", level ); break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (fmt)
|
if (fmt)
|
||||||
{
|
{
|
||||||
vfprintf(logstream,fmt,arg_ptr) ;
|
vfprintf(logstream,fmt,arg_ptr) ;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user