X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=options.c;h=760cfb339a26b0caadd75e3406b2308633f4b321;hp=f58d7f94058e0734b35376c9e07850fe43d25442;hb=2dbfdb87dd122cd057887a16e84cf635f8abf67b;hpb=320159175adced71da64efa80e9334f7bcab96c8 diff --git a/options.c b/options.c index f58d7f9..760cfb3 100644 --- a/options.c +++ b/options.c @@ -9,11 +9,11 @@ ** ** \*****************************************************************************/ -#include "stdio.h" -#include "string.h" -#include "stdarg.h" -#include "unistd.h" -#include "stdlib.h" +#include +#include +#include +#include +#include #include "macro.h" #include "extension.h" #include "options.h" @@ -21,7 +21,7 @@ #include struct options options = { - "/usr/local/lcr/log", /* log file */ + LOG_DIR "/log", /* log file */ 0x0000, /* debug mode */ 'a', /* a-law */ "0", /* national prefix */ @@ -31,11 +31,13 @@ struct options options = { "", /* dummy caller id */ 0, /* by default use priority 0 */ "lcr@your.machine", /* source mail adress */ - "/var/tmp", /* path of lock files */ + "/var/run", /* 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 */ + "mISDN_l1loop.1", /* GSM/Asterisk side */ + "mISDN_l1loop.2", /* LCR side */ }; char options_error[256]; @@ -44,7 +46,7 @@ char options_error[256]; * * read options from options.conf */ -int read_options(void) +int read_options(char *options_error) { FILE *fp=NULL; char filename[128]; @@ -57,7 +59,7 @@ int read_options(void) SPRINT(filename, "%s/options.conf", CONFIG_DATA); if (!(fp=fopen(filename,"r"))) { - SPRINT(options_error, "Cannot open %s\n",filename); + UPRINT(options_error, "Cannot open %s\n",filename); return(0); } @@ -80,7 +82,7 @@ int read_options(void) i=0; /* read option */ while(*p > 32) { if (i+1 >= sizeof(option)) { - SPRINT(options_error, "Error in %s (line %d): option too long.\n",filename,line); + UPRINT(options_error, "Error in %s (line %d): option too long.\n",filename,line); goto error; } option[i+1] = '\0'; @@ -98,7 +100,7 @@ int read_options(void) i=0; /* read param */ while(*p > 31) { if (i+1 >= sizeof(param)) { - SPRINT(options_error, "Error in %s (line %d): param too long.\n",filename,line); + UPRINT(options_error, "Error in %s (line %d): param too long.\n",filename,line); goto error; } param[i+1] = '\0'; @@ -110,12 +112,12 @@ int read_options(void) /* check option */ if (!strcmp(option,"nt_if") || !strcmp(option,"te_if")) { - SPRINT(options_error, "Error in %s (line %d): obsolete option %s. Use multiple 'port' options to define ports to use.\n",filename,line,option); + 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) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); + 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); @@ -123,7 +125,7 @@ int read_options(void) } else if (!strcmp(option,"log")) { if (param[0]==0) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line, option); + UPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line, option); goto error; } SCPY(options.log, param); @@ -139,7 +141,7 @@ int read_options(void) } else if (!strcmp(option,"tones_dir")) { if (param[0]==0) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); + UPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); goto error; } if (param[strlen(param)-1] == '/') @@ -149,7 +151,7 @@ int read_options(void) } else if (!strcmp(option,"fetch_tones")) { if (param[0]==0) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); + UPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); goto error; } if (param[strlen(param)-1] == '/') @@ -173,24 +175,24 @@ int read_options(void) } else if (!strcmp(option,"dsptones")) { - SPRINT(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,option); + 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")) { options.schedule = atoi(param); if (options.schedule < 0) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s must be at least '0'.\n", filename,line,option); + 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) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s must be '99' or less.\n", filename,line,option); + UPRINT(options_error, "Error in %s (line %d): parameter for option %s must be '99' or less.\n", filename,line,option); goto error; } } else if (!strcmp(option,"email")) { if (param[0]==0) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n", filename,line,option); + UPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n", filename,line,option); goto error; } SCPY(options.email, param); @@ -198,7 +200,7 @@ int read_options(void) } else if (!strcmp(option,"lock")) { if (param[0]==0) { - SPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); + UPRINT(options_error, "Error in %s (line %d): parameter for option %s missing.\n",filename,line,option); goto error; } if (param[strlen(param)-1] == '/') @@ -212,7 +214,7 @@ int read_options(void) if (*endptr != '\0') { struct passwd * pwd = getpwnam(param); if (pwd == NULL) { - SPRINT(options_error, "Error in %s (line %d): no such user: %s.\n",filename,line,param); + UPRINT(options_error, "Error in %s (line %d): no such user: %s.\n",filename,line,param); goto error; } options.socketuser = pwd->pw_uid; @@ -224,7 +226,7 @@ int read_options(void) if (*endptr != '\0') { struct group * grp = getgrnam(param); if (grp == NULL) { - SPRINT(options_error, "Error in %s (line %d): no such group: %s.\n",filename,line,param); + UPRINT(options_error, "Error in %s (line %d): no such group: %s.\n",filename,line,param); goto error; } options.socketgroup = grp->gr_gid; @@ -233,16 +235,32 @@ int read_options(void) if (!strcmp(option,"socketrights")) { options.socketrights = strtol(param, NULL, 0); } else - if (!strcmp(option,"gsm")) { - options.gsm = 1; + if (!strcmp(option,"polling")) { + options.polling = 1; + } else + if (!strcmp(option,"loopback-ext")) { + 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.loopback_ext, param); + + } else + if (!strcmp(option,"loopback-lcr")) { + 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.loopback_lcr, param); + } else { - SPRINT(options_error, "Error in %s (line %d): wrong option keyword %s.\n", filename,line,option); + UPRINT(options_error, "Error in %s (line %d): wrong option keyword %s.\n", filename,line,option); goto error; } } if (!options.tones_dir[0]) { - SPRINT(options_error, "Error in %s (line %d): option 'tones_dir' with parameter missing.\n", filename); + UPRINT(options_error, "Error in %s (line %d): option 'tones_dir' with parameter missing.\n", filename,line); goto error; } if (fp) fclose(fp);