4.1. cgr-engine configuration file

Organized into configuration sections. All configuration options come with defaults and we have tried our best to choose the best ones for a minimum of efforts necessary when running.

Below is the default configuration file which comes hardcoded into cgr-engine.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
{
// This file contains the default configuration hardcoded into CGRateS.
// This is what you get when you load CGRateS with an empty configuration file.

// "general": {
// 	"http_skip_tls_verify": false,						// if enabled Http Client will accept any TLS certificate
// 	"rounding_decimals": 5,								// system level precision for floats
// 	"dbdata_encoding": "msgpack",						// encoding used to store object data in strings: <msgpack|json>
// 	"tpexport_dir": "/var/spool/cgrates/tpe",				// path towards export folder for offline Tariff Plans
// 	"httpposter_attempts": 3,							// number of http attempts before considering request failed (eg: *call_url)
// 	"http_failed_dir": "/var/spool/cgrates/http_failed",	// directory path where we store failed http requests
// 	"default_request_type": "*rated",					// default request type to consider when missing from requests: <""|*prepaid|*postpaid|*pseudoprepaid|*rated>
// 	"default_category": "call",							// default category to consider when missing from requests
// 	"default_tenant": "cgrates.org",					// default tenant to consider when missing from requests
// 	"default_timezone": "Local",						// default timezone for timestamps where not specified <""|UTC|Local|$IANA_TZ_DB>
// 	"connect_attempts": 3,								// initial server connect attempts
// 	"reconnects": -1,									// number of retries in case of connection lost
// 	"connect_timeout": "1s",							// consider connection unsuccessful on timeout, 0 to disable the feature
// 	"reply_timeout": "2s",								// consider connection down for replies taking longer than this value
// 	"response_cache_ttl": "0s",							// the life span of a cached response
// 	"internal_ttl": "2m",								// maximum duration to wait for internal connections before giving up
// 	"locking_timeout": "5s",							// timeout internal locks to avoid deadlocks
// },

// "cache":{
//     "destinations": {"limit": 10000, "ttl":"0s", "precache": false},
//     "reverse_destinations": {"limit": 10000, "ttl":"0s", "precache": false},
//     "rating_plans": {"limit": 10000, "ttl":"0s","precache": true},
//     "rating_profiles": {"limit": 10000, "ttl":"0s", "precache": false},
//     "lcr": {"limit": 10000, "ttl":"0s", "precache": false},
//     "cdr_stats": {"limit": 10000, "ttl":"0s", "precache": false},
//     "actions": {"limit": 10000, "ttl":"0s", "precache": false},
//     "action_plans": {"limit": 10000, "ttl":"0s", "precache": false},
//     "action_triggers": {"limit": 10000, "ttl":"0s", "precache": false},
//     "shared_groups": {"limit": 10000, "ttl":"0s", "precache": false},
//     "aliases": {"limit": 10000, "ttl":"0s", "precache": false},
//     "reverse_aliases": {"limit": 10000, "ttl":"0s", "precache": false},
// },

// "listen": {
// 	"rpc_json": "127.0.0.1:2012",			// RPC JSON listening address
// 	"rpc_gob": "127.0.0.1:2013",			// RPC GOB listening address
// 	"http": "127.0.0.1:2080",				// HTTP listening address
// },


// "tariffplan_db": {							// database used to store active tariff plan configuration
// 	"db_type": "redis",						// tariffplan_db type: <redis|mongo>
// 	"db_host": "127.0.0.1",					// tariffplan_db host address
// 	"db_port": 6379, 						// port to reach the tariffplan_db
// 	"db_name": "10", 						// tariffplan_db name to connect to
// 	"db_user": "", 							// sername to use when connecting to tariffplan_db
// 	"db_password": "", 						// password to use when connecting to tariffplan_db
// },


// "data_db": {								// database used to store runtime data (eg: accounts, cdr stats)
// 	"db_type": "redis",						// data_db type: <redis|mongo>
// 	"db_host": "127.0.0.1",					// data_db host address
// 	"db_port": 6379, 						// data_db port to reach the database
// 	"db_name": "11", 						// data_db database name to connect to
// 	"db_user": "", 							// username to use when connecting to data_db
// 	"db_password": "", 						// password to use when connecting to data_db
// 	"load_history_size": 10,				// Number of records in the load history
// },


// "stor_db": {								// database used to store offline tariff plans and CDRs
// 	"db_type": "mysql",						// stor database type to use: <mongo|mysql|postgres>
// 	"db_host": "127.0.0.1",					// the host to connect to
// 	"db_port": 3306,						// the port to reach the stordb
// 	"db_name": "cgrates",					// stor database name
// 	"db_user": "cgrates",					// username to use when connecting to stordb
// 	"db_password": "CGRateS.org",			// password to use when connecting to stordb
// 	"max_open_conns": 100,					// maximum database connections opened
// 	"max_idle_conns": 10,					// maximum database connections idle
// 	"cdrs_indexes": [],						// indexes on cdrs table to speed up queries, used only in case of mongo
// },


// "balancer": {
// 	"enabled": false,						// start Balancer service: <true|false>
// },


// "rals": {
// 	"enabled": false,						// enable Rater service: <true|false>
// 	"balancer": "",							// register to balancer as worker: <""|*internal|x.y.z.y:1234>
// 	"cdrstats_conns": [],					// address where to reach the cdrstats service, empty to disable stats functionality: <""|*internal|x.y.z.y:1234>
// 	"historys_conns": [],					// address where to reach the history service, empty to disable history functionality: <""|*internal|x.y.z.y:1234>
// 	"pubsubs_conns": [],					// address where to reach the pubusb service, empty to disable pubsub functionality: <""|*internal|x.y.z.y:1234>
// 	"users_conns": [],						// address where to reach the user service, empty to disable user profile functionality: <""|*internal|x.y.z.y:1234>
// 	"aliases_conns": [],					// address where to reach the aliases service, empty to disable aliases functionality: <""|*internal|x.y.z.y:1234>
// 	"rp_subject_prefix_matching": false,	// enables prefix matching for the rating profile subject
// 	"lcr_subject_prefix_matching": false	// enables prefix matching for the lcr subject
// },


// "scheduler": {
// 	"enabled": false,						// start Scheduler service: <true|false>
// },


// "cdrs": {
// 	"enabled": false,						// start the CDR Server service:  <true|false>
// 	"extra_fields": [],						// extra fields to store in CDRs for non-generic CDRs
// 	"store_cdrs": true,						// store cdrs in storDb
// 	"rals_conns": [
// 		{"address": "*internal"}			// address where to reach the Rater for cost calculation, empty to disable functionality: <""|*internal|x.y.z.y:1234>
// 	],
// 	"pubsubs_conns": [],					// address where to reach the pubusb service, empty to disable pubsub functionality: <""|*internal|x.y.z.y:1234>
// 	"users_conns": [],						// address where to reach the user service, empty to disable user profile functionality: <""|*internal|x.y.z.y:1234>
// 	"aliases_conns": [],					// address where to reach the aliases service, empty to disable aliases functionality: <""|*internal|x.y.z.y:1234>
// 	"cdrstats_conns": [],					// address where to reach the cdrstats service, empty to disable stats functionality<""|*internal|x.y.z.y:1234>
// 	"cdr_replication":[]					// replicate the raw CDR to a number of servers
// },


// "cdrstats": {
// 	"enabled": false,						// starts the cdrstats service: <true|false>
// 	"save_interval": "1m",					// interval to save changed stats into dataDb storage
// },

// "cdrc": [
// 	{
// 		"id": "*default",								// identifier of the CDRC runner
// 		"enabled": false,							// enable CDR client functionality
// 		"dry_run": false,							// do not send the CDRs to CDRS, just parse them
// 		"cdrs_conns": [
// 			{"address": "*internal"}				// address where to reach CDR server. <*internal|x.y.z.y:1234>
// 		],
// 		"cdr_format": "csv",						// CDR file format <csv|freeswitch_csv|fwv|opensips_flatstore>
// 		"field_separator": ",",						// separator used in case of csv files
// 		"timezone": "",								// timezone for timestamps where not specified <""|UTC|Local|$IANA_TZ_DB>
// 		"run_delay": 0,								// sleep interval in seconds between consecutive runs, 0 to use automation via inotify
// 		"max_open_files": 1024,						// maximum simultaneous files to process, 0 for unlimited
// 		"data_usage_multiply_factor": 1024,			// conversion factor for data usage
// 		"cdr_in_dir": "/var/spool/cgrates/cdrc/in",	// absolute path towards the directory where the CDRs are stored
// 		"cdr_out_dir": "/var/spool/cgrates/cdrc/out",	// absolute path towards the directory where processed CDRs will be moved
// 		"failed_calls_prefix": "missed_calls",		// used in case of flatstore CDRs to avoid searching for BYE records
// 		"cdr_path": "",							// path towards one CDR element in case of XML CDRs
// 		"cdr_source_id": "freeswitch_csv",			// free form field, tag identifying the source of the CDRs within CDRS database
// 		"cdr_filter": "",							// filter CDR records to import
// 		"continue_on_success": false,				// continue to the next template if executed
// 		"partial_record_cache": "10s",				// duration to cache partial records when not pairing
// 		"header_fields": [],						// template of the import header fields
// 		"content_fields":[							// import content_fields template, tag will match internally CDR field, in case of .csv value will be represented by index of the field value
// 			{"tag": "TOR", "field_id": "ToR", "type": "*composed", "value": "2", "mandatory": true},
// 			{"tag": "OriginID", "field_id": "OriginID", "type": "*composed", "value": "3", "mandatory": true},
// 			{"tag": "RequestType", "field_id": "RequestType", "type": "*composed", "value": "4", "mandatory": true},
// 			{"tag": "Direction", "field_id": "Direction", "type": "*composed", "value": "5", "mandatory": true},
// 			{"tag": "Tenant", "field_id": "Tenant", "type": "*composed", "value": "6", "mandatory": true},
// 			{"tag": "Category", "field_id": "Category", "type": "*composed", "value": "7", "mandatory": true},
// 			{"tag": "Account", "field_id": "Account", "type": "*composed", "value": "8", "mandatory": true},
// 			{"tag": "Subject", "field_id": "Subject", "type": "*composed", "value": "9", "mandatory": true},
// 			{"tag": "Destination", "field_id": "Destination", "type": "*composed", "value": "10", "mandatory": true},
// 			{"tag": "SetupTime", "field_id": "SetupTime", "type": "*composed", "value": "11", "mandatory": true},
// 			{"tag": "AnswerTime", "field_id": "AnswerTime", "type": "*composed", "value": "12", "mandatory": true},
// 			{"tag": "Usage", "field_id": "Usage", "type": "*composed", "value": "13", "mandatory": true},
// 		],
// 		"trailer_fields": [],							// template of the import trailer fields
// 	},
// ],


// "cdre": {
// 	"*default": {
// 		"cdr_format": "csv",							// exported CDRs format <csv>
// 		"field_separator": ",",
// 		"data_usage_multiply_factor": 1,				// multiply data usage before export (eg: convert from KBytes to Bytes)
// 		"sms_usage_multiply_factor": 1,					// multiply data usage before export (eg: convert from SMS unit to call duration in some billing systems)
// 		"mms_usage_multiply_factor": 1,					// multiply data usage before export (eg: convert from MMS unit to call duration in some billing systems)
// 		"generic_usage_multiply_factor": 1,				// multiply data usage before export (eg: convert from GENERIC unit to call duration in some billing systems)
// 		"cost_multiply_factor": 1,						// multiply cost before export, eg: add VAT
// 		"cost_rounding_decimals": -1,					// rounding decimals for Cost values. -1 to disable rounding
// 		"cost_shift_digits": 0,							// shift digits in the cost on export (eg: convert from EUR to cents)
// 		"mask_destination_id": "MASKED_DESTINATIONS",	// destination id containing called addresses to be masked on export
// 		"mask_length": 0,								// length of the destination suffix to be masked
// 		"export_folder": "/var/log/cgrates/cdre",		// path where the exported CDRs will be placed
// 		"header_fields": [],							// template of the exported header fields
// 		"content_fields": [								// template of the exported content fields
// 			{"tag": "CGRID", "type": "*composed", "value": "CGRID"},
// 			{"tag":"RunID", "type": "*composed", "value": "RunID"},
// 			{"tag":"TOR", "type": "*composed", "value": "ToR"},
// 			{"tag":"OriginID", "type": "*composed", "value": "OriginID"},
// 			{"tag":"RequestType", "type": "*composed", "value": "RequestType"},
// 			{"tag":"Direction", "type": "*composed", "value": "Direction"},
// 			{"tag":"Tenant", "type": "*composed", "value": "Tenant"},
// 			{"tag":"Category", "type": "*composed", "value": "Category"},
// 			{"tag":"Account", "type": "*composed", "value": "Account"},
// 			{"tag":"Subject", "type": "*composed", "value": "Subject"},
// 			{"tag":"Destination", "type": "*composed", "value": "Destination"},
// 			{"tag":"SetupTime", "type": "*composed", "value": "SetupTime", "layout": "2006-01-02T15:04:05Z07:00"},
// 			{"tag":"AnswerTime", "type": "*composed", "value": "AnswerTime", "layout": "2006-01-02T15:04:05Z07:00"},
// 			{"tag":"Usage", "type": "*composed", "value": "Usage"},
// 			{"tag":"Cost", "type": "*composed", "value": "Cost"},
// 		],
// 		"trailer_fields": [],							// template of the exported trailer fields
// 	},
// },


// "sm_generic": {
// 	"enabled": false,						// starts SessionManager service: <true|false>
// 	"listen_bijson": "127.0.0.1:2014",		// address where to listen for bidirectional JSON-RPC requests
// 	"rals_conns": [
// 		{"address": "*internal"}				// address where to reach the Rater <""|*internal|127.0.0.1:2013>
// 	],
// 	"cdrs_conns": [
// 		{"address": "*internal"}				// address where to reach CDR Server, empty to disable CDR capturing <*internal|x.y.z.y:1234>
// 	],
// 	"debit_interval": "0s",					// interval to perform debits on.
// 	"min_call_duration": "0s",				// only authorize calls with allowed duration higher than this
// 	"max_call_duration": "3h",				// maximum call duration a prepaid call can last
// 	"session_ttl": "0s",					// time after a session with no updates is terminated, not defined by default
	//"session_ttl_last_used": "",			// tweak LastUsed for sessions timing-out, not defined by default
	//"session_ttl_usage": "",				// tweak Usage for sessions timing-out, not defined by default
// },


// "sm_freeswitch": {
// 	"enabled": false,				// starts SessionManager service: <true|false>
// 	"rals_conns": [
// 		{"address": "*internal"}		// address where to reach the Rater <""|*internal|127.0.0.1:2013>
// 	],
// 	"cdrs_conns": [
// 		{"address": "*internal"}		// address where to reach CDR Server, empty to disable CDR capturing <*internal|x.y.z.y:1234>
// 	],
// 	"create_cdr": false,					// create CDR out of events and sends them to CDRS component
// 	"extra_fields": [],						// extra fields to store in auth/CDRs when creating them
// 	"debit_interval": "10s",				// interval to perform debits on.
// 	"min_call_duration": "0s",				// only authorize calls with allowed duration higher than this
// 	"max_call_duration": "3h",				// maximum call duration a prepaid call can last
// 	"min_dur_low_balance": "5s",			// threshold which will trigger low balance warnings for prepaid calls (needs to be lower than debit_interval)
// 	"low_balance_ann_file": "",				// file to be played when low balance is reached for prepaid calls
// 	"empty_balance_context": "",			// if defined, prepaid calls will be transfered to this context on empty balance
// 	"empty_balance_ann_file": "",			// file to be played before disconnecting prepaid calls on empty balance (applies only if no context defined)
// 	"subscribe_park": true,					// subscribe via fsock to receive park events
// 	"channel_sync_interval": "5m",			// sync channels with freeswitch regularly
// 	"max_wait_connection": "2s",			// maximum duration to wait for a connection to be retrieved from the pool
// 	"event_socket_conns":[					// instantiate connections to multiple FreeSWITCH servers
// 		{"address": "127.0.0.1:8021", "password": "ClueCon", "reconnects": 5}
// 	],
// },


// "sm_kamailio": {
// 	"enabled": false,						// starts SessionManager service: <true|false>
// 	"rals_conns": [
// 		{"address": "*internal"}			// address where to reach the Rater <""|*internal|127.0.0.1:2013>
// 	],
// 	"cdrs_conns": [
// 		{"address": "*internal"}			// address where to reach CDR Server, empty to disable CDR capturing <*internal|x.y.z.y:1234>
// 	],
// 	"create_cdr": false,					// create CDR out of events and sends them to CDRS component
// 	"debit_interval": "10s",				// interval to perform debits on.
// 	"min_call_duration": "0s",				// only authorize calls with allowed duration higher than this
// 	"max_call_duration": "3h",				// maximum call duration a prepaid call can last
// 	"evapi_conns":[							// instantiate connections to multiple Kamailio servers
// 		{"address": "127.0.0.1:8448", "reconnects": 5}
// 	],
// },


// "sm_opensips": {
// 	"enabled": false,					// starts SessionManager service: <true|false>
// 	"listen_udp": "127.0.0.1:2020",		// address where to listen for datagram events coming from OpenSIPS
// 	"rals_conns": [
// 		{"address": "*internal"}     // address where to reach the Rater <""|*internal|127.0.0.1:2013>
// 	],
// 	"cdrs_conns": [
// 		{"address": "*internal"}     // address where to reach CDR Server, empty to disable CDR capturing <*internal|x.y.z.y:1234>
// 	],
// 	"reconnects": 5,					// number of reconnects if connection is lost
// 	"create_cdr": false,				// create CDR out of events and sends it to CDRS component
// 	"debit_interval": "10s",			// interval to perform debits on.
// 	"min_call_duration": "0s",			// only authorize calls with allowed duration higher than this
// 	"max_call_duration": "3h",			// maximum call duration a prepaid call can last
// 	"events_subscribe_interval": "60s",	// automatic events subscription to OpenSIPS, 0 to disable it
// 	"mi_addr": "127.0.0.1:8020",		// address where to reach OpenSIPS MI to send session disconnects
// },


// "diameter_agent": {
// 	"enabled": false,											// enables the diameter agent: <true|false>
// 	"listen": "127.0.0.1:3868",									// address where to listen for diameter requests <x.y.z.y:1234>
// 	"dictionaries_dir": "/usr/share/cgrates/diameter/dict/",	// path towards directory holding additional dictionaries to load
// 	"sm_generic_conns": [
// 		{"address": "*internal"}									// connection towards SMG component for session management
// 	],
// 	"pubsubs_conns": [],										// address where to reach the pubusb service, empty to disable pubsub functionality: <""|*internal|x.y.z.y:1234>
// 	"create_cdr": true,											// create CDR out of CCR terminate and send it to SMG component
// 	"debit_interval": "5m",										// interval for CCR updates
// 	"timezone": "",												// timezone for timestamps where not specified, empty for general defaults <""|UTC|Local|$IANA_TZ_DB>
// 	"dialect": "huawei",										// the diameter dialect used in the communication, supported: <huawei>
// 	"origin_host": "CGR-DA",									// diameter Origin-Host AVP used in replies
// 	"origin_realm": "cgrates.org",								// diameter Origin-Realm AVP used in replies
// 	"vendor_id": 0,												// diameter Vendor-Id AVP used in replies
// 	"product_name": "CGRateS",									// diameter Product-Name AVP used in replies
// 	"request_processors": [
// 		{
// 			"id": "*default",												// formal identifier of this processor
// 			"dry_run": false,												// do not send the events to SMG, just log them
// 			"publish_event": false,											// if enabled, it will publish internal event to pubsub
// 			"request_filter": "Subscription-Id>Subscription-Id-Type(0)",	// filter requests processed by this processor
// 			"flags": [],													// flags to influence processing behavior
// 			"continue_on_success": false,				// continue to the next template if executed
// 			"append_cca": true,						// when continuing will append cca fields to the previous ones
// 			"ccr_fields":[							// import content_fields template, tag will match internally CDR field, in case of .csv value will be represented by index of the field value
// 				{"tag": "TOR", "field_id": "ToR", "type": "*composed", "value": "^*voice", "mandatory": true},
// 				{"tag": "OriginID", "field_id": "OriginID", "type": "*composed", "value": "Session-Id", "mandatory": true},
// 				{"tag": "RequestType", "field_id": "RequestType", "type": "*composed", "value": "^*users", "mandatory": true},
// 				{"tag": "Direction", "field_id": "Direction", "type": "*composed", "value": "^*out", "mandatory": true},
// 				{"tag": "Tenant", "field_id": "Tenant", "type": "*composed", "value": "^*users", "mandatory": true},
// 				{"tag": "Category", "field_id": "Category", "type": "*composed", "value": "^call", "mandatory": true},
// 				{"tag": "Account", "field_id": "Account", "type": "*composed", "value": "^*users", "mandatory": true},
// 				{"tag": "Subject", "field_id": "Subject", "type": "*composed", "value": "^*users", "mandatory": true},
// 				{"tag": "Destination", "field_id": "Destination", "type": "*composed", "value": "Service-Information>IN-Information>Real-Called-Number", "mandatory": true},
// 				{"tag": "SetupTime", "field_id": "SetupTime", "type": "*composed", "value": "Event-Timestamp", "mandatory": true},
// 				{"tag": "AnswerTime", "field_id": "AnswerTime", "type": "*composed", "value": "Event-Timestamp", "mandatory": true},
// 				{"tag": "Usage", "field_id": "Usage", "type": "*handler", "handler_id": "*ccr_usage", "mandatory": true},
// 				{"tag": "SubscriberID", "field_id": "SubscriberId", "type": "*composed", "value": "Subscription-Id>Subscription-Id-Data", "mandatory": true},
// 			],
// 			"cca_fields":[								// fields returned in CCA
// 				{"tag": "GrantedUnits", "field_id": "Granted-Service-Unit>CC-Time", "type": "*handler", "handler_id": "*cca_usage", "mandatory": true},
// 			],
// 		},
// 	],
// },


// "historys": {
// 	"enabled": false,							// starts History service: <true|false>.
// 	"history_dir": "/var/lib/cgrates/history",	// location on disk where to store history files.
// 	"save_interval": "1s",						// interval to save changed cache into .git archive
// },


// "pubsubs": {
// 	"enabled": false,							// starts PubSub service: <true|false>.
// },


// "aliases": {
// 	"enabled": false,							// starts Aliases service: <true|false>.
// },


// "users": {
// 	"enabled": false,							// starts User service: <true|false>.
// 	"indexes": [],								// user profile field indexes
// },


// "mailer": {
// 	"server": "localhost",								// the server to use when sending emails out
// 	"auth_user": "cgrates",								// authenticate to email server using this user
// 	"auth_password": "CGRateS.org",						// authenticate to email server with this password
// 	"from_address": "cgr-mailer@localhost.localdomain"	// from address used when sending emails out
// },


// "suretax": {
// 	"url": "",								// API url
// 	"client_number": "",					// client number, provided by SureTax
// 	"validation_key": "",					// validation key provided by SureTax
// 	"business_unit": "",					// client’s Business Unit
// 	"timezone": "Local",					// convert the time of the events to this timezone before sending request out <UTC|Local|$IANA_TZ_DB>
// 	"include_local_cost": false,			// sum local calculated cost with tax one in final cost
// 	"return_file_code": "0",				// default or Quote purposes <0|Q>
// 	"response_group": "03",					// determines how taxes are grouped for the response <03|13>
// 	"response_type": "D4",					// determines the granularity of taxes and (optionally) the decimal precision for the tax calculations and amounts in the response
// 	"regulatory_code": "03",				// provider type
// 	"client_tracking": "CGRID",				// template extracting client information out of StoredCdr; <$RSRFields>
// 	"customer_number": "Subject",			// template extracting customer number out of StoredCdr; <$RSRFields>
// 	"orig_number":  "Subject", 				// template extracting origination number out of StoredCdr; <$RSRFields>
// 	"term_number": "Destination",			// template extracting termination number out of StoredCdr; <$RSRFields>
// 	"bill_to_number": "",					// template extracting billed to number out of StoredCdr; <$RSRFields>
// 	"zipcode": "",							// template extracting billing zip code out of StoredCdr; <$RSRFields>
// 	"plus4": "",							// template extracting billing zip code extension out of StoredCdr; <$RSRFields>
// 	"p2pzipcode": "",						// template extracting secondary zip code out of StoredCdr; <$RSRFields>
// 	"p2pplus4": "",							// template extracting secondary zip code extension out of StoredCdr; <$RSRFields>
// 	"units": "^1",							// template extracting number of “lines” or unique charges contained within the revenue out of StoredCdr; <$RSRFields>
// 	"unit_type": "^00",						// template extracting number of unique access lines out of StoredCdr; <$RSRFields>
// 	"tax_included": "^0",					// template extracting tax included in revenue out of StoredCdr; <$RSRFields>
// 	"tax_situs_rule": "^04",				// template extracting tax situs rule out of StoredCdr; <$RSRFields>
// 	"trans_type_code": "^010101",			// template extracting transaction type indicator out of StoredCdr; <$RSRFields>
// 	"sales_type_code": "^R",				// template extracting sales type code out of StoredCdr; <$RSRFields>
// 	"tax_exemption_code_list": "",			// template extracting tax exemption code list out of StoredCdr; <$RSRFields>
// },

}