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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? um.c

?? 嵌入式vxwork web server
?? C
?? 第 1 頁 / 共 3 頁
字號:
	a_assert(group && *group);
	row = dbSearchStr(didUM, UM_GROUP_TABLENAME, UM_NAME, group, 0);

	if (row >= 0) {
		return dbWriteInt(didUM, UM_GROUP_TABLENAME, UM_DISABLE, row, 
			(int) !enabled);
	} else {
		return UM_ERR_NOT_FOUND;
	}
}

/******************************************************************************/
/*
 *	Returns the protected setting for a given group
 *  Returns FALSE if user is not found
 */

bool_t umGetGroupProtected(char_t *group)
{
	int protect, row;

	a_assert(group && *group);

	protect = 0;
	row = dbSearchStr(didUM, UM_GROUP_TABLENAME, UM_NAME, group, 0);
	if (row >= 0) {
		dbReadInt(didUM, UM_GROUP_TABLENAME, UM_PROT, row, &protect);
	}

	return (bool_t) protect;
}

/******************************************************************************/
/*
 *	Sets the protected setting for a given group
 */

int	umSetGroupProtected(char_t *group, bool_t protect)
{
	int row;

	a_assert(group && *group);
	row = dbSearchStr(didUM, UM_GROUP_TABLENAME, UM_NAME, group, 0);

	if (row >= 0) {
		return dbWriteInt(didUM, UM_GROUP_TABLENAME, UM_PROT, row, 
			(int) protect);
	} else {
		return UM_ERR_NOT_FOUND;
	}
}


/******************************************************************************/
/*
 *	umAddAccessLimit() adds an access limit to the "access" table
 */

int	umAddAccessLimit(char_t *url, accessMeth_t am, short secure, char_t *group)
{
	int row;

	a_assert(url && *url);
	trace(3, T("UM: Adding Access Limit for <%s>\n"), url);

/*
 *	Do not allow duplicates
 */
	if (umAccessLimitExists(url)) {
		return UM_ERR_DUPLICATE;
	}

/*
 *	Add a new row to the table
 */
	if ((row = dbAddRow(didUM, UM_ACCESS_TABLENAME)) < 0) {
		return UM_ERR_GENERAL;
	}

/*
 *	Write the key field
 */
	if(dbWriteStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, row, url) < 0) {
		return UM_ERR_GENERAL;
	}

/*
 *	Write the remaining fields
 */
	dbWriteInt(didUM, UM_ACCESS_TABLENAME, UM_METHOD, row, (int)am);
	dbWriteInt(didUM, UM_ACCESS_TABLENAME, UM_SECURE, row, (int)secure);
	dbWriteStr(didUM, UM_ACCESS_TABLENAME, UM_GROUP, row, group);

	return 0;
}

/******************************************************************************/
/*
 *	umDeleteAccessLimit()
 */

int	umDeleteAccessLimit(char_t *url)
{
	int row;

	a_assert(url && *url);
	trace(3, T("UM: Deleting Access Limit for <%s>\n"), url);
/*
 *	Find the row of the access limit to delete
 */
	if ((row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0)) < 0) {
		return UM_ERR_NOT_FOUND;
	}

	return dbDeleteRow(didUM, UM_ACCESS_TABLENAME, row);
}

/******************************************************************************/
/*
 *	umGetFirstGroup() - return a pointer to the first non-blank access limit
 */

char_t *umGetFirstAccessLimit()
{
	return umGetFirstRowData(UM_ACCESS_TABLENAME, UM_NAME);
}

/******************************************************************************/
/*
 *	umGetNextAccessLimit() -	return a pointer to the first non-blank 
 *								access limit following the given one
 */

char_t *umGetNextAccessLimit(char_t *urlLast)
{
	return umGetNextRowData(UM_ACCESS_TABLENAME, UM_NAME, urlLast);
}

/******************************************************************************/
/*
 *	umAccessLimitExists() returns TRUE if this access limit exists
 */

bool_t	umAccessLimitExists(char_t *url)
{
	a_assert(url && *url);

	if (dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0) < 0) {
		return FALSE;
	} else {
		return TRUE;
	}
}

/******************************************************************************/
/*
 *	umGetAccessLimit() returns the Access Method for the URL
 */

accessMeth_t umGetAccessLimitMethod(char_t *url)
{
	int am, row;

	am = (int) AM_INVALID;
	row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0);

	if (row >= 0) {
		dbReadInt(didUM, UM_ACCESS_TABLENAME, UM_METHOD, row, &am);
	} 

	return (accessMeth_t) am;
}

/******************************************************************************/
/*
 *	umSetAccessLimitMethod() - set Access Method for Access Limit
 */

int	umSetAccessLimitMethod(char_t *url, accessMeth_t am)
{
	int row;

	a_assert(url && *url);
	row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0);

	if (row >= 0) {
		return dbWriteInt(didUM, UM_ACCESS_TABLENAME, UM_METHOD, row, (int) am);
	} else {
		return UM_ERR_NOT_FOUND;
	}
}

/******************************************************************************/
/*
 *	umGetAccessLimitSecure() - returns secure switch for access limit
 */

short umGetAccessLimitSecure(char_t *url)
{
	int secure, row;

	a_assert(url && *url);
	secure = -1;
	row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0);

	if (row >= 0) {
		dbReadInt(didUM, UM_ACCESS_TABLENAME, UM_SECURE, row, &secure);
	}

	return (short)secure;
}

/******************************************************************************/
/*
 *	umSetAccessLimitSecure() - sets the secure flag for the URL
 */

int	umSetAccessLimitSecure(char_t *url, short secure)
{
	int row;

	a_assert(url && *url);
	row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0);

	if (row >= 0) {
		return dbWriteInt(didUM, UM_ACCESS_TABLENAME, UM_SECURE, row, 
			(int)secure);
	} else {
		return UM_ERR_NOT_FOUND;
	}
}

/******************************************************************************/
/*
 *	umGetAccessLimitGroup() - returns the user group of the access limit
 */

char_t *umGetAccessLimitGroup(char_t *url)
{
	char_t	*group;
	int		row;

	a_assert(url && *url);
	group = NULL;
	row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0);

	if (row >= 0) {
		dbReadStr(didUM, UM_ACCESS_TABLENAME, UM_GROUP, row, &group);
	}

	return group;
}

/******************************************************************************/
/*
 *	umSetAccessLimitGroup() - sets the user group for the access limit.
 */

int	umSetAccessLimitGroup(char_t *url, char_t *group)
{
	int row;

	a_assert(url && *url);
	row = dbSearchStr(didUM, UM_ACCESS_TABLENAME, UM_NAME, url, 0);

	if (row >= 0) {
		return dbWriteStr(didUM, UM_ACCESS_TABLENAME, UM_GROUP, row, group);
	} else {
		return UM_ERR_NOT_FOUND;
	}
}

/******************************************************************************/
/*
 *	Returns the access limit to use for a given URL, by checking for URLs up
 *	the directory tree.  Creates a new string that must be deleted.
 */

char_t *umGetAccessLimit(char_t *url)
{
	char_t	*urlRet, *urlCheck, *lastChar;
	int		len;
	
	a_assert(url && *url);
	urlRet = NULL;
	urlCheck = bstrdup(B_L, url);
	a_assert(urlCheck);
	len = gstrlen(urlCheck);
/*
 *	Scan back through URL to see if there is a "parent" access limit
 */
	while (len && !urlRet) {
		if (umAccessLimitExists(urlCheck)) {
			urlRet = bstrdup(B_L, urlCheck);
		} else {
/*
 *	Trim the end portion of the URL to the previous directory marker
 */
			lastChar = urlCheck + len;
			lastChar--;

			while ((lastChar >= urlCheck) && ((*lastChar == '/') || 
				(*lastChar == '\\'))) {
				*lastChar = 0;
				lastChar--;
			}

			while ((lastChar >= urlCheck) && (*lastChar != '/') && 
				(*lastChar != '\\')) {
				*lastChar = 0;
				lastChar--;
			}

			len = gstrlen(urlCheck);
		}
	}
	bfree (B_L, urlCheck);

	return urlRet;
}

/******************************************************************************/
/*
 *	Returns the access method to use for a given URL
 */

accessMeth_t umGetAccessMethodForURL(char_t *url)
{
	accessMeth_t	amRet;
	char_t			*urlHavingLimit, *group;
	
	urlHavingLimit = umGetAccessLimit(url);
	if (urlHavingLimit) {
		group = umGetAccessLimitGroup(urlHavingLimit);

		if (group && *group) {
			amRet = umGetGroupAccessMethod(group);
		} else {
			amRet = umGetAccessLimitMethod(urlHavingLimit);
		}

		bfree(B_L, urlHavingLimit);
	} else {
		amRet = AM_FULL;
	}

	return amRet;
}

/******************************************************************************/
/*
 *	Returns TRUE if user can access URL
 */

bool_t umUserCanAccessURL(char_t *user, char_t *url)
{
	accessMeth_t	amURL;
	char_t			*group, *usergroup, *urlHavingLimit;
	short			priv;
	
	a_assert(user && *user);
	a_assert(url && *url);

/*
 *	Make sure user exists
 */
	if (!umUserExists(user)) {
		return FALSE;
	}

/*
 *	Make sure user is enabled
 */
	if (!umGetUserEnabled(user)) {
		return FALSE;
	}

/*
 *	Make sure user has sufficient privileges (any will do)
 */
	usergroup = umGetUserGroup(user);
	priv = umGetGroupPrivilege(usergroup);
	if (priv == 0) {
		return FALSE;
	}

/*
 *	Make sure user's group is enabled
 */
	if (!umGetGroupEnabled(usergroup)) {
		return FALSE;
	}

/*
 *	The access method of the user group must not be AM_NONE
 */
	if (umGetGroupAccessMethod(usergroup) == AM_NONE) {
		return FALSE;
	}

/*
 *	Check to see if there is an Access Limit for this URL
 */
	urlHavingLimit = umGetAccessLimit(url);
	if (urlHavingLimit) {
		amURL = umGetAccessLimitMethod(urlHavingLimit);
		group = umGetAccessLimitGroup(urlHavingLimit);
		bfree(B_L, urlHavingLimit);
	} else {
/*
 *		If there isn't an access limit for the URL, user has full access
 */
		return TRUE;
	}

/*
 *	If the access method for the URL is AM_NONE then 
 *	the file "doesn't exist".
 */
	if (amURL == AM_NONE) {
		return FALSE;
	} 
	
/*
 *	If Access Limit has a group specified, then the user must be a 
 *	member of that group
 */
	if (group && *group) {
#ifdef qHierarchicalAccess
      /*
       * If we are compiling with the hierarchical access extensions, we
       * instead call the user-provided function that checks to see whether
       * the current user's access level is greater than or equal to the
       * access level required for this URL.
       */
      return dmfCanAccess(usergroup, group);

#else
		if (usergroup && (gstrcmp(group, usergroup) != 0)) {
			return FALSE;

		}
#endif
	} 

/*
 *	Otherwise, user can access the URL 
 */
	return TRUE;

}

/******************************************************************************/
/*
 *	Returns TRUE if given name has only valid chars
 */

static bool_t umCheckName(char_t *name)
{
	a_assert(name && *name);

	if (name && *name) {
		while (*name) {
			if (gisspace(*name)) {
				return FALSE;
			}

			name++;
		}

		return TRUE;
	}

	return FALSE;
}

/******************************************************************************/

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu久久天堂性欧美| 一区二区三区免费| 亚洲视频在线一区| 亚洲高清三级视频| 国产精品99精品久久免费| 色综合久久久久| 日韩一级成人av| 中文字幕在线不卡视频| 日韩高清在线观看| 色综合色综合色综合色综合色综合| 91精品国产一区二区| 国产精品国产三级国产普通话三级| 石原莉奈一区二区三区在线观看| 高清日韩电视剧大全免费| 欧美日韩色综合| 国产精品免费av| 美女视频一区在线观看| 91首页免费视频| 久久久www免费人成精品| 亚洲aⅴ怡春院| 97精品电影院| 国产夜色精品一区二区av| 五月婷婷久久丁香| 99r精品视频| 久久精品人人做人人爽人人| 日本欧美久久久久免费播放网| 91伊人久久大香线蕉| 2023国产精华国产精品| 亚洲电影一区二区| 91在线视频观看| 欧美—级在线免费片| 国产麻豆精品视频| 精品国产伦理网| 免费观看一级欧美片| 欧美三级午夜理伦三级中视频| 中文字幕制服丝袜成人av| 国产精品综合视频| 久久久久国产精品人| 精品一区二区在线观看| 日韩精品一区二区三区视频播放| 午夜电影网亚洲视频| 欧美视频自拍偷拍| 亚洲午夜影视影院在线观看| 91麻豆成人久久精品二区三区| 中文字幕国产一区| 成人免费毛片aaaaa**| 国产三级精品视频| 韩国av一区二区三区在线观看| 日韩欧美区一区二| 免费成人av资源网| 日韩精品中文字幕一区| 紧缚捆绑精品一区二区| 精品区一区二区| 激情六月婷婷久久| 久久精品视频一区二区| 成熟亚洲日本毛茸茸凸凹| 欧美激情中文不卡| thepron国产精品| 亚洲欧美日韩国产另类专区| 91丨九色丨黑人外教| 一区二区三区四区蜜桃| 欧美日韩精品三区| 裸体一区二区三区| 国产日韩欧美综合在线| 成人av影视在线观看| 亚洲欧洲av另类| 在线视频欧美精品| 视频在线观看一区| 欧美一区二区啪啪| 国产一区二区三区免费看| 日韩三级中文字幕| 精品一区二区三区免费| 欧美精品一区二区三区在线| 国产不卡在线播放| 亚洲精品乱码久久久久久| 欧美日韩高清不卡| 极品美女销魂一区二区三区免费| 国产蜜臀97一区二区三区| 不卡一二三区首页| 午夜a成v人精品| 国产欧美日韩亚州综合| 在线观看国产91| 久久电影网电视剧免费观看| 亚洲国产激情av| 一本色道a无线码一区v| 日韩av二区在线播放| 国产清纯美女被跳蛋高潮一区二区久久w| 成人少妇影院yyyy| 日韩精品色哟哟| 日本一区二区三区久久久久久久久不 | 色综合久久99| 日韩成人dvd| 日本一区二区不卡视频| 欧美日本韩国一区| 成人黄色电影在线| 麻豆久久久久久| 亚洲伦在线观看| 精品福利av导航| 欧美日韩1234| 成人免费va视频| 久久99精品一区二区三区三区| 中文字幕中文字幕一区| 欧美成人艳星乳罩| 欧美性猛交xxxx乱大交退制版| 国产精品18久久久久久久久久久久 | 久久精品99国产精品| 亚洲视频一二三| 久久久精品欧美丰满| 欧美日韩国产不卡| 99国产精品久久久| 国产99久久久精品| 韩国v欧美v亚洲v日本v| 日日夜夜免费精品| 成人欧美一区二区三区小说 | 9191成人精品久久| 色一区在线观看| 顶级嫩模精品视频在线看| 老司机精品视频导航| 婷婷中文字幕综合| 亚洲国产中文字幕| 亚洲丝袜另类动漫二区| 国产精品三级av| 国产亚洲短视频| 久久综合久久综合九色| 欧美一区二区三区在线看| 欧美三级电影网站| 在线国产亚洲欧美| 日本高清成人免费播放| 99国产精品久久久久久久久久久| 国产成人免费网站| 国产精品自拍av| 韩国一区二区视频| 国产一区激情在线| 久久国产麻豆精品| 伦理电影国产精品| 久久精品99国产精品日本| 奇米777欧美一区二区| 无码av中文一区二区三区桃花岛| 亚洲国产一区二区三区| 亚洲精品免费一二三区| 亚洲激情五月婷婷| 亚洲午夜三级在线| 香港成人在线视频| 日本亚洲天堂网| 成人app在线| 不卡一区二区三区四区| 色香蕉久久蜜桃| 91国在线观看| 欧美日韩免费观看一区三区| 欧美色图激情小说| 91精品国产综合久久久久久漫画| 欧美日韩中字一区| 日韩欧美在线影院| 精品国精品国产| 国产精品视频在线看| 亚洲美女在线一区| 日韩电影在线一区| 国产精品一区二区在线观看不卡 | 亚洲色图.com| 亚洲一区二区三区三| 天堂av在线一区| 国产一区二区三区精品视频| 成人午夜激情片| 日本韩国欧美国产| 91精品国产色综合久久不卡电影 | 91精品国产一区二区人妖| 欧美xingq一区二区| 国产女人18毛片水真多成人如厕| 国产精品国模大尺度视频| 亚洲国产精品一区二区久久| 日本中文一区二区三区| 国产不卡一区视频| 欧美午夜在线一二页| 欧美成人性福生活免费看| 中文字幕一区在线观看| 午夜欧美2019年伦理| 韩国三级电影一区二区| 色婷婷综合在线| 精品久久国产97色综合| 亚洲精品一二三四区| 免费人成网站在线观看欧美高清| 国产电影一区在线| 欧美日韩免费观看一区二区三区| 日韩欧美一区二区在线视频| 国产女主播在线一区二区| 亚洲国产精品人人做人人爽| 国产suv一区二区三区88区| 在线观看av一区二区| 久久免费电影网| 偷拍亚洲欧洲综合| 99re在线视频这里只有精品| 欧美一区二区三区日韩视频| 中文字幕在线不卡一区| 激情国产一区二区| 欧美色图天堂网| 国产精品久久久久久妇女6080| 全部av―极品视觉盛宴亚洲| 91片黄在线观看| 中文字幕巨乱亚洲| 精品在线免费视频|