/*
* 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
* 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.
*/
#pragma ident "%Z%%M% %I% %E% SMI"
#include <stdio.h>
#include <ctype.h>
#include <project.h>
#include <unistd.h>
#include <userdefs.h>
#include <errno.h>
#include <nss_dbdefs.h>
#include "users.h"
#include "messages.h"
int
{
char **memptr;
int i, modified = 0;
int p_length;
long p_curr = 0;
int exist;
int fd;
return (EX_UPDATE);
}
return (EX_UPDATE);
return (EX_UPDATE);
}
return (EX_UPDATE);
}
/*
* Get ownership and permissions correct
*/
return (EX_UPDATE);
}
/* Make TMP file look like we want project file to look */
/* While there is another group string */
sizeof (workbuf));
/*
* tried to parse a proj string over
* NSS_LINELEN_PROJECT chars
*/
modified = 0; /* bad project file: cannot rebuild */
break;
}
/* first delete the login from the project, if it's there */
memptr++) {
/* Delete this one */
do {
} while (*from++);
modified++;
break;
}
}
}
}
/* now check to see if project is one to add to */
if (projids) {
for (i = 0; projids[i] != -1; i++) {
/* Scan for dups */
exist = 0;
memptr++) {
exist++;
}
if (p_length >=
NSS_LINELEN_PROJECT - 1) {
break;
} else {
if (!exist) {
modified++;
}
}
}
}
}
}
/* Now, update project file, if it was modified */
return (EX_UPDATE);
}
return (EX_SUCCESS);
}