亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 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 + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频一区在线| 亚洲国产精品天堂| 欧美日韩一区成人| 国产在线国偷精品免费看| 亚洲欧美日韩国产综合在线| 精品国产髙清在线看国产毛片| 一本色道久久综合精品竹菊| 国产一区二区网址| 日韩精品乱码免费| 亚洲另类在线一区| 久久精品水蜜桃av综合天堂| 欧美日韩一卡二卡三卡| 99视频热这里只有精品免费| 国模大尺度一区二区三区| 午夜精品影院在线观看| 18成人在线视频| 精品国产sm最大网站| 欧美日韩综合在线免费观看| 99re热这里只有精品视频| 国产精一区二区三区| 日韩精品欧美精品| 性久久久久久久| 樱花影视一区二区| 亚洲欧洲性图库| 国产精品女上位| 久久这里只有精品视频网| 日韩一区和二区| 欧美剧情电影在线观看完整版免费励志电影| 欧美日韩国产另类不卡| 99国产欧美另类久久久精品| 国产不卡视频一区| 国产综合一区二区| 激情综合网最新| 久久精品国产一区二区三 | 国产99久久久久| 国产综合久久久久久久久久久久| 丝袜美腿亚洲综合| 日本伊人精品一区二区三区观看方式 | 韩国视频一区二区| 美女爽到高潮91| 日韩不卡在线观看日韩不卡视频| 亚洲一区二区三区精品在线| 亚洲制服丝袜av| 午夜视频在线观看一区二区| 午夜视黄欧洲亚洲| 青青草国产精品97视觉盛宴| 日本美女视频一区二区| 久久精品国产网站| 狠狠色丁香久久婷婷综| 国产一区二区三区电影在线观看| 国产乱色国产精品免费视频| 国产成人啪免费观看软件| 成人在线综合网| 91丨九色丨黑人外教| 色中色一区二区| 欧美日本一道本在线视频| 欧美一区二区视频网站| 精品乱码亚洲一区二区不卡| 久久久九九九九| 亚洲天堂精品视频| 亚洲综合久久久| 色爱区综合激月婷婷| 在线观看国产精品网站| 欧美欧美午夜aⅴ在线观看| 日韩欧美在线观看一区二区三区| www国产成人| 成人免费在线播放视频| 五月综合激情网| 国产一区在线看| a级高清视频欧美日韩| 欧美三级韩国三级日本一级| 日韩美女视频在线| 国产欧美日本一区二区三区| 亚洲欧美日韩久久精品| 午夜视频在线观看一区二区三区| 免费观看日韩电影| 懂色av一区二区在线播放| 91在线观看下载| 69堂亚洲精品首页| 欧美极品aⅴ影院| 亚洲制服欧美中文字幕中文字幕| 久久精品国产亚洲a| 97精品电影院| 欧美一区二区三区白人| 国产欧美精品国产国产专区| 午夜免费久久看| 国产99精品在线观看| 欧美日韩免费一区二区三区| 国产亚洲一二三区| 亚洲不卡在线观看| 成人精品小蝌蚪| 欧美一级久久久| 亚洲色图制服诱惑| 美女视频第一区二区三区免费观看网站| 成人午夜碰碰视频| 日韩一区二区三区视频在线观看| 国产精品美女视频| 裸体一区二区三区| 日本电影欧美片| 国产欧美一区视频| 日韩精品免费视频人成| 色诱视频网站一区| 亚洲国产精品99久久久久久久久| 日韩精品欧美成人高清一区二区| 99精品视频中文字幕| 久久久久久久久久久久电影| 五月婷婷色综合| 91影视在线播放| 欧美激情一区二区三区蜜桃视频| 免费精品视频在线| 欧美日韩午夜在线| 亚洲天堂成人在线观看| 国产99久久精品| www成人在线观看| 免费成人在线视频观看| 欧美午夜电影在线播放| 国产精品二区一区二区aⅴ污介绍| 极品少妇xxxx精品少妇偷拍| 69堂亚洲精品首页| 亚洲成a天堂v人片| 91激情五月电影| 亚洲视频你懂的| 亚洲精品在线免费播放| 午夜精品国产更新| 91精品办公室少妇高潮对白| 国产精品国产a| 国产99一区视频免费| 国产欧美精品一区aⅴ影院| 国内精品写真在线观看| 精品国产网站在线观看| 另类调教123区| 精品美女被调教视频大全网站| 美日韩黄色大片| 欧美v亚洲v综合ⅴ国产v| 看片网站欧美日韩| 精品免费视频一区二区| 国产在线一区二区| 久久亚洲精精品中文字幕早川悠里| 三级成人在线视频| 91精品国产一区二区| 蜜桃久久久久久| 欧美成人一级视频| 国产精品99久久久| 国产亚洲成aⅴ人片在线观看| 国产伦精品一区二区三区免费 | 久久精品国产亚洲5555| 日韩一级免费一区| 韩国一区二区三区| 欧美国产精品专区| 成人激情免费网站| 亚洲视频小说图片| 欧美色精品在线视频| 午夜电影网一区| 日韩久久久久久| 风间由美一区二区av101| 国产乱码精品一品二品| 欧美极品另类videosde| 色综合天天做天天爱| 亚洲日本中文字幕区| 91亚洲精品乱码久久久久久蜜桃 | 国产精品久久久久天堂| 97久久精品人人澡人人爽| 夜夜亚洲天天久久| 91精品国产乱| 国产69精品久久99不卡| 亚洲精品乱码久久久久久黑人| 欧美在线视频全部完| 蜜臀av一级做a爰片久久| 久久精品一区二区| 一本高清dvd不卡在线观看 | 狠狠色丁香婷婷综合| 中文字幕亚洲一区二区va在线| 欧美午夜精品电影| 国产一区二区在线影院| 中文字幕综合网| 3d动漫精品啪啪| 国产电影精品久久禁18| 一区二区三区日韩| 精品国精品国产| 91伊人久久大香线蕉| 美女视频免费一区| 自拍偷拍欧美精品| 日韩情涩欧美日韩视频| 97久久精品人人爽人人爽蜜臀| 天堂久久一区二区三区| 欧美极品少妇xxxxⅹ高跟鞋| 欧美日韩一区精品| 成人免费高清视频在线观看| 亚洲123区在线观看| 欧美国产日本韩| 欧美一区二区三区在| 97精品国产97久久久久久久久久久久| 奇米精品一区二区三区在线观看| 亚洲国产成人午夜在线一区| 欧美精品精品一区| 99精品偷自拍| 国产一区二区精品久久99| 午夜精品久久久久久久蜜桃app| 中文字幕免费一区| 欧美成人一区二区三区片免费|