1 /* Copyright (c) 1997-2013 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3 Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1997.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
21 #include <rpcsvc/nis.h>
24 nis_removemember (const_nis_name member
, const_nis_name group
)
26 if (group
!= NULL
&& group
[0] != '\0')
28 size_t grouplen
= strlen (group
);
29 char buf
[grouplen
+ 14 + NIS_MAXNAMELEN
];
30 char domainbuf
[grouplen
+ 2];
31 nis_result
*res
, *res2
;
35 cp
= rawmemchr (nis_leaf_of_r (group
, buf
, sizeof (buf
) - 1), '\0');
36 cp
= stpcpy (cp
, ".groups_dir");
37 cp2
= nis_domain_of_r (group
, domainbuf
, sizeof (domainbuf
) - 1);
38 if (cp2
!= NULL
&& cp2
[0] != '\0')
40 cp
= stpcpy (cp
, ".");
43 res
= nis_lookup (buf
, FOLLOW_LINKS
| EXPAND_NAME
);
46 if (NIS_RES_STATUS (res
) != NIS_SUCCESS
)
48 status
= NIS_RES_STATUS (res
);
53 if (NIS_RES_NUMOBJ (res
) != 1
54 || __type_of (NIS_RES_OBJECT (res
)) != NIS_GROUP_OBJ
)
57 return NIS_INVALIDOBJ
;
60 nis_name
*gr_members_val
61 = NIS_RES_OBJECT(res
)->GR_data
.gr_members
.gr_members_val
;
63 = NIS_RES_OBJECT(res
)->GR_data
.gr_members
.gr_members_len
;
66 for (u_int i
= 0; i
< gr_members_len
; ++i
)
67 if (strcmp (gr_members_val
[i
], member
) != 0)
68 gr_members_val
[j
++] = gr_members_val
[i
];
70 free (gr_members_val
[i
]);
72 /* There is no need to reallocate the gr_members_val array. We
73 just adjust the size to match the number of strings still in
74 it. Yes, xdr_array will use mem_free with a size parameter
75 but this is mapped to a simple free call which determines the
76 size of the block by itself. */
77 NIS_RES_OBJECT (res
)->GR_data
.gr_members
.gr_members_len
= j
;
79 cp
= stpcpy (buf
, NIS_RES_OBJECT (res
)->zo_name
);
81 strncpy (cp
, NIS_RES_OBJECT (res
)->zo_domain
, NIS_MAXNAMELEN
);
82 res2
= nis_modify (buf
, NIS_RES_OBJECT (res
));
83 status
= NIS_RES_STATUS (res2
);
85 nis_freeresult (res2
);