mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-04 11:58:52 +00:00
See UserNote below.
Exposed the existing Hangup AMI action in manager.c so we can use
all of it's channel search and AMI protocol handling without
duplicating that code in dialplan_functions.c.
Added a lookup function to res_pjsip.c that takes in the
string represenation of the pjsip_status_code enum and returns
the actual status code. I.E. ast_sip_str2rc("DECLINE") returns
603. This allows the caller to specify PJSIPHangup(decline) in
the dialplan, just like Hangup(call_rejected).
Also extracted the XML documentation to its own file since it was
almost as large as the code itself.
UserNote: A new dialplan app PJSIPHangup and AMI action allows you
to hang up an unanswered incoming PJSIP call with a specific SIP
response code in the 400 -> 699 range.
(cherry picked from commit af7e89ebf8
)
172 lines
5.5 KiB
C
172 lines
5.5 KiB
C
/*
|
|
* Asterisk -- An open source telephony toolkit.
|
|
*
|
|
* Copyright (C) 2013, Digium, Inc.
|
|
*
|
|
* 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 PJSIP dialplan functions header file
|
|
*/
|
|
|
|
#ifndef _PJSIP_DIALPLAN_FUNCTIONS
|
|
#define _PJSIP_DIALPLAN_FUNCTIONS
|
|
|
|
/*!
|
|
* \brief CHANNEL function read callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param buf Out buffer that should be populated with the data
|
|
* \param len Size of the buffer
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_channel_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);
|
|
|
|
/*!
|
|
* \brief PJSIP_MEDIA_OFFER function write callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param value Value to be set by the function
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_media_offer_write(struct ast_channel *chan, const char *cmd, char *data, const char *value);
|
|
|
|
/*!
|
|
* \brief PJSIP_DTMF_MODE function read callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param buf Out buffer that should be populated with the data
|
|
* \param len Size of the buffer
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_dtmf_mode_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);
|
|
|
|
/*!
|
|
* \brief PJSIP_DTMF_MODE function write callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param value Value to be set by the function
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_dtmf_mode_write(struct ast_channel *chan, const char *cmd, char *data, const char *value);
|
|
|
|
/*!
|
|
* \brief PJSIP_MOH_PASSTHROUGH function read callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param buf Out buffer that should be populated with the data
|
|
* \param len Size of the buffer
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_moh_passthrough_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);
|
|
|
|
/*!
|
|
* \brief PJSIP_MOH_PASSTHROUGH function write callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param value Value to be set by the function
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_moh_passthrough_write(struct ast_channel *chan, const char *cmd, char *data, const char *value);
|
|
|
|
/*!
|
|
* \brief PJSIP_MEDIA_OFFER function read callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param buf Out buffer that should be populated with the data
|
|
* \param len Size of the buffer
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_media_offer_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);
|
|
|
|
/*!
|
|
* \brief PJSIP_SEND_SESSION_REFRESH function write callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd the Name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param value Value to be set by the function
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_session_refresh_write(struct ast_channel *chan, const char *cmd, char *data, const char *value);
|
|
|
|
/*!
|
|
* \brief PJSIP_DIAL_CONTACTS function read callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param buf Out buffer that should be populated with the data
|
|
* \param len Size of the buffer
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_dial_contacts_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);
|
|
|
|
/*!
|
|
* \brief PJSIP_PARSE_URI function read callback
|
|
* \param chan The channel the function is called on
|
|
* \param cmd The name of the function
|
|
* \param data Arguments passed to the function
|
|
* \param buf Out buffer that should be populated with the data
|
|
* \param len Size of the buffer
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_acf_parse_uri_read(struct ast_channel *chan, const char *cmd, char *data, char *buf, size_t len);
|
|
|
|
/*!
|
|
* \brief Hang up an incoming PJSIP channel with a SIP response code
|
|
* \param chan The channel the function is called on
|
|
* \param data SIP response code or name
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_app_hangup(struct ast_channel *chan, const char *data);
|
|
|
|
/*!
|
|
* \brief Manager action to hang up an incoming PJSIP channel with a SIP response code
|
|
* \param s session
|
|
* \param m message
|
|
*
|
|
* \retval 0 on success
|
|
* \retval -1 on failure
|
|
*/
|
|
int pjsip_action_hangup(struct mansession *s, const struct message *m);
|
|
|
|
#endif /* _PJSIP_DIALPLAN_FUNCTIONS */
|