X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=options.c;h=88f64246fe932a027736e617ffc787e75168f908;hp=d41680e28031963c3b7ca084f06aa7ce10f10d19;hb=882882e0e2f6c451c4b9a5aa8209aa60352049c9;hpb=2ed0fee489c37a6e2d4473f6185ebbe3e746ac11 diff --git a/options.c b/options.c index d41680e..88f6424 100644 --- a/options.c +++ b/options.c @@ -11,45 +11,41 @@ #include #include +#include +#include #include -#include "main.h" +#include "macro.h" +#include "extension.h" +#include "options.h" +#include +#include 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 */ "00", /* international 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, /* inband patterns on external calls */ - 0, /* use tones by dsp.o */ 0, /* by default use priority 0 */ - "pbx@jolly.de" /* source mail adress */ + "lcr@your.machine", /* source mail adress */ + "/var/tmp", /* path of lock files */ + 0700, /* rights of lcr admin socket */ + -1, /* socket user (-1= no change) */ + -1, /* socket group (-1= no change) */ + 0, /* enable gsm */ + 1 /* use polling of main loop */ }; +char options_error[256]; + /* read options * * read options from options.conf */ -int read_options(void) +int read_options(char *options_error) { FILE *fp=NULL; char filename[128]; @@ -58,28 +54,22 @@ int read_options(void) char param[256]; unsigned int line,i; char buffer[256]; -#ifdef H323 - int codecpri = 0; -#endif - SPRINT(filename, "%s/options.conf", INSTALL_DATA); + SPRINT(filename, "%s/options.conf", CONFIG_DATA); - if (!(fp=fopen(filename,"r"))) - { - PERROR("Cannot open %s\n",filename); - return(-1); + if (!(fp=fopen(filename,"r"))) { + UPRINT(options_error, "Cannot open %s\n",filename); + return(0); } line=0; - while((fgets(buffer,sizeof(buffer),fp))) - { + while((fgets(buffer,sizeof(buffer),fp))) { line++; buffer[sizeof(buffer)-1]=0; if (buffer[0]) buffer[strlen(buffer)-1]=0; p=buffer; - while(*p <= 32) /* skip spaces */ - { + while(*p <= 32) { /* skip spaces */ if (*p == 0) break; p++; @@ -89,33 +79,27 @@ int read_options(void) option[0]=0; i=0; /* read option */ - while(*p > 32) - { - if (i+1 >= sizeof(option)) - { - PERROR_RUNTIME("Error in %s (line %d): option too long.\n",filename,line); + while(*p > 32) { + if (i+1 >= sizeof(option)) { + UPRINT(options_error, "Error in %s (line %d): option too long.\n",filename,line); goto error; } option[i+1] = '\0'; option[i++] = *p++; } - while(*p <= 32) /* skip spaces */ - { + while(*p <= 32) { /* skip spaces */ if (*p == 0) break; p++; } param[0]=0; - if (*p!=0 && *p!='#') /* param */ - { + if (*p!=0 && *p!='#') { /* param */ i=0; /* read param */ - while(*p > 31) - { - if (i+1 >= sizeof(param)) - { - PERROR_RUNTIME("Error in %s (line %d): param too long.\n",filename,line); + while(*p > 31) { + if (i+1 >= sizeof(param)) { + UPRINT(options_error, "Error in %s (line %d): param too long.\n",filename,line); goto error; } param[i+1] = '\0'; @@ -126,365 +110,143 @@ int read_options(void) /* at this point we have option and param */ /* 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); + if (!strcmp(option,"nt_if") || !strcmp(option,"te_if")) { + UPRINT(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); + if (!strcmp(option,"debug")) { + if (param[0]==0) { + UPRINT(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); + if (!strcmp(option,"log")) { + if (param[0]==0) { + UPRINT(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")) - { + if (!strcmp(option,"alaw")) { options.law = 'a'; - PDEBUG(DEBUG_CONFIG, "isdn audio type: alaw\n"); } else - if (!strcmp(option,"ulaw")) - { + 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); + if (!strcmp(option,"tones_dir")) { + if (param[0]==0) { + UPRINT(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); + if (!strcmp(option,"fetch_tones")) { + if (param[0]==0) { + UPRINT(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); - 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); + if (!strcmp(option,"extensions_dir")) { + // obsolete } else - if (!strcmp(option,"national")) - { + if (!strcmp(option,"national")) { SCPY(options.national, param); - PDEBUG(DEBUG_CONFIG, "national dial prefix: %s\n", param); } else - if (!strcmp(option,"international")) - { + 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")) - { + if (!strcmp(option,"dummyid")) { SCPY(options.dummyid, param); - PDEBUG(DEBUG_CONFIG, "dummy caller id\n", param); } else - if (!strcmp(option,"inbandpattern")) - { - if (!strcasecmp(param, "yes")) - options.inbandpattern = 1; - - PDEBUG(DEBUG_CONFIG, "inband pattern = %s\n", (options.inbandpattern)?"yes":"no"); - } else - if (!strcmp(option,"dsptones")) - { - if (!strcasecmp(param, "american")) - options.dsptones = DSP_AMERICAN; - else if (!strcasecmp(param, "german")) - options.dsptones = DSP_GERMAN; - else if (!strcasecmp(param, "oldgerman")) - options.dsptones = DSP_OLDGERMAN; - 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); - goto error; - } - - PDEBUG(DEBUG_CONFIG, "dsp tones = %d\n", options.dsptones); + if (!strcmp(option,"dsptones")) { + UPRINT(options_error, "Error in %s (line %d): parameter 'dsptones' is obsolete. Just define the tones (american,german,oldgerman) at 'tones_dir' option.\n",filename,line); + goto error; } else - if (!strcmp(option,"schedule")) - { + 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); + if (options.schedule < 0) { + UPRINT(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); + if (options.schedule > 99) { + UPRINT(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); + if (!strcmp(option,"email")) { + if (param[0]==0) { + UPRINT(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); + if (!strcmp(option,"lock")) { + if (param[0]==0) { + UPRINT(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.lock, param); + + } else + if (!strcmp(option,"socketuser")) { + char * endptr = NULL; + options.socketuser = strtol(param, &endptr, 10); + if (*endptr != '\0') { + struct passwd * pwd = getpwnam(param); + if (pwd == NULL) { + UPRINT(options_error, "Error in %s (line %d): no such user: %s.\n",filename,line,param); + goto error; + } + options.socketuser = pwd->pw_uid; + } + } else + if (!strcmp(option,"socketgroup")) { + char * endptr = NULL; + options.socketgroup = strtol(param, &endptr, 10); + if (*endptr != '\0') { + struct group * grp = getgrnam(param); + if (grp == NULL) { + UPRINT(options_error, "Error in %s (line %d): no such group: %s.\n",filename,line,param); + goto error; + } + options.socketgroup = grp->gr_gid; + } + } else + if (!strcmp(option,"socketrights")) { + options.socketrights = strtol(param, NULL, 0); + } else + if (!strcmp(option,"gsm")) { + options.gsm = 1; + } else + if (!strcmp(option,"polling")) { + options.polling = 1; + } else { + UPRINT(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); - goto error; - } -#endif - if (!options.tones_dir[0]) - { - PERROR_RUNTIME("Error in %s (line %d): option 'tones_dir' with parameter missing.\n", filename); + if (!options.tones_dir[0]) { + UPRINT(options_error, "Error in %s (line %d): option 'tones_dir' with parameter missing.\n", filename,line); goto error; } if (fp) fclose(fp);