aboutsummaryrefslogtreecommitdiffstats
path: root/include/asterisk/cdr.h
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2001-10-31 15:28:08 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2001-10-31 15:28:08 +0000
commita881107daa6bee3ca7bc537b4c0ed7a568368cb9 (patch)
tree33d790ecbb94ae7c4cececd8b69695ccedce33f0 /include/asterisk/cdr.h
parentb6c1eedcbed1c6ad198bca79b889bfe3c5c698f3 (diff)
Version 0.1.10 from FTP
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@380 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'include/asterisk/cdr.h')
-rwxr-xr-xinclude/asterisk/cdr.h196
1 files changed, 196 insertions, 0 deletions
diff --git a/include/asterisk/cdr.h b/include/asterisk/cdr.h
new file mode 100755
index 000000000..b2e0d1641
--- /dev/null
+++ b/include/asterisk/cdr.h
@@ -0,0 +1,196 @@
+/*
+ * Asterisk -- A telephony toolkit for Linux.
+ *
+ * Call Detail Record API
+ *
+ * Copyright (C) 1999, Mark Spencer
+ *
+ * Mark Spencer <markster@linux-support.net>
+ *
+ * This program is free software, distributed under the terms of
+ * the GNU General Public License.
+ *
+ * Includes code and algorithms from the Zapata library.
+ *
+ */
+
+#ifndef _CDR_H
+#define _CDR_H
+
+#include <asterisk/channel.h>
+#include <sys/time.h>
+
+#define AST_CDR_NOANSWER (1 << 0)
+#define AST_CDR_BUSY (1 << 1)
+#define AST_CDR_ANSWERED (1 << 2)
+
+//! AMA Flags
+#define AST_CDR_OMIT (1)
+#define AST_CDR_BILLING (2)
+#define AST_CDR_DOCUMENTATION (3)
+
+struct ast_channel;
+
+//! Responsible for call detail data
+struct ast_cdr {
+ /*! Caller*ID with text */
+ char clid[AST_MAX_EXTENSION];
+ /*! Caller*ID number */
+ char src[AST_MAX_EXTENSION];
+ /*! Destination extension */
+ char dst[AST_MAX_EXTENSION];
+ /*! Destination context */
+ char dcontext[AST_MAX_EXTENSION];
+
+ char channel[AST_MAX_EXTENSION];
+ /*! Destination channel if appropriate */
+ char dstchannel[AST_MAX_EXTENSION];
+ /*! Last application if appropriate */
+ char lastapp[AST_MAX_EXTENSION];
+ /*! Last application data */
+ char lastdata[AST_MAX_EXTENSION];
+
+ struct timeval start;
+
+ struct timeval answer;
+
+ struct timeval end;
+ /*! Total time in system, in seconds */
+ int duration;
+ /*! Total time call is up, in seconds */
+ int billsec;
+ /*! What happened to the call */
+ int disposition;
+ /*! What flags to use */
+ int amaflags;
+ /*! What account number to use */
+ char accountcode[20];
+ /*! Whether or not the record has been posted */
+ int posted;
+};
+
+typedef int (*ast_cdrbe)(struct ast_cdr *cdr);
+
+//! Allocate a record
+/*!
+ * Returns a malloc'd ast_cdr structure, returns NULL on error (malloc failure)
+ */
+extern struct ast_cdr *ast_cdr_alloc(void);
+
+//! Free a record
+/* \param cdr ast_cdr structure to free
+ * Returns nothing important
+ */
+extern void ast_cdr_free(struct ast_cdr *cdr);
+
+//! Initialize based on a channel
+/*!
+ * \param cdr Call Detail Record to use for channel
+ * \param chan Channel to bind CDR with
+ * Initializes a CDR and associates it with a particular channel
+ * Return is negligible. (returns 0 by default)
+ */
+extern int ast_cdr_init(struct ast_cdr *cdr, struct ast_channel *chan);
+
+//! Register a CDR handling engine
+/*!
+ * \param name name associated with the particular CDR handler
+ * \param desc description of the CDR handler
+ * \param be function pointer to a CDR handler
+ * Used to register a Call Detail Record handler.
+ * Returns -1 on error, 0 on success.
+ */
+extern int ast_cdr_register(char *name, char *desc, ast_cdrbe be);
+
+//! Unregister a CDR handling engine
+/*!
+ * \param name name of CDR handler to unregister
+ * Unregisters a CDR by it's name
+ */
+extern void ast_cdr_unregister(char *name);
+
+//! Start a call
+/*!
+ * \param cdr the cdr you wish to associate with the call
+ * Starts all CDR stuff necessary for monitoring a call
+ * Returns nothing important
+ */
+extern void ast_cdr_start(struct ast_cdr *cdr);
+
+//! Answer a call
+/*!
+ * \param cdr the cdr you wish to associate with the call
+ * Starts all CDR stuff necessary for doing CDR when answering a call
+ */
+extern void ast_cdr_answer(struct ast_cdr *cdr);
+
+//! Busy a call
+/*!
+ * \param cdr the cdr you wish to associate with the call
+ * Returns nothing important
+ */
+extern void ast_cdr_busy(struct ast_cdr *cdr);
+
+//! End a call
+/*!
+ * \param cdr the cdr you have associated the call with
+ * Registers the end of call time in the cdr structure.
+ * Returns nothing important
+ */
+extern void ast_cdr_end(struct ast_cdr *cdr);
+
+//! Post the detail record
+/*!
+ * \param cdr Which cdr to post
+ * Actually outputs the CDR record to the CDR plugins installed
+ * Returns nothing
+ */
+extern void ast_cdr_post(struct ast_cdr *cdr);
+
+//! Set the destination channel, if there was one
+/*!
+ * \param cdr Which cdr it's applied to
+ * Sets the destination channel the CDR is applied to
+ * Returns nothing
+ */
+extern void ast_cdr_setdestchan(struct ast_cdr *cdr, char *chan);
+
+//! Set the last executed application
+/*!
+ * \param cdr which cdr to act upon
+ * \param app the name of the app you wish to change it to
+ * \param data the data you want in the data field of app you set it to
+ * Changes the value of the last executed app
+ * Returns nothing
+ */
+extern void ast_cdr_setapp(struct ast_cdr *cdr, char *app, char *data);
+
+//! Convert a string to a detail record AMA flag
+/*!
+ * \param flag string form of flag
+ * Converts the string form of the flag to the binary form.
+ * Returns the binary form of the flag
+ */
+extern int ast_cdr_amaflags2int(char *flag);
+
+//! Disposition to a string
+/*!
+ * \param flag input binary form
+ * Converts the binary form of a disposition to string form.
+ * Returns a pointer to the string form
+ */
+extern char *ast_cdr_disp2str(int disposition);
+
+//! Flags to a string
+/*!
+ * \param flags binary flag
+ * Converts binary flags to string flags
+ * Returns string with flag name
+ */
+extern char *ast_cdr_flags2str(int flags);
+
+extern int ast_default_amaflags;
+
+extern char ast_default_accountcode[20];
+
+#endif /* _CDR_H */