/* * Asterisk -- A telephony toolkit for Linux. * * Call Detail Record API * * Copyright (C) 1999, Mark Spencer * * Mark Spencer * * 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 #include #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_cdr_setaccount(struct ast_channel *chan, char *account); extern int ast_default_amaflags; extern char ast_default_accountcode[20]; #endif /* _CDR_H */