1 #pragma ident   "%Z%%M% %I%     %E% SMI"
   2 
   3 /****************************************************************************  
   4  
   5   Copyright (c) 1999,2000 WU-FTPD Development Group.  
   6   All rights reserved.
   7   
   8   Portions Copyright (c) 1980, 1985, 1988, 1989, 1990, 1991, 1993, 1994
   9     The Regents of the University of California.
  10   Portions Copyright (c) 1993, 1994 Washington University in Saint Louis.
  11   Portions Copyright (c) 1996, 1998 Berkeley Software Design, Inc.
  12   Portions Copyright (c) 1989 Massachusetts Institute of Technology.
  13   Portions Copyright (c) 1998 Sendmail, Inc.
  14   Portions Copyright (c) 1983, 1995, 1996, 1997 Eric P.  Allman.
  15   Portions Copyright (c) 1997 by Stan Barber.
  16   Portions Copyright (c) 1997 by Kent Landfield.
  17   Portions Copyright (c) 1991, 1992, 1993, 1994, 1995, 1996, 1997
  18     Free Software Foundation, Inc.  
  19  
  20   Use and distribution of this software and its source code are governed 
  21   by the terms and conditions of the WU-FTPD Software License ("LICENSE").
  22  
  23   If you did not receive a copy of the license, it may be obtained online
  24   at http://www.wu-ftpd.org/license.html.
  25  
  26   $Id: authenticate.c,v 1.9 2000/07/01 18:17:38 wuftpd Exp $
  27  
  28 ****************************************************************************/
  29 #include "config.h"
  30 #include <stdio.h>
  31 #include <string.h>
  32 #include "authuser.h"
  33 #include "authenticate.h"
  34 #include "proto.h"
  35 
  36 #define AUTHNAMESIZE 100
  37 
  38 char authuser[AUTHNAMESIZE];
  39 int authenticated;
  40 
  41 extern int disable_rfc931;
  42 extern unsigned int timeout_rfc931;
  43 
  44 /*
  45  * Ideally more authentication schemes would be called from here, with the
  46  * strongest called first.  One possible double-check would be to verify that
  47  * the results of all authentication calls (returning identical data!) are
  48  * checked against each other.
  49  */
  50 int wu_authenticate(void)
  51 {
  52     char *user;
  53 #if USE_A_RFC931
  54     unsigned long in;
  55     unsigned short local, remote;
  56 #endif /* USE_A_RFC931 */
  57 
  58     authenticated = 0;          /* this is a bitmask, one bit per method */
  59 
  60     user = "*";
  61 
  62 #if USE_A_RFC931
  63     if (disable_rfc931 || (timeout_rfc931 == 0))
  64         user = "*";
  65     else if (auth_fd(0, &in, &local, &remote) == -1)
  66         user = "?";             /* getpeername/getsockname failure */
  67     else {
  68         if (!(user = auth_tcpuser(in, local, remote)))
  69             user = "*";         /* remote host doesn't support RFC 931 */
  70         else
  71             authenticated |= A_RFC931;
  72     }
  73 #endif /* USE_A_RFC931 */
  74 
  75     strncpy(authuser, user, sizeof(authuser));
  76     authuser[AUTHNAMESIZE - 1] = '\0';
  77     return (0);
  78 }