1*7c478bd9Sstevel@tonic-gate /* 2*7c478bd9Sstevel@tonic-gate * Copyright 2002 Sun Microsystems, Inc. All rights reserved. 3*7c478bd9Sstevel@tonic-gate * Use is subject to license terms. 4*7c478bd9Sstevel@tonic-gate */ 5*7c478bd9Sstevel@tonic-gate 6*7c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 7*7c478bd9Sstevel@tonic-gate 8*7c478bd9Sstevel@tonic-gate /* 9*7c478bd9Sstevel@tonic-gate * Miscellaneous routines needed by the telnet client for authentication 10*7c478bd9Sstevel@tonic-gate * and / or encryption. 11*7c478bd9Sstevel@tonic-gate */ 12*7c478bd9Sstevel@tonic-gate 13*7c478bd9Sstevel@tonic-gate /* 14*7c478bd9Sstevel@tonic-gate * Copyright (c) 1991, 1993 15*7c478bd9Sstevel@tonic-gate * The Regents of the University of California. All rights reserved. 16*7c478bd9Sstevel@tonic-gate * 17*7c478bd9Sstevel@tonic-gate * Redistribution and use in source and binary forms, with or without 18*7c478bd9Sstevel@tonic-gate * modification, are permitted provided that the following conditions 19*7c478bd9Sstevel@tonic-gate * are met: 20*7c478bd9Sstevel@tonic-gate * 1. Redistributions of source code must retain the above copyright 21*7c478bd9Sstevel@tonic-gate * notice, this list of conditions and the following disclaimer. 22*7c478bd9Sstevel@tonic-gate * 2. Redistributions in binary form must reproduce the above copyright 23*7c478bd9Sstevel@tonic-gate * notice, this list of conditions and the following disclaimer in the 24*7c478bd9Sstevel@tonic-gate * documentation and/or other materials provided with the distribution. 25*7c478bd9Sstevel@tonic-gate * 3. All advertising materials mentioning features or use of this software 26*7c478bd9Sstevel@tonic-gate * must display the following acknowledgement: 27*7c478bd9Sstevel@tonic-gate * This product includes software developed by the University of 28*7c478bd9Sstevel@tonic-gate * California, Berkeley and its contributors. 29*7c478bd9Sstevel@tonic-gate * 4. Neither the name of the University nor the names of its contributors 30*7c478bd9Sstevel@tonic-gate * may be used to endorse or promote products derived from this software 31*7c478bd9Sstevel@tonic-gate * without specific prior written permission. 32*7c478bd9Sstevel@tonic-gate * 33*7c478bd9Sstevel@tonic-gate * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 34*7c478bd9Sstevel@tonic-gate * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 35*7c478bd9Sstevel@tonic-gate * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 36*7c478bd9Sstevel@tonic-gate * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 37*7c478bd9Sstevel@tonic-gate * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 38*7c478bd9Sstevel@tonic-gate * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 39*7c478bd9Sstevel@tonic-gate * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 40*7c478bd9Sstevel@tonic-gate * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 41*7c478bd9Sstevel@tonic-gate * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 42*7c478bd9Sstevel@tonic-gate * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 43*7c478bd9Sstevel@tonic-gate * SUCH DAMAGE. 44*7c478bd9Sstevel@tonic-gate */ 45*7c478bd9Sstevel@tonic-gate 46*7c478bd9Sstevel@tonic-gate #ifndef lint 47*7c478bd9Sstevel@tonic-gate static char sccsid[] = "@(#)authenc.c 8.1 (Berkeley) 6/6/93"; 48*7c478bd9Sstevel@tonic-gate #endif /* not lint */ 49*7c478bd9Sstevel@tonic-gate 50*7c478bd9Sstevel@tonic-gate #include <sys/types.h> 51*7c478bd9Sstevel@tonic-gate #include <arpa/telnet.h> 52*7c478bd9Sstevel@tonic-gate 53*7c478bd9Sstevel@tonic-gate #include "general.h" 54*7c478bd9Sstevel@tonic-gate #include "ring.h" 55*7c478bd9Sstevel@tonic-gate #include "externs.h" 56*7c478bd9Sstevel@tonic-gate #include "defines.h" 57*7c478bd9Sstevel@tonic-gate #include "types.h" 58*7c478bd9Sstevel@tonic-gate 59*7c478bd9Sstevel@tonic-gate char *RemoteHostName = NULL; 60*7c478bd9Sstevel@tonic-gate char *UserNameRequested = NULL; 61*7c478bd9Sstevel@tonic-gate 62*7c478bd9Sstevel@tonic-gate #define MAXNETDATA 16 63*7c478bd9Sstevel@tonic-gate 64*7c478bd9Sstevel@tonic-gate /* 65*7c478bd9Sstevel@tonic-gate * Get ready to do authentication and encryption by calling their 66*7c478bd9Sstevel@tonic-gate * init routines, and clearing the user name variable 67*7c478bd9Sstevel@tonic-gate */ 68*7c478bd9Sstevel@tonic-gate /* ARGSUSED */ 69*7c478bd9Sstevel@tonic-gate void 70*7c478bd9Sstevel@tonic-gate auth_encrypt_init(char *local, char *remote, char *name) 71*7c478bd9Sstevel@tonic-gate { 72*7c478bd9Sstevel@tonic-gate RemoteHostName = remote; 73*7c478bd9Sstevel@tonic-gate 74*7c478bd9Sstevel@tonic-gate auth_init(name); 75*7c478bd9Sstevel@tonic-gate 76*7c478bd9Sstevel@tonic-gate encrypt_init(name); 77*7c478bd9Sstevel@tonic-gate 78*7c478bd9Sstevel@tonic-gate if (UserNameRequested) { 79*7c478bd9Sstevel@tonic-gate free(UserNameRequested); 80*7c478bd9Sstevel@tonic-gate UserNameRequested = NULL; 81*7c478bd9Sstevel@tonic-gate } 82*7c478bd9Sstevel@tonic-gate } 83*7c478bd9Sstevel@tonic-gate 84*7c478bd9Sstevel@tonic-gate /* 85*7c478bd9Sstevel@tonic-gate * Set the user name variable. This is the user name used from now 86*7c478bd9Sstevel@tonic-gate * on for authentication and encryption 87*7c478bd9Sstevel@tonic-gate */ 88*7c478bd9Sstevel@tonic-gate void 89*7c478bd9Sstevel@tonic-gate auth_encrypt_user(char *name) 90*7c478bd9Sstevel@tonic-gate { 91*7c478bd9Sstevel@tonic-gate if (UserNameRequested) 92*7c478bd9Sstevel@tonic-gate free(UserNameRequested); 93*7c478bd9Sstevel@tonic-gate UserNameRequested = name ? strdup(name) : NULL; 94*7c478bd9Sstevel@tonic-gate } 95*7c478bd9Sstevel@tonic-gate 96*7c478bd9Sstevel@tonic-gate int 97*7c478bd9Sstevel@tonic-gate net_write(unsigned char *str, int len) 98*7c478bd9Sstevel@tonic-gate { 99*7c478bd9Sstevel@tonic-gate if (NETROOM() > len) { 100*7c478bd9Sstevel@tonic-gate ring_supply_data(&netoring, str, len); 101*7c478bd9Sstevel@tonic-gate if (str[0] == IAC && str[1] == SE) 102*7c478bd9Sstevel@tonic-gate printsub('>', &str[2], len - 2); 103*7c478bd9Sstevel@tonic-gate return (len); 104*7c478bd9Sstevel@tonic-gate } 105*7c478bd9Sstevel@tonic-gate return (0); 106*7c478bd9Sstevel@tonic-gate } 107*7c478bd9Sstevel@tonic-gate 108*7c478bd9Sstevel@tonic-gate void 109*7c478bd9Sstevel@tonic-gate net_encrypt(void) 110*7c478bd9Sstevel@tonic-gate { 111*7c478bd9Sstevel@tonic-gate if (encrypt_output) 112*7c478bd9Sstevel@tonic-gate ring_encrypt(&netoring, encrypt_output); 113*7c478bd9Sstevel@tonic-gate else 114*7c478bd9Sstevel@tonic-gate ring_clearto(&netoring); 115*7c478bd9Sstevel@tonic-gate } 116*7c478bd9Sstevel@tonic-gate 117*7c478bd9Sstevel@tonic-gate /* 118*7c478bd9Sstevel@tonic-gate * Spin to wait for authentication to complete 119*7c478bd9Sstevel@tonic-gate * This allows for a timeout 120*7c478bd9Sstevel@tonic-gate */ 121*7c478bd9Sstevel@tonic-gate void 122*7c478bd9Sstevel@tonic-gate telnet_spin(void) 123*7c478bd9Sstevel@tonic-gate { 124*7c478bd9Sstevel@tonic-gate extern boolean_t scheduler_lockout_tty; 125*7c478bd9Sstevel@tonic-gate 126*7c478bd9Sstevel@tonic-gate scheduler_lockout_tty = B_TRUE; 127*7c478bd9Sstevel@tonic-gate (void) Scheduler(0); 128*7c478bd9Sstevel@tonic-gate scheduler_lockout_tty = B_FALSE; 129*7c478bd9Sstevel@tonic-gate } 130*7c478bd9Sstevel@tonic-gate 131*7c478bd9Sstevel@tonic-gate 132*7c478bd9Sstevel@tonic-gate /* 133*7c478bd9Sstevel@tonic-gate * Used to print out unsigned chars as decimals for debugging options 134*7c478bd9Sstevel@tonic-gate */ 135*7c478bd9Sstevel@tonic-gate void 136*7c478bd9Sstevel@tonic-gate printd(unsigned char *data, int cnt) 137*7c478bd9Sstevel@tonic-gate { 138*7c478bd9Sstevel@tonic-gate cnt = (cnt < MAXNETDATA) ? cnt:MAXNETDATA; 139*7c478bd9Sstevel@tonic-gate while (cnt-- > 0) 140*7c478bd9Sstevel@tonic-gate (void) printf(" %02x", *data++); 141*7c478bd9Sstevel@tonic-gate } 142