8c27f4f245b2e5c1cd9b4c1fccf7a826382938ca
[asterisk/asterisk.git] / channels / misdn / chan_misdn_config.h
1 /*
2  * Chan_Misdn -- Channel Driver for Asterisk
3  *
4  * Interface to mISDN
5  *
6  * Copyright (C) 2004, Christian Richter
7  *
8  * Christian Richter <crich@beronet.com>
9  *
10  * This program is free software, distributed under the terms of
11  * the GNU General Public License
12  */
13
14 /*! \file \brief
15  * Interface to mISDN - Config
16  * \author Christian Richter <crich@beronet.com>
17  */
18
19
20
21
22 #ifndef CHAN_MISDN_CONFIG_H
23 #define CHAN_MISDN_CONFIG_H
24
25 #define BUFFERSIZE 512
26
27 enum misdn_cfg_elements {
28
29         /* port config items */
30         MISDN_CFG_FIRST = 0,
31         MISDN_CFG_GROUPNAME,           /* char[] */
32         MISDN_CFG_ALLOWED_BEARERS,           /* char[] */
33         MISDN_CFG_FAR_ALERTING,        /* int (bool) */
34         MISDN_CFG_RXGAIN,              /* int */
35         MISDN_CFG_TXGAIN,              /* int */
36         MISDN_CFG_TE_CHOOSE_CHANNEL,   /* int (bool) */
37         MISDN_CFG_PMP_L1_CHECK,        /* int (bool) */
38         MISDN_CFG_REJECT_CAUSE,         /* int */
39         MISDN_CFG_ALARM_BLOCK,        /* int (bool) */
40         MISDN_CFG_HDLC,                /* int (bool) */
41         MISDN_CFG_CONTEXT,             /* char[] */
42         MISDN_CFG_LANGUAGE,            /* char[] */
43         MISDN_CFG_MUSICCLASS,            /* char[] */
44         MISDN_CFG_CALLERID,            /* char[] */
45         MISDN_CFG_METHOD,              /* char[] */
46         MISDN_CFG_DIALPLAN,            /* int */
47         MISDN_CFG_LOCALDIALPLAN,       /* int */
48         MISDN_CFG_CPNDIALPLAN,       /* int */
49         MISDN_CFG_NATPREFIX,           /* char[] */
50         MISDN_CFG_INTERNATPREFIX,      /* char[] */
51         MISDN_CFG_PRES,                /* int */
52         MISDN_CFG_SCREEN,              /* int */
53         MISDN_CFG_ALWAYS_IMMEDIATE,    /* int (bool) */
54         MISDN_CFG_NODIALTONE,    /* int (bool) */
55         MISDN_CFG_IMMEDIATE,           /* int (bool) */
56         MISDN_CFG_SENDDTMF,           /* int (bool) */
57         MISDN_CFG_ASTDTMF,            /* int (bool) */
58         MISDN_CFG_HOLD_ALLOWED,        /* int (bool) */
59         MISDN_CFG_EARLY_BCONNECT,      /* int (bool) */
60         MISDN_CFG_INCOMING_EARLY_AUDIO,      /* int (bool) */
61         MISDN_CFG_ECHOCANCEL,          /* int */
62 #ifdef MISDN_1_2
63         MISDN_CFG_PIPELINE,      /* char[] */
64 #endif
65
66 #ifdef WITH_BEROEC
67         MISDN_CFG_BNECHOCANCEL,
68         MISDN_CFG_BNEC_ANTIHOWL,
69         MISDN_CFG_BNEC_NLP,
70         MISDN_CFG_BNEC_ZEROCOEFF,
71         MISDN_CFG_BNEC_TD,
72         MISDN_CFG_BNEC_ADAPT,
73 #endif
74         MISDN_CFG_NEED_MORE_INFOS,     /* bool */
75         MISDN_CFG_NOAUTORESPOND_ON_SETUP,     /* bool */
76         MISDN_CFG_NTTIMEOUT,            /* bool */
77         MISDN_CFG_BRIDGING,              /* bool */
78         MISDN_CFG_JITTERBUFFER,             /* int */
79         MISDN_CFG_JITTERBUFFER_UPPER_THRESHOLD,              /* int */
80         MISDN_CFG_CALLGROUP,           /* ast_group_t */
81         MISDN_CFG_PICKUPGROUP,         /* ast_group_t */
82         MISDN_CFG_MAX_IN,              /* int */
83         MISDN_CFG_MAX_OUT,              /* int */
84         MISDN_CFG_L1_TIMEOUT,          /* int */
85         MISDN_CFG_OVERLAP_DIAL,         /* int (bool)*/
86         MISDN_CFG_MSNS,                /* char[] */
87         MISDN_CFG_FAXDETECT,           /* char[] */
88         MISDN_CFG_FAXDETECT_CONTEXT,   /* char[] */
89         MISDN_CFG_FAXDETECT_TIMEOUT,   /* int */
90         MISDN_CFG_PTP,                 /* int (bool) */
91         MISDN_CFG_LAST,
92         
93         /* general config items */
94         MISDN_GEN_FIRST,
95 #ifndef MISDN_1_2
96         MISDN_GEN_MISDN_INIT,           /* char[] */
97 #endif
98         MISDN_GEN_DEBUG,               /* int */
99         MISDN_GEN_TRACEFILE,           /* char[] */
100         MISDN_GEN_BRIDGING,            /* int (bool) */
101         MISDN_GEN_STOP_TONE,           /* int (bool) */
102         MISDN_GEN_APPEND_DIGITS2EXTEN, /* int (bool) */
103         MISDN_GEN_DYNAMIC_CRYPT,       /* int (bool) */
104         MISDN_GEN_CRYPT_PREFIX,        /* char[] */
105         MISDN_GEN_CRYPT_KEYS,          /* char[] */
106         MISDN_GEN_NTKEEPCALLS,          /* int (bool) */
107         MISDN_GEN_NTDEBUGFLAGS,          /* int */
108         MISDN_GEN_NTDEBUGFILE,          /* char[] */
109         MISDN_GEN_LAST
110 };
111
112 enum misdn_cfg_method {
113         METHOD_STANDARD = 0,
114         METHOD_ROUND_ROBIN,
115         METHOD_STANDARD_DEC
116 };
117
118 /* you must call misdn_cfg_init before any other function of this header file */
119 int misdn_cfg_init(int max_ports, int reload); 
120 void misdn_cfg_reload(void);
121 void misdn_cfg_destroy(void);
122
123 void misdn_cfg_update_ptp( void );
124
125 /* if you requst a general config element, the port value is ignored. if the requested 
126  * value is not available, or the buffer is too small, the buffer will be nulled (in 
127  * case of a char* only its first byte will be nulled). */
128 void misdn_cfg_get(int port, enum misdn_cfg_elements elem, void* buf, int bufsize);
129
130 /* returns the enum element for the given name, returns MISDN_CFG_FIRST if none was found */
131 enum misdn_cfg_elements misdn_cfg_get_elem (char *name);
132
133 /* fills the buffer with the name of the given config element */
134 void misdn_cfg_get_name (enum misdn_cfg_elements elem, void *buf, int bufsize);
135
136 /* fills the buffer with the description of the given config element */
137 void misdn_cfg_get_desc (enum misdn_cfg_elements elem, void *buf, int bufsize, void *buf_default, int bufsize_default);
138
139 /* fills the buffer with a ',' separated list of all active ports */
140 void misdn_cfg_get_ports_string(char *ports);
141
142 /* fills the buffer with a nice printable string representation of the config element */
143 void misdn_cfg_get_config_string(int port, enum misdn_cfg_elements elem, char* buf, int bufsize);
144
145 /* returns the next available port number. returns -1 if the last one was reached. */
146 int misdn_cfg_get_next_port(int port);
147 int misdn_cfg_get_next_port_spin(int port);
148
149 int misdn_cfg_is_msn_valid(int port, char* msn);
150 int misdn_cfg_is_port_valid(int port);
151 int misdn_cfg_is_group_method(char *group, enum misdn_cfg_method meth);
152
153 #if 0
154 char *misdn_cfg_get_next_group(char *group);
155 int misdn_cfg_get_next_port_in_group(int port, char *group);
156 #endif
157
158 struct ast_jb_conf *misdn_get_global_jbconf(void);
159
160 #endif