freebsd-dev/eBones/krb/kntoln.c
csgr 105186eeee Initial import of eBones.
(Including all changes for FreeBSD - importing the original eBones distribution
would be too complex at this stage, since I don't have access to Piero's 
CVS.)
(If you want to include eBones in your system, don't forget to include
MAKE_EBONES in /etc/make.conf.)
(This stuff is now also suppable from braae.ru.ac.za.)

Bones originally from MIT SIPB.
Original port to FreeBSD 1.x  by Piero Serini.
Moved to FreeBSD 2.0 by Doug Rabson and Geoff Rehmet.
Nice bug fixes from Doug Rabson.
1994-09-30 14:50:09 +00:00

61 lines
1.8 KiB
C

/*
* Copyright 1985, 1986, 1987, 1988 by the Massachusetts Institute
* of Technology.
* For copying and distribution information, please see the file
* <Copyright.MIT>.
*
* from: kntoln.c,v 4.7 89/01/23 09:25:15 jtkohl Exp $
* $Id: kntoln.c,v 1.2 1994/07/19 19:25:40 g89r4222 Exp $
*/
#ifndef lint
static char *rcsid =
"$Id: kntoln.c,v 1.2 1994/07/19 19:25:40 g89r4222 Exp $";
#endif /* lint */
#include <krb.h>
#include <strings.h>
/*
* krb_kntoln converts an auth name into a local name by looking up
* the auth name in the /etc/aname file. The format of the aname
* file is:
*
* +-----+-----+-----+-----+------+----------+-------+-------+
* | anl | inl | rll | lnl | name | instance | realm | lname |
* +-----+-----+-----+-----+------+----------+-------+-------+
* | 1by | 1by | 1by | 1by | name | instance | realm | lname |
* +-----+-----+-----+-----+------+----------+-------+-------+
*
* If the /etc/aname file can not be opened it will set the
* local name to the auth name. Thus, in this case it performs as
* the identity function.
*
* The name instance and realm are passed to krb_kntoln through
* the AUTH_DAT structure (ad).
*
* Now here's what it *really* does:
*
* Given a Kerberos name in an AUTH_DAT structure, check that the
* instance is null, and that the realm is the same as the local
* realm, and return the principal's name in "lname". Return
* KSUCCESS if all goes well, otherwise KFAILURE.
*/
krb_kntoln(ad,lname)
AUTH_DAT *ad;
char *lname;
{
static char lrealm[REALM_SZ] = "";
if (!(*lrealm) && (krb_get_lrealm(lrealm,1) == KFAILURE))
return(KFAILURE);
if (strcmp(ad->pinst,""))
return(KFAILURE);
if (strcmp(ad->prealm,lrealm))
return(KFAILURE);
(void) strcpy(lname,ad->pname);
return(KSUCCESS);
}