|
|
47e33d |
diff --git a/Makefile.am b/Makefile.am
|
|
|
47e33d |
index 264ffa6..0cbea8c 100644
|
|
|
47e33d |
--- a/Makefile.am
|
|
|
47e33d |
+++ b/Makefile.am
|
|
|
47e33d |
@@ -15,6 +15,10 @@ AM_CPPFLAGS += -DRPCBIND_DEBUG -DSVC_RUN_DEBUG -DDEBUG_RMTCALL
|
|
|
47e33d |
AM_CPPFLAGS += -DND_DEBUG -DBIND_DEBUG
|
|
|
47e33d |
endif
|
|
|
47e33d |
|
|
|
47e33d |
+if LIBSETDEBUG
|
|
|
47e33d |
+AM_CPPFLAGS += -DLIB_SET_DEBUG
|
|
|
47e33d |
+endif
|
|
|
47e33d |
+
|
|
|
47e33d |
if WARMSTART
|
|
|
47e33d |
AM_CPPFLAGS += -DWARMSTART
|
|
|
47e33d |
endif
|
|
|
47e33d |
@@ -36,7 +40,8 @@ rpcbind_SOURCES = \
|
|
|
47e33d |
src/rpcbind.h \
|
|
|
47e33d |
src/security.c \
|
|
|
47e33d |
src/util.c \
|
|
|
47e33d |
- src/warmstart.c
|
|
|
47e33d |
+ src/warmstart.c \
|
|
|
47e33d |
+ src/xlog.c
|
|
|
47e33d |
rpcbind_LDADD = $(TIRPC_LIBS)
|
|
|
47e33d |
|
|
|
47e33d |
if SYSTEMD
|
|
|
47e33d |
diff --git a/configure.ac b/configure.ac
|
|
|
47e33d |
index b97b5a0..a260577 100644
|
|
|
47e33d |
--- a/configure.ac
|
|
|
47e33d |
+++ b/configure.ac
|
|
|
47e33d |
@@ -12,6 +12,10 @@ AM_CONDITIONAL(LIBWRAP, test x$enable_libwrap = xyes)
|
|
|
47e33d |
AC_ARG_ENABLE([debug],
|
|
|
47e33d |
AS_HELP_STRING([--enable-debug], [Turns on rpcbind debugging @<:@default=no@:>@]))
|
|
|
47e33d |
AM_CONDITIONAL(DEBUG, test x$enable_debug = xyes)
|
|
|
47e33d |
+if test x"$enable_debug" = xyes; then
|
|
|
47e33d |
+ AC_CHECK_LIB([tirpc], [libtirpc_set_debug], [lib_setdebug=yes])
|
|
|
47e33d |
+fi
|
|
|
47e33d |
+AM_CONDITIONAL(LIBSETDEBUG, test x$lib_setdebug = xyes)
|
|
|
47e33d |
|
|
|
47e33d |
AC_ARG_ENABLE([warmstarts],
|
|
|
47e33d |
AS_HELP_STRING([--enable-warmstarts], [Enables Warm Starts @<:@default=no@:>@]))
|
|
|
47e33d |
diff --git a/man/rpcbind.8 b/man/rpcbind.8
|
|
|
47e33d |
index da32701..af6200f 100644
|
|
|
47e33d |
--- a/man/rpcbind.8
|
|
|
47e33d |
+++ b/man/rpcbind.8
|
|
|
47e33d |
@@ -76,8 +76,8 @@ do an abort on errors.
|
|
|
47e33d |
Run in debug mode.
|
|
|
47e33d |
In this mode,
|
|
|
47e33d |
.Nm
|
|
|
47e33d |
-will not fork when it starts, will print additional information
|
|
|
47e33d |
-during operation, and will abort on certain errors if
|
|
|
47e33d |
+will log additional information during operation,
|
|
|
47e33d |
+and will abort on certain errors if
|
|
|
47e33d |
.Fl a
|
|
|
47e33d |
is also specified.
|
|
|
47e33d |
With this option, the name-to-address translation consistency
|
|
|
47e33d |
diff --git a/src/pmap_svc.c b/src/pmap_svc.c
|
|
|
47e33d |
index 337e64d..ad28b93 100644
|
|
|
47e33d |
--- a/src/pmap_svc.c
|
|
|
47e33d |
+++ b/src/pmap_svc.c
|
|
|
47e33d |
@@ -54,9 +54,11 @@ static char sccsid[] = "@(#)pmap_svc.c 1.23 89/04/05 Copyr 1984 Sun Micro";
|
|
|
47e33d |
#include <rpc/pmap_prot.h>
|
|
|
47e33d |
#include <rpc/rpcb_prot.h>
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
+#include <syslog.h>
|
|
|
47e33d |
#include <stdlib.h>
|
|
|
47e33d |
#endif
|
|
|
47e33d |
#include "rpcbind.h"
|
|
|
47e33d |
+#include "xlog.h"
|
|
|
47e33d |
#include <rpc/svc_soc.h> /* svc_getcaller routine definition */
|
|
|
47e33d |
static struct pmaplist *find_service_pmap __P((rpcprog_t, rpcvers_t,
|
|
|
47e33d |
rpcprot_t));
|
|
|
47e33d |
@@ -78,7 +80,7 @@ pmap_service(struct svc_req *rqstp, SVCXPRT *xprt)
|
|
|
47e33d |
*/
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "PMAPPROC_NULL\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "PMAPPROC_NULL\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
check_access(xprt, rqstp->rq_proc, 0, PMAPVERS);
|
|
|
47e33d |
if ((!svc_sendreply(xprt, (xdrproc_t) xdr_void, NULL)) &&
|
|
|
47e33d |
@@ -117,7 +119,7 @@ pmap_service(struct svc_req *rqstp, SVCXPRT *xprt)
|
|
|
47e33d |
*/
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "PMAPPROC_DUMP\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "PMAPPROC_DUMP\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
pmapproc_dump(rqstp, xprt);
|
|
|
47e33d |
break;
|
|
|
47e33d |
@@ -196,7 +198,7 @@ pmapproc_change(struct svc_req *rqstp /*__unused*/, SVCXPRT *xprt, unsigned long
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "%s request for (%lu, %lu) : ",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "%s request for (%lu, %lu) : ",
|
|
|
47e33d |
op == PMAPPROC_SET ? "PMAP_SET" : "PMAP_UNSET",
|
|
|
47e33d |
reg.pm_prog, reg.pm_vers);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -243,14 +245,14 @@ pmapproc_change(struct svc_req *rqstp /*__unused*/, SVCXPRT *xprt, unsigned long
|
|
|
47e33d |
done_change:
|
|
|
47e33d |
if ((!svc_sendreply(xprt, (xdrproc_t) xdr_long, (caddr_t) &ans)) &&
|
|
|
47e33d |
debugging) {
|
|
|
47e33d |
- fprintf(stderr, "portmap: svc_sendreply\n");
|
|
|
47e33d |
+ xlog(L_ERROR, "portmap: svc_sendreply failed!\n");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "%s\n", ans == TRUE ? "succeeded" : "failed");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "%s\n", ans == TRUE ? "succeeded" : "failed");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if (op == PMAPPROC_SET)
|
|
|
47e33d |
rpcbs_set(RPCBVERS_2_STAT, ans);
|
|
|
47e33d |
@@ -285,7 +287,7 @@ pmapproc_getport(struct svc_req *rqstp /*__unused*/, SVCXPRT *xprt)
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
uaddr = taddr2uaddr(rpcbind_get_conf(xprt->xp_netid),
|
|
|
47e33d |
svc_getrpccaller(xprt));
|
|
|
47e33d |
- fprintf(stderr, "PMAP_GETPORT req for (%lu, %lu, %s) from %s :",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "PMAP_GETPORT req for (%lu, %lu, %s) from %s :",
|
|
|
47e33d |
reg.pm_prog, reg.pm_vers,
|
|
|
47e33d |
pmap_ipprot2netid(reg.pm_prot)?: "<invalid>",
|
|
|
47e33d |
uaddr);
|
|
|
47e33d |
@@ -315,14 +317,14 @@ pmapproc_getport(struct svc_req *rqstp /*__unused*/, SVCXPRT *xprt)
|
|
|
47e33d |
lport = port;
|
|
|
47e33d |
if ((!svc_sendreply(xprt, (xdrproc_t) xdr_long, (caddr_t)&lport)) &&
|
|
|
47e33d |
debugging) {
|
|
|
47e33d |
- (void) fprintf(stderr, "portmap: svc_sendreply\n");
|
|
|
47e33d |
+ xlog(L_ERROR, "portmap: svc_sendreply failed!\n");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "port = %d\n", port);
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "port = %d\n", port);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
rpcbs_getaddr(RPCBVERS_2_STAT, reg.pm_prog, reg.pm_vers,
|
|
|
47e33d |
pmap_ipprot2netid(reg.pm_prot) ?: "<unknown>",
|
|
|
47e33d |
@@ -347,8 +349,7 @@ pmapproc_dump(struct svc_req *rqstp /*__unused*/, SVCXPRT *xprt)
|
|
|
47e33d |
|
|
|
47e33d |
if ((!svc_sendreply(xprt, (xdrproc_t) xdr_pmaplist_ptr,
|
|
|
47e33d |
(caddr_t)&list_pml)) && debugging) {
|
|
|
47e33d |
- if (debugging)
|
|
|
47e33d |
- (void) fprintf(stderr, "portmap: svc_sendreply\n");
|
|
|
47e33d |
+ xlog(L_ERROR, "portmap: svc_sendreply failed!\n");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
diff --git a/src/rpcb_svc.c b/src/rpcb_svc.c
|
|
|
47e33d |
index e350f85..92361a2 100644
|
|
|
47e33d |
--- a/src/rpcb_svc.c
|
|
|
47e33d |
+++ b/src/rpcb_svc.c
|
|
|
47e33d |
@@ -86,7 +86,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
*/
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_NULL\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_NULL");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/* This call just logs, no actual checks */
|
|
|
47e33d |
check_access(transp, rqstp->rq_proc, 0, RPCBVERS);
|
|
|
47e33d |
@@ -114,7 +114,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_DUMP:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_DUMP\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_DUMP");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_void;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_rpcblist_ptr;
|
|
|
47e33d |
@@ -128,7 +128,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_GETTIME:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_GETTIME\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_GETTIME");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_void;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_u_long;
|
|
|
47e33d |
@@ -138,7 +138,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_UADDR2TADDR:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_UADDR2TADDR\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_UADDR2TADDR");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_wrapstring;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_netbuf;
|
|
|
47e33d |
@@ -148,7 +148,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_TADDR2UADDR:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_TADDR2UADDR\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_TADDR2UADDR");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_netbuf;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_wrapstring;
|
|
|
47e33d |
@@ -164,7 +164,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
(char *) &argument)) {
|
|
|
47e33d |
svcerr_decode(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- (void) fprintf(stderr, "rpcbind: could not decode\n");
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "rpcbind: could not decode");
|
|
|
47e33d |
return;
|
|
|
47e33d |
}
|
|
|
47e33d |
|
|
|
47e33d |
@@ -182,7 +182,7 @@ rpcb_service_3(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
result)) {
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- (void) fprintf(stderr, "rpcbind: svc_sendreply\n");
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "rpcbind: svc_sendreply");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -192,7 +192,7 @@ done:
|
|
|
47e33d |
if (!svc_freeargs(transp, (xdrproc_t)xdr_argument, (char *)
|
|
|
47e33d |
&argument)) {
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- (void) fprintf(stderr, "unable to free arguments\n");
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "unable to free arguments");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -220,7 +220,7 @@ rpcbproc_getaddr_3_local(void *arg, struct svc_req *rqstp /*__unused*/,
|
|
|
47e33d |
|
|
|
47e33d |
uaddr = taddr2uaddr(rpcbind_get_conf(transp->xp_netid),
|
|
|
47e33d |
svc_getrpccaller(transp));
|
|
|
47e33d |
- fprintf(stderr, "RPCB_GETADDR req for (%lu, %lu, %s) from %s: ",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_GETADDR req for (%lu, %lu, %s) from %s: ",
|
|
|
47e33d |
(unsigned long)regp->r_prog, (unsigned long)regp->r_vers,
|
|
|
47e33d |
regp->r_netid, uaddr);
|
|
|
47e33d |
free(uaddr);
|
|
|
47e33d |
diff --git a/src/rpcb_svc_4.c b/src/rpcb_svc_4.c
|
|
|
47e33d |
index 313e6d1..f1a72a6 100644
|
|
|
47e33d |
--- a/src/rpcb_svc_4.c
|
|
|
47e33d |
+++ b/src/rpcb_svc_4.c
|
|
|
47e33d |
@@ -89,7 +89,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
*/
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_NULL\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_NULL\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
check_access(transp, rqstp->rq_proc, 0, RPCBVERS4);
|
|
|
47e33d |
(void) svc_sendreply(transp, (xdrproc_t) xdr_void,
|
|
|
47e33d |
@@ -125,7 +125,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_GETVERSADDR:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_GETVERSADDR\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_GETVERSADDR\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_rpcb;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_wrapstring;
|
|
|
47e33d |
@@ -135,7 +135,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_DUMP:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_DUMP\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_DUMP\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_void;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_rpcblist_ptr;
|
|
|
47e33d |
@@ -145,7 +145,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_INDIRECT:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_INDIRECT\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_INDIRECT\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
rpcbproc_callit_com(rqstp, transp, rqstp->rq_proc, RPCBVERS4);
|
|
|
47e33d |
return;
|
|
|
47e33d |
@@ -154,7 +154,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_BCAST:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_BCAST\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_BCAST\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
rpcbproc_callit_com(rqstp, transp, rqstp->rq_proc, RPCBVERS4);
|
|
|
47e33d |
return;
|
|
|
47e33d |
@@ -162,7 +162,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_GETTIME:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_GETTIME\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_GETTIME\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_void;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_u_long;
|
|
|
47e33d |
@@ -172,7 +172,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_UADDR2TADDR:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_UADDR2TADDR\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_UADDR2TADDR\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_wrapstring;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_netbuf;
|
|
|
47e33d |
@@ -182,7 +182,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_TADDR2UADDR:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_TADDR2UADDR\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_TADDR2UADDR\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_netbuf;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_wrapstring;
|
|
|
47e33d |
@@ -192,7 +192,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_GETADDRLIST:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_GETADDRLIST\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_GETADDRLIST\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_rpcb;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_rpcb_entry_list_ptr;
|
|
|
47e33d |
@@ -202,7 +202,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
case RPCBPROC_GETSTAT:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCBPROC_GETSTAT\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCBPROC_GETSTAT\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
xdr_argument = (xdrproc_t)xdr_void;
|
|
|
47e33d |
xdr_result = (xdrproc_t)xdr_rpcb_stat_byvers;
|
|
|
47e33d |
@@ -218,7 +218,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
(char *)&argument)) {
|
|
|
47e33d |
svcerr_decode(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- (void) fprintf(stderr, "rpcbind: could not decode\n");
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "rpcbind: could not decode\n");
|
|
|
47e33d |
return;
|
|
|
47e33d |
}
|
|
|
47e33d |
|
|
|
47e33d |
@@ -236,7 +236,7 @@ rpcb_service_4(struct svc_req *rqstp, SVCXPRT *transp)
|
|
|
47e33d |
result)) {
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- (void) fprintf(stderr, "rpcbind: svc_sendreply\n");
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "rpcbind: svc_sendreply\n");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -246,7 +246,7 @@ done:
|
|
|
47e33d |
if (!svc_freeargs(transp, (xdrproc_t) xdr_argument,
|
|
|
47e33d |
(char *)&argument)) {
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- (void) fprintf(stderr, "unable to free arguments\n");
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "unable to free arguments\n");
|
|
|
47e33d |
if (doabort) {
|
|
|
47e33d |
rpcbind_abort();
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -277,7 +277,7 @@ rpcbproc_getaddr_4_local(void *arg, struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
|
|
|
47e33d |
uaddr = taddr2uaddr(rpcbind_get_conf(transp->xp_netid),
|
|
|
47e33d |
svc_getrpccaller(transp));
|
|
|
47e33d |
- fprintf(stderr, "RPCB_GETADDR req for (%lu, %lu, %s) from %s: ",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_GETADDR req for (%lu, %lu, %s) from %s: ",
|
|
|
47e33d |
(unsigned long)regp->r_prog, (unsigned long)regp->r_vers,
|
|
|
47e33d |
regp->r_netid, uaddr);
|
|
|
47e33d |
free(uaddr);
|
|
|
47e33d |
@@ -307,7 +307,7 @@ rpcbproc_getversaddr_4_local(void *arg, struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
|
|
|
47e33d |
uaddr = taddr2uaddr(rpcbind_get_conf(transp->xp_netid),
|
|
|
47e33d |
svc_getrpccaller(transp));
|
|
|
47e33d |
- fprintf(stderr, "RPCB_GETVERSADDR rqst for (%lu, %lu, %s)"
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_GETVERSADDR rqst for (%lu, %lu, %s)"
|
|
|
47e33d |
" from %s : ",
|
|
|
47e33d |
(unsigned long)regp->r_prog, (unsigned long)regp->r_vers,
|
|
|
47e33d |
regp->r_netid, uaddr);
|
|
|
47e33d |
@@ -353,7 +353,7 @@ rpcbproc_getaddrlist_4_local(void *arg, struct svc_req *rqstp /*__unused*/,
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- fprintf(stderr, "r_addr: %s r_netid: %s nc_protofmly: %s\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "r_addr: %s r_netid: %s nc_protofmly: %s\n",
|
|
|
47e33d |
regp->r_addr, regp->r_netid, reg_nconf->nc_protofmly);
|
|
|
47e33d |
}
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -369,20 +369,20 @@ rpcbproc_getaddrlist_4_local(void *arg, struct svc_req *rqstp /*__unused*/,
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "\tmerge with: %s\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "\tmerge with: %s\n",
|
|
|
47e33d |
rbl->rpcb_map.r_addr);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if ((maddr = mergeaddr(transp, rbl->rpcb_map.r_netid,
|
|
|
47e33d |
rbl->rpcb_map.r_addr, saddr)) == NULL) {
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, " FAILED\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, " FAILED\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
continue;
|
|
|
47e33d |
} else if (!maddr[0]) {
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, " SUCCEEDED, but port died - maddr: nullstring\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, " SUCCEEDED, but port died - maddr: nullstring\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/* The server died. Unset this combination */
|
|
|
47e33d |
delete_prog(regp->r_prog);
|
|
|
47e33d |
@@ -390,7 +390,7 @@ rpcbproc_getaddrlist_4_local(void *arg, struct svc_req *rqstp /*__unused*/,
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, " SUCCEEDED maddr: %s\n", maddr);
|
|
|
47e33d |
+ xlog(LOG_DEBUG, " SUCCEEDED maddr: %s\n", maddr);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/*
|
|
|
47e33d |
* Add it to rlist.
|
|
|
47e33d |
@@ -418,7 +418,7 @@ rpcbproc_getaddrlist_4_local(void *arg, struct svc_req *rqstp /*__unused*/,
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
for (rp = rlist; rp; rp = rp->rpcb_entry_next) {
|
|
|
47e33d |
- fprintf(stderr, "\t%s %s\n", rp->rpcb_entry_map.r_maddr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "\t%s %s\n", rp->rpcb_entry_map.r_maddr,
|
|
|
47e33d |
rp->rpcb_entry_map.r_nc_proto);
|
|
|
47e33d |
}
|
|
|
47e33d |
}
|
|
|
47e33d |
diff --git a/src/rpcb_svc_com.c b/src/rpcb_svc_com.c
|
|
|
47e33d |
index 69a6d2d..3716f04 100644
|
|
|
47e33d |
--- a/src/rpcb_svc_com.c
|
|
|
47e33d |
+++ b/src/rpcb_svc_com.c
|
|
|
47e33d |
@@ -137,14 +137,14 @@ rpcbproc_set_com(void *arg, struct svc_req *rqstp /*__unused*/, SVCXPRT *transp,
|
|
|
47e33d |
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCB_SET request for (%lu, %lu, %s, %s) : ",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_SET request for (%lu, %lu, %s, %s) : ",
|
|
|
47e33d |
(unsigned long)regp->r_prog, (unsigned long)regp->r_vers,
|
|
|
47e33d |
regp->r_netid, regp->r_addr);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
ans = map_set(regp, getowner(transp, owner, sizeof owner));
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "%s\n", ans == TRUE ? "succeeded" : "failed");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_SET: %s", ans == TRUE ? "succeeded" : "failed");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/* XXX: should have used some defined constant here */
|
|
|
47e33d |
rpcbs_set(rpcbversnum - 2, ans);
|
|
|
47e33d |
@@ -225,7 +225,7 @@ rpcbproc_unset_com(void *arg, struct svc_req *rqstp /*__unused*/, SVCXPRT *trans
|
|
|
47e33d |
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "RPCB_UNSET request for (%lu, %lu, %s) : ",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_UNSET request for (%lu, %lu, %s) : ",
|
|
|
47e33d |
(unsigned long)regp->r_prog, (unsigned long)regp->r_vers,
|
|
|
47e33d |
regp->r_netid);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -233,7 +233,7 @@ rpcbproc_unset_com(void *arg, struct svc_req *rqstp /*__unused*/, SVCXPRT *trans
|
|
|
47e33d |
ans = map_unset(regp, getowner(transp, owner, sizeof owner));
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "%s\n", ans == TRUE ? "succeeded" : "failed");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "RPCB_UNSET: %s", ans == TRUE ? "succeeded" : "failed");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/* XXX: should have used some defined constant here */
|
|
|
47e33d |
rpcbs_unset(rpcbversnum - 2, ans);
|
|
|
47e33d |
@@ -264,9 +264,9 @@ map_unset(RPCB *regp, char *owner)
|
|
|
47e33d |
* if superuser or the owner itself.
|
|
|
47e33d |
*/
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
- fprintf(stderr,"Suppression RPC_UNSET(map_unset)\n ");
|
|
|
47e33d |
- fprintf(stderr,"rbl->rpcb_map.r_owner=%s\n ",rbl->rpcb_map.r_owner);
|
|
|
47e33d |
- fprintf(stderr,"owner=%s\n ",owner);
|
|
|
47e33d |
+ xlog(LOG_DEBUG,"Suppression RPC_UNSET(map_unset) ");
|
|
|
47e33d |
+ xlog(LOG_DEBUG,"rbl->rpcb_map.r_owner=%s ",rbl->rpcb_map.r_owner);
|
|
|
47e33d |
+ xlog(LOG_DEBUG,"owner=%s ",owner);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if (strcmp(owner, "superuser") &&
|
|
|
47e33d |
strcmp(rbl->rpcb_map.r_owner, owner))
|
|
|
47e33d |
@@ -349,7 +349,7 @@ rpcbproc_getaddr_com(RPCB *regp, struct svc_req *rqstp /*__unused*/,
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "getaddr: %s\n", uaddr);
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "getaddr: %s", uaddr);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/* XXX: should have used some defined constant here */
|
|
|
47e33d |
rpcbs_getaddr(rpcbversnum - 2, regp->r_prog, regp->r_vers,
|
|
|
47e33d |
@@ -506,7 +506,7 @@ create_rmtcall_fd(struct netconfig *nconf)
|
|
|
47e33d |
|
|
|
47e33d |
if ((fd = __rpc_nconf2fd(nconf)) == -1) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"create_rmtcall_fd: couldn't open \"%s\" (errno %d)\n",
|
|
|
47e33d |
nconf->nc_device, errno);
|
|
|
47e33d |
return (-1);
|
|
|
47e33d |
@@ -514,7 +514,7 @@ create_rmtcall_fd(struct netconfig *nconf)
|
|
|
47e33d |
xprt = svc_tli_create(fd, 0, (struct t_bind *) 0, 0, 0);
|
|
|
47e33d |
if (xprt == NULL) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"create_rmtcall_fd: svc_tli_create failed\n");
|
|
|
47e33d |
return (-1);
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -656,7 +656,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
#endif /* notyet */
|
|
|
47e33d |
if (buf_alloc == NULL) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: No Memory!\n");
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
@@ -672,7 +672,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_decode(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: svc_getargs failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -686,7 +686,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
uaddr = taddr2uaddr(rpcbind_get_conf(transp->xp_netid), caller);
|
|
|
47e33d |
- fprintf(stderr, "%s %s req for (%lu, %lu, %lu, %s) from %s : ",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "%s %s req for (%lu, %lu, %lu, %s) from %s : ",
|
|
|
47e33d |
versnum == PMAPVERS ? "pmap_rmtcall" :
|
|
|
47e33d |
versnum == RPCBVERS ? "rpcb_rmtcall" :
|
|
|
47e33d |
versnum == RPCBVERS4 ? "rpcb_indirect" : "unknown",
|
|
|
47e33d |
@@ -707,7 +707,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (rbl == (rpcblist_ptr)NULL) {
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "not found\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "not found\n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_noprog(transp);
|
|
|
47e33d |
@@ -726,7 +726,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "found at uaddr %s\n", rbl->rpcb_map.r_addr);
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "found at uaddr %s\n", rbl->rpcb_map.r_addr);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
/*
|
|
|
47e33d |
* Check whether this entry is valid and a server is present
|
|
|
47e33d |
@@ -750,14 +750,14 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: rpcbind_get_conf failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
localsa = local_sa(((struct sockaddr *)caller->buf)->sa_family);
|
|
|
47e33d |
if (localsa == NULL) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: no local address\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -780,7 +780,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
nconf->nc_netid);
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, "merged uaddr %s\n", m_uaddr);
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "merged uaddr %s\n", m_uaddr);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if ((fd = find_rmtcallfd_by_netid(nconf->nc_netid)) == -1) {
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
@@ -800,20 +800,20 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
* beat on it any more.
|
|
|
47e33d |
*/
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: duplicate request\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
case -1:
|
|
|
47e33d |
/* forward_register failed. Perhaps no memory. */
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: forward_register failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
|
|
|
47e33d |
#ifdef DEBUG_RMTCALL
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: original XID %x, new XID %x\n",
|
|
|
47e33d |
*xidp, call_msg.rm_xid);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -831,7 +831,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: No memory!\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -843,7 +843,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: xdr_callhdr failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -851,7 +851,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: xdr_u_long failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -870,7 +870,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
} else {
|
|
|
47e33d |
/* we do not support any other authentication scheme */
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: oa_flavor != AUTH_NONE and oa_flavor != AUTH_SYS\n");
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_weakauth(transp); /* XXX too strong.. */
|
|
|
47e33d |
@@ -880,7 +880,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: authwhatever_create returned NULL\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -889,7 +889,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
AUTH_DESTROY(auth);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: AUTH_MARSHALL failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -898,7 +898,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: xdr_opaque_parms failed\n");
|
|
|
47e33d |
goto error;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -918,7 +918,7 @@ rpcbproc_callit_com(struct svc_req *rqstp, SVCXPRT *transp,
|
|
|
47e33d |
if (sendto(fd, outbufp, outlen, 0, (struct sockaddr *)na->buf, na->len)
|
|
|
47e33d |
!= outlen) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbproc_callit_com: sendto failed: errno %d\n", errno);
|
|
|
47e33d |
if (reply_type == RPCBPROC_INDIRECT)
|
|
|
47e33d |
svcerr_systemerr(transp);
|
|
|
47e33d |
@@ -1123,15 +1123,7 @@ my_svc_run()
|
|
|
47e33d |
}
|
|
|
47e33d |
nfds = p - pollfds;
|
|
|
47e33d |
poll_ret = 0;
|
|
|
47e33d |
-#ifdef SVC_RUN_DEBUG
|
|
|
47e33d |
- if (debugging) {
|
|
|
47e33d |
- fprintf(stderr, "polling for read on fd < ");
|
|
|
47e33d |
- for (i = 0, p = pollfds; i < nfds; i++, p++)
|
|
|
47e33d |
- if (p->events)
|
|
|
47e33d |
- fprintf(stderr, "%d ", p->fd);
|
|
|
47e33d |
- fprintf(stderr, ">\n");
|
|
|
47e33d |
- }
|
|
|
47e33d |
-#endif
|
|
|
47e33d |
+
|
|
|
47e33d |
switch (poll_ret = poll(pollfds, nfds, 30 * 1000)) {
|
|
|
47e33d |
case -1:
|
|
|
47e33d |
/*
|
|
|
47e33d |
@@ -1144,15 +1136,6 @@ my_svc_run()
|
|
|
47e33d |
__svc_clean_idle(&cleanfds, 30, FALSE);
|
|
|
47e33d |
continue;
|
|
|
47e33d |
default:
|
|
|
47e33d |
-#ifdef SVC_RUN_DEBUG
|
|
|
47e33d |
- if (debugging) {
|
|
|
47e33d |
- fprintf(stderr, "poll returned read fds < ");
|
|
|
47e33d |
- for (i = 0, p = pollfds; i < nfds; i++, p++)
|
|
|
47e33d |
- if (p->revents)
|
|
|
47e33d |
- fprintf(stderr, "%d ", p->fd);
|
|
|
47e33d |
- fprintf(stderr, ">\n");
|
|
|
47e33d |
- }
|
|
|
47e33d |
-#endif
|
|
|
47e33d |
/*
|
|
|
47e33d |
* If we found as many replies on callback fds
|
|
|
47e33d |
* as the number of descriptors selectable which
|
|
|
47e33d |
@@ -1165,11 +1148,6 @@ my_svc_run()
|
|
|
47e33d |
continue;
|
|
|
47e33d |
svc_getreq_poll(pollfds, poll_ret-check_ret);
|
|
|
47e33d |
}
|
|
|
47e33d |
-#ifdef SVC_RUN_DEBUG
|
|
|
47e33d |
- if (debugging) {
|
|
|
47e33d |
- fprintf(stderr, "svc_maxfd now %u\n", svc_maxfd);
|
|
|
47e33d |
- }
|
|
|
47e33d |
-#endif
|
|
|
47e33d |
}
|
|
|
47e33d |
}
|
|
|
47e33d |
|
|
|
47e33d |
@@ -1189,7 +1167,7 @@ check_rmtcalls(struct pollfd *pfds, int nfds)
|
|
|
47e33d |
ncallbacks_found++;
|
|
|
47e33d |
#ifdef DEBUG_RMTCALL
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"my_svc_run: polled on forwarding fd %d, netid %s - calling handle_reply\n",
|
|
|
47e33d |
pfds[j].fd, xprt->xp_netid);
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -1274,7 +1252,7 @@ handle_reply(int fd, SVCXPRT *xprt)
|
|
|
47e33d |
} while (inlen < 0 && errno == EINTR);
|
|
|
47e33d |
if (inlen < 0) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"handle_reply: recvfrom returned %d, errno %d\n", inlen, errno);
|
|
|
47e33d |
goto done;
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -1286,14 +1264,14 @@ handle_reply(int fd, SVCXPRT *xprt)
|
|
|
47e33d |
xdrmem_create(&reply_xdrs, buffer, (u_int)inlen, XDR_DECODE);
|
|
|
47e33d |
if (!xdr_replymsg(&reply_xdrs, &reply_msg)) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- (void) fprintf(stderr,
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG,
|
|
|
47e33d |
"handle_reply: xdr_replymsg failed\n");
|
|
|
47e33d |
goto done;
|
|
|
47e33d |
}
|
|
|
47e33d |
fi = forward_find(reply_msg.rm_xid);
|
|
|
47e33d |
#ifdef SVC_RUN_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- fprintf(stderr, "handle_reply: reply xid: %d fi addr: %p\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "handle_reply: reply xid: %d fi addr: %p\n",
|
|
|
47e33d |
reply_msg.rm_xid, fi);
|
|
|
47e33d |
}
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -1303,7 +1281,7 @@ handle_reply(int fd, SVCXPRT *xprt)
|
|
|
47e33d |
_seterr_reply(&reply_msg, &reply_error);
|
|
|
47e33d |
if (reply_error.re_status != RPC_SUCCESS) {
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- (void) fprintf(stderr, "handle_reply: %s\n",
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "handle_reply: %s\n",
|
|
|
47e33d |
clnt_sperrno(reply_error.re_status));
|
|
|
47e33d |
send_svcsyserr(xprt, fi);
|
|
|
47e33d |
goto done;
|
|
|
47e33d |
@@ -1327,7 +1305,7 @@ done:
|
|
|
47e33d |
if (reply_msg.rm_xid == 0) {
|
|
|
47e33d |
#ifdef SVC_RUN_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
- fprintf(stderr, "handle_reply: NULL xid on exit!\n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "handle_reply: NULL xid on exit!\n");
|
|
|
47e33d |
}
|
|
|
47e33d |
#endif
|
|
|
47e33d |
} else
|
|
|
47e33d |
diff --git a/src/rpcbind.c b/src/rpcbind.c
|
|
|
47e33d |
index bf40807..2789baf 100644
|
|
|
47e33d |
--- a/src/rpcbind.c
|
|
|
47e33d |
+++ b/src/rpcbind.c
|
|
|
47e33d |
@@ -72,6 +72,7 @@
|
|
|
47e33d |
#include <errno.h>
|
|
|
47e33d |
#include <nss.h>
|
|
|
47e33d |
#include "rpcbind.h"
|
|
|
47e33d |
+#include "xlog.h"
|
|
|
47e33d |
|
|
|
47e33d |
/*#define RPCBIND_DEBUG*/
|
|
|
47e33d |
|
|
|
47e33d |
@@ -110,6 +111,9 @@ int nhosts = 0;
|
|
|
47e33d |
int on = 1;
|
|
|
47e33d |
int rpcbindlockfd;
|
|
|
47e33d |
|
|
|
47e33d |
+#ifdef LIB_SET_DEBUG
|
|
|
47e33d |
+void libtirpc_set_debug(char *name, int level, int use_stderr);
|
|
|
47e33d |
+#endif
|
|
|
47e33d |
#ifdef WARMSTART
|
|
|
47e33d |
/* Local Variable */
|
|
|
47e33d |
static int warmstart = 0; /* Grab an old copy of registrations. */
|
|
|
47e33d |
@@ -159,7 +163,7 @@ main(int argc, char *argv[])
|
|
|
47e33d |
rl.rlim_cur = 128;
|
|
|
47e33d |
setrlimit(RLIMIT_NOFILE, &rl);
|
|
|
47e33d |
}
|
|
|
47e33d |
- openlog("rpcbind", LOG_CONS, LOG_DAEMON);
|
|
|
47e33d |
+
|
|
|
47e33d |
if (geteuid()) { /* This command allowed only to root */
|
|
|
47e33d |
fprintf(stderr, "Sorry. You are not superuser\n");
|
|
|
47e33d |
exit(1);
|
|
|
47e33d |
@@ -184,7 +188,20 @@ main(int argc, char *argv[])
|
|
|
47e33d |
syslog(LOG_ERR, "%s: can't find local transport\n", argv[0]);
|
|
|
47e33d |
exit(1);
|
|
|
47e33d |
}
|
|
|
47e33d |
-
|
|
|
47e33d |
+ xlog_open("rpcbind");
|
|
|
47e33d |
+ if (dofork) {
|
|
|
47e33d |
+ xlog_syslog(TRUE);
|
|
|
47e33d |
+ xlog_stderr(FALSE);
|
|
|
47e33d |
+ } else {
|
|
|
47e33d |
+ xlog_syslog(FALSE);
|
|
|
47e33d |
+ xlog_stderr(TRUE);
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+ if (debugging) {
|
|
|
47e33d |
+ xlog_config(D_ALL, 1);
|
|
|
47e33d |
+#ifdef LIB_SET_DEBUG
|
|
|
47e33d |
+ libtirpc_set_debug("rpcbind", debugging, (dofork == 0));
|
|
|
47e33d |
+#endif
|
|
|
47e33d |
+ }
|
|
|
47e33d |
rpc_control(RPC_SVC_CONNMAXREC_SET, &maxrec);
|
|
|
47e33d |
|
|
|
47e33d |
init_transport(nconf);
|
|
|
47e33d |
@@ -213,18 +230,16 @@ main(int argc, char *argv[])
|
|
|
47e33d |
(void) signal(SIGUSR1, SIG_IGN);
|
|
|
47e33d |
(void) signal(SIGUSR2, SIG_IGN);
|
|
|
47e33d |
|
|
|
47e33d |
- if (debugging) {
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
- printf("rpcbind debugging enabled.");
|
|
|
47e33d |
- if (doabort) {
|
|
|
47e33d |
- printf(" Will abort on errors!\n");
|
|
|
47e33d |
- } else {
|
|
|
47e33d |
- printf("\n");
|
|
|
47e33d |
- }
|
|
|
47e33d |
+ if (debugging) {
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "debugging enabled.");
|
|
|
47e33d |
+ if (doabort)
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "Will abort on errors!\n");
|
|
|
47e33d |
+ }
|
|
|
47e33d |
#endif
|
|
|
47e33d |
- } else if (dofork) {
|
|
|
47e33d |
+ if (dofork) {
|
|
|
47e33d |
if (daemon(0, 0))
|
|
|
47e33d |
- err(1, "fork failed");
|
|
|
47e33d |
+ err(1, "fork failed");
|
|
|
47e33d |
}
|
|
|
47e33d |
|
|
|
47e33d |
if (runasdaemon || rpcbinduser) {
|
|
|
47e33d |
@@ -306,11 +321,11 @@ init_transport(struct netconfig *nconf)
|
|
|
47e33d |
int i;
|
|
|
47e33d |
char **s;
|
|
|
47e33d |
|
|
|
47e33d |
- (void) fprintf(stderr, "%s: %ld lookup routines :\n",
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "%s: %ld lookup routines :\n",
|
|
|
47e33d |
nconf->nc_netid, nconf->nc_nlookups);
|
|
|
47e33d |
for (i = 0, s = nconf->nc_lookups; i < nconf->nc_nlookups;
|
|
|
47e33d |
i++, s++)
|
|
|
47e33d |
- fprintf(stderr, "[%d] - %s\n", i, *s);
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "[%d] - %s\n", i, *s);
|
|
|
47e33d |
}
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if (!__rpc_nconf2sockinfo(nconf, &si)) {
|
|
|
47e33d |
@@ -540,7 +555,7 @@ init_transport(struct netconfig *nconf)
|
|
|
47e33d |
}
|
|
|
47e33d |
nb.len = nb.maxlen = sa_size;
|
|
|
47e33d |
uaddr = taddr2uaddr(nconf, &nb);
|
|
|
47e33d |
- (void) fprintf(stderr,
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG,
|
|
|
47e33d |
"rpcbind : my address is %s\n", uaddr);
|
|
|
47e33d |
(void) free(uaddr);
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -617,7 +632,7 @@ init_transport(struct netconfig *nconf)
|
|
|
47e33d |
}
|
|
|
47e33d |
nb.len = nb.maxlen = sa_size2;
|
|
|
47e33d |
uaddr = taddr2uaddr(nconf, &nb);
|
|
|
47e33d |
- (void) fprintf(stderr, "rpcbind : my address is %s\n",
|
|
|
47e33d |
+ (void) xlog(LOG_DEBUG, "rpcbind : my address is %s\n",
|
|
|
47e33d |
uaddr);
|
|
|
47e33d |
(void) free(uaddr);
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -724,13 +739,13 @@ got_socket:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
if (status < 0) {
|
|
|
47e33d |
- fprintf(stderr, "Error in finding bind status for %s\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "Error in finding bind status for %s\n",
|
|
|
47e33d |
nconf->nc_netid);
|
|
|
47e33d |
} else if (status == 0) {
|
|
|
47e33d |
- fprintf(stderr, "check binding for %s\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "check binding for %s\n",
|
|
|
47e33d |
nconf->nc_netid);
|
|
|
47e33d |
} else if (status > 0) {
|
|
|
47e33d |
- fprintf(stderr, "No check binding for %s\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "No check binding for %s\n",
|
|
|
47e33d |
nconf->nc_netid);
|
|
|
47e33d |
}
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -744,11 +759,11 @@ got_socket:
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging) {
|
|
|
47e33d |
if (status < 0) {
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"Could not create rmtcall fd for %s\n",
|
|
|
47e33d |
nconf->nc_netid);
|
|
|
47e33d |
} else {
|
|
|
47e33d |
- fprintf(stderr, "rmtcall fd for %s is %d\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG, "rmtcall fd for %s is %d\n",
|
|
|
47e33d |
nconf->nc_netid, status);
|
|
|
47e33d |
}
|
|
|
47e33d |
}
|
|
|
47e33d |
@@ -773,8 +788,8 @@ rbllist_add(rpcprog_t prog, rpcvers_t vers, struct netconfig *nconf,
|
|
|
47e33d |
}
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging){
|
|
|
47e33d |
- fprintf(stderr,"FUNCTION rbllist_add");
|
|
|
47e33d |
- fprintf(stderr,"Add the prog %lu vers %lu to the rpcbind list\n",
|
|
|
47e33d |
+ xlog(LOG_DEBUG,"FUNCTION rbllist_add");
|
|
|
47e33d |
+ xlog(LOG_DEBUG,"Add the prog %lu vers %lu to the rpcbind list",
|
|
|
47e33d |
(ulong)prog, (ulong)vers);
|
|
|
47e33d |
}
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -824,7 +839,7 @@ parseargs(int argc, char *argv[])
|
|
|
47e33d |
break; /* errors; for rpcbind developers */
|
|
|
47e33d |
/* only! */
|
|
|
47e33d |
case 'd':
|
|
|
47e33d |
- debugging = 1;
|
|
|
47e33d |
+ debugging++;
|
|
|
47e33d |
break;
|
|
|
47e33d |
case 'h':
|
|
|
47e33d |
++nhosts;
|
|
|
47e33d |
diff --git a/src/security.c b/src/security.c
|
|
|
47e33d |
index d272f74..70edef4 100644
|
|
|
47e33d |
--- a/src/security.c
|
|
|
47e33d |
+++ b/src/security.c
|
|
|
47e33d |
@@ -80,7 +80,7 @@ check_access(SVCXPRT *xprt, rpcproc_t proc, rpcprog_t prog, unsigned int rpcbver
|
|
|
47e33d |
if (!insecure && !is_loopback(caller)) {
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr, " declined (non-loopback sender) \n");
|
|
|
47e33d |
+ xlog(LOG_DEBUG, " declined (non-loopback sender) \n");
|
|
|
47e33d |
#endif
|
|
|
47e33d |
if (verboselog)
|
|
|
47e33d |
logit(log_severity, addr, proc, prog,
|
|
|
47e33d |
@@ -134,7 +134,7 @@ is_loopback(struct netbuf *nbuf)
|
|
|
47e33d |
sin = (struct sockaddr_in *)addr;
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"Checking caller's adress (port = %d)\n",
|
|
|
47e33d |
ntohs(sin->sin_port));
|
|
|
47e33d |
#endif
|
|
|
47e33d |
@@ -146,7 +146,7 @@ is_loopback(struct netbuf *nbuf)
|
|
|
47e33d |
sin6 = (struct sockaddr_in6 *)addr;
|
|
|
47e33d |
#ifdef RPCBIND_DEBUG
|
|
|
47e33d |
if (debugging)
|
|
|
47e33d |
- fprintf(stderr,
|
|
|
47e33d |
+ xlog(LOG_DEBUG,
|
|
|
47e33d |
"Checking caller's adress (port = %d)\n",
|
|
|
47e33d |
ntohs(sin6->sin6_port));
|
|
|
47e33d |
#endif
|
|
|
47e33d |
diff --git a/src/xlog.c b/src/xlog.c
|
|
|
47e33d |
new file mode 100644
|
|
|
47e33d |
index 0000000..ab6c717
|
|
|
47e33d |
--- /dev/null
|
|
|
47e33d |
+++ b/src/xlog.c
|
|
|
47e33d |
@@ -0,0 +1,234 @@
|
|
|
47e33d |
+/*
|
|
|
47e33d |
+ * support/nfs/xlog.c
|
|
|
47e33d |
+ *
|
|
|
47e33d |
+ * This module handles the logging of requests.
|
|
|
47e33d |
+ *
|
|
|
47e33d |
+ * TODO: Merge the two "XXX_log() calls.
|
|
|
47e33d |
+ *
|
|
|
47e33d |
+ * Authors: Donald J. Becker, <becker@super.org>
|
|
|
47e33d |
+ * Rick Sladkey, <jrs@world.std.com>
|
|
|
47e33d |
+ * Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
|
|
|
47e33d |
+ * Olaf Kirch, <okir@monad.swb.de>
|
|
|
47e33d |
+ *
|
|
|
47e33d |
+ * This software maybe be used for any purpose provided
|
|
|
47e33d |
+ * the above copyright notice is retained. It is supplied
|
|
|
47e33d |
+ * as is, with no warranty expressed or implied.
|
|
|
47e33d |
+ */
|
|
|
47e33d |
+
|
|
|
47e33d |
+#ifdef HAVE_CONFIG_H
|
|
|
47e33d |
+#include <config.h>
|
|
|
47e33d |
+#endif
|
|
|
47e33d |
+
|
|
|
47e33d |
+#include <unistd.h>
|
|
|
47e33d |
+#include <signal.h>
|
|
|
47e33d |
+#include <time.h>
|
|
|
47e33d |
+#include <stdlib.h>
|
|
|
47e33d |
+#include <string.h>
|
|
|
47e33d |
+#include <stdio.h>
|
|
|
47e33d |
+#include <stdarg.h>
|
|
|
47e33d |
+#include <syslog.h>
|
|
|
47e33d |
+#include <errno.h>
|
|
|
47e33d |
+#include "xlog.h"
|
|
|
47e33d |
+
|
|
|
47e33d |
+#undef VERBOSE_PRINTF
|
|
|
47e33d |
+
|
|
|
47e33d |
+static int log_stderr = 1;
|
|
|
47e33d |
+static int log_syslog = 1;
|
|
|
47e33d |
+static int logging = 0; /* enable/disable DEBUG logs */
|
|
|
47e33d |
+static int logmask = 0; /* What will be logged */
|
|
|
47e33d |
+static char log_name[256]; /* name of this program */
|
|
|
47e33d |
+static int log_pid = -1; /* PID of this program */
|
|
|
47e33d |
+
|
|
|
47e33d |
+int export_errno = 0;
|
|
|
47e33d |
+
|
|
|
47e33d |
+static void xlog_toggle(int sig);
|
|
|
47e33d |
+static struct xlog_debugfac debugnames[] = {
|
|
|
47e33d |
+ { "general", D_GENERAL, },
|
|
|
47e33d |
+ { "call", D_CALL, },
|
|
|
47e33d |
+ { "auth", D_AUTH, },
|
|
|
47e33d |
+ { "parse", D_PARSE, },
|
|
|
47e33d |
+ { "all", D_ALL, },
|
|
|
47e33d |
+ { NULL, 0, },
|
|
|
47e33d |
+};
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_open(char *progname)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ openlog(progname, LOG_PID, LOG_DAEMON);
|
|
|
47e33d |
+
|
|
|
47e33d |
+ strncpy(log_name, progname, sizeof (log_name) - 1);
|
|
|
47e33d |
+ log_name [sizeof (log_name) - 1] = '\0';
|
|
|
47e33d |
+ log_pid = getpid();
|
|
|
47e33d |
+
|
|
|
47e33d |
+ signal(SIGUSR1, xlog_toggle);
|
|
|
47e33d |
+ signal(SIGUSR2, xlog_toggle);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_stderr(int on)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ log_stderr = on;
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_syslog(int on)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ log_syslog = on;
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+static void
|
|
|
47e33d |
+xlog_toggle(int sig)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ unsigned int tmp, i;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (sig == SIGUSR1) {
|
|
|
47e33d |
+ if ((logmask & D_ALL) && !logging) {
|
|
|
47e33d |
+ xlog(D_GENERAL, "turned on logging");
|
|
|
47e33d |
+ logging = 1;
|
|
|
47e33d |
+ return;
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+ tmp = ~logmask;
|
|
|
47e33d |
+ logmask |= ((logmask & D_ALL) << 1) | D_GENERAL;
|
|
|
47e33d |
+ for (i = -1, tmp &= logmask; tmp; tmp >>= 1, i++)
|
|
|
47e33d |
+ if (tmp & 1)
|
|
|
47e33d |
+ xlog(D_GENERAL,
|
|
|
47e33d |
+ "turned on logging level %d", i);
|
|
|
47e33d |
+ } else {
|
|
|
47e33d |
+ xlog(D_GENERAL, "turned off logging");
|
|
|
47e33d |
+ logging = 0;
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+ signal(sig, xlog_toggle);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_config(int fac, int on)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ if (on)
|
|
|
47e33d |
+ logmask |= fac;
|
|
|
47e33d |
+ else
|
|
|
47e33d |
+ logmask &= ~fac;
|
|
|
47e33d |
+ if (on)
|
|
|
47e33d |
+ logging = 1;
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_sconfig(char *kind, int on)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ struct xlog_debugfac *tbl = debugnames;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ while (tbl->df_name != NULL && strcasecmp(tbl->df_name, kind))
|
|
|
47e33d |
+ tbl++;
|
|
|
47e33d |
+ if (!tbl->df_name) {
|
|
|
47e33d |
+ xlog (L_WARNING, "Invalid debug facility: %s\n", kind);
|
|
|
47e33d |
+ return;
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+ xlog_config(tbl->df_fac, on);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+int
|
|
|
47e33d |
+xlog_enabled(int fac)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ return (logging && (fac & logmask));
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+
|
|
|
47e33d |
+/* Write something to the system logfile and/or stderr */
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_backend(int kind, const char *fmt, va_list args)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ va_list args2;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (!(kind & (L_ALL)) && !(logging && (kind & logmask)))
|
|
|
47e33d |
+ return;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (log_stderr)
|
|
|
47e33d |
+ va_copy(args2, args);
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (log_syslog) {
|
|
|
47e33d |
+ switch (kind) {
|
|
|
47e33d |
+ case L_FATAL:
|
|
|
47e33d |
+ vsyslog(LOG_ERR, fmt, args);
|
|
|
47e33d |
+ break;
|
|
|
47e33d |
+ case L_ERROR:
|
|
|
47e33d |
+ vsyslog(LOG_ERR, fmt, args);
|
|
|
47e33d |
+ break;
|
|
|
47e33d |
+ case L_WARNING:
|
|
|
47e33d |
+ vsyslog(LOG_WARNING, fmt, args);
|
|
|
47e33d |
+ break;
|
|
|
47e33d |
+ case L_NOTICE:
|
|
|
47e33d |
+ vsyslog(LOG_NOTICE, fmt, args);
|
|
|
47e33d |
+ break;
|
|
|
47e33d |
+ default:
|
|
|
47e33d |
+ if (!log_stderr)
|
|
|
47e33d |
+ vsyslog(LOG_INFO, fmt, args);
|
|
|
47e33d |
+ break;
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (log_stderr) {
|
|
|
47e33d |
+#ifdef VERBOSE_PRINTF
|
|
|
47e33d |
+ time_t now;
|
|
|
47e33d |
+ struct tm *tm;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ time(&now;;
|
|
|
47e33d |
+ tm = localtime(&now;;
|
|
|
47e33d |
+ fprintf(stderr, "%s[%d] %04d-%02d-%02d %02d:%02d:%02d ",
|
|
|
47e33d |
+ log_name, log_pid,
|
|
|
47e33d |
+ tm->tm_year+1900, tm->tm_mon + 1, tm->tm_mday,
|
|
|
47e33d |
+ tm->tm_hour, tm->tm_min, tm->tm_sec);
|
|
|
47e33d |
+#else
|
|
|
47e33d |
+ fprintf(stderr, "%s: ", log_name);
|
|
|
47e33d |
+#endif
|
|
|
47e33d |
+ vfprintf(stderr, fmt, args2);
|
|
|
47e33d |
+ fprintf(stderr, "\n");
|
|
|
47e33d |
+ va_end(args2);
|
|
|
47e33d |
+ }
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (kind == L_FATAL)
|
|
|
47e33d |
+ exit(1);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog(int kind, const char* fmt, ...)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ va_list args;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ if (kind & (L_ERROR|D_GENERAL))
|
|
|
47e33d |
+ export_errno = 1;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ va_start(args, fmt);
|
|
|
47e33d |
+ xlog_backend(kind, fmt, args);
|
|
|
47e33d |
+ va_end(args);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_warn(const char* fmt, ...)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ va_list args;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ va_start(args, fmt);
|
|
|
47e33d |
+ xlog_backend(L_WARNING, fmt, args);
|
|
|
47e33d |
+ va_end(args);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_err(const char* fmt, ...)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ va_list args;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ va_start(args, fmt);
|
|
|
47e33d |
+ xlog_backend(L_FATAL, fmt, args);
|
|
|
47e33d |
+ va_end(args);
|
|
|
47e33d |
+}
|
|
|
47e33d |
+
|
|
|
47e33d |
+void
|
|
|
47e33d |
+xlog_errno(int err, const char *fmt, ...)
|
|
|
47e33d |
+{
|
|
|
47e33d |
+ va_list args;
|
|
|
47e33d |
+
|
|
|
47e33d |
+ errno = err;
|
|
|
47e33d |
+ va_start(args, fmt);
|
|
|
47e33d |
+ xlog_backend(L_FATAL, fmt, args);
|
|
|
47e33d |
+ va_end(args);
|
|
|
47e33d |
+}
|
|
|
47e33d |
diff --git a/src/xlog.h b/src/xlog.h
|
|
|
47e33d |
new file mode 100644
|
|
|
47e33d |
index 0000000..a57b96c
|
|
|
47e33d |
--- /dev/null
|
|
|
47e33d |
+++ b/src/xlog.h
|
|
|
47e33d |
@@ -0,0 +1,52 @@
|
|
|
47e33d |
+/*
|
|
|
47e33d |
+ * xlog Logging functionality
|
|
|
47e33d |
+ *
|
|
|
47e33d |
+ * Copyright (C) 1995 Olaf Kirch <okir@monad.swb.de>
|
|
|
47e33d |
+ */
|
|
|
47e33d |
+
|
|
|
47e33d |
+#ifndef XLOG_H
|
|
|
47e33d |
+#define XLOG_H
|
|
|
47e33d |
+
|
|
|
47e33d |
+#include <stdarg.h>
|
|
|
47e33d |
+
|
|
|
47e33d |
+/* These are logged always. L_FATAL also does exit(1) */
|
|
|
47e33d |
+#define L_FATAL 0x0100
|
|
|
47e33d |
+#define L_ERROR 0x0200
|
|
|
47e33d |
+#define L_WARNING 0x0400
|
|
|
47e33d |
+#define L_NOTICE 0x0800
|
|
|
47e33d |
+#define L_ALL 0xFF00
|
|
|
47e33d |
+
|
|
|
47e33d |
+/* These are logged if enabled with xlog_[s]config */
|
|
|
47e33d |
+/* NB: code does not expect ORing together D_ and L_ */
|
|
|
47e33d |
+#define D_GENERAL 0x0001 /* general debug info */
|
|
|
47e33d |
+#define D_CALL 0x0002
|
|
|
47e33d |
+#define D_AUTH 0x0004
|
|
|
47e33d |
+#define D_FAC3 0x0008
|
|
|
47e33d |
+#define D_FAC4 0x0010
|
|
|
47e33d |
+#define D_FAC5 0x0020
|
|
|
47e33d |
+#define D_PARSE 0x0040
|
|
|
47e33d |
+#define D_FAC7 0x0080
|
|
|
47e33d |
+#define D_ALL 0x00FF
|
|
|
47e33d |
+
|
|
|
47e33d |
+/* This can be used to define symbolic log names that can be passed to
|
|
|
47e33d |
+ * xlog_config.
|
|
|
47e33d |
+ */
|
|
|
47e33d |
+struct xlog_debugfac {
|
|
|
47e33d |
+ char *df_name;
|
|
|
47e33d |
+ int df_fac;
|
|
|
47e33d |
+};
|
|
|
47e33d |
+
|
|
|
47e33d |
+extern int export_errno;
|
|
|
47e33d |
+void xlog_open(char *progname);
|
|
|
47e33d |
+void xlog_stderr(int on);
|
|
|
47e33d |
+void xlog_syslog(int on);
|
|
|
47e33d |
+void xlog_config(int fac, int on);
|
|
|
47e33d |
+void xlog_sconfig(char *, int on);
|
|
|
47e33d |
+int xlog_enabled(int fac);
|
|
|
47e33d |
+void xlog(int fac, const char *fmt, ...);
|
|
|
47e33d |
+void xlog_warn(const char *fmt, ...);
|
|
|
47e33d |
+void xlog_err(const char *fmt, ...);
|
|
|
47e33d |
+void xlog_errno(int err, const char *fmt, ...);
|
|
|
47e33d |
+void xlog_backend(int fac, const char *fmt, va_list args);
|
|
|
47e33d |
+
|
|
|
47e33d |
+#endif /* XLOG_H */
|