cookbooks:4.0.x:core:cfg
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
cookbooks:4.0.x:core:cfg [2013/06/18 09:00] – [Comments] poing | cookbooks:4.0.x:core:cfg [2013/06/26 07:39] (current) – [Configuration Directives] poing | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | <fc # | ||
- | |||
====== The Configuration File ====== | ====== The Configuration File ====== | ||
===== Configuration Elements ===== | ===== Configuration Elements ===== | ||
- | For the sake and sanity of the user of this software, we need to cover the basic elements of the configuration before getting to the meat and potatoes. | + | For the sake and sanity of the user of this software, we should |
* Configuration Directives | * Configuration Directives | ||
Line 18: | Line 16: | ||
There are five (5) types of configuration directives used with Kamailio.\\ | There are five (5) types of configuration directives used with Kamailio.\\ | ||
- | <fc #AA0000>**Each configuration directive | + | ^ |
- C-Style Control Directives | - C-Style Control Directives | ||
Line 30: | Line 28: | ||
==== Comments ==== | ==== Comments ==== | ||
- | <fc #FF0000>**The first thing you should understand is the comment syntax used in the configuration file.\\ \\ **</ | + | ^ |
Comments in the configuration file are a mixture of C-Style (**not C++**) and scripting language syntaxes.\\ | Comments in the configuration file are a mixture of C-Style (**not C++**) and scripting language syntaxes.\\ | ||
- | It closely resembles the PHP style, **// | + | It closely resembles the PHP style, **// |
- | It can be confusing seeing the C-Style Control Directives ([[cfg# | + | It can be confusing seeing the C-Style Control Directives ([[cfg# |
- | < | + | ^ Examples: |
- | /* block comment | + | |Block Comment:< |
- | block comment */ | + | /* This is a ... |
- | // this is NOT a line comment | + | block comment */</ |
- | # this is a line comment | + | |<fc # |
- | #!c_style_directive | + | |Line Comment:< |
- | </ | + | |**< |
----- | ----- | ||
Line 53: | Line 52: | ||
The general use is to allow for comments or additional configuration directives be placed on the same line. | The general use is to allow for comments or additional configuration directives be placed on the same line. | ||
- | < | + | ^ Examples: |
+ | |< | ||
configuration_directive_a | configuration_directive_a | ||
configuration_directive_b; | configuration_directive_b; | ||
configuration_directive_c; | configuration_directive_c; | ||
configuration_directive_e; | configuration_directive_e; | ||
- | </ | + | </ |
----- | ----- | ||
Line 64: | Line 64: | ||
===== Configuration Directives ===== | ===== Configuration Directives ===== | ||
+ | |||
+ | ^ Type ^ Format ^ Comment ^ | ||
+ | | C-Style Control Directives | #!directive [ NAME [ VALUE ] ] | Begins with hash-bang (#!) | | ||
+ | | Apache-Like Name/Value Pairs | name " | ||
+ | | Normal Name/Value Pairs | name=value | Delimited by an equals sign | | ||
+ | | Modify Parameter Procedure | modparam(" | ||
+ | | Route Functions | route {...} | Scripting Language | | ||
==== C-Style Control Directives ==== | ==== C-Style Control Directives ==== | ||
Line 79: | Line 86: | ||
* #!substdef | * #!substdef | ||
- | < | + | ^ Example: |
+ | |< | ||
#!define MODULE_NAME | #!define MODULE_NAME | ||
#!ifdef MODULE_NAME | #!ifdef MODULE_NAME | ||
- | .. set directives .. | + | ".. set directives .." |
#!else | #!else | ||
- | .. set alternate directives .. | + | ".. set alternate directives .." |
#!endif | #!endif | ||
- | </ | + | </ |
+ | ----- | ||
==== Apache Name/Value Pairs ==== | ==== Apache Name/Value Pairs ==== | ||
- | | + | ^ Syntax |
+ | | <code c>name " | ||
<fc # | <fc # | ||
- | | + | ^ Examples |
- | loadmodule " | + | |< |
- | include_file " | + | loadmodule " |
- | import_file "/ | + | loadmodule " |
+ | include_file " | ||
+ | import_file "/ | ||
+ | </ | ||
- | | + | ------- |
==== Normal Name/Value Pairs ==== | ==== Normal Name/Value Pairs ==== | ||
- | | + | These name/value pairs are normally |
- | (delimited by an equals | + | |
+ | ^ Syntax: | | ||
+ | |<code c> | ||
- | [[../ | + | <fc # |
+ | Check the [[../ | ||
- | < | + | ^ Examples: |
+ | |< | ||
memdbg=5 | memdbg=5 | ||
memlog=5 | memlog=5 | ||
Line 117: | Line 134: | ||
auto_aliases=no | auto_aliases=no | ||
alias=" | alias=" | ||
- | </ | + | </ |
+ | ------ | ||
==== Modify Parameter Procedure ==== | ==== Modify Parameter Procedure ==== | ||
- | < | + | The modify parameter is similar to other types programming procedure.\\ |
+ | You call the procedure and it modifies the defined modules parameter. | ||
+ | |||
+ | ^ Syntax: | ||
+ | | <code c> | ||
+ | |||
+ | <fc # | ||
+ | |||
+ | See the [[http:// | ||
+ | |||
+ | ^ Examples: | ||
+ | |< | ||
modparam(" | modparam(" | ||
modparam(" | modparam(" | ||
modparam(" | modparam(" | ||
modparam(" | modparam(" | ||
- | </ | + | </ |
+ | ----- | ||
==== Route Functions ==== | ==== Route Functions ==== | ||
+ | |||
+ | I will not go into too much detail here, the scripting methods, functions, and procdedures should be covered elsewhere in this wiki.\\ | ||
+ | |||
+ | |||
+ | ^ Example: | ||
+ | |<code c> | ||
+ | route(REQINIT); | ||
+ | route(NATDETECT); | ||
+ | |||
+ | # CANCEL ?? | ||
+ | if (is_method(" | ||
+ | exit; | ||
+ | } | ||
+ | |||
+ | # OTHER SCRIPT CODE HERE | ||
+ | }</ |
cookbooks/4.0.x/core/cfg.1371546010.txt.gz · Last modified: 2013/06/18 09:00 by poing