mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 06:26:41 +00:00 
			
		
		
		
	ARI: Add mailboxes resource for controlling and polling external MWI
Adds the following AMI commands:
PUT mailboxes/mailboxName
    modifies mailbox state and implicitly creates new mailboxes
GET mailboxes/mailboxName
    retrieves a JSON representation of a single mailbox if it exists
GET mailboxes
    retrieves a JSON array of all mailboxes
DELETE mailbox/mailboxName
    deletes a mailbox
Note that res_mwi_external must be loaded for these functions to
actually do anything.
Review: https://reviewboard.asterisk.org/r/3117/
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/12@405553 65c4cc65-6c06-0410-ace0-fbb531ad65f3
			
			
This commit is contained in:
		
							
								
								
									
										91
									
								
								include/asterisk/stasis_app_mailbox.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								include/asterisk/stasis_app_mailbox.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | ||||
| /* | ||||
|  * Asterisk -- An open source telephony toolkit. | ||||
|  * | ||||
|  * Copyright (C) 2014, Digium, Inc. | ||||
|  * | ||||
|  * Jonathan Rose <jrose@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. | ||||
|  */ | ||||
|  | ||||
| #ifndef _ASTERISK_STASIS_APP_MAILBOX_H | ||||
| #define _ASTERISK_STASIS_APP_MAILBOX_H | ||||
|  | ||||
| /*! \file | ||||
|  * | ||||
|  * \brief Stasis Application Mailbox API. See \ref res_stasis "Stasis | ||||
|  * Application API" for detailed documentation. | ||||
|  * | ||||
|  * \author Jonathan Rose <kharwell@digium.com> | ||||
|  * \since 12 | ||||
|  */ | ||||
|  | ||||
| #include "asterisk/app.h" | ||||
| #include "asterisk/stasis_app.h" | ||||
|  | ||||
| /*! @{ */ | ||||
|  | ||||
| /*! Stasis mailbox operation result codes */ | ||||
| enum stasis_mailbox_result { | ||||
| 	/*! Mailbox operation completed successfully */ | ||||
| 	STASIS_MAILBOX_OK, | ||||
| 	/*! Mailbox of the requested name does not exist */ | ||||
| 	STASIS_MAILBOX_MISSING, | ||||
| 	/*! Mailbox operation failed internally */ | ||||
| 	STASIS_MAILBOX_ERROR, | ||||
| }; | ||||
|  | ||||
| /*! | ||||
|  * \brief Convert mailbox to JSON | ||||
|  * | ||||
|  * \param name the name of the mailbox | ||||
|  * \param json If the query is successful, this pointer at this address will | ||||
|  *        be set to the JSON representation of the mailbox | ||||
|  * | ||||
|  * \return stasis mailbox result code indicating success or failure and cause | ||||
|  * \return \c NULL on error. | ||||
|  */ | ||||
| enum stasis_mailbox_result stasis_app_mailbox_to_json(const char *name, struct ast_json **json); | ||||
|  | ||||
| /*! | ||||
|  * brief Convert mailboxes to json array | ||||
|  * | ||||
|  * \return JSON representation of the mailboxes | ||||
|  * \return \c NULL on error. | ||||
|  */ | ||||
| struct ast_json *stasis_app_mailboxes_to_json(void); | ||||
|  | ||||
| /*! | ||||
|  * \brief Changes the state of a mailbox. | ||||
|  * | ||||
|  * \note Implicitly creates the mailbox. | ||||
|  * | ||||
|  * \param name The name of the ARI controlled mailbox | ||||
|  * \param old_messages count of old (read) messages in the mailbox | ||||
|  * \param new_messages count of new (unread) messages in the mailbox | ||||
|  * | ||||
|  * \return 0 if successful | ||||
|  * \return -1 on internal error. | ||||
|  */ | ||||
| int stasis_app_mailbox_update( | ||||
| 	const char *name, int old_messages, int new_messages); | ||||
|  | ||||
| /*! | ||||
|  * \brief Delete a mailbox controlled by ARI. | ||||
|  * | ||||
|  * \param name the name of the ARI controlled mailbox | ||||
|  * | ||||
|  * \return a stasis mailbox application result | ||||
|  */ | ||||
| enum stasis_mailbox_result stasis_app_mailbox_delete( | ||||
| 	const char *name); | ||||
|  | ||||
| #endif /* _ASTERISK_STASIS_APP_MAILBOX_H */ | ||||
		Reference in New Issue
	
	Block a user