** **
\*****************************************************************************/
-#include <stdio.h>
-#include <string.h>
-#include <stdlib.h>
-#include "main.h"
+#include "stdio.h"
+#include "string.h"
+#include "stdarg.h"
+#include "unistd.h"
+#include "stdlib.h"
+#include "macro.h"
+#include "extension.h"
+#include "options.h"
struct options options = {
- "/usr/local/pbx/log", /* log file */
- {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
+ "/usr/local/lcr/log", /* log file */
0x0000, /* debug mode */
'a', /* a-law */
"0", /* national prefix */
"tones_american", /* directory of tones */
"", /* directories of tones to fetch */
"extensions", /* directory of extensions */
- "", /* h323 endpoint name */
- 0, /* h323 ringconnect */
- 0,4, 0,2, 0, 0, 0, 0,4, 0,4, 0,64, /* h323 codecs to use */
- 0,"",1720, /* allow incoming h323 calls */
- 0,"", /* register with h323 gatekeeper */
- 5060, 5, /* SIP port, maxqueue */
- 0, /* dtmf detection on */
"", /* dummy caller id */
0, /* use tones by dsp.o */
0, /* by default use priority 0 */
- "pbx@jolly.de" /* source mail adress */
+ "lcr@your.machine" /* source mail adress */
};
+char options_error[256];
+
/* read options
*
* read options from options.conf
char param[256];
unsigned int line,i;
char buffer[256];
-#ifdef H323
- int codecpri = 0;
-#endif
SPRINT(filename, "%s/options.conf", INSTALL_DATA);
if (!(fp=fopen(filename,"r")))
{
- PERROR("Cannot open %s\n",filename);
- return(-1);
+ SPRINT(options_error, "Cannot open %s\n",filename);
+ return(0);
}
line=0;
{
if (i+1 >= sizeof(option))
{
- PERROR_RUNTIME("Error in %s (line %d): option too long.\n",filename,line);
+ SPRINT(options_error, "Error in %s (line %d): option too long.\n",filename,line);
goto error;
}
option[i+1] = '\0';
{
if (i+1 >= sizeof(param))
{
- PERROR_RUNTIME("Error in %s (line %d): param too long.\n",filename,line);
+ SPRINT(options_error, "Error in %s (line %d): param too long.\n",filename,line);
goto error;
}
param[i+1] = '\0';
/* check option */
if (!strcmp(option,"nt_if") || !strcmp(option,"te_if"))
{
- PERROR_RUNTIME("Error in %s (line %d): obsolete option %s. Use multiple 'port' options to define ports to use.\n",filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): obsolete option %s. Use multiple 'port' options to define ports to use.\n",filename,line,option);
goto error;
} else
if (!strcmp(option,"debug"))
{
if (param[0]==0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
goto error;
}
options.deb = strtol(param, NULL, 0);
- PDEBUG(DEBUG_CONFIG, "debugging: 0x%x\n", options.deb);
} else
if (!strcmp(option,"log"))
{
if (param[0]==0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n",filename,line, option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line, option);
goto error;
}
SCPY(options.log, param);
- PDEBUG(DEBUG_CONFIG, "log file: %s\n", options.log);
- } else
- if (!strcmp(option,"port"))
- {
- i = strtol(param, NULL, 0);
- if (i < 1 || i > sizeof(options.ports))
- {
- PERROR_RUNTIME("Error in %s (line %d): port number %s out of range.\n", filename, line, option);
- goto error;
- }
- options.ports[i] |= FLAG_PORT_USE;
-
- PDEBUG(DEBUG_CONFIG, "adding interface: %d (param=%s)\n", i, param);
- if (strstr(param, "ptp"))
- {
- options.ports[i] |= FLAG_PORT_PTP;
- PDEBUG(DEBUG_CONFIG, " -> interface shall be ptp\n");
- }
- } else
-#if 0
- if (!strcmp(option,"ptp"))
- {
- options.ptp = 1;
-
- PDEBUG(DEBUG_CONFIG, "ptp layer-2 watch and keep established.\n");
} else
-#endif
if (!strcmp(option,"alaw"))
{
options.law = 'a';
- PDEBUG(DEBUG_CONFIG, "isdn audio type: alaw\n");
} else
if (!strcmp(option,"ulaw"))
{
options.law = 'u';
- PDEBUG(DEBUG_CONFIG, "isdn audio type: ulaw\n");
- } else
- if (!strcmp(option,"h323_name"))
- {
-#ifdef H323
- SCPY(options.h323_name, param);
-
- PDEBUG(DEBUG_CONFIG, "H323 endpoint name: '%s'\n", param);
-#endif
- } else
- if (!strcmp(option,"h323_ringconnect"))
- {
-#ifdef H323
- options.h323_ringconnect = 1;
-
- PDEBUG(DEBUG_CONFIG, "H323 ringconnect: enabled\n");
-#endif
- } else
- if (!strcmp(option,"h323_gsm"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_gsm_pri = codecpri;
- options.h323_gsm_opt = atoi(param);
- if (atoi(param)<1 && atoi(param)>7)
- {
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be in range 1..7.\n",filename,line,option);
- goto error;
- }
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: GSM, MicrosoftGSM priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_g726"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_g726_pri = codecpri;
- options.h323_g726_opt = atoi(param);
- if (atoi(param)<2 && atoi(param)>5)
- {
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be in range 2..5.\n",filename,line,option);
- goto error;
- }
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: G726 priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_g7231"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_g7231_pri = codecpri;
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: G7231 priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_g729a"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_g729a_pri = codecpri;
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: G729A priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_lpc10"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_lpc10_pri = codecpri;
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: LPC-10 priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_speex"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_speex_pri = codecpri;
- options.h323_speex_opt = atoi(param);
- if (atoi(param)<2 && atoi(param)>6)
- {
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be in range 2..6.\n",filename,line,option);
- goto error;
- }
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: Speex priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_xspeex"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_xspeex_pri = codecpri;
- options.h323_xspeex_opt = atoi(param);
- if (atoi(param)<2 && atoi(param)>6)
- {
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be in range 2..6.\n",filename,line,option);
- goto error;
- }
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: XiphSpeex priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_law"))
- {
-#ifdef H323
- codecpri ++;
- options.h323_law_pri = codecpri;
- options.h323_law_opt = atoi(param);
- if (atoi(param)<10 && atoi(param)>240)
- {
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be in range 10..240.\n",filename,line,option);
- goto error;
- }
-
- PDEBUG(DEBUG_CONFIG, "H323 codec to use: Alaw, muLaw priority %d\n", codecpri);
-#endif
- } else
- if (!strcmp(option,"h323_icall"))
- {
-#ifdef H323
- options.h323_icall = 1;
- SCPY(options.h323_icall_prefix, param);
-
- PDEBUG(DEBUG_CONFIG, "process incoming H323 call with prefix '%s'\n", param);
-#endif
- } else
- if (!strcmp(option,"h323_port"))
- {
-#ifdef H323
- options.h323_port = atoi(param);
-
- PDEBUG(DEBUG_CONFIG, "use port for incoming H323 calls: %d\n", atoi(param));
-#endif
- } else
- if (!strcmp(option,"sip_port"))
- {
-#ifdef SIP
- options.sip_port = atoi(param);
-
- PDEBUG(DEBUG_CONFIG, "use port for incoming SIP calls: %d\n", atoi(param));
-#endif
- } else
- if (!strcmp(option,"sip_maxqueue"))
- {
-#ifdef SIP
- options.sip_maxqueue = atoi(param);
-
- PDEBUG(DEBUG_CONFIG, "number of simultanious incoming sockets for SIP calls: %d\n", atoi(param));
-#endif
- } else
- if (!strcmp(option,"h323_gatekeeper"))
- {
-#ifdef H323
- options.h323_gatekeeper = 1;
- if (param[0])
- {
- SCPY(options.h323_gatekeeper_host, param);
- }
- PDEBUG(DEBUG_CONFIG, "register with H323 gatekeeper (%s)\n", (param[0])?param:"automatically");
-#endif
} else
if (!strcmp(option,"tones_dir"))
{
if (param[0]==0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
goto error;
}
if (param[strlen(param)-1] == '/')
param[strlen(param)-1]=0;
SCPY(options.tones_dir, param);
- PDEBUG(DEBUG_CONFIG, "directory of tones: %s\n",param);
} else
if (!strcmp(option,"fetch_tones"))
{
if (param[0]==0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
goto error;
}
if (param[strlen(param)-1] == '/')
param[strlen(param)-1]=0;
SCPY(options.fetch_tones, param);
- PDEBUG(DEBUG_CONFIG, "directories of tones to fetch: %s\n",param);
} else
if (!strcmp(option,"extensions_dir"))
{
if (param[0]==0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
goto error;
}
if (param[strlen(param)-1] == '/')
param[strlen(param)-1]=0;
SCPY(options.extensions_dir, param);
- PDEBUG(DEBUG_CONFIG, "directory of extensions: %s\n",param);
} else
if (!strcmp(option,"national"))
{
SCPY(options.national, param);
- PDEBUG(DEBUG_CONFIG, "national dial prefix: %s\n", param);
} else
if (!strcmp(option,"international"))
{
SCPY(options.international, param);
- PDEBUG(DEBUG_CONFIG, "inernational dial prefix: %s\n", param);
- } else
- if (!strcmp(option,"nodtmf"))
- {
- options.nodtmf = 1;
-
- PDEBUG(DEBUG_CONFIG, "disable dtmf detection\n");
} else
if (!strcmp(option,"dummyid"))
{
SCPY(options.dummyid, param);
- PDEBUG(DEBUG_CONFIG, "dummy caller id\n", param);
} else
if (!strcmp(option,"dsptones"))
{
else if (!strcasecmp(param, "none"))
options.dsptones = DSP_NONE;
else {
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option);
goto error;
}
- PDEBUG(DEBUG_CONFIG, "dsp tones = %d\n", options.dsptones);
} else
if (!strcmp(option,"schedule"))
{
options.schedule = atoi(param);
if (options.schedule < 0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be at least '0'.\n", filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s must be at least '0'.\n", filename,line,option);
goto error;
}
if (options.schedule > 99)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s must be '99' or less.\n", filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s must be '99' or less.\n", filename,line,option);
goto error;
}
- if (atoi(param))
- PDEBUG(DEBUG_CONFIG, "use real time scheduler priority: %d\n", atoi(param));
- else
- PDEBUG(DEBUG_CONFIG, "don't use real time scheduler\n");
} else
if (!strcmp(option,"email"))
{
if (param[0]==0)
{
- PERROR_RUNTIME("Error in %s (line %d): parameter for option %s missing.\n", filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n", filename,line,option);
goto error;
}
SCPY(options.email, param);
- PDEBUG(DEBUG_CONFIG, "source mail address of pbx: %s\n", param);
} else
{
- PERROR_RUNTIME("Error in %s (line %d): wrong option keyword %s.\n", filename,line,option);
+ SPRINT(options_error, "Error in %s (line %d): wrong option keyword %s.\n", filename,line,option);
goto error;
}
}
#if 0
if (!options.dsptones)
{
- PERROR_RUNTIME("Error in %s (line %d): option 'dsptones' missing.\n", filename);
+ SPRINT(options_error, "Error in %s (line %d): option 'dsptones' missing.\n", filename);
goto error;
}
#endif
if (!options.tones_dir[0])
{
- PERROR_RUNTIME("Error in %s (line %d): option 'tones_dir' with parameter missing.\n", filename);
+ SPRINT(options_error, "Error in %s (line %d): option 'tones_dir' with parameter missing.\n", filename);
goto error;
}
if (fp) fclose(fp);