Asterisk - The Open Source Telephony Project  18.5.0
Data Structures | Macros | Functions | Variables
options.c File Reference

Symbols related to asterisk.conf options and paths. More...

#include "asterisk.h"
#include "asterisk/_private.h"
#include "asterisk/app.h"
#include "asterisk/config.h"
#include "asterisk/logger.h"
#include "asterisk/options.h"
#include "asterisk/paths.h"
#include "asterisk/pbx.h"
#include "asterisk/rtp_engine.h"
#include "asterisk/strings.h"
#include "asterisk/utils.h"
#include "../defaults.h"
#include <sys/time.h>
#include <sys/resource.h>
Include dependency graph for options.c:

Go to the source code of this file.

Data Structures

struct  _cfg_paths
 

Macros

#define AST_MIN_DTMF_DURATION   80
 
#define DEFAULT_MONITOR_DIR   DEFAULT_SPOOL_DIR "/monitor"
 
#define DEFAULT_RECORDING_DIR   DEFAULT_SPOOL_DIR "/recording"
 

Functions

void load_asterisk_conf (void)
 
void set_asterisk_conf_path (const char *path)
 
void set_socket_path (const char *path)
 
static void set_ulimit (int value)
 Set maximum open files. More...
 

Variables

const char * ast_config_AST_AGI_DIR = cfg_paths.agi_dir
 
const char * ast_config_AST_CACHE_DIR = cfg_paths.cache_dir
 
const char * ast_config_AST_CONFIG_DIR = cfg_paths.config_dir
 
const char * ast_config_AST_CONFIG_FILE = cfg_paths.config_file
 
const char * ast_config_AST_CTL = cfg_paths.ctl_file
 
const char * ast_config_AST_CTL_GROUP = cfg_paths.ctl_group
 
const char * ast_config_AST_CTL_OWNER = cfg_paths.ctl_owner
 
const char * ast_config_AST_CTL_PERMISSIONS = cfg_paths.ctl_perms
 
const char * ast_config_AST_DATA_DIR = cfg_paths.data_dir
 
const char * ast_config_AST_DB = cfg_paths.db_path
 
const char * ast_config_AST_KEY_DIR = cfg_paths.key_dir
 
const char * ast_config_AST_LOG_DIR = cfg_paths.log_dir
 
const char * ast_config_AST_MODULE_DIR = cfg_paths.module_dir
 
const char * ast_config_AST_MONITOR_DIR = cfg_paths.monitor_dir
 
const char * ast_config_AST_PID = cfg_paths.pid_path
 
const char * ast_config_AST_RECORDING_DIR = cfg_paths.recording_dir
 
const char * ast_config_AST_RUN_DIR = cfg_paths.run_dir
 
const char * ast_config_AST_RUN_GROUP = cfg_paths.run_group
 
const char * ast_config_AST_RUN_USER = cfg_paths.run_user
 
const char * ast_config_AST_SBIN_DIR = cfg_paths.sbin_dir
 
const char * ast_config_AST_SOCKET = cfg_paths.socket_path
 
const char * ast_config_AST_SPOOL_DIR = cfg_paths.spool_dir
 
const char * ast_config_AST_SYSTEM_NAME = cfg_paths.system_name
 
const char * ast_config_AST_VAR_DIR = cfg_paths.var_dir
 
char ast_defaultlanguage [MAX_LANGUAGE] = DEFAULT_LANGUAGE
 
struct ast_eid ast_eid_default
 Global EID. More...
 
int ast_option_maxcalls
 
int ast_option_maxfiles
 
double ast_option_maxload
 
int ast_option_pjproject_cache_pools
 
int ast_option_pjproject_log_level
 
unsigned int ast_option_rtpptdynamic = 35
 
int ast_option_rtpusedynamic = 1
 
struct ast_flags ast_options = { AST_DEFAULT_OPTIONS }
 
int ast_pjproject_max_log_level = -1
 
int ast_verb_sys_level
 
static struct _cfg_paths cfg_paths
 
int option_debug
 
unsigned int option_dtmfminduration = AST_MIN_DTMF_DURATION
 
long option_minmemfree
 
int option_trace
 
int option_verbose
 
char record_cache_dir [AST_CACHE_DIR_LEN] = DEFAULT_TMP_DIR
 

Detailed Description

Symbols related to asterisk.conf options and paths.

Author
Corey Farrell git@c.nosp@m.fwar.nosp@m.e.com

Definition in file options.c.

Macro Definition Documentation

◆ AST_MIN_DTMF_DURATION

#define AST_MIN_DTMF_DURATION   80

Default minimum DTMF digit length - 80ms

Definition at line 49 of file options.c.

Referenced by load_asterisk_conf().

◆ DEFAULT_MONITOR_DIR

#define DEFAULT_MONITOR_DIR   DEFAULT_SPOOL_DIR "/monitor"

Definition at line 51 of file options.c.

◆ DEFAULT_RECORDING_DIR

#define DEFAULT_RECORDING_DIR   DEFAULT_SPOOL_DIR "/recording"

Definition at line 52 of file options.c.

Function Documentation

◆ load_asterisk_conf()

void load_asterisk_conf ( void  )

Definition at line 210 of file options.c.

References _cfg_paths::agi_dir, AST_CACHE_DIR_LEN, ast_clear_flag, ast_config_AST_CONFIG_FILE, ast_config_AST_CTL, ast_config_AST_RUN_DIR, ast_config_AST_SYSTEM_NAME, ast_config_destroy(), ast_config_load2(), ast_copy_string(), ast_defaultlanguage, ast_eid_default, ast_language_is_prefix, AST_LOCK_TYPE_FLOCK, AST_LOCK_TYPE_LOCKFILE, ast_log, AST_MIN_DTMF_DURATION, AST_OPT_FLAG_ALWAYS_FORK, AST_OPT_FLAG_CACHE_MEDIA_FRAMES, AST_OPT_FLAG_CACHE_RECORD_FILES, AST_OPT_FLAG_CONSOLE, AST_OPT_FLAG_DONT_WARN, AST_OPT_FLAG_DUMP_CORE, AST_OPT_FLAG_EXEC_INCLUDES, AST_OPT_FLAG_FORCE_BLACK_BACKGROUND, AST_OPT_FLAG_HIDE_CONSOLE_CONNECT, AST_OPT_FLAG_HIDE_MESSAGING_AMI_EVENTS, AST_OPT_FLAG_HIGH_PRIORITY, AST_OPT_FLAG_INIT_KEYS, AST_OPT_FLAG_LIGHT_BACKGROUND, AST_OPT_FLAG_LOCK_CONFIG_DIR, AST_OPT_FLAG_NO_COLOR, AST_OPT_FLAG_NO_FORK, AST_OPT_FLAG_QUIET, AST_OPT_FLAG_REF_DEBUG, AST_OPT_FLAG_STDEXTEN_MACRO, AST_OPT_FLAG_TIMESTAMP, AST_OPT_FLAG_TRANSCODE_VIA_SLIN, AST_OPT_FLAG_TRANSMIT_SILENCE, ast_opt_remote, ast_option_maxcalls, ast_option_maxfiles, ast_option_maxload, ast_option_rtpptdynamic, ast_option_rtpusedynamic, ast_parse_arg(), AST_RTP_PT_FIRST_DYNAMIC, ast_set2_flag, ast_set_default_eid(), ast_set_flag, ast_set_lock_type(), ast_str_to_eid(), ast_strlen_zero, ast_true(), ast_variable_browse(), _cfg_paths::cache_dir, _cfg_paths::config_dir, CONFIG_FLAG_NOREALTIME, CONFIG_STATUS_FILEINVALID, CONFIG_STATUS_FILEMISSING, CONFIG_STATUS_FILEUNCHANGED, _cfg_paths::ctl_file, _cfg_paths::ctl_group, _cfg_paths::ctl_owner, _cfg_paths::ctl_perms, _cfg_paths::data_dir, _cfg_paths::db_path, getloadavg(), hostname, _cfg_paths::key_dir, live_dangerously, _cfg_paths::log_dir, LOG_ERROR, LOG_WARNING, MAX_LANGUAGE, MAXHOSTNAMELEN, _cfg_paths::module_dir, _cfg_paths::monitor_dir, ast_variable::name, ast_variable::next, option_debug, option_dtmfminduration, option_minmemfree, option_trace, option_verbose, PARSE_IN_RANGE, PARSE_UINT32, pbx_live_dangerously(), _cfg_paths::pid_path, record_cache_dir, _cfg_paths::recording_dir, _cfg_paths::run_dir, _cfg_paths::run_group, _cfg_paths::run_user, _cfg_paths::sbin_dir, set_ulimit(), _cfg_paths::socket_path, _cfg_paths::spool_dir, _cfg_paths::system_name, ast_variable::value, and _cfg_paths::var_dir.

Referenced by main().

211 {
212  struct ast_config *cfg;
213  struct ast_variable *v;
214  char hostname[MAXHOSTNAMELEN] = "";
215  struct ast_flags config_flags = { CONFIG_FLAG_NOREALTIME };
216  struct {
217  unsigned int dbdir:1;
218  unsigned int keydir:1;
219  } found = { 0, 0 };
220  /* Default to false for security */
221  int live_dangerously = 0;
222  int option_debug_new = 0;
223  int option_trace_new = 0;
224  int option_verbose_new = 0;
225 
226  /* init with buildtime config */
227 #ifdef REF_DEBUG
228  /* The REF_DEBUG compiler flag is now only used to enable refdebug by default.
229  * Support for debugging reference counts is always compiled in. */
231 #endif
232 
234 
235  cfg = ast_config_load2(ast_config_AST_CONFIG_FILE, "" /* core, can't reload */, config_flags);
236 
237  /* If AST_OPT_FLAG_EXEC_INCLUDES was previously enabled with -X turn it off now.
238  * Using #exec from other configs requires that it be enabled from asterisk.conf. */
240 
241  /* no asterisk.conf? no problem, use buildtime config! */
243  fprintf(stderr, "Unable to open specified master config file '%s', using built-in defaults\n", ast_config_AST_CONFIG_FILE);
244  return;
245  }
246 
247  for (v = ast_variable_browse(cfg, "files"); v; v = v->next) {
248  if (!strcasecmp(v->name, "astctlpermissions")) {
250  } else if (!strcasecmp(v->name, "astctlowner")) {
252  } else if (!strcasecmp(v->name, "astctlgroup")) {
254  } else if (!strcasecmp(v->name, "astctl")) {
256  }
257  }
258 
259  for (v = ast_variable_browse(cfg, "directories"); v; v = v->next) {
260  if (!strcasecmp(v->name, "astcachedir")) {
262  } else if (!strcasecmp(v->name, "astetcdir")) {
264  } else if (!strcasecmp(v->name, "astspooldir")) {
266  snprintf(cfg_paths.monitor_dir, sizeof(cfg_paths.monitor_dir), "%s/monitor", v->value);
267  snprintf(cfg_paths.recording_dir, sizeof(cfg_paths.recording_dir), "%s/recording", v->value);
268  } else if (!strcasecmp(v->name, "astvarlibdir")) {
270  if (!found.dbdir) {
271  snprintf(cfg_paths.db_path, sizeof(cfg_paths.db_path), "%s/astdb", v->value);
272  }
273  } else if (!strcasecmp(v->name, "astdbdir")) {
274  snprintf(cfg_paths.db_path, sizeof(cfg_paths.db_path), "%s/astdb", v->value);
275  found.dbdir = 1;
276  } else if (!strcasecmp(v->name, "astdatadir")) {
278  if (!found.keydir) {
279  snprintf(cfg_paths.key_dir, sizeof(cfg_paths.key_dir), "%s/keys", v->value);
280  }
281  } else if (!strcasecmp(v->name, "astkeydir")) {
282  snprintf(cfg_paths.key_dir, sizeof(cfg_paths.key_dir), "%s/keys", v->value);
283  found.keydir = 1;
284  } else if (!strcasecmp(v->name, "astlogdir")) {
286  } else if (!strcasecmp(v->name, "astagidir")) {
288  } else if (!strcasecmp(v->name, "astrundir")) {
289  snprintf(cfg_paths.pid_path, sizeof(cfg_paths.pid_path), "%s/%s", v->value, "asterisk.pid");
291  } else if (!strcasecmp(v->name, "astmoddir")) {
293  } else if (!strcasecmp(v->name, "astsbindir")) {
295  }
296  }
297 
298  /* Combine astrundir and astctl settings. */
299  snprintf(cfg_paths.socket_path, sizeof(cfg_paths.socket_path), "%s/%s",
301 
302  for (v = ast_variable_browse(cfg, "options"); v; v = v->next) {
303  /* verbose level (-v at startup) */
304  if (!strcasecmp(v->name, "verbose")) {
305  option_verbose_new = atoi(v->value);
306  /* whether or not to force timestamping in CLI verbose output. (-T at startup) */
307  } else if (!strcasecmp(v->name, "timestamp")) {
309  /* whether or not to support #exec in config files */
310  } else if (!strcasecmp(v->name, "execincludes")) {
312  /* debug level (-d at startup) */
313  } else if (!strcasecmp(v->name, "debug")) {
314  option_debug_new = 0;
315  if (sscanf(v->value, "%30d", &option_debug_new) != 1) {
316  option_debug_new = ast_true(v->value) ? 1 : 0;
317  }
318  } else if (!strcasecmp(v->name, "trace")) {
319  option_trace_new = 0;
320  if (sscanf(v->value, "%30d", &option_trace_new) != 1) {
321  option_trace_new = ast_true(v->value) ? 1 : 0;
322  }
323  } else if (!strcasecmp(v->name, "refdebug")) {
325 #if HAVE_WORKING_FORK
326  /* Disable forking (-f at startup) */
327  } else if (!strcasecmp(v->name, "nofork")) {
329  /* Always fork, even if verbose or debug are enabled (-F at startup) */
330  } else if (!strcasecmp(v->name, "alwaysfork")) {
332 #endif
333  /* Run quietly (-q at startup ) */
334  } else if (!strcasecmp(v->name, "quiet")) {
336  /* Run as console (-c at startup, implies nofork) */
337  } else if (!strcasecmp(v->name, "console")) {
338  if (!ast_opt_remote) {
340  }
341  /* Run with high priority if the O/S permits (-p at startup) */
342  } else if (!strcasecmp(v->name, "highpriority")) {
344  /* Initialize RSA auth keys (IAX2) (-i at startup) */
345  } else if (!strcasecmp(v->name, "initcrypto")) {
347  /* Disable ANSI colors for console (-c at startup) */
348  } else if (!strcasecmp(v->name, "nocolor")) {
350  /* Disable some usage warnings for picky people :p */
351  } else if (!strcasecmp(v->name, "dontwarn")) {
353  /* Dump core in case of crash (-g) */
354  } else if (!strcasecmp(v->name, "dumpcore")) {
356  /* Cache recorded sound files to another directory during recording */
357  } else if (!strcasecmp(v->name, "cache_record_files")) {
359 #if !defined(LOW_MEMORY)
360  /* Cache media frames for performance */
361  } else if (!strcasecmp(v->name, "cache_media_frames")) {
363 #endif
364  /* Specify cache directory */
365  } else if (!strcasecmp(v->name, "record_cache_dir")) {
367  /* Build transcode paths via SLINEAR, instead of directly */
368  } else if (!strcasecmp(v->name, "transcode_via_sln")) {
370  /* Transmit SLINEAR silence while a channel is being recorded or DTMF is being generated on a channel */
371  } else if (!strcasecmp(v->name, "transmit_silence_during_record") || !strcasecmp(v->name, "transmit_silence")) {
373  } else if (!strcasecmp(v->name, "mindtmfduration")) {
374  if (sscanf(v->value, "%30u", &option_dtmfminduration) != 1) {
376  }
377  } else if (!strcasecmp(v->name, "rtp_use_dynamic")) {
379  /* http://www.iana.org/assignments/rtp-parameters
380  * RTP dynamic payload types start at 96 normally; extend down to 0 */
381  } else if (!strcasecmp(v->name, "rtp_pt_dynamic")) {
384  } else if (!strcasecmp(v->name, "maxcalls")) {
385  if ((sscanf(v->value, "%30d", &ast_option_maxcalls) != 1) || (ast_option_maxcalls < 0)) {
387  }
388  } else if (!strcasecmp(v->name, "maxload")) {
389  double test[1];
390 
391  if (getloadavg(test, 1) == -1) {
392  ast_log(LOG_ERROR, "Cannot obtain load average on this system. 'maxload' option disabled.\n");
393  ast_option_maxload = 0.0;
394  } else if ((sscanf(v->value, "%30lf", &ast_option_maxload) != 1) || (ast_option_maxload < 0.0)) {
395  ast_option_maxload = 0.0;
396  }
397  /* Set the maximum amount of open files */
398  } else if (!strcasecmp(v->name, "maxfiles")) {
399  ast_option_maxfiles = atoi(v->value);
400  if (!ast_opt_remote) {
402  }
403  /* What user to run as */
404  } else if (!strcasecmp(v->name, "runuser")) {
406  /* What group to run as */
407  } else if (!strcasecmp(v->name, "rungroup")) {
409  } else if (!strcasecmp(v->name, "systemname")) {
411  } else if (!strcasecmp(v->name, "autosystemname")) {
412  if (ast_true(v->value)) {
413  if (!gethostname(hostname, sizeof(hostname) - 1)) {
415  } else {
418  }
419  ast_log(LOG_ERROR, "Cannot obtain hostname for this system. Using '%s' instead.\n", ast_config_AST_SYSTEM_NAME);
420  }
421  }
422  } else if (!strcasecmp(v->name, "languageprefix")) {
424  } else if (!strcasecmp(v->name, "defaultlanguage")) {
426  } else if (!strcasecmp(v->name, "lockmode")) {
427  if (!strcasecmp(v->value, "lockfile")) {
429  } else if (!strcasecmp(v->value, "flock")) {
431  } else {
432  ast_log(LOG_WARNING, "'%s' is not a valid setting for the lockmode option, "
433  "defaulting to 'lockfile'\n", v->value);
435  }
436 #if defined(HAVE_SYSINFO)
437  } else if (!strcasecmp(v->name, "minmemfree")) {
438  /* specify the minimum amount of free memory to retain. Asterisk should stop accepting new calls
439  * if the amount of free memory falls below this watermark */
440  if ((sscanf(v->value, "%30ld", &option_minmemfree) != 1) || (option_minmemfree < 0)) {
441  option_minmemfree = 0;
442  }
443 #endif
444  } else if (!strcasecmp(v->name, "entityid")) {
445  struct ast_eid tmp_eid;
446  if (!ast_str_to_eid(&tmp_eid, v->value)) {
447  ast_eid_default = tmp_eid;
448  } else {
449  ast_log(LOG_WARNING, "Invalid Entity ID '%s' provided\n", v->value);
450  }
451  } else if (!strcasecmp(v->name, "lightbackground")) {
453  } else if (!strcasecmp(v->name, "forceblackbackground")) {
455  } else if (!strcasecmp(v->name, "hideconnect")) {
457  } else if (!strcasecmp(v->name, "lockconfdir")) {
459  } else if (!strcasecmp(v->name, "stdexten")) {
460  /* Choose how to invoke the extensions.conf stdexten */
461  if (!strcasecmp(v->value, "gosub")) {
463  } else if (!strcasecmp(v->value, "macro")) {
465  } else {
467  "'%s' is not a valid setting for the stdexten option, defaulting to 'gosub'\n",
468  v->value);
470  }
471  } else if (!strcasecmp(v->name, "live_dangerously")) {
472  live_dangerously = ast_true(v->value);
473  } else if (!strcasecmp(v->name, "hide_messaging_ami_events")) {
475  }
476  }
477  if (!ast_opt_remote) {
478  pbx_live_dangerously(live_dangerously);
479  }
480 
481  option_debug += option_debug_new;
482  option_trace += option_trace_new;
483  option_verbose += option_verbose_new;
484 
485  ast_config_destroy(cfg);
486 }
struct ast_variable * next
char run_user[PATH_MAX]
Definition: options.c:119
int ast_option_maxfiles
Definition: options.c:81
void ast_set_lock_type(enum AST_LOCK_TYPE type)
Set the type of locks used by ast_lock_path()
Definition: main/app.c:2452
unsigned int option_dtmfminduration
Definition: options.c:83
char data_dir[PATH_MAX]
Definition: options.c:108
static int live_dangerously
Set to true (non-zero) to globally allow all dangerous dialplan functions to run. ...
Definition: pbx_functions.c:46
char cache_dir[PATH_MAX]
Definition: options.c:101
#define ast_set2_flag(p, value, flag)
Definition: utils.h:94
int option_debug
Definition: options.c:69
struct ast_variable * ast_variable_browse(const struct ast_config *config, const char *category_name)
Definition: extconf.c:1216
#define ast_set_flag(p, flag)
Definition: utils.h:70
#define LOG_WARNING
Definition: logger.h:274
#define CONFIG_STATUS_FILEINVALID
char ctl_group[PATH_MAX]
Definition: options.c:124
struct ast_config * ast_config_load2(const char *filename, const char *who_asked, struct ast_flags flags)
Load a config file.
Definition: main/config.c:3154
Structure for variables, used for configurations and for channel variables.
char var_dir[PATH_MAX]
Definition: options.c:107
const char * ast_config_AST_SYSTEM_NAME
Definition: options.c:170
char module_dir[PATH_MAX]
Definition: options.c:103
int option_verbose
Definition: options.c:67
char key_dir[PATH_MAX]
Definition: options.c:112
void ast_set_default_eid(struct ast_eid *eid)
Fill in an ast_eid with the default eid of this machine.
Definition: main/utils.c:2749
double ast_option_maxload
Definition: options.c:77
#define MAXHOSTNAMELEN
Definition: network.h:69
#define AST_RTP_PT_FIRST_DYNAMIC
Definition: rtp_engine.h:92
#define AST_MIN_DTMF_DURATION
Definition: options.c:49
const char * ast_config_AST_CONFIG_FILE
Definition: options.c:152
An Entity ID is essentially a MAC address, brief and unique.
Definition: utils.h:786
int ast_option_maxcalls
Definition: options.c:79
#define MAX_LANGUAGE
Definition: channel.h:173
#define ast_strlen_zero(foo)
Definition: strings.h:52
const char * ast_config_AST_RUN_DIR
Definition: options.c:162
char sbin_dir[PATH_MAX]
Definition: options.c:116
char run_group[PATH_MAX]
Definition: options.c:120
char ast_defaultlanguage[MAX_LANGUAGE]
Definition: options.c:98
#define ast_log
Definition: astobj2.c:42
char spool_dir[PATH_MAX]
Definition: options.c:104
long option_minmemfree
Definition: options.c:86
int ast_language_is_prefix
The following variable controls the layout of localized sound files. If 0, use the historical layout ...
Definition: file.c:67
#define AST_CACHE_DIR_LEN
Definition: options.h:32
char db_path[PATH_MAX]
Definition: options.c:115
void ast_config_destroy(struct ast_config *config)
Destroys a config.
Definition: extconf.c:1290
int ast_str_to_eid(struct ast_eid *eid, const char *s)
Convert a string into an EID.
Definition: main/utils.c:2825
char recording_dir[PATH_MAX]
Definition: options.c:106
char monitor_dir[PATH_MAX]
Definition: options.c:105
#define CONFIG_STATUS_FILEUNCHANGED
char ctl_owner[PATH_MAX]
Definition: options.c:123
#define LOG_ERROR
Definition: logger.h:285
int attribute_pure ast_true(const char *val)
Make sure something is true. Determine if a string containing a boolean value is "true". This function checks to see whether a string passed to it is an indication of an "true" value. It checks to see if the string is "yes", "true", "y", "t", "on" or "1".
Definition: main/utils.c:1951
#define ast_opt_remote
Definition: options.h:112
char record_cache_dir[AST_CACHE_DIR_LEN]
Definition: options.c:96
char pid_path[PATH_MAX]
Definition: options.c:117
char config_dir[PATH_MAX]
Definition: options.c:102
void pbx_live_dangerously(int new_live_dangerously)
Enable/disable the execution of &#39;dangerous&#39; functions from external protocols (AMI, etc.).
int ast_parse_arg(const char *arg, enum ast_parse_flags flags, void *result,...)
The argument parsing routine.
Definition: main/config.c:3657
Structure used to handle boolean flags.
Definition: utils.h:199
#define ast_clear_flag(p, flag)
Definition: utils.h:77
#define CONFIG_STATUS_FILEMISSING
char run_dir[PATH_MAX]
Definition: options.c:111
struct ast_flags ast_options
Definition: options.c:61
static void set_ulimit(int value)
Set maximum open files.
Definition: options.c:178
char ctl_perms[PATH_MAX]
Definition: options.c:122
void ast_copy_string(char *dst, const char *src, size_t size)
Size-limited null-terminating string copy.
Definition: strings.h:401
char socket_path[PATH_MAX]
Definition: options.c:118
char agi_dir[PATH_MAX]
Definition: options.c:110
const char * ast_config_AST_CTL
Definition: options.c:175
static struct ast_str * hostname
Definition: cdr_mysql.c:77
int getloadavg(double *list, int nelem)
int ast_option_rtpusedynamic
Definition: options.c:88
static struct _cfg_paths cfg_paths
Definition: options.c:128
char log_dir[PATH_MAX]
Definition: options.c:109
char ctl_file[PATH_MAX]
Definition: options.c:125
unsigned int ast_option_rtpptdynamic
Definition: options.c:89
char system_name[128]
Definition: options.c:121
struct ast_eid ast_eid_default
Global EID.
Definition: options.c:93
int option_trace
Definition: options.c:71

◆ set_asterisk_conf_path()

void set_asterisk_conf_path ( const char *  path)

Definition at line 200 of file options.c.

References ast_copy_string(), and _cfg_paths::config_file.

Referenced by main().

201 {
203 }
void ast_copy_string(char *dst, const char *src, size_t size)
Size-limited null-terminating string copy.
Definition: strings.h:401
static struct _cfg_paths cfg_paths
Definition: options.c:128
char config_file[PATH_MAX]
Definition: options.c:114

◆ set_socket_path()

void set_socket_path ( const char *  path)

Definition at line 205 of file options.c.

References ast_copy_string(), and _cfg_paths::socket_path.

Referenced by main().

206 {
208 }
void ast_copy_string(char *dst, const char *src, size_t size)
Size-limited null-terminating string copy.
Definition: strings.h:401
char socket_path[PATH_MAX]
Definition: options.c:118
static struct _cfg_paths cfg_paths
Definition: options.c:128

◆ set_ulimit()

static void set_ulimit ( int  value)
static

Set maximum open files.

Definition at line 178 of file options.c.

References ast_log, errno, LOG_NOTICE, LOG_WARNING, and value.

Referenced by load_asterisk_conf().

179 {
180  struct rlimit l = {0, 0};
181 
182  if (value <= 0) {
183  ast_log(LOG_WARNING, "Unable to change max files open to invalid value %i\n",value);
184  return;
185  }
186 
187  l.rlim_cur = value;
188  l.rlim_max = value;
189 
190  if (setrlimit(RLIMIT_NOFILE, &l)) {
191  ast_log(LOG_WARNING, "Unable to disable core size resource limit: %s\n",strerror(errno));
192  return;
193  }
194 
195  ast_log(LOG_NOTICE, "Setting max files open to %d\n",value);
196 
197  return;
198 }
#define LOG_WARNING
Definition: logger.h:274
int value
Definition: syslog.c:37
#define ast_log
Definition: astobj2.c:42
int errno
#define LOG_NOTICE
Definition: logger.h:263

Variable Documentation

◆ ast_config_AST_AGI_DIR

const char* ast_config_AST_AGI_DIR = cfg_paths.agi_dir

Definition at line 160 of file options.c.

Referenced by ast_str_retrieve_variable(), handle_show_settings(), and launch_script().

◆ ast_config_AST_CACHE_DIR

const char* ast_config_AST_CACHE_DIR = cfg_paths.cache_dir

Definition at line 150 of file options.c.

Referenced by ast_bucket_file_temporary_create(), and ast_str_retrieve_variable().

◆ ast_config_AST_CONFIG_DIR

const char* ast_config_AST_CONFIG_DIR = cfg_paths.config_dir

Definition at line 151 of file options.c.

◆ ast_config_AST_CONFIG_FILE

const char* ast_config_AST_CONFIG_FILE = cfg_paths.config_file

Definition at line 152 of file options.c.

Referenced by handle_show_settings(), launch_script(), and load_asterisk_conf().

◆ ast_config_AST_CTL

const char* ast_config_AST_CTL = cfg_paths.ctl_file

Definition at line 175 of file options.c.

Referenced by load_asterisk_conf().

◆ ast_config_AST_CTL_GROUP

const char* ast_config_AST_CTL_GROUP = cfg_paths.ctl_group

Definition at line 174 of file options.c.

Referenced by ast_makesocket().

◆ ast_config_AST_CTL_OWNER

const char* ast_config_AST_CTL_OWNER = cfg_paths.ctl_owner

Definition at line 173 of file options.c.

Referenced by ast_makesocket().

◆ ast_config_AST_CTL_PERMISSIONS

const char* ast_config_AST_CTL_PERMISSIONS = cfg_paths.ctl_perms

Definition at line 172 of file options.c.

Referenced by ast_makesocket().

◆ ast_config_AST_DATA_DIR

const char* ast_config_AST_DATA_DIR = cfg_paths.data_dir

◆ ast_config_AST_DB

const char* ast_config_AST_DB = cfg_paths.db_path

◆ ast_config_AST_KEY_DIR

const char* ast_config_AST_KEY_DIR = cfg_paths.key_dir

◆ ast_config_AST_LOG_DIR

const char* ast_config_AST_LOG_DIR = cfg_paths.log_dir

◆ ast_config_AST_MODULE_DIR

const char* ast_config_AST_MODULE_DIR = cfg_paths.module_dir

◆ ast_config_AST_MONITOR_DIR

const char* ast_config_AST_MONITOR_DIR = cfg_paths.monitor_dir

◆ ast_config_AST_PID

const char* ast_config_AST_PID = cfg_paths.pid_path

Definition at line 166 of file options.c.

Referenced by asterisk_daemon(), handle_show_settings(), and really_quit().

◆ ast_config_AST_RECORDING_DIR

const char* ast_config_AST_RECORDING_DIR = cfg_paths.recording_dir

◆ ast_config_AST_RUN_DIR

const char* ast_config_AST_RUN_DIR = cfg_paths.run_dir

◆ ast_config_AST_RUN_GROUP

const char* ast_config_AST_RUN_GROUP = cfg_paths.run_group

◆ ast_config_AST_RUN_USER

const char* ast_config_AST_RUN_USER = cfg_paths.run_user

◆ ast_config_AST_SBIN_DIR

const char* ast_config_AST_SBIN_DIR = cfg_paths.sbin_dir

Definition at line 163 of file options.c.

Referenced by asterisk_daemon(), and convert_bdb_to_sqlite3().

◆ ast_config_AST_SOCKET

const char* ast_config_AST_SOCKET = cfg_paths.socket_path

Definition at line 167 of file options.c.

Referenced by ast_makesocket(), ast_tryconnect(), ast_var_Config(), main(), and really_quit().

◆ ast_config_AST_SPOOL_DIR

const char* ast_config_AST_SPOOL_DIR = cfg_paths.spool_dir

◆ ast_config_AST_SYSTEM_NAME

const char* ast_config_AST_SYSTEM_NAME = cfg_paths.system_name

◆ ast_config_AST_VAR_DIR

const char* ast_config_AST_VAR_DIR = cfg_paths.var_dir

Definition at line 157 of file options.c.

◆ ast_defaultlanguage

char ast_defaultlanguage[MAX_LANGUAGE] = DEFAULT_LANGUAGE

◆ ast_eid_default

struct ast_eid ast_eid_default

◆ cfg_paths

struct _cfg_paths cfg_paths
static

Definition at line 128 of file options.c.

◆ record_cache_dir

char record_cache_dir[AST_CACHE_DIR_LEN] = DEFAULT_TMP_DIR

Definition at line 96 of file options.c.

Referenced by ast_writefile(), and load_asterisk_conf().