1 /* Copyright (c) 1997 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 Library General Public License as
7 published by the Free Software Foundation; either version 2 of the
8 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 Library General Public License for more details.
15 You should have received a copy of the GNU Library General Public
16 License along with the GNU C Library; see the file COPYING.LIB. If not,
17 write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA. */
21 #include <rpcsvc/nis.h>
22 #include <rpcsvc/nislib.h>
25 nis_removemember (const_nis_name member
, const_nis_name group
)
27 if (group
!= NULL
&& strlen (group
) > 0)
29 char buf
[strlen (group
) + 14 + NIS_MAXNAMELEN
];
30 char leafbuf
[strlen (group
) + 2];
31 char domainbuf
[strlen (group
) + 2];
33 nis_result
*res
, *res2
;
36 unsigned long int i
, j
, k
;
38 cp
= stpcpy (buf
, nis_leaf_of_r (group
, leafbuf
, sizeof (leafbuf
) - 1));
39 cp
= stpcpy (cp
, ".groups_dir");
40 cp2
= nis_domain_of_r (group
, domainbuf
, sizeof (domainbuf
) - 1);
41 if (cp2
!= NULL
&& strlen (cp2
) > 0)
43 cp
= stpcpy (cp
, ".");
46 res
= nis_lookup (buf
, FOLLOW_LINKS
|EXPAND_NAME
);
47 if (res
->status
!= NIS_SUCCESS
)
53 if ((res
->objects
.objects_len
!= 1) ||
54 (res
->objects
.objects_val
[0].zo_data
.zo_type
!= GROUP_OBJ
))
55 return NIS_INVALIDOBJ
;
58 newmem
= calloc (1, res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_len
*
61 k
= res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_len
;
63 for (i
= 0; i
< res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_len
;
66 if (strcmp (res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_val
[i
],
69 newmem
[j
] = res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_val
[i
];
74 free (res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_val
[i
]);
78 free (res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_val
);
79 newmem
= realloc (newmem
, k
* sizeof (char*));
80 res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_val
= newmem
;
81 res
->objects
.objects_val
[0].GR_data
.gr_members
.gr_members_len
= k
;
83 cp
= stpcpy (buf
, res
->objects
.objects_val
->zo_name
);
85 strncpy (cp
, res
->objects
.objects_val
->zo_domain
, NIS_MAXNAMELEN
);
86 res2
= nis_modify (buf
, res
->objects
.objects_val
);
87 status
= res2
->status
;
89 nis_freeresult (res2
);