ftp.nice.ch/pub/next/unix/network/filetransfer/wu-ftpd.2.4.2-beta-13.NIHS.bs.tar.gz#/wu-ftpd-2.4.2-beta-13.NIHS.bs/src/authenticate.c

This is authenticate.c in view mode; [Download] [Up]

/*
 * Copyright (c) 1993, 1994  Washington University in Saint Louis All rights
 * reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met: 1. Redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer. 2.
 * Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution. 3. All advertising
 * materials mentioning features or use of this software must display the
 * following acknowledgement: This product includes software developed by the
 * Washington University in Saint Louis and its contributors. 4. Neither the
 * name of the University nor the names of its contributors may be used to
 * endorse or promote products derived from this software without specific
 * prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY WASHINGTON UNIVERSITY AND CONTRIBUTORS ``AS IS''
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED.  IN NO EVENT SHALL WASHINGTON UNIVERSITY OR CONTRIBUTORS
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */
#ifndef lint
static char rcsid[] = "@(#)$Id: authenticate.c,v 1.4 1997/03/03 09:39:42 sob Exp sob $";
#endif /* not lint */
#include "config.h"

#include <stdio.h>
#include <string.h>
#include "support/authuser.h"
#include "authenticate.h"

#if USE_A_RFC931
#include <signal.h>
#include <setjmp.h>

#define RFC931_Timeout 10
static jmp_buf  timebuf;

#endif				/* USE_A_RFC931 */


#define AUTHNAMESIZE 100

char authuser[AUTHNAMESIZE];
int authenticated;

#if USE_A_RFC931
static          void
timout (sig)
    int             sig;
{
    longjmp (timebuf, sig);
}

#endif				/* USE_A_RFC931 */
/*
 * This routine actually returns nothing. It just sets the authenticated global
 * variable.
 */
int
authenticate()
{

#if USE_A_RFC931
    unsigned long in;
    unsigned short  local,
                    remote;

#endif /* USE_A_RFC931 */
    char *user;

 /*
  * Ideally more authentication schemes would be called from here, with the
  * strongest called first.  One possible double-check would be to verify that
  * the results of all authentication calls (returning identical data!) are
  * checked against each other.
  */

    authenticated = 0;          /* this is a bitmask, one bit per method */

    user = "*";

#if USE_A_RFC931

 /*
  * Set up a timer so we won't get stuck while waiting for the server.
  */

    signal (SIGALRM, timout);

    if (auth_fd(0, &in, &local, &remote) == -1)
        user = "?";             /* getpeername/getsockname failure */
    else
    {
	alarm (RFC931_Timeout);
	if (setjmp (timebuf) != 0 || !(user = auth_tcpuser (in, local, remote)))
	{
            user = "*";         /* remote host doesn't support RFC 931 */
	}
	else
	{
            authenticated |= A_RFC931;
        }
	alarm (0);
    }
#endif /* USE_A_RFC931 */

    strncpy(authuser, user, sizeof(authuser));
    authuser[AUTHNAMESIZE - 1] = '\0';
    return(0);
}

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.