2 * $Id: modparam.c,v 1.8 2004/12/03 19:09:31 andrei Exp $
5 * Copyright (C) 2001-2003 FhG Fokus
7 * This file is part of ser, a free SIP server.
9 * ser is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version
14 * For a license to use the ser software under conditions
15 * other than those described here, or to purchase support for this
16 * software, please contact iptel.org by e-mail at the following addresses:
19 * ser is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
24 * You should have received a copy of the GNU General Public License
25 * along with this program; if not, write to the Free Software
26 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30 * 2003-03-20 regex support in modparam (janakj)
31 * 2004-03-12 extra flag USE_FUNC_PARAM added to modparam type -
32 * instead of copying the param value, a func is called (bogdan)
39 #include <sys/types.h>
44 int set_mod_param(char* _mod, char* _name, modparam_t _type, void* _val)
49 LOG(L_ERR, "set_mod_param(): Invalid _mod parameter value\n");
54 LOG(L_ERR, "set_mod_param(): Invalid _name parameter value\n");
58 ptr = find_param_export(_mod, _name, _type);
60 LOG(L_ERR, "set_mod_param(): Parameter not found\n");
66 *((char**)ptr) = strdup((char*)_val);
70 *((int*)ptr) = (int)(long)_val;
78 int set_mod_param_regex(char* regex, char* name, modparam_t type, void* val)
81 param_export_t* param;
88 reg = pkg_malloc(len + 2 + 1);
90 LOG(L_ERR, "set_mod_param_regex(): No memory left\n");
94 memcpy(reg + 1, regex, len);
98 if (regcomp(&preg, reg, REG_EXTENDED | REG_NOSUB | REG_ICASE)) {
99 LOG(L_ERR, "set_mod_param_regex(): Error while compiling regular expression\n");
106 for(t = modules; t; t = t->next) {
107 if (regexec(&preg, t->exports->name, 0, 0, 0) == 0) {
108 DBG("set_mod_param_regex: %s matches module %s\n",
109 regex, t->exports->name);
111 for(param=t->exports->params;param && param->name ; param++) {
112 if ((strcmp(name, param->name) == 0) &&
113 ( PARAM_TYPE_MASK(param->type) == type)) {
114 DBG("set_mod_param_regex: found <%s> in module %s [%s]\n",
115 name, t->exports->name, t->path);
117 if (param->type&USE_FUNC_PARAM) {
118 n = ((param_func_t)(param->param_pointer))(type, val );
124 *((char**)(param->param_pointer)) =
128 *((int*)(param->param_pointer)) =
137 if (!param || !param->name) {
138 LOG(L_ERR, "set_mod_param_regex: parameter <%s> not found in module <%s>\n",
139 name, t->exports->name);
149 LOG(L_ERR, "set_mod_param_regex: No module matching %s found\n|", regex);