⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 um.c

📁 RTEMS (Real-Time Executive for Multiprocessor Systems) is a free open source real-time operating sys
💻 C
📖 第 1 页 / 共 2 页
字号:
/* *	um.c -- User Management * *	Copyright (c) GoAhead Software Inc., 1995-2000. All Rights Reserved. * *	See the file "license.txt" for usage and redistribution license requirements * *	$Id: um.c,v 1.1 2000/09/01 10:57:21 joel Exp $ *//******************************** Description *********************************//* *	User Management routines for adding/deleting/changing users and groups *  Also, routines for determining user access *//********************************* Includes ***********************************/#include	"um.h"#include	"emfdb.h"#include	"webs.h"/********************************** Defines ***********************************/#define UM_DB_FILENAME	T("um.xml")#define UM_TXT_FILENAME	T("umconfig.txt")/* *	Table names */#define UM_USER_TABLENAME	T("users")#define UM_GROUP_TABLENAME	T("groups")#define UM_ACCESS_TABLENAME	T("access")/* *	Column names */#define UM_NAME			T("name")#define UM_PASS			T("password")#define UM_GROUP		T("group")#define UM_PROT			T("prot")#define UM_DISABLE		T("disable")#define UM_METHOD		T("method")#define UM_PRIVILEGE	T("priv")#define UM_SECURE		T("secure")/* *	XOR encryption mask *		Note:	This string should be modified for individual sites *				in order to enhance user password security. */#define UM_XOR_ENCRYPT	T("*j7a(L#yZ98sSd5HfSgGjMj8;Ss;d)(*&^#@$a2s0i3g")/******************************** Local Data **********************************/#ifdef UEMF/* *	User table definition */#define NUMBER_OF_USER_COLUMNS	5char_t	*userColumnNames[NUMBER_OF_USER_COLUMNS] = {			UM_NAME, UM_PASS, UM_GROUP, UM_PROT, UM_DISABLE};int		userColumnTypes[NUMBER_OF_USER_COLUMNS] = {			T_STRING, T_STRING, T_STRING, T_INT, T_INT};dbTable_t userTable = {	UM_USER_TABLENAME,	NUMBER_OF_USER_COLUMNS,	userColumnNames,	userColumnTypes,	0,	NULL};/* *	Group table definition */#define NUMBER_OF_GROUP_COLUMNS	5char_t	*groupColumnNames[NUMBER_OF_GROUP_COLUMNS] = {			UM_NAME, UM_PRIVILEGE, UM_METHOD, UM_PROT, UM_DISABLE};int		groupColumnTypes[NUMBER_OF_GROUP_COLUMNS] = {			T_STRING, T_INT, T_INT, T_INT, T_INT};dbTable_t groupTable = {	UM_GROUP_TABLENAME,	NUMBER_OF_GROUP_COLUMNS,	groupColumnNames,	groupColumnTypes,	0,	NULL};/* *	Access Limit table definition */#define NUMBER_OF_ACCESS_COLUMNS	4char_t	*accessColumnNames[NUMBER_OF_ACCESS_COLUMNS] = {			UM_NAME, UM_METHOD, UM_SECURE, UM_GROUP};int		accessColumnTypes[NUMBER_OF_ACCESS_COLUMNS] = {			T_STRING, T_INT, T_INT, T_STRING};dbTable_t accessTable = {	UM_ACCESS_TABLENAME,	NUMBER_OF_ACCESS_COLUMNS,	accessColumnNames,	accessColumnTypes,	0,	NULL};#endif	/* #ifdef UEMF *//*  *	Database Identifier returned from dbOpen() */static int		didUM = -1;	/*  *	Configuration database persist filename */static char_t	*saveFilename = NULL;static int		umOpenCount = 0;		/* count of apps using this module *//*************************** Forward Declarations *****************************/static bool_t umCheckName(char_t *name);/*********************************** Code *************************************//* *	umOpen() registers the UM tables in the fake emf-database  */int umOpen(){	if (++umOpenCount != 1) {		return didUM;	}/* *	Do not initialize if intialization has already taken place */	if (didUM == -1) {		didUM = dbOpen(UM_USER_TABLENAME, UM_DB_FILENAME, NULL, 0);#ifdef UEMF		dbRegisterDBSchema(&userTable);		dbRegisterDBSchema(&groupTable);		dbRegisterDBSchema(&accessTable);#endif	}	if (saveFilename == NULL) {		saveFilename = bstrdup(B_L, UM_TXT_FILENAME);	}	return didUM;}/******************************************************************************//* *	umClose() frees up the UM tables in the fake emf-database  */void umClose(){	if (--umOpenCount > 0) {		return;	}/* *	Do not close if intialization has not taken place */	if (didUM != -1) {		dbClose(didUM);		didUM = -1;	}	if (saveFilename != NULL) {		bfree(B_L, saveFilename);		saveFilename = NULL;	}}/******************************************************************************//* *	umCommit() persists all of the UM tables */int	umCommit(char_t *filename){	if (filename && *filename) {		if (saveFilename != NULL) {			bfree(B_L, saveFilename);		}		saveFilename = bstrdup(B_L, filename);	}	a_assert (saveFilename && *saveFilename);	trace(3, T("UM: Writing User Configuration to file <%s>\n"), 		saveFilename);	return dbSave(didUM, saveFilename, 0);}/******************************************************************************//* *	umRestore() loads up the UM tables with persisted data */int umRestore(char_t *filename){	if (filename && *filename) {		if (saveFilename != NULL) {			bfree(B_L, saveFilename);		}		saveFilename = bstrdup(B_L, filename);	}	a_assert(saveFilename && *saveFilename);	trace(3, T("UM: Loading User Configuration from file <%s>\n"), 		saveFilename);/* *	First empty the database, otherwise we wind up with duplicates! */	dbZero(didUM);	return dbLoad(didUM, saveFilename, 0);}/******************************************************************************//* *	Encrypt/Decrypt a text string.   *		Returns the number of characters encrypted. */static int umEncryptString(char_t *textString){	char_t	*enMask;	char_t	enChar;	int		numChars;	a_assert(textString);	enMask = UM_XOR_ENCRYPT;	numChars = 0;	while (*textString) {		enChar = *textString ^ *enMask;/* *		Do not produce encrypted text with embedded linefeeds or tabs. *			Simply use existing character. */		if (enChar && !gisspace(enChar)) 			*textString = enChar;/* *		Increment all pointers. */		enMask++;		textString++;		numChars++;/* *		Wrap encryption mask pointer if at end of length. */		if (*enMask == '\0') {			enMask = UM_XOR_ENCRYPT;		}	}	return numChars;}/******************************************************************************//* *	umGetFirstRowData() -	return a pointer to the first non-blank key value *							in the given column for the given table. */static char_t *umGetFirstRowData(char_t *tableName, char_t *columnName){	char_t	*columnData;	int		row;	int		check;	a_assert(tableName && *tableName);	a_assert(columnName && *columnName);	row = 0;/* *	Move through table until we retrieve the first row with non-null  *	column data. */	columnData = NULL;	while ((check = dbReadStr(didUM, tableName, columnName, row++, 		&columnData)) == 0 || (check == DB_ERR_ROW_DELETED)) {		if (columnData && *columnData) {			return columnData;		}	}	return NULL;}/******************************************************************************//* *	umGetNextRowData() -	return a pointer to the first non-blank  *						key value following the given one. */static char_t *umGetNextRowData(char_t *tableName, char_t *columnName, 								char_t *keyLast){	char_t	*key;	int		row;	int		check;	a_assert(tableName && *tableName);	a_assert(columnName && *columnName);	a_assert(keyLast && *keyLast);/* *	Position row counter to row where the given key value was found */	row = 0;	key = NULL;	while ((((check = dbReadStr(didUM, tableName, columnName, row++, 		&key)) == 0) || (check == DB_ERR_ROW_DELETED)) &&		((key == NULL) || (gstrcmp(key, keyLast) != 0))) {	}/* *	If the last key value was not found, return NULL */	if (!key || gstrcmp(key, keyLast) != 0) {		return NULL;	}/* *	Move through table until we retrieve the next row with a non-null key */	while (((check = dbReadStr(didUM, tableName, columnName, row++, &key)) 		== 0) || (check == DB_ERR_ROW_DELETED)) {		if (key && *key && (gstrcmp(key, keyLast) != 0)) {			return key;		}	}	return NULL;}/******************************************************************************//* *	umAddUser() - Adds a user to the "users" table. */int	umAddUser(char_t *user, char_t *pass, char_t *group, 			  bool_t prot, bool_t disabled){	int		row;	char_t	*password;	a_assert(user && *user);	a_assert(pass && *pass);	a_assert(group && *group);	trace(3, T("UM: Adding User <%s>\n"), user);/* *	Do not allow duplicates */	if (umUserExists(user)) {		return UM_ERR_DUPLICATE;	}/* *	Make sure user name and password contain valid characters */	if (!umCheckName(user)) {		return UM_ERR_BAD_NAME;	}	if (!umCheckName(pass)) {		return UM_ERR_BAD_PASSWORD;	}/* *	Make sure group exists */	if (!umGroupExists(group)) {		return UM_ERR_NOT_FOUND;	}/* *	Now create the user record */	row = dbAddRow(didUM, UM_USER_TABLENAME);	if (row < 0) {		return UM_ERR_GENERAL;	}	if (dbWriteStr(didUM, UM_USER_TABLENAME, UM_NAME, row, user) != 0) {		return UM_ERR_GENERAL;	}	password = bstrdup(B_L, pass);	umEncryptString(password);	dbWriteStr(didUM, UM_USER_TABLENAME, UM_PASS, row, password);	bfree(B_L, password);	dbWriteStr(didUM, UM_USER_TABLENAME, UM_GROUP, row, group);	dbWriteInt(didUM, UM_USER_TABLENAME, UM_PROT, row, prot); 	dbWriteInt(didUM, UM_USER_TABLENAME, UM_DISABLE, row, disabled);	return 0;}/******************************************************************************//* *	umDeleteUser() - remove a user from the "users" table */int	umDeleteUser(char_t *user){	int row;	a_assert(user && *user);	trace(3, T("UM: Deleting User <%s>\n"), user);/* *	Check to see if user is delete-protected */	if (umGetUserProtected(user)) {		return UM_ERR_PROTECTED;	} /* *	If found, delete the user from the database */	if ((row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0)) >= 0) {		return dbDeleteRow(didUM, UM_USER_TABLENAME, row);	} 	return UM_ERR_NOT_FOUND;}/******************************************************************************//* *	umGetFirstUser() -	Returns the user ID of the first user found in the *						"users" table. */char_t *umGetFirstUser(){	return umGetFirstRowData(UM_USER_TABLENAME, UM_NAME);}/******************************************************************************//* *	umGetNextUser()	Returns the next user found in the "users" table after *					the given user. 	 */char_t *umGetNextUser(char_t *userLast){	return umGetNextRowData(UM_USER_TABLENAME, UM_NAME, userLast);}/******************************************************************************//* *	umUserExists()	Returns TRUE if userid exists. */bool_t umUserExists(char_t *user){	a_assert(user && *user);	if (dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0) >= 0) {		return TRUE;	} else {		return FALSE;	}}/******************************************************************************//* *	umGetUserPassword() returns a de-crypted copy of the user password */char_t *umGetUserPassword(char_t *user){	char_t	*password;	int		row;	a_assert(user && *user);	password = NULL;	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	if (row >= 0) {		char_t *pass = NULL;		dbReadStr(didUM, UM_USER_TABLENAME, UM_PASS, row, &pass);/* *		Decrypt	password *		Note, this function returns a copy of the password, which must *		be deleted at some time in the future. */		password = bstrdup(B_L, pass);		umEncryptString(password);	}	return password;}/******************************************************************************//* *	umSetUserPassword() updates the user password in the user "table" after *						encrypting the given password */int	umSetUserPassword(char_t *user, char_t *pass){	int		row, nRet;	char_t	*password;	a_assert(user && *user);	a_assert(pass && *pass);	trace(3, T("UM: Attempting to change the password for user <%s>\n"), user);/* *	Find the row of the user */	if ((row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0)) < 0) {		return UM_ERR_NOT_FOUND;	}	password = bstrdup(B_L, pass);	umEncryptString(password);	nRet = dbWriteStr(didUM, UM_USER_TABLENAME, UM_PASS, row, password);	bfree(B_L, password);	return nRet;}/******************************************************************************//* *	umGetUserGroup() returns the name of the user group */char_t *umGetUserGroup(char_t *user){	char_t	*group;	int		row;	a_assert(user && *user);	group = NULL;/* *	Find the row of the user */	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	if (row >= 0) {		dbReadStr(didUM, UM_USER_TABLENAME, UM_GROUP, row, &group);	}	return group;}/******************************************************************************//* *	umSetUserGroup() Sets the name of the user group for the user */int	umSetUserGroup(char_t *user, char_t *group){	int row;	a_assert(user && *user);	a_assert(group && *group);/* *	Find the row of the user */	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	if (row >= 0) {		return dbWriteStr(didUM, UM_USER_TABLENAME, UM_GROUP, row, group);	} else {		return UM_ERR_NOT_FOUND;	}}/******************************************************************************//* *	umGetUserEnabled() - returns if the user is enabled *	Returns FALSE if the user is not found. */bool_t	umGetUserEnabled(char_t *user){	int disabled, row;	a_assert(user && *user);	disabled = 1;/* *	Find the row of the user */	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	if (row >= 0) {		dbReadInt(didUM, UM_USER_TABLENAME, UM_DISABLE, row, &disabled);	}	return (bool_t)!disabled;}/******************************************************************************//* *	umSetUserEnabled() Enables/disables the user */int	umSetUserEnabled(char_t *user, bool_t enabled){	int row;	a_assert(user && *user);/* *	Find the row of the user */	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	if (row >= 0) {		return dbWriteInt(didUM, UM_USER_TABLENAME, UM_DISABLE, row, !enabled);	} else {		return UM_ERR_NOT_FOUND;	}}/******************************************************************************//* *	umGetUserProtected() - determine deletability of user */bool_t umGetUserProtected(char_t *user){	int protect, row;	a_assert(user && *user);/* *	Find the row of the user */	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	protect = FALSE;	if (row >= 0) {		dbReadInt(didUM, UM_USER_TABLENAME, UM_PROT, row, &protect);	}	return (bool_t)protect;}/******************************************************************************//* *	umSetUserProtected() sets the delete protection for the user */int	umSetUserProtected(char_t *user, bool_t protect){	int row;	a_assert(user && *user);/* *	Find the row of the user */	row = dbSearchStr(didUM, UM_USER_TABLENAME, UM_NAME, user, 0);	if (row >= 0) {		return dbWriteInt(didUM, UM_USER_TABLENAME, UM_PROT, row, protect);	} else {		return UM_ERR_NOT_FOUND;	}}/******************************************************************************//* *	umAddGroup() adds a group to the "Group" table */int	umAddGroup(char_t *group, short priv, accessMeth_t am, 			   bool_t prot, bool_t disabled){	int row;	a_assert(group && *group);	trace(3, T("UM: Adding group <%s>\n"), group);	/* *	Do not allow duplicates */	if (umGroupExists(group)) {		return UM_ERR_DUPLICATE;	}/*

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -