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

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

?? auth.c

?? vxwork源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * logout - Logout the user. */static voidlogout(){    char *tty;    tty = strrchr(ppp_if[ppp_unit]->devname, '/');    if (tty == NULL)	tty = ppp_if[ppp_unit]->devname;    else	tty++;    ppp_if[ppp_unit]->logged_in = FALSE;}#endif	/* notyet *//* * null_login - Check if a username of "" and a password of "" are * acceptable, and iff so, set the list of acceptable IP addresses * and return 1. */static intnull_login(unit)    int unit;{    char *filename;    FILE *f = NULL;    int i, ret;    struct wordlist *addrs = NULL;    char secret[MAXWORDLEN];    i = pppSecretFind ("", ppp_if[unit]->our_name, secret, &addrs);    ret = i >= 0 && (i & NONWILD_CLIENT) != 0 && secret[0] == 0;    if (!ret)	{        /*         * Open the file of upap secrets and scan for a suitable secret.         * We don't accept a wildcard client.         */        if ((filename = ppp_if[unit]->options->pap_file) != NULL)            f = fopen(filename, "r");        if (f == NULL)            return 0;        check_access(f, filename);        i = scan_authfile(f, "", ppp_if[unit]->our_name, secret, &addrs,		      filename);        ret = i >= 0 && (i & NONWILD_CLIENT) != 0 && secret[0] == 0;        fclose(f);        }    if (ret) {        if (ppp_if[unit]->addresses != NULL)            free_wordlist(ppp_if[unit]->addresses);        ppp_if[unit]->addresses = addrs;        }    return ret;}/* * get_upap_passwd - get a password for authenticating ourselves with * our peer using PAP.  Returns 1 on success, 0 if no suitable password * could be found. */static intget_upap_passwd(){    char *filename;    FILE *f = NULL;    char secret[MAXWORDLEN];    if (pppSecretFind (ppp_if[ppp_unit]->user, ppp_if[ppp_unit]->remote_name,	secret, NULL) < 0)        {        if ((filename = ppp_if[ppp_unit]->options->pap_file) != NULL)            f = fopen(filename, "r");        if (f == NULL)	    return 0;        check_access(f, filename);        if (scan_authfile(f, ppp_if[ppp_unit]->user,	    ppp_if[ppp_unit]->remote_name, secret, NULL, filename) < 0)	    {            fclose(f);	    return 0;	    }        fclose(f);        }    strncpy(ppp_if[ppp_unit]->passwd, secret, MAXSECRETLEN);    ppp_if[ppp_unit]->passwd[MAXSECRETLEN-1] = 0;    return 1;}/* * have_upap_secret - check whether we have a PAP file with any * secrets that we could possibly use for authenticating the peer. */static inthave_upap_secret(){    FILE *f = NULL;    int ret;    char *filename;    if (ppp_if[ppp_unit]->uselogin)	return 1;    if (pppSecretFind (NULL, ppp_if[ppp_unit]->our_name, NULL, NULL) < 0)        {        if ((filename = ppp_if[ppp_unit]->options->pap_file) != NULL)            f = fopen(filename, "r");        if (f == NULL)	    return 0;        ret = scan_authfile(f, NULL, ppp_if[ppp_unit]->our_name, NULL, NULL,			filename);        fclose(f);        if (ret < 0)	    return 0;	}    return 1;}/* * have_chap_secret - check whether we have a CHAP file with a * secret that we could possibly use for authenticating `client' * on `server'.  Either can be the null string, meaning we don't * know the identity yet. */static inthave_chap_secret(client, server)    char *client;    char *server;{    FILE *f = NULL;    int ret;    char *filename;    if (client[0] == 0)        client = NULL;    else if (server[0] == 0)        server = NULL;    if (pppSecretFind (client, server, NULL, NULL) < 0)	{        if ((filename = ppp_if[ppp_unit]->options->chap_file) != NULL)            f = fopen(filename, "r");        if (f == NULL)            return 0;        ret = scan_authfile(f, client, server, NULL, NULL, filename);        fclose(f);        if (ret < 0)	    return 0;	}    return 1;}/* * get_secret - open the CHAP secret file and return the secret * for authenticating the given client on the given server. * (We could be either client or server). */intget_secret(unit, client, server, secret, secret_len, save_addrs)    int unit;    char *client;    char *server;    char *secret;    int *secret_len;    int save_addrs;{    FILE *f = NULL;    int ret, len;    char *filename;    struct wordlist *addrs = NULL;    char secbuf[MAXWORDLEN];    secbuf[0] = 0;    if (pppSecretFind (client, server, secbuf, &addrs) < 0)	{        if ((filename = ppp_if[unit]->options->chap_file) != NULL)            f = fopen(filename, "r");        if (f == NULL) {	    syslog(LOG_ERR, "Can't open chap secret file %s", filename);	    return 0;        }        check_access(f, filename);        ret = scan_authfile(f, client, server, secbuf, &addrs, filename);        fclose(f);        if (ret < 0)	    return 0;        }    if (save_addrs) {	if (ppp_if[unit]->addresses != NULL)	    free_wordlist(ppp_if[unit]->addresses);	ppp_if[unit]->addresses = addrs;    }    len = strlen(secbuf);    if (len > MAXSECRETLEN) {	syslog(LOG_ERR, "Secret for %s on %s is too long", client, server);	len = MAXSECRETLEN;    }    BCOPY(secbuf, secret, len);    *secret_len = len;    return 1;}/* * auth_ip_addr - check whether the peer is authorized to use * a given IP address.  Returns 1 if authorized, 0 otherwise. */intauth_ip_addr(unit, addr)    int unit;    u_long addr;{    u_long a;    struct wordlist *addrs;    /* don't allow loopback or multicast address */    if (bad_ip_adrs(addr))        return 0;    if ((addrs = ppp_if[unit]->addresses) == NULL)	return 1;		/* no restriction */    for (; addrs != NULL; addrs = addrs->next) {	/* "-" means no addresses authorized */	if (strcmp(addrs->word, "-") == 0)	    break;	if ((a = inet_addr(addrs->word)) == -1) {	    if ((a = hostGetByName (addrs->word)) == NULL) {		syslog(LOG_WARNING, "unknown host %s in auth. address list",		       addrs->word);		continue;		}	}	if (addr == a)	    return 1;    }    return 0;			/* not in list => can't have it */}/* * bad_ip_adrs - return 1 if the IP address is one we don't want * to use, such as an address in the loopback net or a multicast address. * addr is in network byte order. */intbad_ip_adrs(addr)    u_long addr;{    addr = ntohl(addr);#if	CPU==SIMSPARCSOLARIS    return IN_MULTICAST(addr) || IN_BADCLASS(addr);#else    return (addr >> IN_CLASSA_NSHIFT) == IN_LOOPBACKNET        || IN_MULTICAST(addr) || IN_BADCLASS(addr);#endif}/* * check_access - complain if a secret file has too-liberal permissions. */voidcheck_access(f, fileName)    FILE *f;    char *fileName;{    struct stat sbuf;    if (fstat(fileno(f), &sbuf) < 0) {	syslog(LOG_WARNING, "cannot stat secret file %s: %m", fileName);    } else if ((sbuf.st_mode & (S_IRWXG | S_IRWXO)) != 0) {	syslog(LOG_WARNING, "Warning - secret file %s has world and/or group access", fileName);    }}/* * scan_authfile - Scan an authorization file for a secret suitable * for authenticating `client' on `server'.  The return value is -1 * if no secret is found, otherwise >= 0.  The return value has * NONWILD_CLIENT set if the secret didn't have "*" for the client, and * NONWILD_SERVER set if the secret didn't have "*" for the server. * Any following words on the line (i.e. address authorization * info) are placed in a wordlist and returned in *addrs.   */static intscan_authfile(f, client, server, secret, addrs, fileName)    FILE *f;    char *client;    char *server;    char *secret;    struct wordlist **addrs;    char *fileName;{    int newline, xxx;    int got_flag, best_flag;    FILE *sf;    struct wordlist *ap, *addr_list, *addr_last;    char word[MAXWORDLEN];    char atfile[MAXWORDLEN];    if (addrs != NULL)	*addrs = NULL;    addr_list = NULL;    if (!getword(f, word, &newline, fileName))	return -1;		/* file is empty??? */    newline = 1;    best_flag = -1;    for (;;) {	/*	 * Skip until we find a word at the start of a line.	 */	while (!newline && getword(f, word, &newline, fileName))	    ;	if (!newline)	    break;		/* got to end of file */	/*	 * Got a client - check if it's a match or a wildcard.	 */	got_flag = 0;	if (client != NULL && client[0] && strcmp(word, client) != 0 &&	    !ISWILD(word)) {	    newline = 0;	    continue;	}	if (!ISWILD(word))	    got_flag = NONWILD_CLIENT;	/*	 * Now get a server and check if it matches.	 */	if (!getword(f, word, &newline, fileName))	    break;	if (newline)	    continue;	if (server != NULL && server[0] && strcmp(word, server) != 0 &&	    !ISWILD(word))	    continue;	if (!ISWILD(word))	    got_flag |= NONWILD_SERVER;	/*	 * Got some sort of a match - see if it's better than what	 * we have already.	 */	if (got_flag <= best_flag)	    continue;	/*	 * Get the secret.	 */	if (!getword(f, word, &newline, fileName))	    break;	if (newline)	    continue;	/*	 * Special syntax: @filename means read secret from file.	 */	if (word[0] == '@') {	    strcpy(atfile, word+1);	    if ((sf = fopen(atfile, "r")) == NULL) {		syslog(LOG_WARNING, "can't open indirect secret file %s",                       atfile);		continue;	    }	    check_access(sf, atfile);	    if (!getword(sf, word, &xxx, atfile)) {		syslog(LOG_WARNING, "no secret in indirect secret file %s",                       atfile);		fclose(sf);		continue;	    }	    fclose(sf);	}	if (secret != NULL)	    strcpy(secret, word);			best_flag = got_flag;	/*	 * Now read address authorization info and make a wordlist.	 */	if (addr_list)	    free_wordlist(addr_list);	addr_list = addr_last = NULL;	for (;;) {	    if (!getword(f, word, &newline, fileName) || newline)		break;	    ap = (struct wordlist *) malloc(sizeof(struct wordlist)					    + strlen(word));	    if (ap == NULL)		novm("authorized addresses");	    ap->next = NULL;	    strcpy(ap->word, word);	    if (addr_list == NULL)		addr_list = ap;	    else		addr_last->next = ap;	    addr_last = ap;	}	if (!newline)	    break;    }    if (addrs != NULL)	*addrs = addr_list;    else if (addr_list != NULL)	free_wordlist(addr_list);    return best_flag;}/* * free_wordlist - release memory allocated for a wordlist. */static voidfree_wordlist(wp)    struct wordlist *wp;{    struct wordlist *next;    while (wp != NULL) {	next = wp->next;	free(wp);	wp = next;    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲靠逼com| 国产一区在线看| 91精品国产色综合久久| 一本色道**综合亚洲精品蜜桃冫| 国产成人av福利| 顶级嫩模精品视频在线看| 韩国女主播一区| 国产精品自拍av| 成a人片亚洲日本久久| 成人激情综合网站| av不卡免费电影| 99久久综合色| 欧美亚一区二区| 91精品国产91热久久久做人人| 在线综合亚洲欧美在线视频| 日韩无一区二区| www久久精品| 国产精品卡一卡二卡三| 亚洲美女电影在线| 天堂va蜜桃一区二区三区| 精品一区二区在线观看| 国产精品一区二区三区四区| 成人av一区二区三区| 在线观看网站黄不卡| 欧美撒尿777hd撒尿| 婷婷综合久久一区二区三区| 韩国v欧美v亚洲v日本v| 波多野结衣在线一区| 在线视频欧美精品| 日韩三级伦理片妻子的秘密按摩| 欧美激情一区二区三区不卡| 一区二区三区四区高清精品免费观看| 不卡一区二区三区四区| 欧美性三三影院| 国产午夜精品一区二区三区嫩草| 亚洲精品视频在线观看免费| 蜜臀av一区二区| 91在线码无精品| 日韩欧美在线123| 亚洲人成网站影音先锋播放| 免费看黄色91| av一二三不卡影片| 精品国产乱码91久久久久久网站| 国产精品国产三级国产aⅴ原创| 亚洲精品乱码久久久久久久久 | 亚洲人成网站色在线观看| 亚洲一区二区三区中文字幕在线 | 中文字幕免费一区| 日韩高清不卡一区二区三区| 成人av网站大全| 欧美一级理论性理论a| 亚洲摸摸操操av| 国产精品一区二区黑丝| 717成人午夜免费福利电影| 国产肉丝袜一区二区| 日韩av一区二区在线影视| 91免费国产视频网站| 免费在线成人网| 91久久精品一区二区三| 久久久精品影视| 久久er99热精品一区二区| 欧美日韩国产高清一区二区| 中文字幕日本乱码精品影院| 韩国成人在线视频| 欧美mv日韩mv国产网站app| 亚洲综合在线免费观看| 成人的网站免费观看| 精品国产凹凸成av人网站| 天堂蜜桃91精品| 欧美伦理视频网站| 夜夜爽夜夜爽精品视频| 99久久久国产精品免费蜜臀| 国产精品美女久久久久久久网站| 精品一区二区在线视频| 日韩精品中午字幕| 国产一区二区成人久久免费影院| 欧美一区二区精品在线| 日韩va欧美va亚洲va久久| 欧美日韩国产首页| 日韩在线一二三区| 91精品国产综合久久久久久久久久| 亚洲国产日韩精品| 欧美日韩国产另类一区| 免费在线看成人av| 久久婷婷久久一区二区三区| 国产毛片精品一区| 久久精品亚洲精品国产欧美kt∨| 国产毛片精品视频| 成人欧美一区二区三区| 一本一道波多野结衣一区二区| 亚洲一卡二卡三卡四卡五卡| 欧美精品九九99久久| 精品亚洲成a人| 国产免费观看久久| 欧美亚洲国产怡红院影院| 香蕉加勒比综合久久| 7777女厕盗摄久久久| 激情小说亚洲一区| 91丨九色porny丨蝌蚪| 成人激情小说网站| 国产a级毛片一区| 日韩一区国产二区欧美三区| 久久91精品国产91久久小草| 亚洲亚洲精品在线观看| 欧美一区欧美二区| 国产精品一区二区三区99| 国产精品久久久久9999吃药| 欧美三级蜜桃2在线观看| 国产呦精品一区二区三区网站| 国产精品麻豆久久久| 欧美人与性动xxxx| 国产在线精品视频| 一区二区三区蜜桃网| 精品国产乱码久久久久久免费| 色系网站成人免费| 国产美女一区二区| 午夜精品福利一区二区三区av| 欧美国产日产图区| 91精品婷婷国产综合久久 | 久久久三级国产网站| 在线亚洲免费视频| 高清不卡一二三区| 日韩和欧美一区二区三区| 国产精品毛片久久久久久久| 精品国产一区二区三区不卡| 91九色最新地址| 国产91色综合久久免费分享| 日韩一区欧美二区| 亚洲精品国产视频| 中文一区二区在线观看| 欧美一区二区三区免费观看视频| 色噜噜狠狠一区二区三区果冻| 国产精品影视天天线| 久久成人免费日本黄色| 亚洲午夜三级在线| 中文字幕欧美三区| 亚洲成人久久影院| 中文字幕一区二区三区四区不卡 | 国产福利91精品一区二区三区| 亚洲成在线观看| 亚洲精品国产无天堂网2021 | 一区二区三区美女视频| 国产人成亚洲第一网站在线播放| 欧美一区二区不卡视频| 欧美日韩亚洲不卡| 欧美婷婷六月丁香综合色| 色综合久久99| 色哟哟国产精品| 91视频在线看| 91黄色激情网站| 91黄视频在线| 欧美日韩在线电影| 色婷婷综合中文久久一本| 99精品久久只有精品| 波多野洁衣一区| 一本久久a久久精品亚洲| 99精品国产91久久久久久 | 热久久久久久久| 日韩av在线免费观看不卡| 亚欧色一区w666天堂| 洋洋av久久久久久久一区| 午夜精品久久久久久久久久| 五月婷婷激情综合网| 秋霞av亚洲一区二区三| 久久99日本精品| 国产一区二区三区视频在线播放| 国产真实精品久久二三区| 国产成人av网站| 一本大道av伊人久久综合| 91精彩视频在线观看| 91麻豆精品国产自产在线观看一区 | 国产一区二区电影| 成人福利视频网站| 欧美午夜寂寞影院| 欧美大尺度电影在线| 久久天天做天天爱综合色| 成人免费在线播放视频| 亚洲三级在线免费观看| 亚洲国产精品久久人人爱| 日韩激情av在线| 国产高清精品在线| 在线免费观看不卡av| 欧美大片免费久久精品三p| 国产精品免费久久| 午夜精品久久久久久久99水蜜桃| 美女视频第一区二区三区免费观看网站| 久久99国产精品免费网站| 99re这里都是精品| 日韩手机在线导航| 国产精品国产三级国产aⅴ中文| 午夜精品福利视频网站| 成人一区二区三区视频| 在线不卡欧美精品一区二区三区| 国产亚洲福利社区一区| 亚洲在线观看免费视频| 国v精品久久久网| 日韩美女天天操| 亚洲成av人片观看| 成人黄色免费短视频| 精品国产免费视频|