/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2003 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
/*
* Portions of this source code were derived from Berkeley 4.3 BSD
* under license from the Regents of the University of California.
*/
#pragma ident "%Z%%M% %I% %E% SMI"
#ifndef lint
static char sccsid[] = "@(#)ypserv_ancil.c 1.13 88/02/08 Copyr 1984 Sun Micro";
#endif
#include <dirent.h>
#include <syslog.h>
#include "ypsym.h"
#include "ypdefs.h"
USE_YPDBPATH
USE_DBM
#include "shim_hooks.h"
#include "shim.h"
#include "yptol.h"
extern unsigned int strlen();
extern int strcmp();
extern int isvar_sysv();
extern char *strncpy();
extern int yp_getkey();
/*
* This generates a list of the maps in a domain.
*/
int
yplist_maps(domain, list)
char *domain;
struct ypmaplist **list;
{
DIR *dirp;
struct dirent *dp;
char domdir[MAXNAMLEN + 1];
char path[MAXNAMLEN + 1];
char map_key[YPMAXMAP + 1];
int error;
char *ext;
struct ypmaplist *map;
int namesz;
char *mapname;
*list = (struct ypmaplist *)NULL;
if (!ypcheck_domain(domain)) {
return (YP_NODOM);
}
(void) strcpy(domdir, ypdbpath);
(void) strcat(domdir, "/");
(void) strcat(domdir, domain);
if ((dirp = opendir(domdir)) == NULL) {
return (YP_YPERR);
}
error = YP_TRUE;
for (dp = readdir(dirp); error == YP_TRUE && dp != NULL;
dp = readdir(dirp)) {
/*
* If it's possible that the file name is one of the two files
* implementing a map, remove the extension (dbm_pag or dbm_dir)
*/
namesz = (int)strlen(dp->d_name);
if (namesz < sizeof (dbm_pag) - 1)
continue; /* Too Short */
ext = &(dp->d_name[namesz - (sizeof (dbm_pag) - 1)]);
if (strcmp(ext, dbm_pag) != 0)
continue; /* No dbm file extension */
*ext = '\0';
/*
* In yptol mode look at LDAP_ prefixed maps. In non yptol mode
* ignore them.
*/
if (yptol_mode) {
if (0 != strncmp(dp->d_name, NTOL_PREFIX,
strlen(NTOL_PREFIX)))
continue;
/*
* Already have an LDAP_ prefix. Don't want to add it
* twice.
*/
mapname = dp->d_name + strlen(NTOL_PREFIX);
} else {
if (0 == strncmp(dp->d_name, NTOL_PREFIX,
strlen(NTOL_PREFIX)))
continue;
mapname = dp->d_name;
}
ypmkfilename(domain, mapname, path);
/*
* At this point, path holds the map file base name (no dbm
* file extension), and mapname holds the map name.
*/
if (ypcheck_map_existence(path) &&
!onmaplist(mapname, *list)) {
if ((map = (struct ypmaplist *)malloc(
sizeof (struct ypmaplist))) == NULL) {
error = YP_YPERR;
break;
}
map->ypml_next = *list;
*list = map;
namesz = (int)strlen(mapname);
if (namesz <= YPMAXMAP) {
if (yp_getkey(mapname, map_key,
MAXALIASLEN) < 0) {
fprintf(stderr,
"yplist_maps: getkey failed for %s\n",
mapname);
error = YP_YPERR;
break;
} else
(void) strcpy(map->ypml_name, map_key);
} else {
if (yp_getkey(mapname, map_key,
MAXALIASLEN) < 0) {
fprintf(stderr,
"yplist_maps: getkey failed for %s\n",
mapname);
error = YP_YPERR;
break;
} else if (strcmp(mapname, map_key) == 0) {
(void) strncpy(map->ypml_name,
mapname,
(unsigned int) namesz);
map->ypml_name[YPMAXMAP] = '\0';
} else {
(void) strcpy(map->ypml_name, map_key);
}
}
}
}
closedir(dirp);
return (error);
}