| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | #ifndef _SIG_PRI_H
 | 
					
						
							|  |  |  | #define _SIG_PRI_H
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Asterisk -- An open source telephony toolkit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 1999 - 2009, Digium, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Mark Spencer <markster@digium.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See http://www.asterisk.org for more information about
 | 
					
						
							|  |  |  |  * the Asterisk project. Please do not directly contact | 
					
						
							|  |  |  |  * any of the maintainers of this project for assistance; | 
					
						
							|  |  |  |  * the project provides a web site, mailing lists and IRC | 
					
						
							|  |  |  |  * channels for your use. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software, distributed under the terms of | 
					
						
							|  |  |  |  * the GNU General Public License Version 2. See the LICENSE file | 
					
						
							|  |  |  |  * at the top of the source tree. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! \file
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \brief Interface header for PRI signaling module | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \author Matthew Fredrickson <creslin@digium.com> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "asterisk/channel.h"
 | 
					
						
							|  |  |  | #include "asterisk/frame.h"
 | 
					
						
							| 
									
										
										
										
											2010-06-03 00:02:14 +00:00
										 |  |  | #include "asterisk/event.h"
 | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | #include "asterisk/ccss.h"
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | #include <libpri.h>
 | 
					
						
							|  |  |  | #include <dahdi/user.h>
 | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if defined(HAVE_PRI_CCSS)
 | 
					
						
							|  |  |  | /*! PRI debug message flags when normal PRI debugging is turned on at the command line. */ | 
					
						
							|  |  |  | #define SIG_PRI_DEBUG_NORMAL	\
 | 
					
						
							|  |  |  | 	(PRI_DEBUG_APDU | PRI_DEBUG_Q931_DUMP | PRI_DEBUG_Q931_STATE | PRI_DEBUG_Q921_STATE \ | 
					
						
							|  |  |  | 	| PRI_DEBUG_CC) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! PRI debug message flags when intense PRI debugging is turned on at the command line. */ | 
					
						
							|  |  |  | #define SIG_PRI_DEBUG_INTENSE	\
 | 
					
						
							|  |  |  | 	(PRI_DEBUG_APDU | PRI_DEBUG_Q931_DUMP | PRI_DEBUG_Q931_STATE | PRI_DEBUG_Q921_STATE \ | 
					
						
							|  |  |  | 	| PRI_DEBUG_CC | PRI_DEBUG_Q921_RAW | PRI_DEBUG_Q921_DUMP) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! PRI debug message flags when normal PRI debugging is turned on at the command line. */ | 
					
						
							|  |  |  | #define SIG_PRI_DEBUG_NORMAL	\
 | 
					
						
							|  |  |  | 	(PRI_DEBUG_APDU | PRI_DEBUG_Q931_DUMP | PRI_DEBUG_Q931_STATE | PRI_DEBUG_Q921_STATE) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! PRI debug message flags when intense PRI debugging is turned on at the command line. */ | 
					
						
							|  |  |  | #define SIG_PRI_DEBUG_INTENSE	\
 | 
					
						
							|  |  |  | 	(PRI_DEBUG_APDU | PRI_DEBUG_Q931_DUMP | PRI_DEBUG_Q931_STATE | PRI_DEBUG_Q921_STATE \ | 
					
						
							|  |  |  | 	| PRI_DEBUG_Q921_RAW | PRI_DEBUG_Q921_DUMP) | 
					
						
							|  |  |  | #endif	/* !defined(HAVE_PRI_CCSS) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if 0
 | 
					
						
							|  |  |  | /*! PRI debug message flags set on initial startup. */ | 
					
						
							|  |  |  | #define SIG_PRI_DEBUG_DEFAULT	SIG_PRI_DEBUG_NORMAL
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | /*! PRI debug message flags set on initial startup. */ | 
					
						
							|  |  |  | #define SIG_PRI_DEBUG_DEFAULT	0
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | #define SIG_PRI_AOC_GRANT_S    (1 << 0)
 | 
					
						
							|  |  |  | #define SIG_PRI_AOC_GRANT_D    (1 << 1)
 | 
					
						
							|  |  |  | #define SIG_PRI_AOC_GRANT_E    (1 << 2)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | enum sig_pri_tone { | 
					
						
							|  |  |  | 	SIG_PRI_TONE_RINGTONE = 0, | 
					
						
							|  |  |  | 	SIG_PRI_TONE_STUTTER, | 
					
						
							|  |  |  | 	SIG_PRI_TONE_CONGESTION, | 
					
						
							|  |  |  | 	SIG_PRI_TONE_DIALTONE, | 
					
						
							|  |  |  | 	SIG_PRI_TONE_DIALRECALL, | 
					
						
							|  |  |  | 	SIG_PRI_TONE_INFO, | 
					
						
							|  |  |  | 	SIG_PRI_TONE_BUSY, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum sig_pri_law { | 
					
						
							|  |  |  | 	SIG_PRI_DEFLAW = 0, | 
					
						
							|  |  |  | 	SIG_PRI_ULAW, | 
					
						
							|  |  |  | 	SIG_PRI_ALAW | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | struct sig_pri_span; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct sig_pri_callback { | 
					
						
							|  |  |  | 	/* Unlock the private in the signalling private structure.  This is used for three way calling madness. */ | 
					
						
							|  |  |  | 	void (* const unlock_private)(void *pvt); | 
					
						
							|  |  |  | 	/* Lock the private in the signalling private structure.  ... */ | 
					
						
							|  |  |  | 	void (* const lock_private)(void *pvt); | 
					
						
							| 
									
										
										
										
											2010-11-24 22:52:07 +00:00
										 |  |  | 	/* Function which is called back to handle any other DTMF events that are received.  Called by analog_handle_event.  Why is this
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	 * important to use, instead of just directly using events received before they are passed into the library?  Because sometimes, | 
					
						
							|  |  |  | 	 * (CWCID) the library absorbs DTMF events received. */ | 
					
						
							| 
									
										
										
										
											2010-11-24 22:52:07 +00:00
										 |  |  | 	//void (* const handle_dtmf)(void *pvt, struct ast_channel *ast, enum analog_sub analog_index, struct ast_frame **dest);
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	//int (* const dial_digits)(void *pvt, enum analog_sub sub, struct analog_dialoperation *dop);
 | 
					
						
							|  |  |  | 	int (* const play_tone)(void *pvt, enum sig_pri_tone tone); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int (* const set_echocanceller)(void *pvt, int enable); | 
					
						
							|  |  |  | 	int (* const train_echocanceller)(void *pvt); | 
					
						
							| 
									
										
										
										
											2009-08-10 15:53:23 +00:00
										 |  |  | 	int (* const dsp_reset_and_flush_digits)(void *pvt); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-07 20:04:42 +00:00
										 |  |  | 	struct ast_channel * (* const new_ast_channel)(void *pvt, int state, enum sig_pri_law law, char *exten, const struct ast_channel *chan); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	void (* const fixup_chans)(void *old_chan, void *new_chan); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Note: Called with PRI lock held */ | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | 	void (* const handle_dchan_exception)(struct sig_pri_span *pri, int index); | 
					
						
							| 
									
										
										
										
											2010-05-04 21:10:58 +00:00
										 |  |  | 	void (* const set_alarm)(void *pvt, int in_alarm); | 
					
						
							|  |  |  | 	void (* const set_dialing)(void *pvt, int is_dialing); | 
					
						
							|  |  |  | 	void (* const set_digital)(void *pvt, int is_digital); | 
					
						
							| 
									
										
										
										
											2009-08-04 17:46:03 +00:00
										 |  |  | 	void (* const set_callerid)(void *pvt, const struct ast_party_caller *caller); | 
					
						
							|  |  |  | 	void (* const set_dnid)(void *pvt, const char *dnid); | 
					
						
							|  |  |  | 	void (* const set_rdnis)(void *pvt, const char *rdnis); | 
					
						
							| 
									
										
										
										
											2009-10-19 14:32:08 +00:00
										 |  |  | 	void (* const queue_control)(void *pvt, int subclass); | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | 	int (* const new_nobch_intf)(struct sig_pri_span *pri); | 
					
						
							|  |  |  | 	void (* const init_config)(void *pvt, struct sig_pri_span *pri); | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 	const char *(* const get_orig_dialstring)(void *pvt); | 
					
						
							|  |  |  | 	void (* const make_cc_dialstring)(void *pvt, char *buf, size_t buf_size); | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | 	void (* const update_span_devstate)(struct sig_pri_span *pri); | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | 	void (* const open_media)(void *pvt); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 	/*! Reference the parent module. */ | 
					
						
							|  |  |  | 	void (*module_ref)(void); | 
					
						
							|  |  |  | 	/*! Unreference the parent module. */ | 
					
						
							|  |  |  | 	void (*module_unref)(void); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | #define SIG_PRI_NUM_DCHANS		4		/*!< No more than 4 d-channels */
 | 
					
						
							|  |  |  | #define SIG_PRI_MAX_CHANNELS	672		/*!< No more than a DS3 per trunk group */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define SIG_PRI		DAHDI_SIG_CLEAR
 | 
					
						
							|  |  |  | #define SIG_BRI		(0x2000000 | DAHDI_SIG_CLEAR)
 | 
					
						
							|  |  |  | #define SIG_BRI_PTMP	(0X4000000 | DAHDI_SIG_CLEAR)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-05 22:46:37 +00:00
										 |  |  | /* QSIG channel mapping option types */ | 
					
						
							|  |  |  | #define DAHDI_CHAN_MAPPING_PHYSICAL	0
 | 
					
						
							|  |  |  | #define DAHDI_CHAN_MAPPING_LOGICAL	1
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | /* Overlap dialing option types */ | 
					
						
							|  |  |  | #define DAHDI_OVERLAPDIAL_NONE 0
 | 
					
						
							|  |  |  | #define DAHDI_OVERLAPDIAL_OUTGOING 1
 | 
					
						
							|  |  |  | #define DAHDI_OVERLAPDIAL_INCOMING 2
 | 
					
						
							|  |  |  | #define DAHDI_OVERLAPDIAL_BOTH (DAHDI_OVERLAPDIAL_INCOMING|DAHDI_OVERLAPDIAL_OUTGOING)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #if defined(HAVE_PRI_SERVICE_MESSAGES)
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | /*! \brief Persistent Service State */ | 
					
						
							|  |  |  | #define SRVST_DBKEY "service-state"
 | 
					
						
							|  |  |  | /*! \brief The out-of-service SERVICE state */ | 
					
						
							|  |  |  | #define SRVST_TYPE_OOS "O"
 | 
					
						
							| 
									
										
										
										
											2009-08-03 16:24:13 +00:00
										 |  |  | /*! \brief SRVST_INITIALIZED is used to indicate a channel being out-of-service
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  |  *  The SRVST_INITIALIZED is mostly used maintain backwards compatibility but also may | 
					
						
							|  |  |  |  *  mean that the channel has not yet received a RESTART message.  If a channel is | 
					
						
							|  |  |  |  *  out-of-service with this reason a RESTART message will result in the channel | 
					
						
							|  |  |  |  *  being put into service. */ | 
					
						
							|  |  |  | #define SRVST_INITIALIZED 0
 | 
					
						
							|  |  |  | /*! \brief SRVST_NEAREND is used to indicate that the near end was put out-of-service */ | 
					
						
							|  |  |  | #define SRVST_NEAREND  (1 << 0)
 | 
					
						
							|  |  |  | /*! \brief SRVST_FAREND is used to indicate that the far end was taken out-of-service */ | 
					
						
							|  |  |  | #define SRVST_FAREND   (1 << 1)
 | 
					
						
							|  |  |  | /*! \brief SRVST_BOTH is used to indicate that both sides of the channel are out-of-service */ | 
					
						
							|  |  |  | #define SRVST_BOTH (SRVST_NEAREND | SRVST_FAREND)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! \brief The AstDB family */ | 
					
						
							|  |  |  | static const char dahdi_db[] = "dahdi/registry"; | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #endif	/* defined(HAVE_PRI_SERVICE_MESSAGES) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct sig_pri_chan { | 
					
						
							|  |  |  | 	/* Options to be set by user */ | 
					
						
							|  |  |  | 	unsigned int hidecallerid:1; | 
					
						
							|  |  |  | 	unsigned int hidecalleridname:1;      /*!< Hide just the name not the number for legacy PBX use */ | 
					
						
							|  |  |  | 	unsigned int immediate:1;			/*!< Answer before getting digits? */ | 
					
						
							|  |  |  | 	unsigned int priexclusive:1;			/*!< Whether or not to override and use exculsive mode for channel selection */ | 
					
						
							|  |  |  | 	unsigned int priindication_oob:1; | 
					
						
							|  |  |  | 	unsigned int use_callerid:1;			/*!< Whether or not to use caller id on this channel */ | 
					
						
							|  |  |  | 	unsigned int use_callingpres:1;			/*!< Whether to use the callingpres the calling switch sends */ | 
					
						
							|  |  |  | 	char context[AST_MAX_CONTEXT]; | 
					
						
							|  |  |  | 	char mohinterpret[MAX_MUSICCLASS]; | 
					
						
							|  |  |  | 	int stripmsd; | 
					
						
							| 
									
										
										
										
											2010-03-11 18:07:16 +00:00
										 |  |  | 	int channel;					/*!< Channel Number or CRV */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-04 17:46:03 +00:00
										 |  |  | 	/* Options to be checked by user */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	int cid_ani2;						/*!< Automatic Number Identification number (Alternate PRI caller ID number) */ | 
					
						
							|  |  |  | 	int cid_ton;					/*!< Type Of Number (TON) */ | 
					
						
							| 
									
										
										
										
											2009-08-04 17:46:03 +00:00
										 |  |  | 	int callingpres;				/*!< The value of calling presentation that we're going to use when placing a PRI call */ | 
					
						
							|  |  |  | 	char cid_num[AST_MAX_EXTENSION]; | 
					
						
							| 
									
										
										
										
											2009-11-02 17:34:22 +00:00
										 |  |  | 	char cid_subaddr[AST_MAX_EXTENSION]; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	char cid_name[AST_MAX_EXTENSION]; | 
					
						
							|  |  |  | 	char cid_ani[AST_MAX_EXTENSION]; | 
					
						
							| 
									
										
										
										
											2010-06-14 15:55:35 +00:00
										 |  |  | 	/*! \brief User tag for party id's sent from this device driver. */ | 
					
						
							|  |  |  | 	char user_tag[AST_MAX_EXTENSION]; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	char exten[AST_MAX_EXTENSION]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Internal variables -- Don't touch */ | 
					
						
							|  |  |  | 	/* Probably will need DS0 number, DS1 number, and a few other things */ | 
					
						
							|  |  |  | 	char dialdest[256];				/* Queued up digits for overlap dialing.  They will be sent out as information messages when setup ACK is received */ | 
					
						
							| 
									
										
										
										
											2009-10-23 16:57:33 +00:00
										 |  |  | #if defined(HAVE_PRI_SETUP_KEYPAD)
 | 
					
						
							|  |  |  | 	/*! \brief Keypad digits that came in with the SETUP message. */ | 
					
						
							|  |  |  | 	char keypad_digits[AST_MAX_EXTENSION]; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_SETUP_KEYPAD) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Generic Advice of Charge.
Asterisk Generic AOC Representation
- Generic AOC encode/decode routines.
  (Generic AOC must be encoded to be passed on the wire in the AST_CONTROL_AOC frame)
- AST_CONTROL_AOC frame type to represent generic encoded AOC data
- Manager events for AOC-S, AOC-D, and AOC-E messages
Asterisk App Support
- app_dial AOC-S pass-through support on call setup
- app_queue AOC-S pass-through support on call setup
AOC Unit Tests
- AOC Unit Tests for encode/decode routines
- AOC Unit Test for manager event representation.
SIP AOC Support
- Pass-through of generic AOC-D and AOC-E messages to snom phones via the
  snom AOC specification.
- Creation of chan_sip page3 flags for the addition of the new
  'snom_aoc_enabled' sip.conf option.
IAX AOC Support
- Natively supports AOC pass-through through the use of the new
  AST_CONTROL_AOC frame type
DAHDI AOC Support
- ETSI PRI full AOC Pass-through support
- 'aoc_enable' chan_dahdi.conf option for independently enabling
  pass-through of AOC-S, AOC-D, AOC-E.
- 'aoce_delayhangup' option for retrieving AOC-E on disconnect.
- DAHDI A() dial string option for requesting AOC services.
  example usage:
  ;requests AOC-S, AOC-D, and AOC-E on call setup
  exten=>1111,1,Dial(DAHDI/g1/1112/A(s,d,e))
Review:	https://reviewboard.asterisk.org/r/552/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@267096 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-06-02 18:10:15 +00:00
										 |  |  | #if defined(HAVE_PRI_AOC_EVENTS)
 | 
					
						
							|  |  |  | 	struct pri_subcmd_aoc_e aoc_e; | 
					
						
							|  |  |  | 	int aoc_s_request_invoke_id;     /*!< If an AOC-S request was present for the call, this is the invoke_id to use for the response */ | 
					
						
							|  |  |  | 	unsigned int aoc_s_request_invoke_id_valid:1; /*!< This is set when the AOC-S invoke id is present */ | 
					
						
							| 
									
										
										
										
											2010-12-20 09:14:45 +00:00
										 |  |  | 	unsigned int waiting_for_aoce:1; /*!< Delaying hangup for AOC-E msg. If this is set and AOC-E is received, continue with hangup before timeout period. */ | 
					
						
							| 
									
										
											  
											
												Generic Advice of Charge.
Asterisk Generic AOC Representation
- Generic AOC encode/decode routines.
  (Generic AOC must be encoded to be passed on the wire in the AST_CONTROL_AOC frame)
- AST_CONTROL_AOC frame type to represent generic encoded AOC data
- Manager events for AOC-S, AOC-D, and AOC-E messages
Asterisk App Support
- app_dial AOC-S pass-through support on call setup
- app_queue AOC-S pass-through support on call setup
AOC Unit Tests
- AOC Unit Tests for encode/decode routines
- AOC Unit Test for manager event representation.
SIP AOC Support
- Pass-through of generic AOC-D and AOC-E messages to snom phones via the
  snom AOC specification.
- Creation of chan_sip page3 flags for the addition of the new
  'snom_aoc_enabled' sip.conf option.
IAX AOC Support
- Natively supports AOC pass-through through the use of the new
  AST_CONTROL_AOC frame type
DAHDI AOC Support
- ETSI PRI full AOC Pass-through support
- 'aoc_enable' chan_dahdi.conf option for independently enabling
  pass-through of AOC-S, AOC-D, AOC-E.
- 'aoce_delayhangup' option for retrieving AOC-E on disconnect.
- DAHDI A() dial string option for requesting AOC services.
  example usage:
  ;requests AOC-S, AOC-D, and AOC-E on call setup
  exten=>1111,1,Dial(DAHDI/g1/1112/A(s,d,e))
Review:	https://reviewboard.asterisk.org/r/552/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@267096 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-06-02 18:10:15 +00:00
										 |  |  | 	unsigned int holding_aoce:1;     /*!< received AOC-E msg from asterisk. holding for disconnect/release */ | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_AOC_EVENTS) */
 | 
					
						
							| 
									
										
										
										
											2010-03-11 18:07:16 +00:00
										 |  |  | 	unsigned int inalarm:1; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	unsigned int alerting:1;		/*!< TRUE if channel is alerting/ringing */ | 
					
						
							|  |  |  | 	unsigned int alreadyhungup:1;	/*!< TRUE if the call has already gone/hungup */ | 
					
						
							|  |  |  | 	unsigned int isidlecall:1;		/*!< TRUE if this is an idle call */ | 
					
						
							|  |  |  | 	unsigned int proceeding:1;		/*!< TRUE if call is in a proceeding state */ | 
					
						
							|  |  |  | 	unsigned int progress:1;		/*!< TRUE if the call has seen progress through the network */ | 
					
						
							|  |  |  | 	unsigned int resetting:1;		/*!< TRUE if this channel is being reset/restarted */ | 
					
						
							|  |  |  | 	unsigned int setup_ack:1;		/*!< TRUE if this channel has received a SETUP_ACKNOWLEDGE */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	unsigned int outgoing:1; | 
					
						
							|  |  |  | 	unsigned int digital:1; | 
					
						
							| 
									
										
										
										
											2009-10-23 16:57:33 +00:00
										 |  |  | 	/*! \brief TRUE if this interface has no B channel.  (call hold and call waiting) */ | 
					
						
							|  |  |  | 	unsigned int no_b_channel:1; | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | #if defined(HAVE_PRI_CALL_WAITING)
 | 
					
						
							|  |  |  | 	/*! \brief TRUE if this is a call waiting call */ | 
					
						
							|  |  |  | 	unsigned int is_call_waiting:1; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_CALL_WAITING) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	struct ast_channel *owner; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | 	struct sig_pri_span *pri; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	q931_call *call;				/*!< opaque libpri call control structure */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int prioffset;					/*!< channel number in span */ | 
					
						
							|  |  |  | 	int logicalspan;				/*!< logical span number within trunk group */ | 
					
						
							| 
									
										
										
										
											2009-07-23 15:59:44 +00:00
										 |  |  | 	int mastertrunkgroup;			/*!< what trunk group is our master */ | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #if defined(HAVE_PRI_SERVICE_MESSAGES)
 | 
					
						
							|  |  |  | 	/*! \brief Active SRVST_DBKEY out-of-service status value. */ | 
					
						
							|  |  |  | 	unsigned service_status; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_SERVICE_MESSAGES) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	struct sig_pri_callback *calls; | 
					
						
							| 
									
										
										
										
											2009-08-04 17:46:03 +00:00
										 |  |  | 	void *chan_pvt;					/*!< Private structure of the user of this module. */ | 
					
						
							| 
									
										
										
										
											2009-07-03 15:44:01 +00:00
										 |  |  | #if defined(HAVE_PRI_REVERSE_CHARGE)
 | 
					
						
							| 
									
										
										
										
											2010-03-11 18:07:16 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Reverse charging indication | 
					
						
							|  |  |  | 	 * \details | 
					
						
							|  |  |  | 	 * -1 - No reverse charging, | 
					
						
							|  |  |  | 	 *  1 - Reverse charging, | 
					
						
							|  |  |  | 	 * 0,2-7 - Reserved for future use | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-07-02 17:46:14 +00:00
										 |  |  | 	int reverse_charging_indication; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:44:01 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-03 00:02:14 +00:00
										 |  |  | #if defined(HAVE_PRI_MWI)
 | 
					
						
							|  |  |  | /*! Maximum number of mailboxes per span. */ | 
					
						
							|  |  |  | #define SIG_PRI_MAX_MWI_MAILBOXES			8
 | 
					
						
							|  |  |  | /*! Typical maximum length of mwi mailbox number */ | 
					
						
							|  |  |  | #define SIG_PRI_MAX_MWI_MBOX_NUMBER_LEN		10	/* digits in number */
 | 
					
						
							|  |  |  | /*! Typical maximum length of mwi mailbox context */ | 
					
						
							|  |  |  | #define SIG_PRI_MAX_MWI_CONTEXT_LEN			10
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief Maximum mwi_mailbox string length. | 
					
						
							|  |  |  |  * \details | 
					
						
							|  |  |  |  * max_length = #mailboxes * (mbox_number + '@' + context + ',') | 
					
						
							|  |  |  |  * The last ',' is a null terminator instead. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define SIG_PRI_MAX_MWI_MAILBOX_STR		(SIG_PRI_MAX_MWI_MAILBOXES	\
 | 
					
						
							|  |  |  | 	* (SIG_PRI_MAX_MWI_MBOX_NUMBER_LEN + 1 + SIG_PRI_MAX_MWI_CONTEXT_LEN + 1)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct sig_pri_mbox { | 
					
						
							|  |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief MWI mailbox event subscription. | 
					
						
							|  |  |  | 	 * \note NULL if mailbox not configured. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	struct ast_event_sub *sub; | 
					
						
							|  |  |  | 	/*! \brief Mailbox number */ | 
					
						
							|  |  |  | 	const char *number; | 
					
						
							|  |  |  | 	/*! \brief Mailbox context. */ | 
					
						
							|  |  |  | 	const char *context; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_MWI) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | struct sig_pri_span { | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	/* Should be set by user */ | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 	struct ast_cc_config_params *cc_params;			/*!< CC config parameters for each new call. */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	int	pritimers[PRI_MAX_TIMERS]; | 
					
						
							|  |  |  | 	int overlapdial;								/*!< In overlap dialing mode */ | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | 	int qsigchannelmapping;							/*!< QSIG channel mapping type */ | 
					
						
							|  |  |  | 	int discardremoteholdretrieval;					/*!< shall remote hold or remote retrieval notifications be discarded? */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	int facilityenable;								/*!< Enable facility IEs */ | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | 	int dchan_logical_span[SIG_PRI_NUM_DCHANS];		/*!< Logical offset the DCHAN sits in */ | 
					
						
							|  |  |  | 	int fds[SIG_PRI_NUM_DCHANS];					/*!< FD's for d-channels */ | 
					
						
							| 
									
										
											  
											
												Generic Advice of Charge.
Asterisk Generic AOC Representation
- Generic AOC encode/decode routines.
  (Generic AOC must be encoded to be passed on the wire in the AST_CONTROL_AOC frame)
- AST_CONTROL_AOC frame type to represent generic encoded AOC data
- Manager events for AOC-S, AOC-D, and AOC-E messages
Asterisk App Support
- app_dial AOC-S pass-through support on call setup
- app_queue AOC-S pass-through support on call setup
AOC Unit Tests
- AOC Unit Tests for encode/decode routines
- AOC Unit Test for manager event representation.
SIP AOC Support
- Pass-through of generic AOC-D and AOC-E messages to snom phones via the
  snom AOC specification.
- Creation of chan_sip page3 flags for the addition of the new
  'snom_aoc_enabled' sip.conf option.
IAX AOC Support
- Natively supports AOC pass-through through the use of the new
  AST_CONTROL_AOC frame type
DAHDI AOC Support
- ETSI PRI full AOC Pass-through support
- 'aoc_enable' chan_dahdi.conf option for independently enabling
  pass-through of AOC-S, AOC-D, AOC-E.
- 'aoce_delayhangup' option for retrieving AOC-E on disconnect.
- DAHDI A() dial string option for requesting AOC services.
  example usage:
  ;requests AOC-S, AOC-D, and AOC-E on call setup
  exten=>1111,1,Dial(DAHDI/g1/1112/A(s,d,e))
Review:	https://reviewboard.asterisk.org/r/552/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@267096 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-06-02 18:10:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if defined(HAVE_PRI_AOC_EVENTS)
 | 
					
						
							| 
									
										
										
										
											2010-08-18 15:35:23 +00:00
										 |  |  | 	int aoc_passthrough_flag;						/*!< Represents what AOC messages (S,D,E) are allowed to pass-through */ | 
					
						
							|  |  |  | 	unsigned int aoce_delayhangup:1;				/*!< defines whether the aoce_delayhangup option is enabled or not */ | 
					
						
							| 
									
										
											  
											
												Generic Advice of Charge.
Asterisk Generic AOC Representation
- Generic AOC encode/decode routines.
  (Generic AOC must be encoded to be passed on the wire in the AST_CONTROL_AOC frame)
- AST_CONTROL_AOC frame type to represent generic encoded AOC data
- Manager events for AOC-S, AOC-D, and AOC-E messages
Asterisk App Support
- app_dial AOC-S pass-through support on call setup
- app_queue AOC-S pass-through support on call setup
AOC Unit Tests
- AOC Unit Tests for encode/decode routines
- AOC Unit Test for manager event representation.
SIP AOC Support
- Pass-through of generic AOC-D and AOC-E messages to snom phones via the
  snom AOC specification.
- Creation of chan_sip page3 flags for the addition of the new
  'snom_aoc_enabled' sip.conf option.
IAX AOC Support
- Natively supports AOC pass-through through the use of the new
  AST_CONTROL_AOC frame type
DAHDI AOC Support
- ETSI PRI full AOC Pass-through support
- 'aoc_enable' chan_dahdi.conf option for independently enabling
  pass-through of AOC-S, AOC-D, AOC-E.
- 'aoce_delayhangup' option for retrieving AOC-E on disconnect.
- DAHDI A() dial string option for requesting AOC services.
  example usage:
  ;requests AOC-S, AOC-D, and AOC-E on call setup
  exten=>1111,1,Dial(DAHDI/g1/1112/A(s,d,e))
Review:	https://reviewboard.asterisk.org/r/552/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@267096 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-06-02 18:10:15 +00:00
										 |  |  | #endif	/* defined(HAVE_PRI_AOC_EVENTS) */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #if defined(HAVE_PRI_SERVICE_MESSAGES)
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	unsigned int enable_service_message_support:1;	/*!< enable SERVICE message support */ | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #endif	/* defined(HAVE_PRI_SERVICE_MESSAGES) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | #ifdef HAVE_PRI_INBANDDISCONNECT
 | 
					
						
							|  |  |  | 	unsigned int inbanddisconnect:1;				/*!< Should we support inband audio after receiving DISCONNECT? */ | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-10-23 16:57:33 +00:00
										 |  |  | #if defined(HAVE_PRI_CALL_HOLD)
 | 
					
						
							|  |  |  | 	/*! \brief TRUE if held calls are transferred on disconnect. */ | 
					
						
							|  |  |  | 	unsigned int hold_disconnect_transfer:1; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_CALL_HOLD) */
 | 
					
						
							| 
									
										
										
										
											2010-06-02 16:14:12 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief TRUE if call transfer is enabled for the span. | 
					
						
							|  |  |  | 	 * \note Support switch-side transfer (called 2BCT, RLT or other names) | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	unsigned int transfer:1; | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | #if defined(HAVE_PRI_CALL_WAITING)
 | 
					
						
							|  |  |  | 	/*! \brief TRUE if we will allow incoming ISDN call waiting calls. */ | 
					
						
							|  |  |  | 	unsigned int allow_call_waiting_calls:1; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_CALL_WAITING) */
 | 
					
						
							| 
									
										
										
										
											2010-06-14 15:55:35 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * TRUE if a new call's sig_pri_chan.user_tag[] has the MSN | 
					
						
							|  |  |  | 	 * appended to the initial_user_tag[]. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	unsigned int append_msn_to_user_tag:1; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	int dialplan;							/*!< Dialing plan */ | 
					
						
							|  |  |  | 	int localdialplan;						/*!< Local dialing plan */ | 
					
						
							|  |  |  | 	char internationalprefix[10];			/*!< country access code ('00' for european dialplans) */ | 
					
						
							|  |  |  | 	char nationalprefix[10];				/*!< area access code ('0' for european dialplans) */ | 
					
						
							|  |  |  | 	char localprefix[20];					/*!< area access code + area code ('0'+area code for european dialplans) */ | 
					
						
							|  |  |  | 	char privateprefix[20];					/*!< for private dialplans */ | 
					
						
							|  |  |  | 	char unknownprefix[20];					/*!< for unknown dialplans */ | 
					
						
							|  |  |  | 	long resetinterval;						/*!< Interval (in seconds) for resetting unused channels */ | 
					
						
							| 
									
										
										
										
											2010-06-03 00:02:14 +00:00
										 |  |  | #if defined(HAVE_PRI_MWI)
 | 
					
						
							|  |  |  | 	/*! \brief Active MWI mailboxes */ | 
					
						
							|  |  |  | 	struct sig_pri_mbox mbox[SIG_PRI_MAX_MWI_MAILBOXES]; | 
					
						
							|  |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Comma separated list of mailboxes to indicate MWI. | 
					
						
							|  |  |  | 	 * \note Empty if disabled. | 
					
						
							|  |  |  | 	 * \note Format: mailbox_number[@context]{,mailbox_number[@context]} | 
					
						
							|  |  |  | 	 * \note String is split apart when span is started. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	char mwi_mailboxes[SIG_PRI_MAX_MWI_MAILBOX_STR]; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_MWI) */
 | 
					
						
							| 
									
										
										
										
											2010-06-14 15:55:35 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Initial user tag for party id's sent from this device driver. | 
					
						
							|  |  |  | 	 * \note String set by config file. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	char initial_user_tag[AST_MAX_EXTENSION]; | 
					
						
							| 
									
										
										
										
											2009-09-02 23:25:33 +00:00
										 |  |  | 	char msn_list[AST_MAX_EXTENSION];		/*!< Comma separated list of MSNs to handle.  Empty if disabled. */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	char idleext[AST_MAX_EXTENSION];		/*!< Where to idle extra calls */ | 
					
						
							|  |  |  | 	char idlecontext[AST_MAX_CONTEXT];		/*!< What context to use for idle */ | 
					
						
							|  |  |  | 	char idledial[AST_MAX_EXTENSION];		/*!< What to dial before dumping */ | 
					
						
							|  |  |  | 	int minunused;							/*!< Min # of channels to keep empty */ | 
					
						
							|  |  |  | 	int minidle;							/*!< Min # of "idling" calls to keep active */ | 
					
						
							|  |  |  | 	int nodetype;							/*!< Node type */ | 
					
						
							|  |  |  | 	int switchtype;							/*!< Type of switch to emulate */ | 
					
						
							|  |  |  | 	int nsf;								/*!< Network-Specific Facilities */ | 
					
						
							|  |  |  | 	int trunkgroup;							/*!< What our trunkgroup is */ | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | #if defined(HAVE_PRI_CCSS)
 | 
					
						
							|  |  |  | 	int cc_ptmp_recall_mode;				/*!< CC PTMP recall mode. globalRecall(0), specificRecall(1) */ | 
					
						
							|  |  |  | 	int cc_qsig_signaling_link_req;			/*!< CC Q.SIG signaling link retention (Party A) release(0), retain(1), do-not-care(2) */ | 
					
						
							|  |  |  | 	int cc_qsig_signaling_link_rsp;			/*!< CC Q.SIG signaling link retention (Party B) release(0), retain(1) */ | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_CCSS) */
 | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | #if defined(HAVE_PRI_CALL_WAITING)
 | 
					
						
							|  |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Number of extra outgoing calls to allow on a span before | 
					
						
							|  |  |  | 	 * considering that span congested. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	int max_call_waiting_calls; | 
					
						
							|  |  |  | 	struct { | 
					
						
							|  |  |  | 		int stripmsd; | 
					
						
							|  |  |  | 		unsigned int hidecallerid:1; | 
					
						
							|  |  |  | 		unsigned int hidecalleridname:1;      /*!< Hide just the name not the number for legacy PBX use */ | 
					
						
							|  |  |  | 		unsigned int immediate:1;			/*!< Answer before getting digits? */ | 
					
						
							|  |  |  | 		unsigned int priexclusive:1;			/*!< Whether or not to override and use exculsive mode for channel selection */ | 
					
						
							|  |  |  | 		unsigned int priindication_oob:1; | 
					
						
							|  |  |  | 		unsigned int use_callerid:1;			/*!< Whether or not to use caller id on this channel */ | 
					
						
							|  |  |  | 		unsigned int use_callingpres:1;			/*!< Whether to use the callingpres the calling switch sends */ | 
					
						
							|  |  |  | 		char context[AST_MAX_CONTEXT]; | 
					
						
							|  |  |  | 		char mohinterpret[MAX_MUSICCLASS]; | 
					
						
							|  |  |  | 	} ch_cfg; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Number of outstanding call waiting calls. | 
					
						
							|  |  |  | 	 * \note Must be zero to allow new calls from asterisk to | 
					
						
							|  |  |  | 	 * immediately allocate a B channel. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	int num_call_waiting_calls; | 
					
						
							|  |  |  | #endif	/* defined(HAVE_PRI_CALL_WAITING) */
 | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | 	int dchanavail[SIG_PRI_NUM_DCHANS];		/*!< Whether each channel is available */ | 
					
						
							| 
									
										
										
										
											2010-09-02 21:08:41 +00:00
										 |  |  | 	int debug;								/*!< set to true if to dump PRI event info */ | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | 	int span;								/*!< span number put into user output messages */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	int resetting;							/*!< true if span is being reset/restarted */ | 
					
						
							|  |  |  | 	int resetpos;							/*!< current position during a reset (-1 if not started) */ | 
					
						
							|  |  |  | 	int sig;								/*!< ISDN signalling type (SIG_PRI, SIG_BRI, SIG_BRI_PTMP, etc...) */ | 
					
						
							| 
									
										
										
										
											2009-10-01 19:48:58 +00:00
										 |  |  | 	int new_chan_seq;						/*!< New struct ast_channel sequence number */ | 
					
						
							| 
									
										
										
										
											2010-11-12 02:46:03 +00:00
										 |  |  | 	/*! TRUE if we have already whined about no D channels available. */ | 
					
						
							|  |  |  | 	unsigned int no_d_channels:1; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Everything after here is internally set */ | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | 	struct pri *dchans[SIG_PRI_NUM_DCHANS];		/*!< Actual d-channels */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	struct pri *pri;							/*!< Currently active D-channel */ | 
					
						
							| 
									
										
										
										
											2009-10-23 16:57:33 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * List of private structures of the user of this module for no B channel | 
					
						
							|  |  |  | 	 * interfaces. (hold and call waiting interfaces) | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	void *no_b_chan_iflist; | 
					
						
							|  |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * List of private structures of the user of this module for no B channel | 
					
						
							|  |  |  | 	 * interfaces. (hold and call waiting interfaces) | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	void *no_b_chan_end; | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	int numchans;								/*!< Num of channels we represent */ | 
					
						
							| 
									
										
										
										
											2010-04-30 22:24:28 +00:00
										 |  |  | 	struct sig_pri_chan *pvts[SIG_PRI_MAX_CHANNELS];/*!< Member channel pvt structs */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	pthread_t master;							/*!< Thread of master */ | 
					
						
							| 
									
										
										
										
											2009-08-04 17:46:03 +00:00
										 |  |  | 	ast_mutex_t lock;							/*!< libpri access Mutex */ | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 	time_t lastreset;							/*!< time when unused channels were last reset */ | 
					
						
							|  |  |  | 	struct sig_pri_callback *calls; | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Congestion device state of the span. | 
					
						
							|  |  |  | 	 * \details | 
					
						
							|  |  |  | 	 * AST_DEVICE_NOT_INUSE - Span does not have all B channels in use. | 
					
						
							|  |  |  | 	 * AST_DEVICE_BUSY - All B channels are in use. | 
					
						
							|  |  |  | 	 * AST_DEVICE_UNAVAILABLE - Span is in alarm. | 
					
						
							|  |  |  | 	 * \note | 
					
						
							| 
									
										
										
										
											2010-06-08 14:38:18 +00:00
										 |  |  | 	 * Device name: \startverbatim DAHDI/I<span>/congestion. \endverbatim | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	int congestion_devstate; | 
					
						
							|  |  |  | #if defined(THRESHOLD_DEVSTATE_PLACEHOLDER)
 | 
					
						
							|  |  |  | 	/*! \todo An ISDN span threshold device state could be useful in determining how often a span utilization goes over a configurable threshold. */ | 
					
						
							|  |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief User threshold device state of the span. | 
					
						
							|  |  |  | 	 * \details | 
					
						
							|  |  |  | 	 * AST_DEVICE_NOT_INUSE - There are no B channels in use. | 
					
						
							|  |  |  | 	 * AST_DEVICE_INUSE - The number of B channels in use is less than | 
					
						
							|  |  |  | 	 *    the configured threshold but not zero. | 
					
						
							|  |  |  | 	 * AST_DEVICE_BUSY - The number of B channels in use meets or exceeds | 
					
						
							|  |  |  | 	 *    the configured threshold. | 
					
						
							|  |  |  | 	 * AST_DEVICE_UNAVAILABLE - Span is in alarm. | 
					
						
							|  |  |  | 	 * \note | 
					
						
							|  |  |  | 	 * Device name:  DAHDI/I<span>/threshold | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	int threshold_devstate; | 
					
						
							|  |  |  | 	/*!
 | 
					
						
							|  |  |  | 	 * \brief Number of B channels in use to consider the span in a busy state. | 
					
						
							|  |  |  | 	 * \note Setting the threshold to zero is interpreted as all B channels. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	int user_busy_threshold; | 
					
						
							|  |  |  | #endif	/* defined(THRESHOLD_DEVSTATE_PLACEHOLDER) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-02 17:34:22 +00:00
										 |  |  | void sig_pri_extract_called_num_subaddr(struct sig_pri_chan *p, const char *rdest, char *called, size_t called_buff_size); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | int sig_pri_call(struct sig_pri_chan *p, struct ast_channel *ast, char *rdest, int timeout, int layer1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int sig_pri_hangup(struct sig_pri_chan *p, struct ast_channel *ast); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int sig_pri_indicate(struct sig_pri_chan *p, struct ast_channel *chan, int condition, const void *data, size_t datalen); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int sig_pri_answer(struct sig_pri_chan *p, struct ast_channel *ast); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-02 21:05:32 +00:00
										 |  |  | int sig_pri_available(struct sig_pri_chan **pvt, int is_specific_channel); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | void sig_pri_init_pri(struct sig_pri_span *pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* If return 0, it means this function was able to handle it (pre setup digits).  If non zero, the user of this
 | 
					
						
							|  |  |  |  * functions should handle it normally (generate inband DTMF) */ | 
					
						
							|  |  |  | int sig_pri_digit_begin(struct sig_pri_chan *pvt, struct ast_channel *ast, char digit); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | void sig_pri_stop_pri(struct sig_pri_span *pri); | 
					
						
							|  |  |  | int sig_pri_start_pri(struct sig_pri_span *pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void sig_pri_chan_alarm_notify(struct sig_pri_chan *p, int noalarm); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | void pri_event_alarm(struct sig_pri_span *pri, int index, int before_start_pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | void pri_event_noalarm(struct sig_pri_span *pri, int index, int before_start_pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-24 17:12:25 +00:00
										 |  |  | struct ast_channel *sig_pri_request(struct sig_pri_chan *p, enum sig_pri_law law, const struct ast_channel *requestor, int transfercapability); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | struct sig_pri_chan *sig_pri_chan_new(void *pvt_data, struct sig_pri_callback *callback, struct sig_pri_span *pri, int logicalspan, int channo, int trunkgroup); | 
					
						
							| 
									
										
										
										
											2009-09-08 23:37:57 +00:00
										 |  |  | void sig_pri_chan_delete(struct sig_pri_chan *doomed); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | int pri_is_up(struct sig_pri_span *pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | void sig_pri_cli_show_spans(int fd, int span, struct sig_pri_span *pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 15:41:44 +00:00
										 |  |  | void sig_pri_cli_show_span(int fd, int *dchannels, struct sig_pri_span *pri); | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | int pri_send_keypad_facility_exec(struct sig_pri_chan *p, const char *digits); | 
					
						
							|  |  |  | int pri_send_callrerouting_facility_exec(struct sig_pri_chan *p, enum ast_channel_state chanstate, const char *destination, const char *original, const char *reason); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #if defined(HAVE_PRI_SERVICE_MESSAGES)
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | int pri_maintenance_bservice(struct pri *pri, struct sig_pri_chan *p, int changestatus); | 
					
						
							| 
									
										
										
										
											2010-03-10 03:16:50 +00:00
										 |  |  | #endif	/* defined(HAVE_PRI_SERVICE_MESSAGES) */
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-10 23:49:09 +00:00
										 |  |  | void sig_pri_fixup(struct ast_channel *oldchan, struct ast_channel *newchan, struct sig_pri_chan *pchan); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merge Call completion support into trunk.
From Reviewboard:
CCSS stands for Call Completion Supplementary Services. An admittedly out-of-date
overview of the architecture can be found in the file doc/CCSS_architecture.pdf
in the CCSS branch. Off the top of my head, the big differences between what is
implemented and what is in the document are as follows:
1. We did not end up modifying the Hangup application at all.
2. The document states that a single call completion monitor may be used across
   multiple calls to the same device. This proved to not be such a good idea
   when implementing protocol-specific monitors, and so we ended up using one
   monitor per-device per-call.
3. There are some configuration options which were conceived after the document
   was written. These are documented in the ccss.conf.sample that is on this
   review request.
		      
For some basic understanding of terminology used throughout this code, see the
ccss.tex document that is on this review.
This implements CCBS and CCNR in several flavors.
First up is a "generic" implementation, which can work over any channel technology
provided that the channel technology can accurately report device state. Call
completion is requested using the dialplan application CallCompletionRequest and can
be canceled using CallCompletionCancel. Device state subscriptions are used in order
to monitor the state of called parties.
Next, there is a SIP-specific implementation of call completion. This method uses the
methods outlined in draft-ietf-bliss-call-completion-06 to implement call completion
using SIP signaling. There are a few things to note here:
* The agent/monitor terminology used throughout Asterisk sometimes is the reverse of
  what is defined in the referenced draft.
* Implementation of the draft required support for SIP PUBLISH. I attempted to write
  this in a generic-enough fashion such that if someone were to want to write PUBLISH
  support for other event packages, such as dialog-state or presence, most of the effort
  would be in writing callbacks specific to the event package.
* A subportion of supporting PUBLISH reception was that we had to implement a PIDF
  parser. The PIDF support added is a bit minimal. I first wrote a validation
  routine to ensure that the PIDF document is formatted properly. The rest of the
  PIDF reading is done in-line in the call-completion-specific PUBLISH-handling
  code. In other words, while there is PIDF support here, it is not in any state
  where it could easily be applied to other event packages as is.
Finally, there are a variety of ISDN-related call completion protocols supported. These
were written by Richard Mudgett, and as such I can't really say much about their
implementation. There are notes in the CHANGES file that indicate the ISDN protocols
over which call completion is supported.
Review: https://reviewboard.asterisk.org/r/523
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@256528 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-04-09 15:31:32 +00:00
										 |  |  | int sig_pri_cc_agent_init(struct ast_cc_agent *agent, struct sig_pri_chan *pvt_chan); | 
					
						
							|  |  |  | int sig_pri_cc_agent_start_offer_timer(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | int sig_pri_cc_agent_stop_offer_timer(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | void sig_pri_cc_agent_req_ack(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | int sig_pri_cc_agent_status_req(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | int sig_pri_cc_agent_stop_ringing(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | int sig_pri_cc_agent_party_b_free(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | int sig_pri_cc_agent_start_monitoring(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | int sig_pri_cc_agent_callee_available(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | void sig_pri_cc_agent_destructor(struct ast_cc_agent *agent); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int sig_pri_cc_monitor_req_cc(struct ast_cc_monitor *monitor, int *available_timer_id); | 
					
						
							|  |  |  | int sig_pri_cc_monitor_suspend(struct ast_cc_monitor *monitor); | 
					
						
							|  |  |  | int sig_pri_cc_monitor_unsuspend(struct ast_cc_monitor *monitor); | 
					
						
							|  |  |  | int sig_pri_cc_monitor_status_rsp(struct ast_cc_monitor *monitor, enum ast_device_state devstate); | 
					
						
							|  |  |  | int sig_pri_cc_monitor_cancel_available_timer(struct ast_cc_monitor *monitor, int *sched_id); | 
					
						
							|  |  |  | void sig_pri_cc_monitor_destructor(void *monitor_pvt); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int sig_pri_load(const char *cc_type_name); | 
					
						
							|  |  |  | void sig_pri_unload(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-25 19:54:12 +00:00
										 |  |  | #endif /* _SIG_PRI_H */
 |