xref: /illumos-gate/usr/src/lib/passwdutil/__user_to_authenticate.c (revision cbea7aca3fd7787405cbdbd93752998f03dfc25f)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  * Copyright 2024 OmniOS Community Edition (OmniOSce) Association.
26  */
27 
28 #include "passwdutil.h"
29 
30 int
__user_to_authenticate(const char * name,pwu_repository_t * rep,char ** auth_user,int * auth_self)31 __user_to_authenticate(const char *name, pwu_repository_t *rep,
32     char **auth_user, int *auth_self)
33 {
34 	int repositories;
35 	int i;
36 	int pwu_res;
37 
38 	/*
39 	 * This function is called only by passwd command performing
40 	 * update operation, so use PWU_WRITE as the access type to
41 	 * find the repositories for WRITE operation.
42 	 */
43 	repositories = get_ns(rep, PWU_WRITE);
44 
45 	if (repositories == 0)
46 		return (PWU_SYSTEM_ERROR);
47 
48 	if (repositories == REP_ERANGE || repositories == REP_NSS)
49 		return (PWU_REPOSITORY_ERROR);
50 
51 	i = REP_FILES;
52 
53 	/* Loop over repositories until we find the user */
54 	while (i <= REP_LAST) {
55 		if (repositories & i) {
56 			pwu_res = rops[i]->user_to_authenticate(name, rep,
57 							auth_user, auth_self);
58 			if (pwu_res != PWU_NOT_FOUND)
59 				return (pwu_res);
60 		}
61 		i <<= 1;
62 	}
63 
64 	return (PWU_NOT_FOUND);
65 }
66