]>
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 * "Portions Copyright (c) 1999 Apple Computer, Inc. All Rights
7 * Reserved. This file contains Original Code and/or Modifications of
8 * Original Code as defined in and that are subject to the Apple Public
9 * Source License Version 1.0 (the 'License'). You may not use this file
10 * except in compliance with the License. Please obtain a copy of the
11 * License at http://www.apple.com/publicsource and read it before using
14 * The Original Code and all software distributed under the License are
15 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
16 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
17 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
19 * License for the specific language governing rights and limitations
22 * @APPLE_LICENSE_HEADER_END@
25 * Portions Copyright (c) 1998 by Apple Computer, Inc.
26 * Portions Copyright (c) 1988 by Sun Microsystems, Inc.
27 * Portions Copyright (c) 1988 The Regents of the University of California.
28 * All rights reserved.
30 * Redistribution and use in source and binary forms, with or without
31 * modification, are permitted provided that the following conditions
33 * 1. Redistributions of source code must retain the above copyright
34 * notice, this list of conditions and the following disclaimer.
35 * 2. Redistributions in binary form must reproduce the above copyright
36 * notice, this list of conditions and the following disclaimer in the
37 * documentation and/or other materials provided with the distribution.
38 * 3. All advertising materials mentioning features or use of this software
39 * must display the following acknowledgement:
40 * This product includes software developed by the University of
41 * California, Berkeley and its contributors.
42 * 4. Neither the name of the University nor the names of its contributors
43 * may be used to endorse or promote products derived from this software
44 * without specific prior written permission.
46 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
47 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
48 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
49 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
50 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
51 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
52 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
53 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
54 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
55 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
60 /* update a user's password in NIS. This was based on the Sun implementation
61 * we used in NEXTSTEP, although I've added some stuff from OpenBSD. And
62 * it uses the API to support Rhapsody's proprietry infosystem switch.
71 #include <netinet/in.h>
72 #include <rpc/types.h>
75 #include <rpcsvc/yp_prot.h>
76 #include <rpcsvc/ypclnt.h>
77 #include <rpcsvc/yppasswd.h>
79 #include <sys/socket.h>
83 extern int getrpcport(char *, int, int, int);
84 extern void getpasswd(char *, int, int, int, int, char *, char **, char**, char **);
86 static struct passwd
*ypgetpwnam(char *name
, char *domain
);
88 int nis_passwd(char *uname
, char *domain
)
90 int ans
, port
, ok
= -1;
92 char *ne
; /* new encrypted password */
93 char *oc
; /* old cleartext password */
94 char *nc
; /* new cleartext password */
95 static struct yppasswd yppasswd
;
103 if (yp_get_default_domain(&domain
) != 0)
105 (void)fprintf(stderr
, "can't get domain\n");
110 if (yp_master(domain
, "passwd.byname", &master
) != 0)
112 (void)fprintf(stderr
, "can't get master for passwd file\n");
116 port
= getrpcport(master
, YPPASSWDPROG
, YPPASSWDPROC_UPDATE
,
120 (void)fprintf(stderr
, "%s is not running yppasswd daemon\n",
124 if (port
>= IPPORT_RESERVED
)
126 (void)fprintf(stderr
,
127 "yppasswd daemon is not running on privileged port\n");
131 pwd
= ypgetpwnam(uname
, domain
);
134 (void)fprintf(stderr
, "user %s not found\n", uname
);
139 if (uid
!= 0 && uid
!= pwd
->pw_uid
)
141 (void)fprintf(stderr
, "you may only change your own password\n");
145 getpasswd(uname
, 0, 5, 0, 0, pwd
->pw_passwd
, &ne
, &oc
, &nc
);
147 yppasswd
.oldpass
= oc
;
148 yppasswd
.newpw
.pw_name
= pwd
->pw_name
;
149 yppasswd
.newpw
.pw_passwd
= ne
;
150 yppasswd
.newpw
.pw_uid
= pwd
->pw_uid
;
151 yppasswd
.newpw
.pw_gid
= pwd
->pw_gid
;
152 yppasswd
.newpw
.pw_gecos
= pwd
->pw_gecos
;
153 yppasswd
.newpw
.pw_dir
= pwd
->pw_dir
;
154 yppasswd
.newpw
.pw_shell
= pwd
->pw_shell
;
156 cl
= clnt_create(master
, YPPASSWDPROG
, YPPASSWDVERS
, "udp");
159 (void)fprintf(stderr
, "could not contact yppasswdd on %s\n", master
);
162 cl
->cl_auth
= authunix_create_default();
165 ans
= clnt_call(cl
, YPPASSWDPROC_UPDATE
,
166 (xdrproc_t
)xdr_yppasswd
, &yppasswd
, (xdrproc_t
)xdr_int
, &ok
, tv
);
171 (void)fprintf(stderr
, "\n");
172 (void)fprintf(stderr
, "couldn't change passwd\n");
177 (void)fprintf(stderr
, "couldn't change passwd\n");
184 pwskip(register char *p
)
186 while (*p
&& *p
!= ':' && *p
!= '\n')
194 interpret(struct passwd
*pwent
, char *line
)
196 register char *p
= line
;
198 pwent
->pw_passwd
= "*";
201 pwent
->pw_gecos
= "";
203 pwent
->pw_shell
= "";
205 pwent
->pw_change
= 0;
206 pwent
->pw_expire
= 0;
207 pwent
->pw_class
= "";
210 /* line without colon separators is no good, so ignore it */
216 pwent
->pw_passwd
= p
;
218 pwent
->pw_uid
= (uid_t
)strtoul(p
, NULL
, 10);
220 pwent
->pw_gid
= (gid_t
)strtoul(p
, NULL
, 10);
227 while (*p
&& *p
!= '\n')
234 static struct passwd
*
235 ypgetpwnam(char *nam
, char *domain
)
237 static struct passwd pwent
;
240 static char *__yplin
= NULL
;
242 reason
= yp_match(domain
, "passwd.byname", nam
, strlen(nam
),
254 __yplin
= (char *)malloc(vallen
+ 1);
255 strcpy(__yplin
, val
);
258 return(interpret(&pwent
, __yplin
));