]> git.saurik.com Git - apple/network_cmds.git/blame - rlogin.tproj/krcmd.c
network_cmds-245.1.3.tar.gz
[apple/network_cmds.git] / rlogin.tproj / krcmd.c
CommitLineData
b7080c8e
A
1/*
2 * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
ffda1f4a
A
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
b7080c8e
A
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
ffda1f4a
A
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
b7080c8e
A
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23/*
24 * Copyright (c) 1989, 1993
25 * The Regents of the University of California. All rights reserved.
26 *
27 * Redistribution and use in source and binary forms, with or without
28 * modification, are permitted provided that the following conditions
29 * are met:
30 * 1. Redistributions of source code must retain the above copyright
31 * notice, this list of conditions and the following disclaimer.
32 * 2. Redistributions in binary form must reproduce the above copyright
33 * notice, this list of conditions and the following disclaimer in the
34 * documentation and/or other materials provided with the distribution.
35 * 3. All advertising materials mentioning features or use of this software
36 * must display the following acknowledgement:
37 * This product includes software developed by the University of
38 * California, Berkeley and its contributors.
39 * 4. Neither the name of the University nor the names of its contributors
40 * may be used to endorse or promote products derived from this software
41 * without specific prior written permission.
42 *
43 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
44 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
45 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
46 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
47 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
48 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
49 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
50 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
51 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
52 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
53 * SUCH DAMAGE.
54 */
55
56
57/*
285dd90c 58 * $Source: /cvs/root/network_cmds/rlogin.tproj/krcmd.c,v $
b7080c8e
A
59 * $Header: /mit/kerberos/ucb/mit/kcmd/RCS/krcmd.c,v 5.1
60 * 89/07/25 15:38:44 kfall Exp Locker: kfall $
61 * static char *rcsid_kcmd_c =
62 * "$Header: /mit/kerberos/ucb/mit/kcmd/RCS/krcmd.c,v 5.1 89/07/25 15:38:44
63 * kfall Exp Locker: kfall $";
64 */
65
66#ifdef KERBEROS
67#include <sys/types.h>
68#ifdef CRYPT
69#include <sys/socket.h>
70#endif
71
72#include <netinet/in.h>
73
74#include <kerberosIV/des.h>
75#include <kerberosIV/krb.h>
76
77#include <stdio.h>
78
79#define SERVICE_NAME "rcmd"
80
81int kcmd __P((int *, char **, u_short, char *, char *, char *, int *,
82 KTEXT, char *, char *, CREDENTIALS *, Key_schedule, MSG_DAT *,
83 struct sockaddr_in *, struct sockaddr_in *, long));
84
85/*
86 * krcmd: simplified version of Athena's "kcmd"
87 * returns a socket attached to the destination, -1 or krb error on error
88 * if fd2p is non-NULL, another socket is filled in for it
89 */
90
91int
92krcmd(ahost, rport, remuser, cmd, fd2p, realm)
93 char **ahost;
94 u_short rport;
95 char *remuser, *cmd;
96 int *fd2p;
97 char *realm;
98{
99 int sock = -1, err = 0;
100 KTEXT_ST ticket;
101 long authopts = 0L;
102
103 err = kcmd(
104 &sock,
105 ahost,
106 rport,
107 NULL, /* locuser not used */
108 remuser,
109 cmd,
110 fd2p,
111 &ticket,
112 SERVICE_NAME,
113 realm,
114 (CREDENTIALS *) NULL, /* credentials not used */
115 (bit_64 *) NULL, /* key schedule not used */
116 (MSG_DAT *) NULL, /* MSG_DAT not used */
117 (struct sockaddr_in *) NULL, /* local addr not used */
118 (struct sockaddr_in *) NULL, /* foreign addr not used */
119 authopts
120 );
121
122 if (err > KSUCCESS && err < MAX_KRB_ERRORS) {
123 fprintf(stderr, "krcmd: %s\n", krb_err_txt[err]);
124 return(-1);
125 }
126 if (err < 0)
127 return(-1);
128 return(sock);
129}
130
131#ifdef CRYPT
132int
133krcmd_mutual(ahost, rport, remuser, cmd, fd2p, realm, cred, sched)
134 char **ahost;
135 u_short rport;
136 char *remuser, *cmd;
137 int *fd2p;
138 char *realm;
139 CREDENTIALS *cred;
140 Key_schedule sched;
141{
142 int sock, err;
143 KTEXT_ST ticket;
144 MSG_DAT msg_dat;
145 struct sockaddr_in laddr, faddr;
146 long authopts = KOPT_DO_MUTUAL;
147
148 err = kcmd(
149 &sock,
150 ahost,
151 rport,
152 NULL, /* locuser not used */
153 remuser,
154 cmd,
155 fd2p,
156 &ticket,
157 SERVICE_NAME,
158 realm,
159 cred, /* filled in */
160 sched, /* filled in */
161 &msg_dat, /* filled in */
162 &laddr, /* filled in */
163 &faddr, /* filled in */
164 authopts
165 );
166
167 if (err > KSUCCESS && err < MAX_KRB_ERRORS) {
168 fprintf(stderr, "krcmd_mutual: %s\n", krb_err_txt[err]);
169 return(-1);
170 }
171
172 if (err < 0)
173 return (-1);
174 return(sock);
175}
176#endif /* CRYPT */
177#endif /* KERBEROS */