154 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
 | |
| #ifndef CALLBACK_H
 | |
| #define CALLBACK_H
 | |
| 
 | |
| /*!
 | |
|  * \file
 | |
|  */
 | |
| 
 | |
| /*!
 | |
|  * \brief The reason code for an event callback.
 | |
|  *
 | |
|  * The \b Event parameter will be different depending on the reason for the
 | |
|  * callback. The descriptions for each event type describe the contents of the
 | |
|  * \b Event parameter.
 | |
|  */
 | |
| enum Upnp_EventType_e {
 | |
| 	/*
 | |
| 	 * Control callbacks
 | |
| 	 */
 | |
| 
 | |
| 	/*! Received by a device when a control point issues a control
 | |
| 	 * request.  The \b Event parameter contains a pointer to a \b
 | |
| 	 * UpnpActionRequest structure containing the action.  The application
 | |
| 	 * stores the results of the action in this structure. */
 | |
| 	UPNP_CONTROL_ACTION_REQUEST,
 | |
| 
 | |
| 	/*! A \b UpnpSendActionAsync call completed. The \b Event
 | |
| 	 * parameter contains a pointer to a \b UpnpActionComplete structure
 | |
| 	 * with the results of the action.  */
 | |
| 	UPNP_CONTROL_ACTION_COMPLETE,
 | |
| 
 | |
| 	/*! Received by a device when a query for a single service variable
 | |
| 	 * arrives.  The \b Event parameter contains a pointer to a \b
 | |
| 	 * UpnpStateVarRequest structure containing the name of the variable
 | |
| 	 * and value.  */
 | |
| 	UPNP_CONTROL_GET_VAR_REQUEST,
 | |
| 
 | |
| 	/*! A \b UpnpGetServiceVarStatus call completed. The \b Event
 | |
| 	 * parameter contains a pointer to a \b UpnpStateVarComplete structure
 | |
| 	 * containing the value for the variable.  */
 | |
| 	UPNP_CONTROL_GET_VAR_COMPLETE,
 | |
| 
 | |
| 	/*
 | |
| 	 * Discovery callbacks
 | |
| 	 */
 | |
| 
 | |
| 	/*! Received by a control point when a new device or service is available.  
 | |
| 	 * The \b Event parameter contains a pointer to a \b
 | |
| 	 * UpnpDiscovery structure with the information about the device
 | |
| 	 * or service.  */
 | |
| 	UPNP_DISCOVERY_ADVERTISEMENT_ALIVE,
 | |
| 
 | |
| 	/*! Received by a control point when a device or service shuts down. The \b
 | |
| 	 * Event parameter contains a pointer to a \b UpnpDiscovery
 | |
| 	 * structure containing the information about the device or
 | |
| 	 * service.  */
 | |
| 	UPNP_DISCOVERY_ADVERTISEMENT_BYEBYE,
 | |
| 
 | |
| 	/*! Received by a control point when a matching device or service responds.
 | |
| 	 * The \b Event parameter contains a pointer to a \b
 | |
| 	 * UpnpDiscovery structure containing the information about
 | |
| 	 * the reply to the search request.  */
 | |
| 	UPNP_DISCOVERY_SEARCH_RESULT,
 | |
| 
 | |
| 	/*! Received by a control point when the search timeout expires.  The
 | |
| 	 * SDK generates no more callbacks for this search after this 
 | |
| 	 * event.  The \b Event parameter is \c NULL.  */
 | |
| 	UPNP_DISCOVERY_SEARCH_TIMEOUT,
 | |
| 
 | |
| 	/*
 | |
| 	 * Eventing callbacks
 | |
| 	 */
 | |
| 
 | |
| 	/*! Received by a device when a subscription arrives.
 | |
| 	 * The \b Event parameter contains a pointer to a \b
 | |
| 	 * UpnpSubscriptionRequest structure.  At this point, the
 | |
| 	 * subscription has already been accepted.  \b UpnpAcceptSubscription
 | |
| 	 * needs to be called to confirm the subscription and transmit the
 | |
| 	 * initial state table.  This can be done during this callback.  The SDK
 | |
| 	 * generates no events for a subscription unless the device 
 | |
| 	 * application calls \b UpnpAcceptSubscription.
 | |
| 	 */
 | |
| 	UPNP_EVENT_SUBSCRIPTION_REQUEST,
 | |
| 
 | |
| 	/*! Received by a control point when an event arrives. The \b
 | |
| 	 * Event parameter contains a \b UpnpEvent structure
 | |
| 	 * with the information about the event.  */
 | |
| 	UPNP_EVENT_RECEIVED,
 | |
| 
 | |
| 	/*! A \b UpnpRenewSubscriptionAsync call completed. The status of
 | |
| 	 * the renewal is in the \b Event parameter as a \b
 | |
| 	 * Upnp_Event_Subscription structure.  */
 | |
| 	UPNP_EVENT_RENEWAL_COMPLETE,
 | |
| 
 | |
| 	/*! A \b UpnpSubscribeAsync call completed. The status of the
 | |
| 	 * subscription is in the \b Event parameter as a \b
 | |
| 	 * Upnp_Event_Subscription structure.  */
 | |
| 	UPNP_EVENT_SUBSCRIBE_COMPLETE,
 | |
| 
 | |
| 	/*! A \b UpnpUnSubscribeAsync call completed. The status of the
 | |
| 	 * subscription is in the \b Event parameter as a \b
 | |
| 	 * UpnpEventSubscribe structure.  */
 | |
| 	UPNP_EVENT_UNSUBSCRIBE_COMPLETE,
 | |
| 
 | |
| 	/*! The auto-renewal of a client subscription failed.   
 | |
| 	 * The \b Event parameter is a \b UpnpEventSubscribe structure 
 | |
| 	 * with the error code set appropriately. The subscription is no longer 
 | |
| 	 * valid. */
 | |
| 	UPNP_EVENT_AUTORENEWAL_FAILED,
 | |
| 
 | |
| 	/*! A client subscription has expired. This will only occur 
 | |
| 	 * if auto-renewal of subscriptions is disabled.
 | |
| 	 * The \b Event parameter is a \b UpnpEventSubscribe
 | |
| 	 * structure. The subscription is no longer valid. */
 | |
| 	UPNP_EVENT_SUBSCRIPTION_EXPIRED
 | |
| };
 | |
| 
 | |
| typedef enum Upnp_EventType_e Upnp_EventType;
 | |
| 
 | |
| /*!
 | |
|  *  All callback functions share the same prototype, documented below.
 | |
|  *  Note that any memory passed to the callback function
 | |
|  *  is valid only during the callback and should be copied if it
 | |
|  *  needs to persist.  This callback function needs to be thread
 | |
|  *  safe.  The context of the callback is always on a valid thread 
 | |
|  *  context and standard synchronization methods can be used.  Note, 
 | |
|  *  however, because of this the callback cannot call SDK functions
 | |
|  *  unless explicitly noted.
 | |
|  *
 | |
|  *  \verbatim
 | |
|       int CallbackFxn(Upnp_EventType EventType, void *Event, void *Cookie);
 | |
|     \endverbatim 
 | |
|  *
 | |
|  *  where \b EventType is the event that triggered the callback, 
 | |
|  *  \b Event is a structure that denotes event-specific information for that
 | |
|  *  event, and \b Cookie is the user data passed when the callback was
 | |
|  *  registered.
 | |
|  *
 | |
|  *  See \b Upnp_EventType for more information on the callback values and
 | |
|  *  the associated \b Event parameter.  
 | |
|  *
 | |
|  *  The return value of the callback is currently ignored. It may be used
 | |
|  *  in the future to communicate results back to the SDK.
 | |
|  */
 | |
| typedef int (*Upnp_FunPtr)(
 | |
| 	/*! [in] .*/
 | |
| 	Upnp_EventType EventType,
 | |
| 	/*! [in] .*/
 | |
| 	const void *Event,
 | |
| 	/*! [in] .*/
 | |
| 	void *Cookie);
 | |
| 
 | |
| #endif /* CALLBACK_H */
 | 
