]>
git.saurik.com Git - apple/system_cmds.git/blob - passwd.tproj/nis_passwd.c
2 * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * Copyright (c) 1999-2003 Apple Computer, Inc. All Rights Reserved.
8 * This file contains Original Code and/or Modifications of Original Code
9 * as defined in and that are subject to the Apple Public Source License
10 * Version 2.0 (the 'License'). You may not use this file except in
11 * compliance with the License. Please obtain a copy of the License at
12 * http://www.opensource.apple.com/apsl/ and read it before using this
15 * The Original Code and all software distributed under the License are
16 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
17 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
18 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
20 * Please see the License for the specific language governing rights and
21 * limitations under the License.
23 * @APPLE_LICENSE_HEADER_END@
26 * Portions Copyright (c) 1998 by Apple Computer, Inc.
27 * Portions Copyright (c) 1988 by Sun Microsystems, Inc.
28 * Portions Copyright (c) 1988 The Regents of the University of California.
29 * All rights reserved.
31 * Redistribution and use in source and binary forms, with or without
32 * modification, are permitted provided that the following conditions
34 * 1. Redistributions of source code must retain the above copyright
35 * notice, this list of conditions and the following disclaimer.
36 * 2. Redistributions in binary form must reproduce the above copyright
37 * notice, this list of conditions and the following disclaimer in the
38 * documentation and/or other materials provided with the distribution.
39 * 3. All advertising materials mentioning features or use of this software
40 * must display the following acknowledgement:
41 * This product includes software developed by the University of
42 * California, Berkeley and its contributors.
43 * 4. Neither the name of the University nor the names of its contributors
44 * may be used to endorse or promote products derived from this software
45 * without specific prior written permission.
47 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
48 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
49 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
50 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
51 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
52 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
53 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
54 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
55 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
56 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
61 /* update a user's password in NIS. This was based on the Sun implementation
62 * we used in NEXTSTEP, although I've added some stuff from OpenBSD. And
63 * it uses the API to support Rhapsody's proprietry infosystem switch.
72 #include <netinet/in.h>
73 #include <rpc/types.h>
76 #include <rpcsvc/yp_prot.h>
77 #include <rpcsvc/ypclnt.h>
78 #include <rpcsvc/yppasswd.h>
80 #include <sys/socket.h>
84 extern int getrpcport(char *, int, int, int);
85 extern void getpasswd(char *, int, int, int, int, char *, char **, char**, char **);
87 static struct passwd
*ypgetpwnam(char *name
, char *domain
);
89 int nis_passwd(char *uname
, char *domain
)
91 int ans
, port
, ok
= -1;
93 char *ne
; /* new encrypted password */
94 char *oc
; /* old cleartext password */
95 char *nc
; /* new cleartext password */
96 static struct yppasswd yppasswd
;
104 if (yp_get_default_domain(&domain
) != 0)
106 (void)fprintf(stderr
, "can't get domain\n");
111 if (yp_master(domain
, "passwd.byname", &master
) != 0)
113 (void)fprintf(stderr
, "can't get master for passwd file\n");
117 port
= getrpcport(master
, YPPASSWDPROG
, YPPASSWDPROC_UPDATE
,
121 (void)fprintf(stderr
, "%s is not running yppasswd daemon\n",
125 if (port
>= IPPORT_RESERVED
)
127 (void)fprintf(stderr
,
128 "yppasswd daemon is not running on privileged port\n");
132 pwd
= ypgetpwnam(uname
, domain
);
135 (void)fprintf(stderr
, "user %s not found\n", uname
);
140 if (uid
!= 0 && uid
!= pwd
->pw_uid
)
142 (void)fprintf(stderr
, "you may only change your own password\n");
146 getpasswd(uname
, 0, 5, 0, 0, pwd
->pw_passwd
, &ne
, &oc
, &nc
);
148 yppasswd
.oldpass
= oc
;
149 yppasswd
.newpw
.pw_name
= pwd
->pw_name
;
150 yppasswd
.newpw
.pw_passwd
= ne
;
151 yppasswd
.newpw
.pw_uid
= pwd
->pw_uid
;
152 yppasswd
.newpw
.pw_gid
= pwd
->pw_gid
;
153 yppasswd
.newpw
.pw_gecos
= pwd
->pw_gecos
;
154 yppasswd
.newpw
.pw_dir
= pwd
->pw_dir
;
155 yppasswd
.newpw
.pw_shell
= pwd
->pw_shell
;
157 cl
= clnt_create(master
, YPPASSWDPROG
, YPPASSWDVERS
, "udp");
160 (void)fprintf(stderr
, "could not contact yppasswdd on %s\n", master
);
163 cl
->cl_auth
= authunix_create_default();
166 ans
= clnt_call(cl
, YPPASSWDPROC_UPDATE
,
167 xdr_yppasswd
, &yppasswd
, xdr_int
, &ok
, tv
);
172 (void)fprintf(stderr
, "\n");
173 (void)fprintf(stderr
, "couldn't change passwd\n");
178 (void)fprintf(stderr
, "couldn't change passwd\n");
185 pwskip(register char *p
)
187 while (*p
&& *p
!= ':' && *p
!= '\n')
195 interpret(struct passwd
*pwent
, char *line
)
197 register char *p
= line
;
199 pwent
->pw_passwd
= "*";
202 pwent
->pw_gecos
= "";
204 pwent
->pw_shell
= "";
206 pwent
->pw_change
= 0;
207 pwent
->pw_expire
= 0;
208 pwent
->pw_class
= "";
211 /* line without colon separators is no good, so ignore it */
217 pwent
->pw_passwd
= p
;
219 pwent
->pw_uid
= (uid_t
)strtoul(p
, NULL
, 10);
221 pwent
->pw_gid
= (gid_t
)strtoul(p
, NULL
, 10);
228 while (*p
&& *p
!= '\n')
235 static struct passwd
*
236 ypgetpwnam(char *nam
, char *domain
)
238 static struct passwd pwent
;
241 static char *__yplin
= NULL
;
243 reason
= yp_match(domain
, "passwd.byname", nam
, strlen(nam
),
255 __yplin
= (char *)malloc(vallen
+ 1);
256 strcpy(__yplin
, val
);
259 return(interpret(&pwent
, __yplin
));