xref: /freebsd/usr.sbin/pw/grupd.c (revision e55af20b47344704943105c5fe44862c17bc5e3a)
1d6f907dcSJoerg Wunsch /*-
2ad7cf975SJoerg Wunsch  * Copyright (C) 1996
3ad7cf975SJoerg Wunsch  *	David L. Nugent.  All rights reserved.
4d6f907dcSJoerg Wunsch  *
5d6f907dcSJoerg Wunsch  * Redistribution and use in source and binary forms, with or without
6d6f907dcSJoerg Wunsch  * modification, are permitted provided that the following conditions
7d6f907dcSJoerg Wunsch  * are met:
8d6f907dcSJoerg Wunsch  * 1. Redistributions of source code must retain the above copyright
9ad7cf975SJoerg Wunsch  *    notice, this list of conditions and the following disclaimer.
10d6f907dcSJoerg Wunsch  * 2. Redistributions in binary form must reproduce the above copyright
11d6f907dcSJoerg Wunsch  *    notice, this list of conditions and the following disclaimer in the
12d6f907dcSJoerg Wunsch  *    documentation and/or other materials provided with the distribution.
13d6f907dcSJoerg Wunsch  *
14ad7cf975SJoerg Wunsch  * THIS SOFTWARE IS PROVIDED BY DAVID L. NUGENT AND CONTRIBUTORS ``AS IS'' AND
15d6f907dcSJoerg Wunsch  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16d6f907dcSJoerg Wunsch  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17ad7cf975SJoerg Wunsch  * ARE DISCLAIMED.  IN NO EVENT SHALL DAVID L. NUGENT OR CONTRIBUTORS BE LIABLE
18d6f907dcSJoerg Wunsch  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19d6f907dcSJoerg Wunsch  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20d6f907dcSJoerg Wunsch  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21d6f907dcSJoerg Wunsch  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22d6f907dcSJoerg Wunsch  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23d6f907dcSJoerg Wunsch  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24d6f907dcSJoerg Wunsch  * SUCH DAMAGE.
25d6f907dcSJoerg Wunsch  */
26d6f907dcSJoerg Wunsch 
271dcc6ec7SPhilippe Charnier #ifndef lint
281dcc6ec7SPhilippe Charnier static const char rcsid[] =
2997d92980SPeter Wemm   "$FreeBSD$";
301dcc6ec7SPhilippe Charnier #endif /* not lint */
311dcc6ec7SPhilippe Charnier 
32fb2db031SBaptiste Daroussin #include <grp.h>
33fb2db031SBaptiste Daroussin #include <libutil.h>
34fb2db031SBaptiste Daroussin #include <err.h>
35d6f907dcSJoerg Wunsch #include <stdio.h>
36d6f907dcSJoerg Wunsch #include <stdlib.h>
37d6f907dcSJoerg Wunsch #include <string.h>
385f12594aSDavid Nugent #include <sys/param.h>
39d6f907dcSJoerg Wunsch 
40d6f907dcSJoerg Wunsch #include "pwupd.h"
41d6f907dcSJoerg Wunsch 
425f12594aSDavid Nugent static char * grpath = _PATH_PWD;
435f12594aSDavid Nugent 
445f12594aSDavid Nugent int
455f12594aSDavid Nugent setgrdir(const char * dir)
465f12594aSDavid Nugent {
475f12594aSDavid Nugent 	if (dir == NULL)
485f12594aSDavid Nugent 		return -1;
49fa65b91aSEitan Adler 	else
50fa65b91aSEitan Adler 		grpath = strdup(dir);
51fa65b91aSEitan Adler 	if (grpath == NULL)
525f12594aSDavid Nugent 		return -1;
53fa65b91aSEitan Adler 
545f12594aSDavid Nugent 	return 0;
555f12594aSDavid Nugent }
565f12594aSDavid Nugent 
575f12594aSDavid Nugent char *
585f12594aSDavid Nugent getgrpath(const char * file)
595f12594aSDavid Nugent {
605f12594aSDavid Nugent 	static char pathbuf[MAXPATHLEN];
615f12594aSDavid Nugent 
625f12594aSDavid Nugent 	snprintf(pathbuf, sizeof pathbuf, "%s/%s", grpath, file);
635f12594aSDavid Nugent 	return pathbuf;
645f12594aSDavid Nugent }
655f12594aSDavid Nugent 
66d6f907dcSJoerg Wunsch static int
67fb2db031SBaptiste Daroussin gr_update(struct group * grp, char const * group)
68d6f907dcSJoerg Wunsch {
69fb2db031SBaptiste Daroussin 	int pfd, tfd;
70fb2db031SBaptiste Daroussin 	struct group *gr = NULL;
71fb2db031SBaptiste Daroussin 	struct group *old_gr = NULL;
72d6f907dcSJoerg Wunsch 
73fb2db031SBaptiste Daroussin 	if (grp != NULL)
74fb2db031SBaptiste Daroussin 		gr = gr_dup(grp);
75d6f907dcSJoerg Wunsch 
76fb2db031SBaptiste Daroussin 	if (group != NULL)
77fb2db031SBaptiste Daroussin 		old_gr = GETGRNAM(group);
78fb2db031SBaptiste Daroussin 
79fb2db031SBaptiste Daroussin 	if (gr_init(grpath, NULL))
80fb2db031SBaptiste Daroussin 		err(1, "gr_init()");
81fb2db031SBaptiste Daroussin 
82fb2db031SBaptiste Daroussin 	if ((pfd = gr_lock()) == -1) {
83fb2db031SBaptiste Daroussin 		gr_fini();
84fb2db031SBaptiste Daroussin 		err(1, "gr_lock()");
855f12594aSDavid Nugent 	}
86fb2db031SBaptiste Daroussin 	if ((tfd = gr_tmp(-1)) == -1) {
87fb2db031SBaptiste Daroussin 		gr_fini();
88fb2db031SBaptiste Daroussin 		err(1, "gr_tmp()");
89fb2db031SBaptiste Daroussin 	}
90fb2db031SBaptiste Daroussin 	if (gr_copy(pfd, tfd, gr, old_gr) == -1) {
91fb2db031SBaptiste Daroussin 		gr_fini();
92fb2db031SBaptiste Daroussin 		err(1, "gr_copy()");
93fb2db031SBaptiste Daroussin 	}
94fb2db031SBaptiste Daroussin 	if (gr_mkdb() == -1) {
95fb2db031SBaptiste Daroussin 		gr_fini();
96fb2db031SBaptiste Daroussin 		err(1, "gr_mkdb()");
97fb2db031SBaptiste Daroussin 	}
98fb2db031SBaptiste Daroussin 	free(gr);
99fb2db031SBaptiste Daroussin 	gr_fini();
100fb2db031SBaptiste Daroussin 	return 0;
101d6f907dcSJoerg Wunsch }
102d6f907dcSJoerg Wunsch 
103d6f907dcSJoerg Wunsch 
104d6f907dcSJoerg Wunsch int
105d6f907dcSJoerg Wunsch addgrent(struct group * grp)
106d6f907dcSJoerg Wunsch {
107fb2db031SBaptiste Daroussin 	return gr_update(grp, NULL);
108d6f907dcSJoerg Wunsch }
109d6f907dcSJoerg Wunsch 
110d6f907dcSJoerg Wunsch int
111d6f907dcSJoerg Wunsch chggrent(char const * login, struct group * grp)
112d6f907dcSJoerg Wunsch {
113fb2db031SBaptiste Daroussin 	return gr_update(grp, login);
114d6f907dcSJoerg Wunsch }
115d6f907dcSJoerg Wunsch 
116d6f907dcSJoerg Wunsch int
117d6f907dcSJoerg Wunsch delgrent(struct group * grp)
118d6f907dcSJoerg Wunsch {
119fb2db031SBaptiste Daroussin 
120*e55af20bSBaptiste Daroussin 	return (gr_update(NULL, grp->gr_name));
121d6f907dcSJoerg Wunsch }
122