forked from OpenSIPS/opensips
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmod_fix.h
75 lines (64 loc) · 2.34 KB
/
mod_fix.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
* Copyright (C) 2001-2003 FhG Fokus
*
* This file is part of opensips, a free SIP server.
*
* opensips 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
*
* opensips 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef _mod_fix_h_
#define _mod_fix_h_
#include <regex.h>
#include "mem/mem.h"
#include "pvar.h"
#include "route_struct.h"
#define GPARAM_TYPE_VAL 0
#define GPARAM_TYPE_PVS 1
#define GPARAM_TYPE_PVE 2
#define GPARAM_TYPE_FIXUP 3
typedef struct _gparam
{
int type;
void *pval;
union {
int ival;
str sval;
} v;
} gparam_t, *gparam_p;
struct cmd_param;
int check_cmd(const struct cmd_param *params, action_elem_t *elems);
int fix_cmd(const struct cmd_param *params, action_elem_t *elems);
int get_cmd_fixups(struct sip_msg* msg, const struct cmd_param *params,
action_elem_t *elems, void **cmdp, pv_value_t *tmp_val);
int free_cmd_fixups(const struct cmd_param *params, action_elem_t *elems, void **cmdp);
/**
* Parses CSV named flags and sets the bitmasks / returns
* the string values for key-value type of flags ("flag_name=flag_value").
* @param: function parameter as received by the fixup function; *param will
* be set with the OR'ed bitmasks.
* @flag_names: array of flag names which will be translated to bitmasks
* according to the indexes of the flag names in the array, i.e. (1<<array_idx).
* @kv_flag_names: array of key-value flag names.
* @kv_flag_vals: array of flag values to be returned. Each str the in the
* array will be set with the flag value if the corresponding flag from
* @kv_flag_names is present, otherwise it will be set to {NULL, 0}
*/
int fixup_named_flags(void** param, str *flag_names, str *kv_flag_names,
str *kv_flag_vals);
static inline int fixup_free_pkg(void **param)
{
pkg_free(*param);
return 0;
}
#endif