]> arthur.barton.de Git - netatalk.git/blobdiff - etc/papd/session.c
- merge branch-netatalk-afp-3x-dev, HEAD was tagged before
[netatalk.git] / etc / papd / session.c
index b142a4c877a205c1acf68b8ccaca2d8e783a44e9..6e1cfd783a15538f70387ccea3cdb0f0c4fd1fa7 100644 (file)
@@ -1,15 +1,25 @@
 /*
+ * $Id: session.c,v 1.15 2005-04-28 20:49:49 bfernhomberg Exp $
+ *
  * Copyright (c) 1990,1994 Regents of The University of Michigan.
  * All Rights Reserved.  See COPYRIGHT.
  */
 
 #ifdef HAVE_CONFIG_H
 #include "config.h"
-#endif
+#endif /* HAVE_CONFIG_H */
 
+#ifdef HAVE_SYS_ERRNO_H
+#include <sys/errno.h>
+#endif /* HAVE_SYS_ERRNO_H */
+#ifdef HAVE_ERRNO_H
+#include <errno.h>
+#endif /* HAVE_ERRNO_H */
+
+#include <stdlib.h>
 #include <string.h>
 #include <sys/types.h>
-#include <sys/syslog.h>
+#include <atalk/logger.h>
 #include <sys/time.h>
 #include <sys/uio.h>
 #include <netatalk/endian.h>
 #include <atalk/pap.h>
 
 #include "file.h"
+#include "lp.h"
+#include "session.h"
+
+int ps(struct papfile *infile, struct papfile *outfile, struct sockaddr_at *sat);
 
 extern unsigned char   connid, quantum, oquantum;
 
@@ -48,7 +62,7 @@ struct iovec  iov[ PAP_MAXQUANTUM ] = {
  * Read lines of a file, until the client sends eof, after
  * which we'll send eof also.
  */
-session( atp, sat )
+int session( atp, sat )
     ATP                        atp;
     struct sockaddr_at *sat;
 {
@@ -60,7 +74,7 @@ session( atp, sat )
     char               cbuf[ 578 ];
     int                        i, cc, timeout = 0, readpending = 0;
     u_int16_t          seq = 0, rseq = 1, netseq;
-    u_char             readport;
+    u_char             readport; /* uninitialized, OK 310105 */
 
     infile.pf_state = PF_BOT;
     infile.pf_bufsize = 0;
@@ -81,15 +95,15 @@ session( atp, sat )
     cbuf[ 1 ] = PAP_READ;
     if (++seq == 0) seq = 1;
     netseq = htons( seq );
-    bcopy( &netseq, &cbuf[ 2 ], sizeof( netseq ));
+    memcpy( &cbuf[ 2 ], &netseq, sizeof( netseq ));
     atpb.atp_saddr = sat;
     atpb.atp_sreqdata = cbuf;
     atpb.atp_sreqdlen = 4;             /* bytes in SendData request */
     atpb.atp_sreqto = 5;               /* retry timer */
     atpb.atp_sreqtries = -1;           /* infinite retries */
     if ( atp_sreq( atp, &atpb, oquantum, ATP_XO )) {
-       syslog( LOG_ERR, "atp_sreq: %m" );
-       exit( 1 );
+       LOG(log_error, logtype_papd, "atp_sreq: %m" );
+       return( -1 );
     }
 
     for (;;) {
@@ -105,15 +119,20 @@ session( atp, sat )
        FD_ZERO( &fds );
        FD_SET( atp_fileno( atp ), &fds );
 
-       if (( cc = select( FD_SETSIZE, &fds, 0, 0, &tv )) < 0 ) {
-           syslog( LOG_ERR, "select: %m" );
-           exit( 1 );
+       do { /* do list until success or an unrecoverable error occurs */
+         if (( cc = select( FD_SETSIZE, &fds, 0, 0, &tv )) < 0 )
+             LOG(log_error, logtype_papd, "select: %m" ); /* log all errors */
+       } while (( cc < 0 ) && (errno == 4));
+
+       if ( cc < 0 ) {
+         LOG(log_error, logtype_papd, "select: Error is unrecoverable" );
+         return( -1 );
        }
        if ( cc == 0 ) {
            if ( timeout++ > 2 ) {
-               syslog( LOG_ERR, "connection timed out" );
+               LOG(log_error, logtype_papd, "connection timed out" );
                lp_cancel();
-               exit( 1 );
+               return( -1 );
            }
 
            /*
@@ -128,27 +147,27 @@ session( atp, sat )
            atpb.atp_sreqto = 0;                /* best effort */
            atpb.atp_sreqtries = 1;             /* try once */
            if ( atp_sreq( atp, &atpb, 0, 0 )) {
-               syslog( LOG_ERR, "atp_sreq: %m" );
-               exit( 1 );
+               LOG(log_error, logtype_papd, "atp_sreq: %m" );
+               return( -1 );
            }
            continue;
        } else {
            timeout = 0;
        }
 
-       bzero( &ssat, sizeof( struct sockaddr_at ));
+       memset( &ssat, 0, sizeof( struct sockaddr_at ));
        switch( atp_rsel( atp, &ssat, ATP_TRESP | ATP_TREQ )) {
        case ATP_TREQ :
            atpb.atp_saddr = &ssat;
            atpb.atp_rreqdata = cbuf;
            atpb.atp_rreqdlen = sizeof( cbuf );
            if ( atp_rreq( atp, &atpb ) < 0 ) {
-               syslog( LOG_ERR, "atp_rreq: %m" );
-               exit( 1 );
+               LOG(log_error, logtype_papd, "atp_rreq: %m" );
+               return( -1 );
            }
            /* sanity */
            if ( (unsigned char)cbuf[ 0 ] != connid ) {
-               syslog( LOG_ERR, "Bad ATP request!" );
+               LOG(log_error, logtype_papd, "Bad ATP request!" );
                continue;
            }
 
@@ -157,7 +176,7 @@ session( atp, sat )
                /*
                 * Other side is ready for some data.
                 */
-               bcopy( &cbuf[ 2 ], &netseq, sizeof( netseq ));
+               memcpy( &netseq, &cbuf[ 2 ], sizeof( netseq ));
                if ( netseq != 0 ) {
                    if ( rseq != ntohs( netseq )) {
                        break;
@@ -189,16 +208,16 @@ session( atp, sat )
                atpb.atp_sresiov = niov;
                atpb.atp_sresiovcnt = 1;
                if ( atp_sresp( atp, &atpb ) < 0 ) {
-                   syslog( LOG_ERR, "atp_sresp: %m" );
+                   LOG(log_error, logtype_papd, "atp_sresp: %m" );
                    exit( 1 );
                }
-               exit( 0 );
+               return( 0 );
                break;
 
            case PAP_TICKLE :
                break;
            default :
-               syslog( LOG_ERR, "Bad PAP request!" );
+               LOG(log_error, logtype_papd, "Bad PAP request!" );
            }
 
            break;
@@ -211,20 +230,20 @@ session( atp, sat )
            atpb.atp_rresiov = niov;
            atpb.atp_rresiovcnt = oquantum;
            if ( atp_rresp( atp, &atpb ) < 0 ) {
-               syslog( LOG_ERR, "atp_rresp: %m" );
-               exit( 1 );
+               LOG(log_error, logtype_papd, "atp_rresp: %m" );
+               return( -1 );
            }
 
            /* sanity */
            if ( ((unsigned char *)niov[ 0 ].iov_base)[ 0 ] != connid ||
                    ((char *)niov[ 0 ].iov_base)[ 1 ] != PAP_DATA ) {
-               syslog( LOG_ERR, "Bad data response!" );
+               LOG(log_error, logtype_papd, "Bad data response!" );
                continue;
            }
 
            for ( i = 0; i < atpb.atp_rresiovcnt; i++ ) {
                append( &infile,
-                       niov[ i ].iov_base + 4, niov[ i ].iov_len - 4 );
+                       (char *)niov[ i ].iov_base + 4, niov[ i ].iov_len - 4 );
                if (( infile.pf_state & PF_EOF ) == 0 &&
                        ((char *)niov[ 0 ].iov_base)[ 2 ] ) {
                    infile.pf_state |= PF_EOF;
@@ -233,8 +252,8 @@ session( atp, sat )
 
            /* move data */
            if ( ps( &infile, &outfile, sat ) < 0 ) {
-               syslog( LOG_ERR, "parse: bad return" );
-               exit( 1 );      /* really?  close? */
+               LOG(log_error, logtype_papd, "parse: bad return" );
+               return( -1 );   /* really?  close? */
            }
 
            /*
@@ -244,15 +263,15 @@ session( atp, sat )
            cbuf[ 1 ] = PAP_READ;
            if ( ++seq == 0 ) seq = 1;
            netseq = htons( seq );
-           bcopy( &netseq, &cbuf[ 2 ], sizeof( netseq ));
+           memcpy( &cbuf[ 2 ], &netseq, sizeof( netseq ));
            atpb.atp_saddr = sat;
            atpb.atp_sreqdata = cbuf;
            atpb.atp_sreqdlen = 4;              /* bytes in SendData request */
            atpb.atp_sreqto = 5;                /* retry timer */
            atpb.atp_sreqtries = -1;            /* infinite retries */
            if ( atp_sreq( atp, &atpb, oquantum, ATP_XO )) {
-               syslog( LOG_ERR, "atp_sreq: %m" );
-               exit( 1 );
+               LOG(log_error, logtype_papd, "atp_sreq: %m" );
+               return( -1 );
            }
            break;
 
@@ -260,8 +279,8 @@ session( atp, sat )
            break;
 
        default :
-           syslog( LOG_ERR, "atp_rsel: %m" );
-           exit( 1 );
+           LOG(log_error, logtype_papd, "atp_rsel: %m" );
+           return( -1 );
        }
 
        /* send any data that we have */
@@ -285,7 +304,7 @@ session( atp, sat )
                }
 
                niov[ i ].iov_len = 4 + cc;
-               bcopy( outfile.pf_data, niov[ i ].iov_base + 4, cc );
+               memcpy( (char *)niov[ i ].iov_base + 4, outfile.pf_data, cc );
                CONSUME( &outfile, cc );
                if ( outfile.pf_datalen == 0 ) {
                    i++;
@@ -297,8 +316,8 @@ session( atp, sat )
            atpb.atp_sresiov = niov;
            atpb.atp_sresiovcnt = i;    /* reported by stevebn@pc1.eos.co.uk */
            if ( atp_sresp( atp, &atpb ) < 0 ) {
-               syslog( LOG_ERR, "atp_sresp: %m" );
-               exit( 1 );
+               LOG(log_error, logtype_papd, "atp_sresp: %m" );
+               return( -1 );
            }
            readpending = 0;
        }