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

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

?? eap_sim_db.c

?? 最新的Host AP 新添加了許多pcmcia 的驅動
?? C
?? 第 1 頁 / 共 3 頁
字號:
 * @priv: Private data pointer from eap_sim_db_init() */void eap_sim_db_deinit(void *priv){	struct eap_sim_db_data *data = priv;	struct eap_sim_pseudonym *p, *prev;	struct eap_sim_reauth *r, *prevr;	struct eap_sim_db_pending *pending, *prev_pending;	eap_sim_db_close_socket(data);	os_free(data->fname);	p = data->pseudonyms;	while (p) {		prev = p;		p = p->next;		eap_sim_db_free_pseudonym(prev);	}	r = data->reauths;	while (r) {		prevr = r;		r = r->next;		eap_sim_db_free_reauth(prevr);	}	pending = data->pending;	while (pending) {		prev_pending = pending;		pending = pending->next;		os_free(prev_pending);	}	os_free(data);}static int eap_sim_db_send(struct eap_sim_db_data *data, const char *msg,			   size_t len){	int _errno = 0;	if (send(data->sock, msg, len, 0) < 0) {		_errno = errno;		perror("send[EAP-SIM DB UNIX]");	}	if (_errno == ENOTCONN || _errno == EDESTADDRREQ || _errno == EINVAL ||	    _errno == ECONNREFUSED) {		/* Try to reconnect */		eap_sim_db_close_socket(data);		if (eap_sim_db_open_socket(data) < 0)			return -1;		wpa_printf(MSG_DEBUG, "EAP-SIM DB: Reconnected to the "			   "external server");		if (send(data->sock, msg, len, 0) < 0) {			perror("send[EAP-SIM DB UNIX]");			return -1;		}	}	return 0;}static void eap_sim_db_expire_pending(struct eap_sim_db_data *data){	/* TODO: add limit for maximum length for pending list; remove latest	 * (i.e., last) entry from the list if the limit is reached; could also	 * use timeout to expire pending entries */}/** * eap_sim_db_get_gsm_triplets - Get GSM triplets * @priv: Private data pointer from eap_sim_db_init() * @identity: User name identity * @identity_len: Length of identity in bytes * @max_chal: Maximum number of triplets * @_rand: Buffer for RAND values * @kc: Buffer for Kc values * @sres: Buffer for SRES values * @cb_session_ctx: Session callback context for get_complete_cb() * Returns: Number of triplets received (has to be less than or equal to * max_chal), -1 (EAP_SIM_DB_FAILURE) on error (e.g., user not found), or * -2 (EAP_SIM_DB_PENDING) if results are not yet available. In this case, the * callback function registered with eap_sim_db_init() will be called once the * results become available. * * In most cases, the user name is '1' | IMSI, i.e., 1 followed by the IMSI in * ASCII format. * * When using an external server for GSM triplets, this function can always * start a request and return EAP_SIM_DB_PENDING immediately if authentication * triplets are not available. Once the triplets are received, callback * function registered with eap_sim_db_init() is called to notify EAP state * machine to reprocess the message. This eap_sim_db_get_gsm_triplets() * function will then be called again and the newly received triplets will then * be given to the caller. */int eap_sim_db_get_gsm_triplets(void *priv, const u8 *identity,				size_t identity_len, int max_chal,				u8 *_rand, u8 *kc, u8 *sres,				void *cb_session_ctx){	struct eap_sim_db_data *data = priv;	struct eap_sim_db_pending *entry;	int len, ret;	size_t i;	char msg[40];	if (identity_len < 2 || identity[0] != EAP_SIM_PERMANENT_PREFIX) {		wpa_hexdump_ascii(MSG_DEBUG, "EAP-SIM DB: unexpected identity",				  identity, identity_len);		return EAP_SIM_DB_FAILURE;	}	identity++;	identity_len--;	for (i = 0; i < identity_len; i++) {		if (identity[i] == '@') {			identity_len = i;			break;		}	}	if (identity_len + 1 > sizeof(entry->imsi)) {		wpa_hexdump_ascii(MSG_DEBUG, "EAP-SIM DB: unexpected identity",				  identity, identity_len);		return EAP_SIM_DB_FAILURE;	}	wpa_hexdump_ascii(MSG_DEBUG, "EAP-SIM DB: Get GSM triplets for IMSI",			  identity, identity_len);	entry = eap_sim_db_get_pending(data, identity, identity_len, 0);	if (entry) {		int num_chal;		if (entry->state == FAILURE) {			wpa_printf(MSG_DEBUG, "EAP-SIM DB: Pending entry -> "				   "failure");			os_free(entry);			return EAP_SIM_DB_FAILURE;		}		if (entry->state == PENDING) {			wpa_printf(MSG_DEBUG, "EAP-SIM DB: Pending entry -> "				   "still pending");			eap_sim_db_add_pending(data, entry);			return EAP_SIM_DB_PENDING;		}		wpa_printf(MSG_DEBUG, "EAP-SIM DB: Pending entry -> "			   "%d challenges", entry->u.sim.num_chal);		num_chal = entry->u.sim.num_chal;		if (num_chal > max_chal)			num_chal = max_chal;		os_memcpy(_rand, entry->u.sim.rand, num_chal * GSM_RAND_LEN);		os_memcpy(sres, entry->u.sim.sres,			  num_chal * EAP_SIM_SRES_LEN);		os_memcpy(kc, entry->u.sim.kc, num_chal * EAP_SIM_KC_LEN);		os_free(entry);		return num_chal;	}	if (data->sock < 0) {		if (eap_sim_db_open_socket(data) < 0)			return EAP_SIM_DB_FAILURE;	}	len = os_snprintf(msg, sizeof(msg), "SIM-REQ-AUTH ");	if (len < 0 || len + identity_len >= sizeof(msg))		return EAP_SIM_DB_FAILURE;	os_memcpy(msg + len, identity, identity_len);	len += identity_len;	ret = os_snprintf(msg + len, sizeof(msg) - len, " %d", max_chal);	if (ret < 0 || (size_t) ret >= sizeof(msg) - len)		return EAP_SIM_DB_FAILURE;	len += ret;	wpa_hexdump(MSG_DEBUG, "EAP-SIM DB: requesting SIM authentication "		    "data for IMSI", identity, identity_len);	if (eap_sim_db_send(data, msg, len) < 0)		return EAP_SIM_DB_FAILURE;	entry = os_zalloc(sizeof(*entry));	if (entry == NULL)		return EAP_SIM_DB_FAILURE;	os_get_time(&entry->timestamp);	os_memcpy(entry->imsi, identity, identity_len);	entry->imsi_len = identity_len;	entry->cb_session_ctx = cb_session_ctx;	entry->state = PENDING;	eap_sim_db_add_pending(data, entry);	eap_sim_db_expire_pending(data);	return EAP_SIM_DB_PENDING;}static struct eap_sim_pseudonym *eap_sim_db_get_pseudonym(struct eap_sim_db_data *data, const u8 *identity,			 size_t identity_len){	char *pseudonym;	size_t len;	struct eap_sim_pseudonym *p;	if (identity_len == 0 ||	    (identity[0] != EAP_SIM_PSEUDONYM_PREFIX &&	     identity[0] != EAP_AKA_PSEUDONYM_PREFIX))		return NULL;	/* Remove possible realm from identity */	len = 0;	while (len < identity_len) {		if (identity[len] == '@')			break;		len++;	}	pseudonym = os_malloc(len + 1);	if (pseudonym == NULL)		return NULL;	os_memcpy(pseudonym, identity, len);	pseudonym[len] = '\0';	p = data->pseudonyms;	while (p) {		if (os_strcmp(p->pseudonym, pseudonym) == 0)			break;		p = p->next;	}	os_free(pseudonym);	return p;}static struct eap_sim_pseudonym *eap_sim_db_get_pseudonym_id(struct eap_sim_db_data *data, const u8 *identity,			    size_t identity_len){	struct eap_sim_pseudonym *p;	if (identity_len == 0 ||	    (identity[0] != EAP_SIM_PERMANENT_PREFIX &&	     identity[0] != EAP_AKA_PERMANENT_PREFIX))		return NULL;	p = data->pseudonyms;	while (p) {		if (identity_len == p->identity_len &&		    os_memcmp(p->identity, identity, identity_len) == 0)			break;		p = p->next;	}	return p;}static struct eap_sim_reauth *eap_sim_db_get_reauth(struct eap_sim_db_data *data, const u8 *identity,		      size_t identity_len){	char *reauth_id;	size_t len;	struct eap_sim_reauth *r;	if (identity_len == 0 ||	    (identity[0] != EAP_SIM_REAUTH_ID_PREFIX &&	     identity[0] != EAP_AKA_REAUTH_ID_PREFIX))		return NULL;	/* Remove possible realm from identity */	len = 0;	while (len < identity_len) {		if (identity[len] == '@')			break;		len++;	}	reauth_id = os_malloc(len + 1);	if (reauth_id == NULL)		return NULL;	os_memcpy(reauth_id, identity, len);	reauth_id[len] = '\0';	r = data->reauths;	while (r) {		if (os_strcmp(r->reauth_id, reauth_id) == 0)			break;		r = r->next;	}	os_free(reauth_id);	return r;}static struct eap_sim_reauth *eap_sim_db_get_reauth_id(struct eap_sim_db_data *data, const u8 *identity,			 size_t identity_len){	struct eap_sim_pseudonym *p;	struct eap_sim_reauth *r;	if (identity_len == 0)		return NULL;	p = eap_sim_db_get_pseudonym(data, identity, identity_len);	if (p == NULL)		p = eap_sim_db_get_pseudonym_id(data, identity, identity_len);	if (p) {		identity = p->identity;		identity_len = p->identity_len;	}	r = data->reauths;	while (r) {		if (identity_len == r->identity_len &&		    os_memcmp(r->identity, identity, identity_len) == 0)			break;		r = r->next;	}	return r;}/** * eap_sim_db_identity_known - Verify whether the given identity is known * @priv: Private data pointer from eap_sim_db_init() * @identity: User name identity * @identity_len: Length of identity in bytes  * Returns: 0 if the user is found or -1 on failure * * In most cases, the user name is ['0','1'] | IMSI, i.e., 1 followed by the * IMSI in ASCII format, ['2','3'] | pseudonym, or ['4','5'] | reauth_id. */int eap_sim_db_identity_known(void *priv, const u8 *identity,			      size_t identity_len){	struct eap_sim_db_data *data = priv;	if (identity == NULL || identity_len < 2)		return -1;	if (identity[0] == EAP_SIM_PSEUDONYM_PREFIX ||	    identity[0] == EAP_AKA_PSEUDONYM_PREFIX) {		struct eap_sim_pseudonym *p =			eap_sim_db_get_pseudonym(data, identity, identity_len);		return p ? 0 : -1;	}	if (identity[0] == EAP_SIM_REAUTH_ID_PREFIX ||	    identity[0] == EAP_AKA_REAUTH_ID_PREFIX) {		struct eap_sim_reauth *r =			eap_sim_db_get_reauth(data, identity, identity_len);		return r ? 0 : -1;	}	if (identity[0] != EAP_SIM_PERMANENT_PREFIX &&	    identity[0] != EAP_AKA_PERMANENT_PREFIX) {		/* Unknown identity prefix */		return -1;	}	/* TODO: Should consider asking HLR/AuC gateway whether this permanent	 * identity is known. If it is, EAP-SIM/AKA can skip identity request.	 * In case of EAP-AKA, this would reduce number of needed round-trips.	 * Ideally, this would be done with one wait, i.e., just request	 * authentication data and store it for the next use. This would then	 * need to use similar pending-request functionality as the normal	 * request for authentication data at later phase.	 */	return -1;}static char * eap_sim_db_get_next(struct eap_sim_db_data *data, char prefix){	char *id, *pos, *end;	u8 buf[10];	if (os_get_random(buf, sizeof(buf)))		return NULL;	id = os_malloc(sizeof(buf) * 2 + 2);	if (id == NULL)		return NULL;	pos = id;	end = id + sizeof(buf) * 2 + 2;	*pos++ = prefix;	pos += wpa_snprintf_hex(pos, end - pos, buf, sizeof(buf));		return id;}/** * eap_sim_db_get_next_pseudonym - EAP-SIM DB: Get next pseudonym * @priv: Private data pointer from eap_sim_db_init() * @aka: Using EAP-AKA instead of EAP-SIM * Returns: Next pseudonym (allocated string) or %NULL on failure * * This function is used to generate a pseudonym for EAP-SIM. The returned * pseudonym is not added to database at this point; it will need to be added * with eap_sim_db_add_pseudonym() once the authentication has been completed * successfully. Caller is responsible for freeing the returned buffer. */char * eap_sim_db_get_next_pseudonym(void *priv, int aka){	struct eap_sim_db_data *data = priv;	return eap_sim_db_get_next(data, aka ? EAP_AKA_PSEUDONYM_PREFIX :				   EAP_SIM_PSEUDONYM_PREFIX);}/** * eap_sim_db_get_next_reauth_id - EAP-SIM DB: Get next reauth_id * @priv: Private data pointer from eap_sim_db_init() * @aka: Using EAP-AKA instead of EAP-SIM * Returns: Next reauth_id (allocated string) or %NULL on failure * * This function is used to generate a fast re-authentication identity for * EAP-SIM. The returned reauth_id is not added to database at this point; it * will need to be added with eap_sim_db_add_reauth() once the authentication * has been completed successfully. Caller is responsible for freeing the * returned buffer. */char * eap_sim_db_get_next_reauth_id(void *priv, int aka){	struct eap_sim_db_data *data = priv;	return eap_sim_db_get_next(data, aka ? EAP_AKA_REAUTH_ID_PREFIX :				   EAP_SIM_REAUTH_ID_PREFIX);}/** * eap_sim_db_add_pseudonym - EAP-SIM DB: Add new pseudonym * @priv: Private data pointer from eap_sim_db_init() * @identity: Identity of the user (may be permanent identity or pseudonym) * @identity_len: Length of identity * @pseudonym: Pseudonym for this user. This needs to be an allocated buffer,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品黑人一区二区三区久久| 欧美日韩国产一二三| 久久精品国产亚洲aⅴ| 亚洲一区二区三区四区在线观看| 国产精品热久久久久夜色精品三区 | 国产欧美一区二区精品性色超碰| 日韩三级中文字幕| 精品国产免费人成电影在线观看四季| 日韩亚洲电影在线| 欧美xxxxxxxx| 国产欧美日韩麻豆91| 国产精品久久久久久久久久免费看| 国产精品三级av| 一区二区三区中文字幕| 亚洲国产色一区| 久久99热狠狠色一区二区| 国产精品香蕉一区二区三区| 国产成人8x视频一区二区| proumb性欧美在线观看| 在线亚洲高清视频| 日韩欧美亚洲国产精品字幕久久久| 日韩三级在线免费观看| 国产欧美精品一区二区色综合| 中文字幕亚洲电影| 日日欢夜夜爽一区| 国产二区国产一区在线观看| 色综合天天综合网国产成人综合天| 欧美性大战久久久| 久久久美女艺术照精彩视频福利播放| 国产精品福利av| 日韩二区三区四区| hitomi一区二区三区精品| 777亚洲妇女| 国产精品国产三级国产有无不卡 | 欧美日韩国产大片| 国产色产综合色产在线视频| 亚洲色图.com| 国产精品一区在线观看你懂的| 色噜噜狠狠一区二区三区果冻| 欧美精品一区二区在线观看| 亚洲精品国产a| 国产精品一线二线三线| 欧美日韩一本到| 国产日产精品1区| 日韩不卡免费视频| 日本丶国产丶欧美色综合| 久久男人中文字幕资源站| 午夜电影一区二区| 91蜜桃传媒精品久久久一区二区| 日韩一卡二卡三卡| 亚洲一区二区在线免费观看视频 | 91麻豆精品在线观看| 精品国产麻豆免费人成网站| 洋洋av久久久久久久一区| 国产成人日日夜夜| 精品国产免费人成电影在线观看四季 | 欧美mv日韩mv国产网站| 一区二区激情视频| 99精品国产视频| 国产精品天天看| 国产一区福利在线| 欧美大度的电影原声| 日韩黄色在线观看| 欧美视频一区二区三区在线观看 | 国产三级精品视频| 乱一区二区av| 欧美卡1卡2卡| 天使萌一区二区三区免费观看| 91久久久免费一区二区| 日韩毛片视频在线看| 成人亚洲精品久久久久软件| 亚洲精品一区二区三区蜜桃下载 | 久久精品人人做| 精品一区二区三区久久久| 欧美一区二区三区免费在线看| 亚洲成年人影院| 欧美日韩精品高清| 视频一区视频二区中文字幕| 欧美午夜片在线看| 亚洲第一二三四区| 91精品婷婷国产综合久久竹菊| 亚洲成av人**亚洲成av**| 欧美日韩一区二区三区免费看 | 国产精品久久99| 另类人妖一区二区av| 欧美日韩国产高清一区| 日韩精品久久久久久| 日韩精品一区国产麻豆| 国产麻豆一精品一av一免费 | 久久久精品蜜桃| 国产成人鲁色资源国产91色综| 国产亚洲一区字幕| 99免费精品在线| 偷拍与自拍一区| 亚洲精品一区二区三区99| 国产福利一区二区三区视频在线| 国产精品美女久久久久aⅴ国产馆| 成熟亚洲日本毛茸茸凸凹| 一区二区三区欧美视频| 日韩欧美在线网站| 高清日韩电视剧大全免费| 亚洲综合自拍偷拍| 日韩欧美国产一区二区在线播放| 国产精品99久久久久久宅男| 亚洲美女精品一区| 日韩精品中文字幕在线一区| 国产精品一区二区不卡| 亚洲精品国产a| 久久综合九色综合久久久精品综合 | 97成人超碰视| 欧美aaa在线| 1024成人网色www| 欧美成人三级在线| 91网站在线播放| 久久69国产一区二区蜜臀| 国产精品久久久久影院| 日韩亚洲欧美中文三级| 成人黄色av电影| 久久精品999| 一区二区国产视频| 国产欧美综合在线| 日韩精品影音先锋| 欧美怡红院视频| 91在线视频免费91| 国产丶欧美丶日本不卡视频| 亚洲五月六月丁香激情| 国产精品免费丝袜| 久久久青草青青国产亚洲免观| 欧美人牲a欧美精品| 972aa.com艺术欧美| 国产精品伊人色| 奇米综合一区二区三区精品视频| 亚洲精品国产高清久久伦理二区| 久久久久久久网| 精品欧美一区二区久久| 制服丝袜亚洲播放| 欧美日韩一区二区三区在线看| 91麻豆精品视频| 99精品视频中文字幕| 国产成人8x视频一区二区| 精品亚洲国内自在自线福利| 日韩主播视频在线| 亚洲国产精品一区二区www在线| 国产欧美日韩精品在线| 久久久久久久久久久99999| 欧美大尺度电影在线| 欧美videossexotv100| 日韩一区和二区| 91精品福利在线一区二区三区| 欧美日韩一区二区电影| 欧美午夜精品一区二区三区| 在线观看一区二区视频| 色播五月激情综合网| 色欧美日韩亚洲| 欧美在线看片a免费观看| 欧美性生活一区| 欧美体内she精视频| 欧美日韩一区二区三区四区五区 | 人禽交欧美网站| 久久精品国产免费看久久精品| 裸体一区二区三区| 国产一区二区三区综合| 国产成人免费xxxxxxxx| 99视频热这里只有精品免费| 91美女片黄在线| 在线播放国产精品二区一二区四区| 欧洲国内综合视频| 91精品国产高清一区二区三区蜜臀| 欧美一级精品大片| 国产欧美一区二区三区在线看蜜臀| 中文字幕高清不卡| 亚洲一区视频在线观看视频| 视频精品一区二区| 国产99久久久国产精品免费看| 99精品国产视频| 91精品国产日韩91久久久久久| 精品国产亚洲在线| 亚洲欧美日韩中文字幕一区二区三区| 亚洲精品日日夜夜| 久久精品av麻豆的观看方式| 成人av在线看| 欧美日韩一区成人| 国产午夜精品久久久久久久 | 欧美一级日韩一级| 亚洲国产成人午夜在线一区| 亚洲综合区在线| 久草这里只有精品视频| 成人免费黄色在线| 欧美日韩mp4| 日韩美女视频一区二区| 蜜臀av在线播放一区二区三区| 成人av在线资源网站| 91精品国产乱码久久蜜臀| 中文天堂在线一区| 日韩电影免费一区| 色综合亚洲欧洲| 国产精品天美传媒| 免费在线观看精品| 欧美日韩午夜在线| 国产精品久久免费看|