Asterisk - The Open Source Telephony Project GIT-master-77d630f
Data Structures | Typedefs | Enumerations | Functions
cdr.h File Reference

Call Detail Record API. More...

#include "asterisk/channel.h"
Include dependency graph for cdr.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  ast_cdr
 Responsible for call detail data. More...
 
struct  ast_cdr_config
 The global options available for CDRs. More...
 
struct  ast_cdr_config::batch_settings
 

Typedefs

typedef int(* ast_cdrbe) (struct ast_cdr *cdr)
 CDR backend callback. More...
 

Enumerations

enum  ast_cdr_batch_mode_settings { BATCH_MODE_SCHEDULER_ONLY = 1 << 0 , BATCH_MODE_SAFE_SHUTDOWN = 1 << 1 }
 CDR Batch Mode settings. More...
 
enum  ast_cdr_disposition {
  AST_CDR_NOANSWER = 0 , AST_CDR_NULL = (1 << 0) , AST_CDR_FAILED = (1 << 1) , AST_CDR_BUSY = (1 << 2) ,
  AST_CDR_ANSWERED = (1 << 3) , AST_CDR_CONGESTION = (1 << 4) , AST_CDR_CANCEL = (1 << 5)
}
 CDR Flags - Disposition. More...
 
enum  ast_cdr_options {
  AST_CDR_FLAG_KEEP_VARS = (1 << 0) , AST_CDR_FLAG_DISABLE = (1 << 1) , AST_CDR_FLAG_DISABLE_ALL = (3 << 1) , AST_CDR_FLAG_PARTY_A = (1 << 3) ,
  AST_CDR_FLAG_FINALIZE = (1 << 4) , AST_CDR_FLAG_SET_ANSWER = (1 << 5) , AST_CDR_FLAG_RESET = (1 << 6) , AST_CDR_LOCK_APP = (1 << 7)
}
 CDR manipulation options. Certain function calls will manipulate the state of a CDR object based on these flags. More...
 
enum  ast_cdr_settings {
  CDR_ENABLED = 1 << 0 , CDR_BATCHMODE = 1 << 1 , CDR_UNANSWERED = 1 << 2 , CDR_CONGESTION = 1 << 3 ,
  CDR_END_BEFORE_H_EXTEN = 1 << 4 , CDR_INITIATED_SECONDS = 1 << 5 , CDR_DEBUG = 1 << 6 , CDR_CHANNEL_DEFAULT_ENABLED = 1 << 7 ,
  CDR_IGNORE_STATE_CHANGES = 1 << 8 , CDR_IGNORE_DIAL_CHANGES = 1 << 9 , CDR_CANCEL_DISPOSITION_ENABLED = 1 << 10
}
 CDR engine settings. More...
 

Functions

struct ast_cdrast_cdr_alloc (void)
 Allocate a CDR record. More...
 
int ast_cdr_backend_suspend (const char *name)
 Suspend a CDR backend temporarily. More...
 
int ast_cdr_backend_unsuspend (const char *name)
 Unsuspend a CDR backend. More...
 
int ast_cdr_clear_property (const char *channel_name, enum ast_cdr_options option)
 Clear a property on a CDR for a channel. More...
 
const char * ast_cdr_disp2str (int disposition)
 Disposition to a string. More...
 
struct ast_cdrast_cdr_dup (struct ast_cdr *cdr)
 Duplicate a public CDR. More...
 
void ast_cdr_engine_term (void)
 
int ast_cdr_fork (const char *channel_name, struct ast_flags *options)
 Fork a CDR. More...
 
void ast_cdr_format_var (struct ast_cdr *cdr, const char *name, char **ret, char *workspace, int workspacelen, int raw)
 Format a CDR variable from an already posted CDR. More...
 
void ast_cdr_free (struct ast_cdr *cdr)
 Free a CDR record. More...
 
struct ast_cdr_configast_cdr_get_config (void)
 Obtain the current CDR configuration. More...
 
int ast_cdr_getvar (const char *channel_name, const char *name, char *value, size_t length)
 Retrieve a CDR variable from a channel's current CDR. More...
 
int ast_cdr_is_enabled (void)
 Return TRUE if CDR subsystem is enabled. More...
 
struct stasis_message_routerast_cdr_message_router (void)
 Return the message router for the CDR engine. More...
 
int ast_cdr_modifier_register (const char *name, const char *desc, ast_cdrbe be)
 Register a CDR modifier. More...
 
int ast_cdr_modifier_unregister (const char *name)
 Unregister a CDR modifier. More...
 
int ast_cdr_register (const char *name, const char *desc, ast_cdrbe be)
 Register a CDR handling engine. More...
 
int ast_cdr_reset (const char *channel_name, int keep_variables)
 Reset the detail record. More...
 
int ast_cdr_serialize_variables (const char *channel_name, struct ast_str **buf, char delim, char sep)
 Serializes all the data and variables for a current CDR record. More...
 
void ast_cdr_set_config (struct ast_cdr_config *config)
 Set the current CDR configuration. More...
 
int ast_cdr_set_property (const char *channel_name, enum ast_cdr_options option)
 Set a property on a CDR for a channel. More...
 
void ast_cdr_setuserfield (const char *channel_name, const char *userfield)
 Set CDR user field for channel (stored in CDR) More...
 
int ast_cdr_setvar (const char *channel_name, const char *name, const char *value)
 Set a variable on a CDR. More...
 
int ast_cdr_unregister (const char *name)
 Unregister a CDR handling engine. More...
 

Detailed Description

Call Detail Record API.

Call Detail Record Engine.

Author
Mark Spencer marks.nosp@m.ter@.nosp@m.digiu.nosp@m.m.co.nosp@m.m
Since
12

Definition in file cdr.h.

Typedef Documentation

◆ ast_cdrbe

typedef int(* ast_cdrbe) (struct ast_cdr *cdr)

CDR backend callback.

Warning
CDR backends should NOT attempt to access the channel associated with a CDR record. This channel is not guaranteed to exist when the CDR backend is invoked.

Definition at line 467 of file cdr.h.

Enumeration Type Documentation

◆ ast_cdr_batch_mode_settings

CDR Batch Mode settings.

Enumerator
BATCH_MODE_SCHEDULER_ONLY 

Don't spawn a thread to handle the batches - do it on the scheduler

BATCH_MODE_SAFE_SHUTDOWN 

During safe shutdown, submit the batched CDRs

Definition at line 234 of file cdr.h.

234 {
235 BATCH_MODE_SCHEDULER_ONLY = 1 << 0, /*!< Don't spawn a thread to handle the batches - do it on the scheduler */
236 BATCH_MODE_SAFE_SHUTDOWN = 1 << 1, /*!< During safe shutdown, submit the batched CDRs */
237};
@ BATCH_MODE_SAFE_SHUTDOWN
Definition: cdr.h:236
@ BATCH_MODE_SCHEDULER_ONLY
Definition: cdr.h:235

◆ ast_cdr_disposition

CDR Flags - Disposition.

Enumerator
AST_CDR_NOANSWER 
AST_CDR_NULL 
AST_CDR_FAILED 
AST_CDR_BUSY 
AST_CDR_ANSWERED 
AST_CDR_CONGESTION 
AST_CDR_CANCEL 

Definition at line 257 of file cdr.h.

257 {
259 AST_CDR_NULL = (1 << 0),
260 AST_CDR_FAILED = (1 << 1),
261 AST_CDR_BUSY = (1 << 2),
262 AST_CDR_ANSWERED = (1 << 3),
263 AST_CDR_CONGESTION = (1 << 4),
264 AST_CDR_CANCEL = (1 << 5),
265};
@ AST_CDR_CONGESTION
Definition: cdr.h:263
@ AST_CDR_NULL
Definition: cdr.h:259
@ AST_CDR_NOANSWER
Definition: cdr.h:258
@ AST_CDR_ANSWERED
Definition: cdr.h:262
@ AST_CDR_CANCEL
Definition: cdr.h:264
@ AST_CDR_BUSY
Definition: cdr.h:261
@ AST_CDR_FAILED
Definition: cdr.h:260

◆ ast_cdr_options

CDR manipulation options. Certain function calls will manipulate the state of a CDR object based on these flags.

Enumerator
AST_CDR_FLAG_KEEP_VARS 

Copy variables during the operation

AST_CDR_FLAG_DISABLE 

Disable the current CDR

AST_CDR_FLAG_DISABLE_ALL 

Disable the CDR and all future CDRs

AST_CDR_FLAG_PARTY_A 

Set the channel as party A

AST_CDR_FLAG_FINALIZE 

Finalize the current CDRs

AST_CDR_FLAG_SET_ANSWER 

If the channel is answered, set the answer time to now

AST_CDR_FLAG_RESET 

If set, set the start and answer time to now

AST_CDR_LOCK_APP 

Prevent any further changes to the application field/data field for this CDR

Definition at line 243 of file cdr.h.

243 {
244 AST_CDR_FLAG_KEEP_VARS = (1 << 0), /*!< Copy variables during the operation */
245 AST_CDR_FLAG_DISABLE = (1 << 1), /*!< Disable the current CDR */
246 AST_CDR_FLAG_DISABLE_ALL = (3 << 1), /*!< Disable the CDR and all future CDRs */
247 AST_CDR_FLAG_PARTY_A = (1 << 3), /*!< Set the channel as party A */
248 AST_CDR_FLAG_FINALIZE = (1 << 4), /*!< Finalize the current CDRs */
249 AST_CDR_FLAG_SET_ANSWER = (1 << 5), /*!< If the channel is answered, set the answer time to now */
250 AST_CDR_FLAG_RESET = (1 << 6), /*!< If set, set the start and answer time to now */
251 AST_CDR_LOCK_APP = (1 << 7), /*!< Prevent any further changes to the application field/data field for this CDR */
252};
@ AST_CDR_FLAG_DISABLE_ALL
Definition: cdr.h:246
@ AST_CDR_LOCK_APP
Definition: cdr.h:251
@ AST_CDR_FLAG_FINALIZE
Definition: cdr.h:248
@ AST_CDR_FLAG_DISABLE
Definition: cdr.h:245
@ AST_CDR_FLAG_PARTY_A
Definition: cdr.h:247
@ AST_CDR_FLAG_KEEP_VARS
Definition: cdr.h:244
@ AST_CDR_FLAG_RESET
Definition: cdr.h:250
@ AST_CDR_FLAG_SET_ANSWER
Definition: cdr.h:249

◆ ast_cdr_settings

CDR engine settings.

Enumerator
CDR_ENABLED 

Enable CDRs

CDR_BATCHMODE 

Whether or not we should dispatch CDRs in batches

CDR_UNANSWERED 

Log unanswered CDRs

CDR_CONGESTION 

Treat congestion as if it were a failed call

CDR_END_BEFORE_H_EXTEN 

End the CDR before the 'h' extension runs

CDR_INITIATED_SECONDS 

Include microseconds into the billing time

CDR_DEBUG 

Enables extra debug statements

CDR_CHANNEL_DEFAULT_ENABLED 

Whether CDR is enabled for each channel by default

CDR_IGNORE_STATE_CHANGES 

Whether to ignore bridge and other call state change events

CDR_IGNORE_DIAL_CHANGES 

Whether to ignore dial state changes

CDR_CANCEL_DISPOSITION_ENABLED 

Whether to enable CANCEL disposition in CDR

Definition at line 219 of file cdr.h.

219 {
220 CDR_ENABLED = 1 << 0, /*!< Enable CDRs */
221 CDR_BATCHMODE = 1 << 1, /*!< Whether or not we should dispatch CDRs in batches */
222 CDR_UNANSWERED = 1 << 2, /*!< Log unanswered CDRs */
223 CDR_CONGESTION = 1 << 3, /*!< Treat congestion as if it were a failed call */
224 CDR_END_BEFORE_H_EXTEN = 1 << 4, /*!< End the CDR before the 'h' extension runs */
225 CDR_INITIATED_SECONDS = 1 << 5, /*!< Include microseconds into the billing time */
226 CDR_DEBUG = 1 << 6, /*!< Enables extra debug statements */
227 CDR_CHANNEL_DEFAULT_ENABLED = 1 << 7, /*!< Whether CDR is enabled for each channel by default */
228 CDR_IGNORE_STATE_CHANGES = 1 << 8, /*!< Whether to ignore bridge and other call state change events */
229 CDR_IGNORE_DIAL_CHANGES = 1 << 9, /*!< Whether to ignore dial state changes */
230 CDR_CANCEL_DISPOSITION_ENABLED = 1 << 10, /*!< Whether to enable CANCEL disposition in CDR */
231};
@ CDR_UNANSWERED
Definition: cdr.h:222
@ CDR_IGNORE_STATE_CHANGES
Definition: cdr.h:228
@ CDR_CANCEL_DISPOSITION_ENABLED
Definition: cdr.h:230
@ CDR_INITIATED_SECONDS
Definition: cdr.h:225
@ CDR_ENABLED
Definition: cdr.h:220
@ CDR_CHANNEL_DEFAULT_ENABLED
Definition: cdr.h:227
@ CDR_END_BEFORE_H_EXTEN
Definition: cdr.h:224
@ CDR_IGNORE_DIAL_CHANGES
Definition: cdr.h:229
@ CDR_BATCHMODE
Definition: cdr.h:221
@ CDR_CONGESTION
Definition: cdr.h:223
@ CDR_DEBUG
Definition: cdr.h:226

Function Documentation

◆ ast_cdr_alloc()

struct ast_cdr * ast_cdr_alloc ( void  )

Allocate a CDR record.

Returns
a malloc'd ast_cdr structure
Return values
NULLon error (malloc failure)

Definition at line 3568 of file cdr.c.

3569{
3570 struct ast_cdr *x;
3571
3572 x = ast_calloc(1, sizeof(*x));
3573 return x;
3574}
#define ast_calloc(num, len)
A wrapper for calloc()
Definition: astmm.h:202
Responsible for call detail data.
Definition: cdr.h:281

References ast_calloc.

Referenced by ast_cdr_dup().

◆ ast_cdr_backend_suspend()

int ast_cdr_backend_suspend ( const char *  name)

Suspend a CDR backend temporarily.

Return values
0The backend is suspended
-1The backend could not be suspended

Definition at line 2999 of file cdr.c.

3000{
3001 int success = -1;
3002 struct cdr_beitem *i = NULL;
3003
3005 AST_RWLIST_TRAVERSE(&be_list, i, list) {
3006 if (!strcasecmp(name, i->name)) {
3007 ast_debug(3, "Suspending CDR backend %s\n", i->name);
3008 i->suspended = 1;
3009 success = 0;
3010 }
3011 }
3013
3014 return success;
3015}
static const char name[]
Definition: format_mp3.c:68
#define ast_debug(level,...)
Log a DEBUG message.
#define AST_RWLIST_WRLOCK(head)
Write locks a list.
Definition: linkedlists.h:52
#define AST_RWLIST_UNLOCK(head)
Attempts to unlock a read/write based list.
Definition: linkedlists.h:151
#define AST_RWLIST_TRAVERSE
Definition: linkedlists.h:494
#define NULL
Definition: resample.c:96
List of registered backends.
Definition: cdr.c:434
Registration object for CDR backends.
Definition: cdr.c:425
char name[20]
Definition: cdr.c:426

References ast_debug, AST_RWLIST_TRAVERSE, AST_RWLIST_UNLOCK, AST_RWLIST_WRLOCK, cdr_beitem::name, name, and NULL.

Referenced by load_config(), and odbc_load_module().

◆ ast_cdr_backend_unsuspend()

int ast_cdr_backend_unsuspend ( const char *  name)

Unsuspend a CDR backend.

Return values
0The backend was unsuspended
-1The back could not be unsuspended

Definition at line 3017 of file cdr.c.

3018{
3019 int success = -1;
3020 struct cdr_beitem *i = NULL;
3021
3023 AST_RWLIST_TRAVERSE(&be_list, i, list) {
3024 if (!strcasecmp(name, i->name)) {
3025 ast_debug(3, "Unsuspending CDR backend %s\n", i->name);
3026 i->suspended = 0;
3027 success = 0;
3028 }
3029 }
3031
3032 return success;
3033}

References ast_debug, AST_RWLIST_TRAVERSE, AST_RWLIST_UNLOCK, AST_RWLIST_WRLOCK, cdr_beitem::name, name, and NULL.

Referenced by load_config(), and odbc_load_module().

◆ ast_cdr_clear_property()

int ast_cdr_clear_property ( const char *  channel_name,
enum ast_cdr_options  option 
)

Clear a property on a CDR for a channel.

Since
12

Clears a flag previously set by ast_cdr_set_property

Parameters
channel_nameThe CDR's channel
optionOption to clear from the CDR
Return values
0on success
1on error

Definition at line 3723 of file cdr.c.

3724{
3725 struct cdr_object *cdr;
3726 struct cdr_object *it_cdr;
3727
3728 cdr = cdr_object_get_by_name(channel_name);
3729 if (!cdr) {
3730 return -1;
3731 }
3732
3733 ao2_lock(cdr);
3734 for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {
3735 if (it_cdr->fn_table == &finalized_state_fn_table) {
3736 continue;
3737 }
3738 ast_clear_flag(&it_cdr->flags, option);
3739 }
3740 ao2_unlock(cdr);
3741
3742 ao2_cleanup(cdr);
3743 return 0;
3744}
#define ao2_cleanup(obj)
Definition: astobj2.h:1934
#define ao2_unlock(a)
Definition: astobj2.h:729
#define ao2_lock(a)
Definition: astobj2.h:717
struct cdr_object_fn_table finalized_state_fn_table
The virtual table for the finalized state.
Definition: cdr.c:798
static struct cdr_object * cdr_object_get_by_name(const char *name)
Definition: cdr.c:3458
An in-memory representation of an active CDR.
Definition: cdr.c:816
struct cdr_object_fn_table * fn_table
Definition: cdr.c:819
struct cdr_object * next
Definition: cdr.c:840
struct ast_flags flags
Definition: cdr.c:827
#define ast_clear_flag(p, flag)
Definition: utils.h:77

References ao2_cleanup, ao2_lock, ao2_unlock, ast_clear_flag, cdr_object_get_by_name(), finalized_state_fn_table, cdr_object::flags, cdr_object::fn_table, and cdr_object::next.

Referenced by AST_TEST_DEFINE(), and cdr_prop_write_callback().

◆ ast_cdr_disp2str()

const char * ast_cdr_disp2str ( int  disposition)

Disposition to a string.

Parameters
dispositioninput binary form Converts the binary form of a disposition to string form.
Returns
a pointer to the string form

Definition at line 3576 of file cdr.c.

3577{
3578 switch (disposition) {
3579 case AST_CDR_NULL:
3580 return "NO ANSWER"; /* by default, for backward compatibility */
3581 case AST_CDR_NOANSWER:
3582 return "NO ANSWER";
3583 case AST_CDR_FAILED:
3584 return "FAILED";
3585 case AST_CDR_BUSY:
3586 return "BUSY";
3587 case AST_CDR_ANSWERED:
3588 return "ANSWERED";
3589 case AST_CDR_CONGESTION:
3590 return "CONGESTION";
3591 case AST_CDR_CANCEL:
3592 return "CANCEL";
3593 }
3594 return "UNKNOWN";
3595}

References AST_CDR_ANSWERED, AST_CDR_BUSY, AST_CDR_CANCEL, AST_CDR_CONGESTION, AST_CDR_FAILED, AST_CDR_NOANSWER, AST_CDR_NULL, and ast_cdr::disposition.

Referenced by ast_cdr_format_var(), beanstalk_put(), build_csv_record(), build_radius_record(), cdr_object_finalize(), cdr_read_callback(), execute_cb(), manager_log(), and tds_log().

◆ ast_cdr_dup()

struct ast_cdr * ast_cdr_dup ( struct ast_cdr cdr)

Duplicate a public CDR.

Parameters
cdrthe record to duplicate
Returns
a malloc'd ast_cdr structure,
Return values
NULLon error (malloc failure)

Definition at line 3131 of file cdr.c.

3132{
3133 struct ast_cdr *newcdr;
3134
3135 if (!cdr) {
3136 return NULL;
3137 }
3138 newcdr = ast_cdr_alloc();
3139 if (!newcdr) {
3140 return NULL;
3141 }
3142
3143 *newcdr = *cdr;
3145 copy_variables(&newcdr->varshead, &cdr->varshead);
3146 newcdr->next = NULL;
3147
3148 return newcdr;
3149}
struct ast_cdr * ast_cdr_alloc(void)
Allocate a CDR record.
Definition: cdr.c:3568
static int copy_variables(struct varshead *to_list, struct varshead *from_list)
Copy variables from one list to another.
Definition: cdr.c:851
#define AST_LIST_HEAD_INIT_NOLOCK(head)
Initializes a list head structure.
Definition: linkedlists.h:681
struct ast_cdr * next
Definition: cdr.h:334
struct varshead varshead
Definition: cdr.h:332

References ast_cdr_alloc(), AST_LIST_HEAD_INIT_NOLOCK, copy_variables(), ast_cdr::next, NULL, and ast_cdr::varshead.

Referenced by custom_log(), manager_log(), and write_cdr().

◆ ast_cdr_engine_term()

void ast_cdr_engine_term ( void  )

Submit any remaining CDRs and prepare for shutdown

Definition at line 4753 of file cdr.c.

4754{
4755 RAII_VAR(struct module_config *, mod_cfg, ao2_global_obj_ref(module_configs), ao2_cleanup);
4756
4757 /* Since this is called explicitly during process shutdown, we might not have ever
4758 * been initialized. If so, the config object will be NULL.
4759 */
4760 if (!mod_cfg) {
4761 return;
4762 }
4763
4764 if (cdr_sync_message_type()) {
4765 void *payload;
4766 struct stasis_message *message;
4767
4768 if (!stasis_router) {
4769 return;
4770 }
4771
4772 /* Make sure we have the needed items */
4773 payload = ao2_alloc(sizeof(*payload), NULL);
4774 if (!payload) {
4775 return;
4776 }
4777
4778 ast_debug(1, "CDR Engine termination request received; waiting on messages...\n");
4779
4780 message = stasis_message_create(cdr_sync_message_type(), payload);
4781 if (message) {
4783 }
4785 ao2_cleanup(payload);
4786 }
4787
4788 if (ast_test_flag(&mod_cfg->general->settings, CDR_BATCHMODE)) {
4789 cdr_submit_batch(ast_test_flag(&mod_cfg->general->batch_settings.settings, BATCH_MODE_SAFE_SHUTDOWN));
4790 }
4791}
#define ao2_global_obj_ref(holder)
Get a reference to the object stored in the global holder.
Definition: astobj2.h:918
#define ao2_alloc(data_size, destructor_fn)
Definition: astobj2.h:409
static struct stasis_message_router * stasis_router
Message router for stasis messages regarding channel state.
Definition: cdr.c:475
static void cdr_submit_batch(int shutdown)
Definition: cdr.c:3914
struct stasis_message * stasis_message_create(struct stasis_message_type *type, void *data)
Create a new message.
void stasis_message_router_publish_sync(struct stasis_message_router *router, struct stasis_message *message)
Publish a message to a message router's subscription synchronously.
The configuration settings for this module.
Definition: cdr.c:326
#define ast_test_flag(p, flag)
Definition: utils.h:63
#define RAII_VAR(vartype, varname, initval, dtor)
Declare a variable that will call a destructor function when it goes out of scope.
Definition: utils.h:978

References ao2_alloc, ao2_cleanup, ao2_global_obj_ref, ast_debug, ast_test_flag, BATCH_MODE_SAFE_SHUTDOWN, CDR_BATCHMODE, cdr_submit_batch(), NULL, RAII_VAR, stasis_message_create(), stasis_message_router_publish_sync(), and stasis_router.

Referenced by can_safely_quit(), and finalize_batch_mode().

◆ ast_cdr_fork()

int ast_cdr_fork ( const char *  channel_name,
struct ast_flags options 
)

Fork a CDR.

Since
12
Parameters
channel_nameThe name of the channel whose CDR should be forked
optionsOptions to control how the fork occurs.
Return values
0on success
-1on failure

Definition at line 3785 of file cdr.c.

3786{
3787 RAII_VAR(struct cdr_object *, cdr, cdr_object_get_by_name(channel_name), ao2_cleanup);
3788 struct cdr_object *new_cdr;
3789 struct cdr_object *it_cdr;
3790 struct cdr_object *cdr_obj;
3791
3792 if (!cdr) {
3793 return -1;
3794 }
3795
3796 {
3797 SCOPED_AO2LOCK(lock, cdr);
3798 struct timeval now = ast_tvnow();
3799
3800 cdr_obj = cdr->last;
3801 if (cdr_obj->fn_table == &finalized_state_fn_table) {
3802 /* If the last CDR in the chain is finalized, don't allow a fork -
3803 * things are already dying at this point
3804 */
3805 return -1;
3806 }
3807
3808 /* Copy over the basic CDR information. The Party A information is
3809 * copied over automatically as part of the append
3810 */
3811 ast_debug(1, "Forking CDR for channel %s\n", cdr->party_a.snapshot->base->name);
3812 new_cdr = cdr_object_create_and_append(cdr, &now);
3813 if (!new_cdr) {
3814 return -1;
3815 }
3816 new_cdr->fn_table = cdr_obj->fn_table;
3817 ast_string_field_set(new_cdr, bridge, cdr->bridge);
3818 ast_string_field_set(new_cdr, appl, cdr->appl);
3819 ast_string_field_set(new_cdr, data, cdr->data);
3820 ast_string_field_set(new_cdr, context, cdr->context);
3821 ast_string_field_set(new_cdr, exten, cdr->exten);
3822 new_cdr->flags = cdr->flags;
3823 /* Explicitly clear the AST_CDR_LOCK_APP flag - we want
3824 * the application to be changed on the new CDR if the
3825 * dialplan demands it
3826 */
3828
3829 /* If there's a Party B, copy it over as well */
3830 if (cdr_obj->party_b.snapshot) {
3831 new_cdr->party_b.snapshot = cdr_obj->party_b.snapshot;
3832 ao2_ref(new_cdr->party_b.snapshot, +1);
3833 cdr_all_relink(new_cdr);
3834 strcpy(new_cdr->party_b.userfield, cdr_obj->party_b.userfield);
3835 new_cdr->party_b.flags = cdr_obj->party_b.flags;
3837 copy_variables(&new_cdr->party_b.variables, &cdr_obj->party_b.variables);
3838 }
3839 }
3840 new_cdr->start = cdr_obj->start;
3841 new_cdr->answer = cdr_obj->answer;
3842 new_cdr->lastevent = ast_tvnow();
3843
3844 /* Modify the times based on the flags passed in */
3846 && new_cdr->party_a.snapshot->state == AST_STATE_UP) {
3847 new_cdr->answer = ast_tvnow();
3848 }
3850 new_cdr->answer = ast_tvnow();
3851 new_cdr->start = ast_tvnow();
3852 }
3853
3854 /* Create and append, by default, copies over the variables */
3856 free_variables(&new_cdr->party_a.variables);
3857 }
3858
3859 /* Finalize any current CDRs */
3861 for (it_cdr = cdr; it_cdr != new_cdr; it_cdr = it_cdr->next) {
3862 if (it_cdr->fn_table == &finalized_state_fn_table) {
3863 continue;
3864 }
3865 /* Force finalization on the CDR. This will bypass any checks for
3866 * end before 'h' extension.
3867 */
3868 cdr_object_finalize(it_cdr);
3870 }
3871 }
3872 }
3873
3874 return 0;
3875}
ast_mutex_t lock
Definition: app_sla.c:337
#define ao2_ref(o, delta)
Reference/unreference an object and return the old refcount.
Definition: astobj2.h:459
static struct cdr_object * cdr_object_create_and_append(struct cdr_object *cdr, const struct timeval *event_time)
Create a new cdr_object and append it to an existing chain.
Definition: cdr.c:1179
static void cdr_object_finalize(struct cdr_object *cdr)
Finalize a CDR.
Definition: cdr.c:1544
static void cdr_all_relink(struct cdr_object *cdr)
Definition: cdr.c:1053
static void free_variables(struct varshead *headp)
Delete all variables from a variable list.
Definition: cdr.c:882
static void cdr_object_transition_state(struct cdr_object *cdr, struct cdr_object_fn_table *fn_table)
Transition a cdr_object to a new state.
Definition: cdr.c:927
@ AST_STATE_UP
Definition: channelstate.h:42
#define SCOPED_AO2LOCK(varname, obj)
scoped lock specialization for ao2 mutexes.
Definition: lock.h:611
#define ast_string_field_set(x, field, data)
Set a field to a simple string value.
Definition: stringfields.h:521
enum ast_channel_state state
unsigned int flags
Definition: utils.h:218
char userfield[AST_MAX_USER_FIELD]
Definition: cdr.c:810
struct varshead variables
Definition: cdr.c:812
struct ast_channel_snapshot * snapshot
Definition: cdr.c:809
unsigned int flags
Definition: cdr.c:811
struct timeval answer
Definition: cdr.c:823
struct cdr_object_snapshot party_a
Definition: cdr.c:817
struct timeval lastevent
Definition: cdr.c:825
struct cdr_object * last
Definition: cdr.c:841
struct timeval start
Definition: cdr.c:822
struct cdr_object_snapshot party_b
Definition: cdr.c:818
static struct test_options options
struct timeval ast_tvnow(void)
Returns current timeval. Meant to replace calls to gettimeofday().
Definition: time.h:159

References cdr_object::answer, ao2_cleanup, ao2_ref, cdr_object::appl, AST_CDR_FLAG_FINALIZE, AST_CDR_FLAG_KEEP_VARS, AST_CDR_FLAG_RESET, AST_CDR_FLAG_SET_ANSWER, AST_CDR_LOCK_APP, ast_clear_flag, ast_debug, AST_STATE_UP, ast_string_field_set, ast_test_flag, ast_tvnow(), cdr_object::bridge, cdr_all_relink(), cdr_object_create_and_append(), cdr_object_finalize(), cdr_object_get_by_name(), cdr_object_transition_state(), voicemailpwcheck::context, copy_variables(), cdr_object::data, cdr_object::exten, finalized_state_fn_table, ast_flags::flags, cdr_object_snapshot::flags, cdr_object::flags, cdr_object::fn_table, free_variables(), cdr_object::last, cdr_object::lastevent, lock, cdr_object::next, options, cdr_object::party_a, cdr_object::party_b, RAII_VAR, SCOPED_AO2LOCK, cdr_object_snapshot::snapshot, cdr_object::start, ast_channel_snapshot::state, cdr_object_snapshot::userfield, and cdr_object_snapshot::variables.

Referenced by AST_TEST_DEFINE(), and forkcdr_callback().

◆ ast_cdr_format_var()

void ast_cdr_format_var ( struct ast_cdr cdr,
const char *  name,
char **  ret,
char *  workspace,
int  workspacelen,
int  raw 
)

Format a CDR variable from an already posted CDR.

Since
12
Parameters
cdrThe dispatched CDR to process
nameThe name of the variable
retPointer to the formatted buffer
workspaceA pointer to the buffer to use to format the variable
workspacelenThe size of workspace
rawIf non-zero and a date/time is extracted, provide epoch seconds. Otherwise format as a date/time stamp

Definition at line 3183 of file cdr.c.

3184{
3185 const char *fmt = "%Y-%m-%d %T";
3186 const char *varbuf;
3187
3188 if (!cdr) {
3189 return;
3190 }
3191
3192 *ret = NULL;
3193
3194 if (!strcasecmp(name, "clid")) {
3195 ast_copy_string(workspace, cdr->clid, workspacelen);
3196 } else if (!strcasecmp(name, "src")) {
3197 ast_copy_string(workspace, cdr->src, workspacelen);
3198 } else if (!strcasecmp(name, "dst")) {
3199 ast_copy_string(workspace, cdr->dst, workspacelen);
3200 } else if (!strcasecmp(name, "dcontext")) {
3201 ast_copy_string(workspace, cdr->dcontext, workspacelen);
3202 } else if (!strcasecmp(name, "channel")) {
3203 ast_copy_string(workspace, cdr->channel, workspacelen);
3204 } else if (!strcasecmp(name, "dstchannel")) {
3205 ast_copy_string(workspace, cdr->dstchannel, workspacelen);
3206 } else if (!strcasecmp(name, "lastapp")) {
3207 ast_copy_string(workspace, cdr->lastapp, workspacelen);
3208 } else if (!strcasecmp(name, "lastdata")) {
3209 ast_copy_string(workspace, cdr->lastdata, workspacelen);
3210 } else if (!strcasecmp(name, "start")) {
3211 cdr_get_tv(cdr->start, raw ? NULL : fmt, workspace, workspacelen);
3212 } else if (!strcasecmp(name, "answer")) {
3213 cdr_get_tv(cdr->answer, raw ? NULL : fmt, workspace, workspacelen);
3214 } else if (!strcasecmp(name, "end")) {
3215 cdr_get_tv(cdr->end, raw ? NULL : fmt, workspace, workspacelen);
3216 } else if (!strcasecmp(name, "duration")) {
3217 snprintf(workspace, workspacelen, "%ld", cdr->end.tv_sec != 0 ? cdr->duration : (long)ast_tvdiff_ms(ast_tvnow(), cdr->start) / 1000);
3218 } else if (!strcasecmp(name, "billsec")) {
3219 snprintf(workspace, workspacelen, "%ld", (cdr->billsec || !ast_tvzero(cdr->end) || ast_tvzero(cdr->answer)) ? cdr->billsec : (long)ast_tvdiff_ms(ast_tvnow(), cdr->answer) / 1000);
3220 } else if (!strcasecmp(name, "disposition")) {
3221 if (raw) {
3222 snprintf(workspace, workspacelen, "%ld", cdr->disposition);
3223 } else {
3224 ast_copy_string(workspace, ast_cdr_disp2str(cdr->disposition), workspacelen);
3225 }
3226 } else if (!strcasecmp(name, "amaflags")) {
3227 if (raw) {
3228 snprintf(workspace, workspacelen, "%ld", cdr->amaflags);
3229 } else {
3230 ast_copy_string(workspace, ast_channel_amaflags2string(cdr->amaflags), workspacelen);
3231 }
3232 } else if (!strcasecmp(name, "accountcode")) {
3233 ast_copy_string(workspace, cdr->accountcode, workspacelen);
3234 } else if (!strcasecmp(name, "peeraccount")) {
3235 ast_copy_string(workspace, cdr->peeraccount, workspacelen);
3236 } else if (!strcasecmp(name, "uniqueid")) {
3237 ast_copy_string(workspace, cdr->uniqueid, workspacelen);
3238 } else if (!strcasecmp(name, "linkedid")) {
3239 ast_copy_string(workspace, cdr->linkedid, workspacelen);
3240 } else if (!strcasecmp(name, "tenantid")) {
3241 ast_copy_string(workspace, cdr->tenantid, workspacelen);
3242 } else if (!strcasecmp(name, "peertenantid")) {
3243 ast_copy_string(workspace, cdr->peertenantid, workspacelen);
3244 } else if (!strcasecmp(name, "userfield")) {
3245 ast_copy_string(workspace, cdr->userfield, workspacelen);
3246 } else if (!strcasecmp(name, "sequence")) {
3247 snprintf(workspace, workspacelen, "%d", cdr->sequence);
3248 } else if ((varbuf = cdr_format_var_internal(cdr, name))) {
3249 ast_copy_string(workspace, varbuf, workspacelen);
3250 } else {
3251 workspace[0] = '\0';
3252 }
3253
3254 if (!ast_strlen_zero(workspace)) {
3255 *ret = workspace;
3256 }
3257}
static void cdr_get_tv(struct timeval when, const char *fmt, char *buf, int bufsize)
Definition: cdr.c:3168
static const char * cdr_format_var_internal(struct ast_cdr *cdr, const char *name)
Definition: cdr.c:3151
const char * ast_cdr_disp2str(int disposition)
Disposition to a string.
Definition: cdr.c:3576
const char * ast_channel_amaflags2string(enum ama_flags flags)
Convert the enum representation of an AMA flag to a string representation.
Definition: channel.c:4340
static force_inline int attribute_pure ast_strlen_zero(const char *s)
Definition: strings.h:65
void ast_copy_string(char *dst, const char *src, size_t size)
Size-limited null-terminating string copy.
Definition: strings.h:425
char dstchannel[AST_MAX_EXTENSION]
Definition: cdr.h:293
long int disposition
Definition: cdr.h:309
char lastdata[AST_MAX_EXTENSION]
Definition: cdr.h:297
char linkedid[AST_MAX_UNIQUEID]
Definition: cdr.h:321
char userfield[AST_MAX_USER_FIELD]
Definition: cdr.h:327
char peertenantid[AST_MAX_TENANT_ID]
Definition: cdr.h:325
long int billsec
Definition: cdr.h:307
struct timeval answer
Definition: cdr.h:301
char channel[AST_MAX_EXTENSION]
Definition: cdr.h:291
char peeraccount[AST_MAX_ACCOUNT_CODE]
Definition: cdr.h:315
long int duration
Definition: cdr.h:305
long int amaflags
Definition: cdr.h:311
char src[AST_MAX_EXTENSION]
Definition: cdr.h:285
char dst[AST_MAX_EXTENSION]
Definition: cdr.h:287
char clid[AST_MAX_EXTENSION]
Definition: cdr.h:283
char uniqueid[AST_MAX_UNIQUEID]
Definition: cdr.h:319
char tenantid[AST_MAX_TENANT_ID]
Definition: cdr.h:323
int sequence
Definition: cdr.h:329
struct timeval start
Definition: cdr.h:299
char accountcode[AST_MAX_ACCOUNT_CODE]
Definition: cdr.h:313
char lastapp[AST_MAX_EXTENSION]
Definition: cdr.h:295
char dcontext[AST_MAX_EXTENSION]
Definition: cdr.h:289
struct timeval end
Definition: cdr.h:303
int ast_tvzero(const struct timeval t)
Returns true if the argument is 0,0.
Definition: time.h:117
int64_t ast_tvdiff_ms(struct timeval end, struct timeval start)
Computes the difference (in milliseconds) between two struct timeval instances.
Definition: time.h:107

References ast_cdr::accountcode, ast_cdr::amaflags, ast_cdr::answer, ast_cdr_disp2str(), ast_channel_amaflags2string(), ast_copy_string(), ast_strlen_zero(), ast_tvdiff_ms(), ast_tvnow(), ast_tvzero(), ast_cdr::billsec, cdr_format_var_internal(), cdr_get_tv(), ast_cdr::channel, ast_cdr::clid, ast_cdr::dcontext, ast_cdr::disposition, ast_cdr::dst, ast_cdr::dstchannel, ast_cdr::duration, ast_cdr::end, ast_cdr::lastapp, ast_cdr::lastdata, ast_cdr::linkedid, name, NULL, ast_cdr::peeraccount, ast_cdr::peertenantid, ast_cdr::sequence, ast_cdr::src, ast_cdr::start, ast_cdr::tenantid, ast_cdr::uniqueid, and ast_cdr::userfield.

Referenced by cdr_read_callback(), cdr_retrieve_time(), odbc_log(), and pgsql_log().

◆ ast_cdr_free()

void ast_cdr_free ( struct ast_cdr cdr)

Free a CDR record.

Parameters
cdrast_cdr structure to free

Definition at line 3557 of file cdr.c.

3558{
3559 while (cdr) {
3560 struct ast_cdr *next = cdr->next;
3561
3562 free_variables(&cdr->varshead);
3563 ast_free(cdr);
3564 cdr = next;
3565 }
3566}
#define ast_free(a)
Definition: astmm.h:180

References ast_free, free_variables(), ast_cdr::next, and ast_cdr::varshead.

Referenced by ast_channel_destructor(), ast_dummy_channel_destructor(), cdr_detach(), clear_mock_cdr_backend(), and do_batch_backend_process().

◆ ast_cdr_get_config()

struct ast_cdr_config * ast_cdr_get_config ( void  )

Obtain the current CDR configuration.

Since
12

The configuration is a ref counted object. The caller of this function must decrement the ref count when finished with the configuration.

Return values
NULLon error
Returns
The current CDR configuration

Definition at line 2959 of file cdr.c.

2960{
2961 struct ast_cdr_config *general;
2962 struct module_config *mod_cfg;
2963
2964 mod_cfg = ao2_global_obj_ref(module_configs);
2965 if (!mod_cfg) {
2966 return NULL;
2967 }
2968 general = ao2_bump(mod_cfg->general);
2969 ao2_cleanup(mod_cfg);
2970 return general;
2971}
#define ao2_bump(obj)
Bump refcount on an AO2 object by one, returning the object.
Definition: astobj2.h:480
The global options available for CDRs.
Definition: cdr.h:269
struct ast_cdr_config * general
Definition: cdr.c:327

References ao2_bump, ao2_cleanup, ao2_global_obj_ref, module_config::general, and NULL.

Referenced by test_cdr_init_cb().

◆ ast_cdr_getvar()

int ast_cdr_getvar ( const char *  channel_name,
const char *  name,
char *  value,
size_t  length 
)

Retrieve a CDR variable from a channel's current CDR.

Since
12
Parameters
channel_nameThe name of the party A channel that the CDR is associated with
nameThe name of the variable to retrieve
valueBuffer to hold the value
lengthThe size of the buffer
Return values
0on success
non-zeroon failure

Definition at line 3470 of file cdr.c.

3471{
3472 struct cdr_object *cdr;
3473 struct cdr_object *cdr_obj;
3474
3475 if (ast_strlen_zero(name)) {
3476 return 1;
3477 }
3478
3479 cdr = cdr_object_get_by_name(channel_name);
3480 if (!cdr) {
3481 ast_log(AST_LOG_ERROR, "Unable to find CDR for channel %s\n", channel_name);
3482 return 1;
3483 }
3484
3485 ao2_lock(cdr);
3486
3487 cdr_obj = cdr->last;
3488 if (cdr_object_format_property(cdr_obj, name, value, length)) {
3489 /* Property failed; attempt variable */
3490 cdr_object_format_var_internal(cdr_obj, name, value, length);
3491 }
3492
3493 ao2_unlock(cdr);
3494
3495 ao2_cleanup(cdr);
3496 return 0;
3497}
#define ast_log
Definition: astobj2.c:42
static int cdr_object_format_property(struct cdr_object *cdr_obj, const char *name, char *value, size_t length)
Format one of the standard properties on a cdr_object.
Definition: cdr.c:3381
static void cdr_object_format_var_internal(struct cdr_object *cdr, const char *name, char *value, size_t length)
Format a variable on a cdr_object.
Definition: cdr.c:3364
#define AST_LOG_ERROR
int value
Definition: syslog.c:37

References ao2_cleanup, ao2_lock, ao2_unlock, ast_log, AST_LOG_ERROR, ast_strlen_zero(), cdr_object_format_property(), cdr_object_format_var_internal(), cdr_object_get_by_name(), cdr_object::last, name, and value.

Referenced by AST_TEST_DEFINE(), cdr_read_callback(), and cdr_retrieve_time().

◆ ast_cdr_is_enabled()

int ast_cdr_is_enabled ( void  )

Return TRUE if CDR subsystem is enabled.

Definition at line 2994 of file cdr.c.

2995{
2997}
static int is_cdr_flag_set(unsigned int cdr_flag)
Definition: cdr.c:1229

References CDR_ENABLED, and is_cdr_flag_set().

Referenced by action_coresettings(), and handle_show_settings().

◆ ast_cdr_message_router()

struct stasis_message_router * ast_cdr_message_router ( void  )

Return the message router for the CDR engine.

This returns the stasis_message_router that the CDR engine uses for dispatching Stasis Message Bus API messages. The reference on the message router is bumped and must be released by the caller of this function.

Return values
NULLif the CDR engine is disabled or unavailable
Returns
the stasis_message_router otherwise

Definition at line 4443 of file cdr.c.

4444{
4445 if (!stasis_router) {
4446 return NULL;
4447 }
4448
4450 return stasis_router;
4451}

References ao2_bump, NULL, and stasis_router.

Referenced by cdr_prop_write(), cdr_read(), cdr_write(), forkcdr_exec(), load_module(), publish_app_cdr_message(), and unload_module().

◆ ast_cdr_modifier_register()

int ast_cdr_modifier_register ( const char *  name,
const char *  desc,
ast_cdrbe  be 
)

Register a CDR modifier.

Parameters
namename associated with the particular CDR modifier
descdescription of the CDR modifier
befunction pointer to a CDR modifier

Used to register a Call Detail Record modifier.

This gives modules a chance to modify CDR fields before they are dispatched to registered backends (odbc, syslog, etc).

Note
The modified CDR will be passed to all registered backends for logging. For instance, if cdr_manager changes the CDR data, cdr_adaptive_odbc will also get the modified CDR.
Return values
0on success.
-1on error

Definition at line 3081 of file cdr.c.

3082{
3083 return cdr_generic_register((struct be_list *)&mo_list, name, desc, be);
3084}
static int cdr_generic_register(struct be_list *generic_list, const char *name, const char *desc, ast_cdrbe be)
Definition: cdr.c:3035
static const char desc[]
Definition: cdr_radius.c:84
char * be
Definition: eagi_proxy.c:73
List of registered modifiers.
Definition: cdr.c:437

References be, cdr_generic_register(), desc, and name.

◆ ast_cdr_modifier_unregister()

int ast_cdr_modifier_unregister ( const char *  name)

Unregister a CDR modifier.

Parameters
namename of CDR modifier to unregister Unregisters a CDR modifier by its name
Return values
0The modifier unregistered successfully
-1The modifier could not be unregistered at this time

Definition at line 3126 of file cdr.c.

3127{
3128 return ast_cdr_generic_unregister((struct be_list *)&mo_list, name);
3129}
static int ast_cdr_generic_unregister(struct be_list *generic_list, const char *name)
Definition: cdr.c:3086

References ast_cdr_generic_unregister(), and name.

◆ ast_cdr_register()

int ast_cdr_register ( const char *  name,
const char *  desc,
ast_cdrbe  be 
)

Register a CDR handling engine.

Parameters
namename associated with the particular CDR handler
descdescription of the CDR handler
befunction pointer to a CDR handler Used to register a Call Detail Record handler.
Return values
0on success.
-1on error

Definition at line 3076 of file cdr.c.

3077{
3079}

References be, cdr_generic_register(), desc, and name.

Referenced by load_module(), odbc_load_module(), and unload_module().

◆ ast_cdr_reset()

int ast_cdr_reset ( const char *  channel_name,
int  keep_variables 
)

Reset the detail record.

Parameters
channel_nameThe channel that the CDR is associated with
keep_variablesKeep the variables during the reset. If zero, variables are discarded during the reset.
Return values
0on success
-1on failure

Definition at line 3746 of file cdr.c.

3747{
3748 struct cdr_object *cdr;
3749 struct ast_var_t *vardata;
3750 struct cdr_object *it_cdr;
3751
3752 cdr = cdr_object_get_by_name(channel_name);
3753 if (!cdr) {
3754 return -1;
3755 }
3756
3757 ao2_lock(cdr);
3758 for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {
3759 /* clear variables */
3760 if (!keep_variables) {
3761 while ((vardata = AST_LIST_REMOVE_HEAD(&it_cdr->party_a.variables, entries))) {
3762 ast_var_delete(vardata);
3763 }
3764 if (cdr->party_b.snapshot) {
3765 while ((vardata = AST_LIST_REMOVE_HEAD(&it_cdr->party_b.variables, entries))) {
3766 ast_var_delete(vardata);
3767 }
3768 }
3769 }
3770
3771 /* Reset to initial state */
3772 memset(&it_cdr->start, 0, sizeof(it_cdr->start));
3773 memset(&it_cdr->end, 0, sizeof(it_cdr->end));
3774 memset(&it_cdr->answer, 0, sizeof(it_cdr->answer));
3775 it_cdr->start = ast_tvnow();
3776 it_cdr->lastevent = it_cdr->start;
3778 }
3779 ao2_unlock(cdr);
3780
3781 ao2_cleanup(cdr);
3782 return 0;
3783}
static void cdr_object_check_party_a_answer(struct cdr_object *cdr)
Check to see if a CDR needs to be answered based on its Party A. Note that this is safe to call as mu...
Definition: cdr.c:1598
void ast_var_delete(struct ast_var_t *var)
Definition: extconf.c:2469
#define AST_LIST_REMOVE_HEAD(head, field)
Removes and returns the head entry from a list.
Definition: linkedlists.h:833
struct timeval end
Definition: cdr.c:824

References cdr_object::answer, ao2_cleanup, ao2_lock, ao2_unlock, AST_LIST_REMOVE_HEAD, ast_tvnow(), ast_var_delete(), cdr_object_check_party_a_answer(), cdr_object_get_by_name(), cdr_object::end, cdr_object::lastevent, cdr_object::next, cdr_object::party_a, cdr_object::party_b, cdr_object_snapshot::snapshot, cdr_object::start, and cdr_object_snapshot::variables.

Referenced by appcdr_callback(), and dial_exec_full().

◆ ast_cdr_serialize_variables()

int ast_cdr_serialize_variables ( const char *  channel_name,
struct ast_str **  buf,
char  delim,
char  sep 
)

Serializes all the data and variables for a current CDR record.

Parameters
channel_nameThe channel to get the CDR for
bufA buffer to use for formatting the data
delimA delimeter to use to separate variable keys/values
sepA separator to use between nestings
Returns
the total number of serialized variables

Definition at line 3499 of file cdr.c.

3500{
3501 struct cdr_object *cdr;
3502 struct cdr_object *it_cdr;
3503 struct ast_var_t *variable;
3504 const char *var;
3505 char workspace[256];
3506 int total = 0, x = 0, i;
3507
3508 cdr = cdr_object_get_by_name(channel_name);
3509 if (!cdr) {
3511 ast_log(AST_LOG_ERROR, "Unable to find CDR for channel %s\n", channel_name);
3512 }
3513 return 0;
3514 }
3515
3517
3518 ao2_lock(cdr);
3519 for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {
3520 if (++x > 1) {
3521 ast_str_append(buf, 0, "\n");
3522 }
3523
3524 AST_LIST_TRAVERSE(&it_cdr->party_a.variables, variable, entries) {
3525 if (!(var = ast_var_name(variable))) {
3526 continue;
3527 }
3528
3529 if (ast_str_append(buf, 0, "level %d: %s%c%s%c", x, var, delim, S_OR(ast_var_value(variable), ""), sep) < 0) {
3530 ast_log(LOG_ERROR, "Data Buffer Size Exceeded!\n");
3531 break;
3532 }
3533
3534 total++;
3535 }
3536
3537 for (i = 0; cdr_readonly_vars[i]; i++) {
3538 if (cdr_object_format_property(it_cdr, cdr_readonly_vars[i], workspace, sizeof(workspace))) {
3539 /* Unhandled read-only CDR variable. */
3540 ast_assert(0);
3541 continue;
3542 }
3543
3544 if (!ast_strlen_zero(workspace)
3545 && ast_str_append(buf, 0, "level %d: %s%c%s%c", x, cdr_readonly_vars[i], delim, workspace, sep) < 0) {
3546 ast_log(LOG_ERROR, "Data Buffer Size Exceeded!\n");
3547 break;
3548 }
3549 total++;
3550 }
3551 }
3552 ao2_unlock(cdr);
3553 ao2_cleanup(cdr);
3554 return total;
3555}
#define var
Definition: ast_expr2f.c:605
static const char *const cdr_readonly_vars[]
Definition: cdr.c:3291
const char * ast_var_name(const struct ast_var_t *var)
Definition: chanvars.c:60
const char * ast_var_value(const struct ast_var_t *var)
Definition: chanvars.c:80
char buf[BUFSIZE]
Definition: eagi_proxy.c:66
#define LOG_ERROR
#define AST_LIST_TRAVERSE(head, var, field)
Loops over (traverses) the entries in a list.
Definition: linkedlists.h:491
static int total
Definition: res_adsi.c:970
int ast_str_append(struct ast_str **buf, ssize_t max_len, const char *fmt,...)
Append to a thread local dynamic string.
Definition: strings.h:1139
#define S_OR(a, b)
returns the equivalent of logic or for strings: first one if not empty, otherwise second one.
Definition: strings.h:80
void ast_str_reset(struct ast_str *buf)
Reset the content of a dynamic string. Useful before a series of ast_str_append.
Definition: strings.h:693
struct ast_var_t::@216 entries
#define ast_assert(a)
Definition: utils.h:776

References ao2_cleanup, ao2_lock, ao2_unlock, ast_assert, AST_LIST_TRAVERSE, ast_log, AST_LOG_ERROR, ast_str_append(), ast_str_reset(), ast_strlen_zero(), ast_var_name(), ast_var_value(), buf, CDR_ENABLED, cdr_object_format_property(), cdr_object_get_by_name(), cdr_readonly_vars, ast_var_t::entries, is_cdr_flag_set(), LOG_ERROR, cdr_object::next, cdr_object::party_a, S_OR, total, var, and cdr_object_snapshot::variables.

Referenced by handle_showchan().

◆ ast_cdr_set_config()

void ast_cdr_set_config ( struct ast_cdr_config config)

Set the current CDR configuration.

Since
12
Parameters
configThe new CDR configuration

Definition at line 2973 of file cdr.c.

2974{
2975 struct module_config *mod_cfg;
2976
2977 if (!config) {
2978 return;
2979 }
2980
2981 mod_cfg = ao2_global_obj_ref(module_configs);
2982 if (!mod_cfg) {
2983 return;
2984 }
2985
2986 ao2_replace(mod_cfg->general, config);
2987
2988 cdr_set_debug_mode(mod_cfg);
2990
2991 ao2_cleanup(mod_cfg);
2992}
#define ao2_replace(dst, src)
Replace one object reference with another cleaning up the original.
Definition: astobj2.h:501
#define cdr_set_debug_mode(mod_cfg)
Definition: cdr.c:306
static int cdr_toggle_runtime_options(void)
Checks if CDRs are enabled and enables/disables the necessary options.
Definition: cdr.c:4640
static const char config[]
Definition: chan_ooh323.c:111

References ao2_cleanup, ao2_global_obj_ref, ao2_replace, cdr_set_debug_mode, cdr_toggle_runtime_options(), config, and module_config::general.

Referenced by test_cdr_cleanup_cb().

◆ ast_cdr_set_property()

int ast_cdr_set_property ( const char *  channel_name,
enum ast_cdr_options  option 
)

Set a property on a CDR for a channel.

Since
12

This function sets specific administrative properties on a CDR for a channel. This includes properties like preventing a CDR from being dispatched, to setting the channel as the preferred Party A in future CDRs. See ast_cdr_options for more information.

Parameters
channel_nameThe CDR's channel
optionOption to apply to the CDR
Return values
0on success
1on error

Definition at line 3696 of file cdr.c.

3697{
3698 struct cdr_object *cdr;
3699 struct cdr_object *it_cdr;
3700
3701 cdr = cdr_object_get_by_name(channel_name);
3702 if (!cdr) {
3703 return -1;
3704 }
3705
3706 ao2_lock(cdr);
3707 for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {
3708 if (it_cdr->fn_table == &finalized_state_fn_table) {
3709 continue;
3710 }
3711 /* Note: in general, set the flags on both the CDR record as well as the
3712 * Party A. Sometimes all we have is the Party A to look at.
3713 */
3714 ast_set_flag(&it_cdr->flags, option);
3715 ast_set_flag(&it_cdr->party_a, option);
3716 }
3717 ao2_unlock(cdr);
3718
3719 ao2_cleanup(cdr);
3720 return 0;
3721}
#define ast_set_flag(p, flag)
Definition: utils.h:70

References ao2_cleanup, ao2_lock, ao2_unlock, ast_set_flag, cdr_object_get_by_name(), finalized_state_fn_table, cdr_object::flags, cdr_object::fn_table, cdr_object::next, and cdr_object::party_a.

Referenced by AST_TEST_DEFINE(), and cdr_prop_write_callback().

◆ ast_cdr_setuserfield()

void ast_cdr_setuserfield ( const char *  channel_name,
const char *  userfield 
)

Set CDR user field for channel (stored in CDR)

Parameters
channel_nameThe name of the channel that owns the CDR
userfieldThe user field to set

Definition at line 3625 of file cdr.c.

3626{
3627 struct cdr_object *cdr;
3628 struct party_b_userfield_update party_b_info = {
3630 .userfield = userfield,
3631 };
3632 struct cdr_object *it_cdr;
3633
3634 /* Handle Party A */
3635 cdr = cdr_object_get_by_name(channel_name);
3636 if (cdr) {
3637 ao2_lock(cdr);
3638 for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {
3639 if (it_cdr->fn_table == &finalized_state_fn_table && it_cdr->next != NULL) {
3640 continue;
3641 }
3642 ast_copy_string(it_cdr->party_a.userfield, userfield,
3643 sizeof(it_cdr->party_a.userfield));
3644 }
3645 ao2_unlock(cdr);
3646 }
3647
3648 /* Handle Party B */
3651 &party_b_info);
3652
3653 ao2_cleanup(cdr);
3654}
#define ao2_callback_data(container, flags, cb_fn, arg, data)
Definition: astobj2.h:1723
@ OBJ_NODATA
Definition: astobj2.h:1044
@ OBJ_MULTIPLE
Definition: astobj2.h:1049
@ OBJ_SEARCH_KEY
The arg parameter is a search key, but is not an object.
Definition: astobj2.h:1101
static int cdr_object_update_party_b_userfield_cb(void *obj, void *arg, void *data, int flags)
Callback used to update the userfield on Party B on all CDRs.
Definition: cdr.c:3603
static struct ao2_container * active_cdrs_all
A container of all active CDRs with a Party B indexed by Party B channel name.
Definition: cdr.c:472
const char * userfield
Definition: cdr.c:3599
const char * channel_name
Definition: cdr.c:3598

References active_cdrs_all, ao2_callback_data, ao2_cleanup, ao2_lock, ao2_unlock, ast_copy_string(), cdr_object_get_by_name(), cdr_object_update_party_b_userfield_cb(), party_b_userfield_update::channel_name, finalized_state_fn_table, cdr_object::fn_table, cdr_object::next, NULL, OBJ_MULTIPLE, OBJ_NODATA, OBJ_SEARCH_KEY, cdr_object::party_a, cdr_object_snapshot::userfield, and party_b_userfield_update::userfield.

Referenced by AST_TEST_DEFINE(), and cdr_write_callback().

◆ ast_cdr_setvar()

int ast_cdr_setvar ( const char *  channel_name,
const char *  name,
const char *  value 
)

Set a variable on a CDR.

Since
12
Parameters
channel_nameThe channel to set the variable on
nameThe name of the variable to set
valueThe value of the variable to set
Return values
0on success
non-zeroon failure

Definition at line 3316 of file cdr.c.

3317{
3318 struct cdr_object *cdr;
3319 struct cdr_object *it_cdr;
3320 struct ao2_iterator *it_cdrs;
3321 char *arg = ast_strdupa(channel_name);
3322 int x;
3323
3324 for (x = 0; cdr_readonly_vars[x]; x++) {
3325 if (!strcasecmp(name, cdr_readonly_vars[x])) {
3326 ast_log(LOG_ERROR, "Attempt to set the '%s' read-only variable!\n", name);
3327 return -1;
3328 }
3329 }
3330
3332 if (!it_cdrs) {
3333 ast_log(AST_LOG_ERROR, "Unable to find CDR for channel %s\n", channel_name);
3334 return -1;
3335 }
3336
3337 for (; (cdr = ao2_iterator_next(it_cdrs)); ao2_unlock(cdr), ao2_cleanup(cdr)) {
3338 ao2_lock(cdr);
3339 for (it_cdr = cdr; it_cdr; it_cdr = it_cdr->next) {
3340 struct varshead *headp = NULL;
3341
3342 if (it_cdr->fn_table == &finalized_state_fn_table && it_cdr->next != NULL) {
3343 continue;
3344 }
3345 if (!strcasecmp(channel_name, it_cdr->party_a.snapshot->base->name)) {
3346 headp = &it_cdr->party_a.variables;
3347 } else if (it_cdr->party_b.snapshot
3348 && !strcasecmp(channel_name, it_cdr->party_b.snapshot->base->name)) {
3349 headp = &it_cdr->party_b.variables;
3350 }
3351 if (headp) {
3352 set_variable(headp, name, value);
3353 }
3354 }
3355 }
3356 ao2_iterator_destroy(it_cdrs);
3357
3358 return 0;
3359}
#define ast_strdupa(s)
duplicate a string in memory from the stack
Definition: astmm.h:298
#define ao2_iterator_next(iter)
Definition: astobj2.h:1911
#define ao2_callback(c, flags, cb_fn, arg)
ao2_callback() is a generic function that applies cb_fn() to all objects in a container,...
Definition: astobj2.h:1693
void ao2_iterator_destroy(struct ao2_iterator *iter)
Destroy a container iterator.
static int cdr_object_select_all_by_name_cb(void *obj, void *arg, int flags)
Definition: cdr.c:3263
static void set_variable(struct varshead *headp, const char *name, const char *value)
Definition: cdr.c:1364
static struct ao2_container * active_cdrs_master
A container of the active master CDRs indexed by Party A channel uniqueid.
Definition: cdr.c:469
When we need to walk through a container, we use an ao2_iterator to keep track of the current positio...
Definition: astobj2.h:1821
const ast_string_field name
struct ast_channel_snapshot_base * base

References active_cdrs_master, ao2_callback, ao2_cleanup, ao2_iterator_destroy(), ao2_iterator_next, ao2_lock, ao2_unlock, ast_log, AST_LOG_ERROR, ast_strdupa, ast_channel_snapshot::base, cdr_object_select_all_by_name_cb(), cdr_readonly_vars, finalized_state_fn_table, cdr_object::fn_table, LOG_ERROR, name, ast_channel_snapshot_base::name, cdr_object::next, NULL, OBJ_MULTIPLE, cdr_object::party_a, cdr_object::party_b, set_variable(), cdr_object_snapshot::snapshot, value, and cdr_object_snapshot::variables.

Referenced by AST_TEST_DEFINE(), and cdr_write_callback().

◆ ast_cdr_unregister()

int ast_cdr_unregister ( const char *  name)

Unregister a CDR handling engine.

Parameters
namename of CDR handler to unregister Unregisters a CDR by it's name
Return values
0The backend unregistered successfully
-1The backend could not be unregistered at this time

Definition at line 3121 of file cdr.c.

3122{
3124}

References ast_cdr_generic_unregister(), and name.

Referenced by load_module(), reload(), tds_unload_module(), and unload_module().