xref: /freebsd/contrib/telnet/libtelnet/misc.c (revision a3c858005cae175e277f6f6735ca9eaea7eaf3c3)
181cb6ddcSMark Murray /*-
281cb6ddcSMark Murray  * Copyright (c) 1991, 1993
381cb6ddcSMark Murray  *	The Regents of the University of California.  All rights reserved.
481cb6ddcSMark Murray  *
581cb6ddcSMark Murray  * Redistribution and use in source and binary forms, with or without
681cb6ddcSMark Murray  * modification, are permitted provided that the following conditions
781cb6ddcSMark Murray  * are met:
881cb6ddcSMark Murray  * 1. Redistributions of source code must retain the above copyright
981cb6ddcSMark Murray  *    notice, this list of conditions and the following disclaimer.
1081cb6ddcSMark Murray  * 2. Redistributions in binary form must reproduce the above copyright
1181cb6ddcSMark Murray  *    notice, this list of conditions and the following disclaimer in the
1281cb6ddcSMark Murray  *    documentation and/or other materials provided with the distribution.
13*83129c0bSEd Maste  * 3. Neither the name of the University nor the names of its contributors
1481cb6ddcSMark Murray  *    may be used to endorse or promote products derived from this software
1581cb6ddcSMark Murray  *    without specific prior written permission.
1681cb6ddcSMark Murray  *
1781cb6ddcSMark Murray  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
1881cb6ddcSMark Murray  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1981cb6ddcSMark Murray  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2081cb6ddcSMark Murray  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2181cb6ddcSMark Murray  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2281cb6ddcSMark Murray  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2381cb6ddcSMark Murray  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2481cb6ddcSMark Murray  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2581cb6ddcSMark Murray  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2681cb6ddcSMark Murray  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2781cb6ddcSMark Murray  * SUCH DAMAGE.
2881cb6ddcSMark Murray  */
2981cb6ddcSMark Murray 
3081cb6ddcSMark Murray #ifndef lint
31ecece7e3SPeter Wemm #if 0
3204c426ccSMark Murray static const char sccsid[] = "@(#)misc.c	8.1 (Berkeley) 6/4/93";
33ecece7e3SPeter Wemm #endif
3481cb6ddcSMark Murray #endif /* not lint */
3581cb6ddcSMark Murray 
3604c426ccSMark Murray #include <stdio.h>
3704c426ccSMark Murray #include <stdlib.h>
388fa113e5SMark Murray #include <string.h>
398fa113e5SMark Murray 
4081cb6ddcSMark Murray #include "misc.h"
418fa113e5SMark Murray #ifdef	AUTHENTICATION
4204c426ccSMark Murray #include "auth.h"
4321f083c0SMark Murray #endif
4421f083c0SMark Murray #ifdef	ENCRYPTION
4504c426ccSMark Murray #include "encrypt.h"
4621f083c0SMark Murray #endif	/* ENCRYPTION */
4781cb6ddcSMark Murray 
4881cb6ddcSMark Murray char *RemoteHostName;
4981cb6ddcSMark Murray char *LocalHostName;
5081cb6ddcSMark Murray char *UserNameRequested = 0;
5181cb6ddcSMark Murray int ConnectedCount = 0;
5281cb6ddcSMark Murray 
538fa113e5SMark Murray #ifndef AUTHENTICATION
548fa113e5SMark Murray #define undef1 __unused
558fa113e5SMark Murray #else
568fa113e5SMark Murray #define undef1
578fa113e5SMark Murray #endif
588fa113e5SMark Murray 
5981cb6ddcSMark Murray void
auth_encrypt_init(char * local,char * remote,const char * name undef1,int server undef1)608fa113e5SMark Murray auth_encrypt_init(char *local, char *remote, const char *name undef1, int server undef1)
6181cb6ddcSMark Murray {
6281cb6ddcSMark Murray 	RemoteHostName = remote;
6381cb6ddcSMark Murray 	LocalHostName = local;
648fa113e5SMark Murray #ifdef	AUTHENTICATION
6581cb6ddcSMark Murray 	auth_init(name, server);
6681cb6ddcSMark Murray #endif
6781cb6ddcSMark Murray #ifdef	ENCRYPTION
6881cb6ddcSMark Murray 	encrypt_init(name, server);
6981cb6ddcSMark Murray #endif	/* ENCRYPTION */
7081cb6ddcSMark Murray 	if (UserNameRequested) {
7181cb6ddcSMark Murray 		free(UserNameRequested);
7281cb6ddcSMark Murray 		UserNameRequested = 0;
7381cb6ddcSMark Murray 	}
7481cb6ddcSMark Murray }
7581cb6ddcSMark Murray 
768fa113e5SMark Murray #ifdef	ENCRYPTION
7781cb6ddcSMark Murray void
auth_encrypt_user(char * name)788fa113e5SMark Murray auth_encrypt_user(char *name)
7981cb6ddcSMark Murray {
8081cb6ddcSMark Murray 	if (UserNameRequested)
8181cb6ddcSMark Murray 		free(UserNameRequested);
8281cb6ddcSMark Murray 	UserNameRequested = name ? strdup(name) : 0;
8381cb6ddcSMark Murray }
8481cb6ddcSMark Murray 
8509e8dea7SMark Murray /* ARGSUSED */
8681cb6ddcSMark Murray void
auth_encrypt_connect(int cnt __unused)878fa113e5SMark Murray auth_encrypt_connect(int cnt __unused)
8881cb6ddcSMark Murray {
8981cb6ddcSMark Murray }
908fa113e5SMark Murray #endif	/* ENCRYPTION */
9181cb6ddcSMark Murray 
9281cb6ddcSMark Murray void
printd(const unsigned char * data,int cnt)938fa113e5SMark Murray printd(const unsigned char *data, int cnt)
9481cb6ddcSMark Murray {
9581cb6ddcSMark Murray 	if (cnt > 16)
9681cb6ddcSMark Murray 		cnt = 16;
9781cb6ddcSMark Murray 	while (cnt-- > 0) {
9881cb6ddcSMark Murray 		printf(" %02x", *data);
9981cb6ddcSMark Murray 		++data;
10081cb6ddcSMark Murray 	}
10181cb6ddcSMark Murray }
102