xref: /freebsd/usr.sbin/pw/grupd.c (revision eba230afba4932f02a1ca44efc797cf7499a5cb0)
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 
29bcbdb01eSBaptiste Daroussin #include <err.h>
30fb2db031SBaptiste Daroussin #include <grp.h>
31fb2db031SBaptiste Daroussin #include <libutil.h>
32d6f907dcSJoerg Wunsch #include <stdio.h>
33d6f907dcSJoerg Wunsch #include <stdlib.h>
3407c4acccSAlan Somers #include <unistd.h>
35d6f907dcSJoerg Wunsch 
36d6f907dcSJoerg Wunsch #include "pwupd.h"
37d6f907dcSJoerg Wunsch 
385f12594aSDavid Nugent char *
getgrpath(const char * file)395f12594aSDavid Nugent getgrpath(const char * file)
405f12594aSDavid Nugent {
415f12594aSDavid Nugent 	static char pathbuf[MAXPATHLEN];
425f12594aSDavid Nugent 
432cc63cd1SBaptiste Daroussin 	snprintf(pathbuf, sizeof pathbuf, "%s/%s", conf.etcpath, file);
442cc63cd1SBaptiste Daroussin 
452cc63cd1SBaptiste Daroussin 	return (pathbuf);
465f12594aSDavid Nugent }
475f12594aSDavid Nugent 
48d6f907dcSJoerg Wunsch static int
gr_update(struct group * grp,char const * group)49fb2db031SBaptiste Daroussin gr_update(struct group * grp, char const * group)
50d6f907dcSJoerg Wunsch {
51fb2db031SBaptiste Daroussin 	int pfd, tfd;
52fb2db031SBaptiste Daroussin 	struct group *gr = NULL;
53fb2db031SBaptiste Daroussin 	struct group *old_gr = NULL;
54d6f907dcSJoerg Wunsch 
55fb2db031SBaptiste Daroussin 	if (grp != NULL)
56fb2db031SBaptiste Daroussin 		gr = gr_dup(grp);
57d6f907dcSJoerg Wunsch 
58fb2db031SBaptiste Daroussin 	if (group != NULL)
59fb2db031SBaptiste Daroussin 		old_gr = GETGRNAM(group);
60fb2db031SBaptiste Daroussin 
612cc63cd1SBaptiste Daroussin 	if (gr_init(conf.etcpath, NULL))
62fb2db031SBaptiste Daroussin 		err(1, "gr_init()");
63fb2db031SBaptiste Daroussin 
64fb2db031SBaptiste Daroussin 	if ((pfd = gr_lock()) == -1) {
65fb2db031SBaptiste Daroussin 		gr_fini();
66fb2db031SBaptiste Daroussin 		err(1, "gr_lock()");
675f12594aSDavid Nugent 	}
68fb2db031SBaptiste Daroussin 	if ((tfd = gr_tmp(-1)) == -1) {
69fb2db031SBaptiste Daroussin 		gr_fini();
70fb2db031SBaptiste Daroussin 		err(1, "gr_tmp()");
71fb2db031SBaptiste Daroussin 	}
72fb2db031SBaptiste Daroussin 	if (gr_copy(pfd, tfd, gr, old_gr) == -1) {
73fb2db031SBaptiste Daroussin 		gr_fini();
7407c4acccSAlan Somers 		close(tfd);
75fb2db031SBaptiste Daroussin 		err(1, "gr_copy()");
76fb2db031SBaptiste Daroussin 	}
77cbaba16bSAlan Somers 	fsync(tfd);
7807c4acccSAlan Somers 	close(tfd);
79fb2db031SBaptiste Daroussin 	if (gr_mkdb() == -1) {
80fb2db031SBaptiste Daroussin 		gr_fini();
81fb2db031SBaptiste Daroussin 		err(1, "gr_mkdb()");
82fb2db031SBaptiste Daroussin 	}
83fb2db031SBaptiste Daroussin 	free(gr);
84fb2db031SBaptiste Daroussin 	gr_fini();
85fb2db031SBaptiste Daroussin 	return 0;
86d6f907dcSJoerg Wunsch }
87d6f907dcSJoerg Wunsch 
88d6f907dcSJoerg Wunsch 
89d6f907dcSJoerg Wunsch int
addgrent(struct group * grp)90d6f907dcSJoerg Wunsch addgrent(struct group * grp)
91d6f907dcSJoerg Wunsch {
92fb2db031SBaptiste Daroussin 	return gr_update(grp, NULL);
93d6f907dcSJoerg Wunsch }
94d6f907dcSJoerg Wunsch 
95d6f907dcSJoerg Wunsch int
chggrent(char const * login,struct group * grp)96d6f907dcSJoerg Wunsch chggrent(char const * login, struct group * grp)
97d6f907dcSJoerg Wunsch {
98fb2db031SBaptiste Daroussin 	return gr_update(grp, login);
99d6f907dcSJoerg Wunsch }
100d6f907dcSJoerg Wunsch 
101d6f907dcSJoerg Wunsch int
delgrent(struct group * grp)102d6f907dcSJoerg Wunsch delgrent(struct group * grp)
103d6f907dcSJoerg Wunsch {
104fb2db031SBaptiste Daroussin 
105e55af20bSBaptiste Daroussin 	return (gr_update(NULL, grp->gr_name));
106d6f907dcSJoerg Wunsch }
107