mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 06:26:41 +00:00 
			
		
		
		
	This commit introduces the first phase of an effort to manage documentation of the interfaces in Asterisk in an XML format. Currently, a new format is available for applications and dialplan functions. A good number of conversions to the new format are also included. For more information, see the following message to asterisk-dev: http://lists.digium.com/pipermail/asterisk-dev/2008-October/034968.html git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@153365 65c4cc65-6c06-0410-ace0-fbb531ad65f3
		
			
				
	
	
		
			123 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Asterisk -- An open source telephony toolkit.
 | |
|  *
 | |
|  * Copyright (C) 1999 - 2005, 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 App to set callerid presentation
 | |
|  *
 | |
|  * \author Mark Spencer <markster@digium.com>
 | |
|  * 
 | |
|  * \ingroup applications
 | |
|  */
 | |
|  
 | |
| #include "asterisk.h"
 | |
| 
 | |
| ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 | |
| 
 | |
| #include "asterisk/lock.h"
 | |
| #include "asterisk/file.h"
 | |
| #include "asterisk/channel.h"
 | |
| #include "asterisk/pbx.h"
 | |
| #include "asterisk/module.h"
 | |
| #include "asterisk/translate.h"
 | |
| #include "asterisk/image.h"
 | |
| #include "asterisk/callerid.h"
 | |
| 
 | |
| /*** DOCUMENTATION
 | |
| 	<application name="SetCallerPres" language="en_US">
 | |
| 		<synopsis>
 | |
| 			Set CallerID Presentation.
 | |
| 		</synopsis>
 | |
| 		<syntax>
 | |
| 			<parameter name="presentation" required="true">
 | |
| 				<enumlist>
 | |
| 					<enum name="allowed_not_screened">
 | |
| 						<para>Presentation Allowed, Not Screened.</para>
 | |
| 					</enum>
 | |
| 					<enum name="allowed_passed_screen">
 | |
| 						<para>Presentation Allowed, Passed Screen.</para>
 | |
| 					</enum>
 | |
| 					<enum name="allowed_failed_screen">
 | |
| 						<para>Presentation Allowed, Failed Screen.</para>
 | |
| 					</enum>
 | |
| 					<enum name="allowed">
 | |
| 						<para>Presentation Allowed, Network Number.</para>
 | |
| 					</enum>
 | |
| 					<enum name="prohib_not_screened">
 | |
| 						<para>Presentation Prohibited, Not Screened.</para>
 | |
| 					</enum>
 | |
| 					<enum name="prohib_passed_screen">
 | |
| 						<para>Presentation Prohibited, Passed Screen.</para>
 | |
| 					</enum>
 | |
| 					<enum name="prohib_failed_screen">
 | |
| 						<para>Presentation Prohibited, Failed Screen.</para>
 | |
| 					</enum>
 | |
| 					<enum name="prohib">
 | |
| 						<para>Presentation Prohibited, Network Number.</para>
 | |
| 					</enum>
 | |
| 					<enum name="unavailable">
 | |
| 						<para>Number Unavailable.</para>
 | |
| 					</enum>
 | |
| 				</enumlist>
 | |
| 			</parameter>
 | |
| 		</syntax>
 | |
| 		<description>
 | |
| 			<para>Set Caller*ID presentation on a call.</para>
 | |
| 		</description>
 | |
| 	</application>
 | |
|  ***/
 | |
| 
 | |
| static char *app2 = "SetCallerPres";
 | |
| 
 | |
| static int setcallerid_pres_exec(struct ast_channel *chan, void *data)
 | |
| {
 | |
| 	int pres = -1;
 | |
| 	static int deprecated = 0;
 | |
| 
 | |
| 	if (!deprecated) {
 | |
| 		deprecated = 1;
 | |
| 		ast_log(LOG_WARNING, "SetCallerPres is deprecated.  Please use Set(CALLERPRES()=%s) instead.\n", (char *)data);
 | |
| 	}
 | |
| 
 | |
| 	/* For interface consistency, permit the argument to be specified as a number */
 | |
| 	if (sscanf(data, "%d", &pres) != 1 || pres < 0 || pres > 255 || (pres & 0x9c)) {
 | |
| 		pres = ast_parse_caller_presentation(data);
 | |
| 	}
 | |
| 
 | |
| 	if (pres < 0) {
 | |
| 		ast_log(LOG_WARNING, "'%s' is not a valid presentation (see 'show application SetCallerPres')\n",
 | |
| 			(char *) data);
 | |
| 		return 0;
 | |
| 	}
 | |
| 	
 | |
| 	chan->cid.cid_pres = pres;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static int unload_module(void)
 | |
| {
 | |
| 	return ast_unregister_application(app2);
 | |
| }
 | |
| 
 | |
| static int load_module(void)
 | |
| {
 | |
| 	return ast_register_application_xml(app2, setcallerid_pres_exec);
 | |
| }
 | |
| 
 | |
| AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Set CallerID Presentation Application");
 |