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

📄 rule.c

📁 用来作为linux中SIP SERVER,完成VOIP网络电话中服务器的功能
💻 C
字号:
/* * $Id: rule.c,v 1.5 2003/11/05 21:04:47 jiri Exp $ * * PERMISSIONS module * * Copyright (C) 2003 Mikl髎 Tirp醟 (mtirpak@sztaki.hu) * * This file is part of ser, a free SIP server. * * ser is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version * * For a license to use the ser software under conditions * other than those described here, or to purchase support for this * software, please contact iptel.org by e-mail at the following addresses: *    info@iptel.org * * ser is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License  * along with this program; if not, write to the Free Software  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * */ #include <stdio.h>#include <stdlib.h>#include <sys/types.h>#include <regex.h>#include "../../mem/mem.h"#include "../../sr_module.h"#include "../../mem/mem.h"#include "rule.h"/*  * allocate memory for a new rule  */rule *new_rule(void) {	rule	*r;	r = (rule *)pkg_malloc(sizeof(rule));	if (!r) {		LOG(L_ERR, "permissions:new_rule(): Not enough memory\n");		return 0;	}	memset(r, 0, sizeof(rule));	return r;}/*  * free memory allocated by a rule  */void free_rule(rule *r) {	if (!r) return;			if (r->left) free_expression(r->left);	if (r->left_exceptions) free_expression(r->left_exceptions);	if (r->right) free_expression(r->right);	if (r->right_exceptions) free_expression(r->right_exceptions);	if (r->next) free_rule(r->next);	pkg_free(r);}/*  * list rules  */void print_rule(rule *r) {	if (!r) return;			printf("\nNEW RULE:\n");	printf("\n\tLEFT: ");	if (r->left) print_expression(r->left);  else printf("ALL");	if (r->left_exceptions) {		printf("\n\tLEFT EXCEPTIONS: ");		print_expression(r->left_exceptions);	}	printf("\n\tRIGHT: ");	if (r->right) print_expression(r->right);  else printf("ALL");	if (r->right_exceptions) {		printf("\n\tRIGHT EXCEPTIONS: ");		print_expression(r->right_exceptions);	}	printf("\n");	if (r->next) print_rule(r->next);}/*  * look for a proper rule matching with left:right  */int search_rule(rule *r, char *left, char *right) {	rule	*r1;	r1 = r;	while (r1) {		if (( (!r->left) || (search_expression(r1->left, left)) )		&& (!search_expression(r1->left_exceptions, left))		&& ( (!r1->right) || (search_expression(r1->right, right)) )		&& (!search_expression(r1->right_exceptions, right))) return 1;		r1 = r1->next;	}	return 0;}/*  * allocate memory for a new expression * str is saved in vale, and compiled to POSIX regexp (reg_value) */expression *new_expression(char *str) {	expression	*e;		if (!str) return 0;	e = (expression *)pkg_malloc(sizeof(expression));	if (!e) {		LOG(L_ERR, "permissions:new_expression(): Not enough memory\n");		return 0;	}	strcpy(e->value, str);		e->reg_value = (regex_t*)pkg_malloc(sizeof(regex_t));	if (!e->reg_value) {		LOG(L_ERR, "permissions:new_expression(): Not enough memory\n");		pkg_free(e);		return 0;	}	if (regcomp(e->reg_value, str, REG_EXTENDED|REG_NOSUB|REG_ICASE) ) {		LOG(L_ERR, "permissions:new_expression(): Bad regular expression: %s\n", str);		pkg_free(e->reg_value);		pkg_free(e);		return NULL;	}		e->next = 0;	return e;}/*  * free memory allocated by an expression  */void free_expression(expression *e) {	if (!e) return;	if (e->next) free_expression(e->next);	regfree(e->reg_value);	pkg_free(e);}/*  * list expressions  */void print_expression(expression *e) {	if (!e) return;	printf("%s, ", e->value);	if (e->next) print_expression(e->next);}/*  * look for matching expression  */int search_expression(expression *e, char *value) {	expression	*e1;	e1 = e;	while (e1) {		if (regexec(e1->reg_value, value, 0, 0, 0) == 0) 	return 1;		e1 = e1->next;	}	return 0;}

⌨️ 快捷键说明

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