xref: /freebsd/usr.sbin/pw/grupd.c (revision 4d846d260e2b9a3d4d0a701462568268cbfe7a5b)
1d6f907dcSJoerg Wunsch /*-
2*4d846d26SWarner Losh  * SPDX-License-Identifier: BSD-2-Clause
31de7b4b8SPedro F. Giffuni  *
4ad7cf975SJoerg Wunsch  * Copyright (C) 1996
5ad7cf975SJoerg Wunsch  *	David L. Nugent.  All rights reserved.
6d6f907dcSJoerg Wunsch  *
7d6f907dcSJoerg Wunsch  * Redistribution and use in source and binary forms, with or without
8d6f907dcSJoerg Wunsch  * modification, are permitted provided that the following conditions
9d6f907dcSJoerg Wunsch  * are met:
10d6f907dcSJoerg Wunsch  * 1. Redistributions of source code must retain the above copyright
11ad7cf975SJoerg Wunsch  *    notice, this list of conditions and the following disclaimer.
12d6f907dcSJoerg Wunsch  * 2. Redistributions in binary form must reproduce the above copyright
13d6f907dcSJoerg Wunsch  *    notice, this list of conditions and the following disclaimer in the
14d6f907dcSJoerg Wunsch  *    documentation and/or other materials provided with the distribution.
15d6f907dcSJoerg Wunsch  *
16ad7cf975SJoerg Wunsch  * THIS SOFTWARE IS PROVIDED BY DAVID L. NUGENT AND CONTRIBUTORS ``AS IS'' AND
17d6f907dcSJoerg Wunsch  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18d6f907dcSJoerg Wunsch  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19ad7cf975SJoerg Wunsch  * ARE DISCLAIMED.  IN NO EVENT SHALL DAVID L. NUGENT OR CONTRIBUTORS BE LIABLE
20d6f907dcSJoerg Wunsch  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21d6f907dcSJoerg Wunsch  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22d6f907dcSJoerg Wunsch  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23d6f907dcSJoerg Wunsch  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24d6f907dcSJoerg Wunsch  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25d6f907dcSJoerg Wunsch  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26d6f907dcSJoerg Wunsch  * SUCH DAMAGE.
27d6f907dcSJoerg Wunsch  */
28d6f907dcSJoerg Wunsch 
291dcc6ec7SPhilippe Charnier #ifndef lint
301dcc6ec7SPhilippe Charnier static const char rcsid[] =
3197d92980SPeter Wemm   "$FreeBSD$";
321dcc6ec7SPhilippe Charnier #endif /* not lint */
331dcc6ec7SPhilippe Charnier 
34bcbdb01eSBaptiste Daroussin #include <err.h>
35fb2db031SBaptiste Daroussin #include <grp.h>
36fb2db031SBaptiste Daroussin #include <libutil.h>
37d6f907dcSJoerg Wunsch #include <stdio.h>
38d6f907dcSJoerg Wunsch #include <stdlib.h>
3907c4acccSAlan Somers #include <unistd.h>
40d6f907dcSJoerg Wunsch 
41d6f907dcSJoerg Wunsch #include "pwupd.h"
42d6f907dcSJoerg Wunsch 
435f12594aSDavid Nugent char *
445f12594aSDavid Nugent getgrpath(const char * file)
455f12594aSDavid Nugent {
465f12594aSDavid Nugent 	static char pathbuf[MAXPATHLEN];
475f12594aSDavid Nugent 
482cc63cd1SBaptiste Daroussin 	snprintf(pathbuf, sizeof pathbuf, "%s/%s", conf.etcpath, file);
492cc63cd1SBaptiste Daroussin 
502cc63cd1SBaptiste Daroussin 	return (pathbuf);
515f12594aSDavid Nugent }
525f12594aSDavid Nugent 
53d6f907dcSJoerg Wunsch static int
54fb2db031SBaptiste Daroussin gr_update(struct group * grp, char const * group)
55d6f907dcSJoerg Wunsch {
56fb2db031SBaptiste Daroussin 	int pfd, tfd;
57fb2db031SBaptiste Daroussin 	struct group *gr = NULL;
58fb2db031SBaptiste Daroussin 	struct group *old_gr = NULL;
59d6f907dcSJoerg Wunsch 
60fb2db031SBaptiste Daroussin 	if (grp != NULL)
61fb2db031SBaptiste Daroussin 		gr = gr_dup(grp);
62d6f907dcSJoerg Wunsch 
63fb2db031SBaptiste Daroussin 	if (group != NULL)
64fb2db031SBaptiste Daroussin 		old_gr = GETGRNAM(group);
65fb2db031SBaptiste Daroussin 
662cc63cd1SBaptiste Daroussin 	if (gr_init(conf.etcpath, NULL))
67fb2db031SBaptiste Daroussin 		err(1, "gr_init()");
68fb2db031SBaptiste Daroussin 
69fb2db031SBaptiste Daroussin 	if ((pfd = gr_lock()) == -1) {
70fb2db031SBaptiste Daroussin 		gr_fini();
71fb2db031SBaptiste Daroussin 		err(1, "gr_lock()");
725f12594aSDavid Nugent 	}
73fb2db031SBaptiste Daroussin 	if ((tfd = gr_tmp(-1)) == -1) {
74fb2db031SBaptiste Daroussin 		gr_fini();
75fb2db031SBaptiste Daroussin 		err(1, "gr_tmp()");
76fb2db031SBaptiste Daroussin 	}
77fb2db031SBaptiste Daroussin 	if (gr_copy(pfd, tfd, gr, old_gr) == -1) {
78fb2db031SBaptiste Daroussin 		gr_fini();
7907c4acccSAlan Somers 		close(tfd);
80fb2db031SBaptiste Daroussin 		err(1, "gr_copy()");
81fb2db031SBaptiste Daroussin 	}
82cbaba16bSAlan Somers 	fsync(tfd);
8307c4acccSAlan Somers 	close(tfd);
84fb2db031SBaptiste Daroussin 	if (gr_mkdb() == -1) {
85fb2db031SBaptiste Daroussin 		gr_fini();
86fb2db031SBaptiste Daroussin 		err(1, "gr_mkdb()");
87fb2db031SBaptiste Daroussin 	}
88fb2db031SBaptiste Daroussin 	free(gr);
89fb2db031SBaptiste Daroussin 	gr_fini();
90fb2db031SBaptiste Daroussin 	return 0;
91d6f907dcSJoerg Wunsch }
92d6f907dcSJoerg Wunsch 
93d6f907dcSJoerg Wunsch 
94d6f907dcSJoerg Wunsch int
95d6f907dcSJoerg Wunsch addgrent(struct group * grp)
96d6f907dcSJoerg Wunsch {
97fb2db031SBaptiste Daroussin 	return gr_update(grp, NULL);
98d6f907dcSJoerg Wunsch }
99d6f907dcSJoerg Wunsch 
100d6f907dcSJoerg Wunsch int
101d6f907dcSJoerg Wunsch chggrent(char const * login, struct group * grp)
102d6f907dcSJoerg Wunsch {
103fb2db031SBaptiste Daroussin 	return gr_update(grp, login);
104d6f907dcSJoerg Wunsch }
105d6f907dcSJoerg Wunsch 
106d6f907dcSJoerg Wunsch int
107d6f907dcSJoerg Wunsch delgrent(struct group * grp)
108d6f907dcSJoerg Wunsch {
109fb2db031SBaptiste Daroussin 
110e55af20bSBaptiste Daroussin 	return (gr_update(NULL, grp->gr_name));
111d6f907dcSJoerg Wunsch }
112