NY OG FORBEDRET
Fixed bug #191365. Støtte for grupper med underscore i navnet.
This commit is contained in:
parent
bcf7ceab37
commit
33ffd2c485
76
common.c
76
common.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* @(#) $Header: /tmp/cvs/mysql-admutils/common.c,v 1.4 2002-06-05 08:01:31 tlan Exp $
|
* @(#) $Header: /tmp/cvs/mysql-admutils/common.c,v 1.5 2004-11-16 20:58:54 lkarsten Exp $
|
||||||
*
|
*
|
||||||
* functions used by mysql-dbadm.c and mysql-useradm.c
|
* functions used by mysql-dbadm.c and mysql-useradm.c
|
||||||
*
|
*
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
char *program_name;
|
char *program_name;
|
||||||
|
|
||||||
static char *rcsheader = "@(#) " PACKAGE " " VERSION " ljosa@initio.no $Header: /tmp/cvs/mysql-admutils/common.c,v 1.4 2002-06-05 08:01:31 tlan Exp $";
|
static char *rcsheader = "@(#) " PACKAGE " " VERSION " ljosa@initio.no $Header: /tmp/cvs/mysql-admutils/common.c,v 1.5 2004-11-16 20:58:54 lkarsten Exp $";
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -138,7 +138,7 @@ member(char *gr) {
|
||||||
p = getpwuid(getuid());
|
p = getpwuid(getuid());
|
||||||
if (!p) {
|
if (!p) {
|
||||||
fprintf(stderr, "Failed to look up your UNIX username.");
|
fprintf(stderr, "Failed to look up your UNIX username.");
|
||||||
exit(1);
|
return 0;
|
||||||
}
|
}
|
||||||
username = p->pw_name;
|
username = p->pw_name;
|
||||||
|
|
||||||
|
@ -149,42 +149,60 @@ member(char *gr) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
foo = strchr(group, '_');
|
// ettersom man kan få inn gruppenavn med underscore i, må man rett og
|
||||||
if (foo) {
|
// slett prøve seg fram for å sjekke om det er en gruppe personen er med
|
||||||
#if DEBUG
|
// i.
|
||||||
printf("gr = %s, group = %s, foo = %s\n", gr, group, foo);
|
// eksempel: www_esb_test_users, hvor personen ikke er med i www_est_test
|
||||||
#endif
|
// (som kanskje finnes), men er med i www_esb.
|
||||||
*foo = '\0';
|
// group er databasenavnet som brukeren ville ha. Vi må finne gruppenavnet
|
||||||
}
|
// ut av den, og stripper av en og en underscore til vi finner noe som
|
||||||
|
// passer.
|
||||||
/* Get group */
|
while ( 1 ) {
|
||||||
g = getgrnam(group);
|
|
||||||
if (g == NULL) {
|
|
||||||
fprintf(stderr, "No such group: %s\n", group);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if user is member of group */
|
|
||||||
while(*g->gr_mem != NULL) {
|
|
||||||
char * member = *g->gr_mem;
|
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
printf("Medlem: %s\n", *g->gr_mem);
|
// printf("gr = %s, group = %s, foo = %s\n", gr, group, foo);
|
||||||
|
#endif
|
||||||
|
g = getgrnam(group);
|
||||||
|
#if DEBUG
|
||||||
|
printf("tror gruppenavnet er: %s\n", group);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// hvis gruppen ikke finnes, må vi i allefall prøve å se om
|
||||||
|
// det er noe lengre inn.
|
||||||
|
if (g) {
|
||||||
|
/* Check if user is member of group */
|
||||||
|
while(*g->gr_mem != NULL) {
|
||||||
|
char * member = *g->gr_mem;
|
||||||
|
#if DEBUG
|
||||||
|
printf("Medlem: %s\n", *g->gr_mem);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (strcmp(member,username) == 0) {
|
if (strcmp(member,username) == 0) {
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
printf("You have access to '%s'\n", gr);
|
printf("You have access to '%s'\n", gr);
|
||||||
#endif
|
#endif
|
||||||
return 1; /* OK */
|
return 1; /* OK */
|
||||||
} else
|
} else
|
||||||
*g->gr_mem++;
|
*g->gr_mem++;
|
||||||
}
|
}
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
printf("You have no access to '%s'\n", gr);
|
printf("You have no access to '%s'\n", gr);
|
||||||
#endif
|
#endif
|
||||||
|
} // if
|
||||||
|
// brukeren var ikke med i gruppen, så vi må prøve neste.
|
||||||
|
|
||||||
return 0;
|
// finner den siste _-en i navnet.
|
||||||
|
foo = strrchr(group, '_');
|
||||||
|
if (foo == NULL) {
|
||||||
|
// hvis vi har kommet helt til bunn, og fremdeles
|
||||||
|
// ikke har blitt avbrutt, fantes det ingen slik gruppe.
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
// det som nå er bak siste underscore er passe uinteressant, så
|
||||||
|
// vi flytter slutten av strengen litt framover.
|
||||||
|
*foo = '\0';
|
||||||
|
|
||||||
|
} // while
|
||||||
}
|
}
|
||||||
|
|
||||||
/* return a list of the user's groupnames */
|
/* return a list of the user's groupnames */
|
||||||
|
|
Loading…
Reference in New Issue