/usr/include/sipxtapi/net/SipPublishServer.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 | //
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _SipPublishServer_h_
#define _SipPublishServer_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include <os/OsServerTask.h>
#include <os/OsDefs.h>
#include <os/OsRWMutex.h>
#include <utl/UtlString.h>
#include <utl/UtlHashMap.h>
#include <net/SipUserAgent.h>
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// FORWARD DECLARATIONS
class SipPublishServerEventStateCompositor;
class SipUserAgent;
class SipPublishServerEventStateMgr;
class OsMsg;
class SipMessage;
// TYPEDEFS
//! Top level class for accepting and processing PUBLISH requests
/*! This implements a generic RFC 3903 PUBLISH server. This class
* receives PUBLISH requests, passes the event content to the event
* state compositor class, and send back the appropriate response.
* The SipPublishServer is designed to handle several different event
* types so that you can have multiple instances of the SipPublishServer
* each handling different event type. However you can not have an
* event type that is handled by more than one SipPublishServer.
*
* \par Event Specific Handling and Processing
* Event types are enabled with the enableEventType method. This method
* handling and processing of the specified Event type to be specialized
* by providing an Event specific: SipEventPlugin and SipUserAgent.
*
* \par Event State Compositor
*
* \par Event State
* The SipPublishServerEventStateMgr is used by SipPublishServer to maintain
* the event state (PUBLISH event state not event state content).
*
* \par Overall Data Flow
* The SipPublishServer needs to address 2 general stimulus:
* 1) Respond to incoming PUBLISH requests.
* 2) Some notification error responses should cause the subscription to expire
*
* When enabling a SIP event type via the enableEventType method, the SipPublishServer
* registers with the SipUserAgent to receive PUBLISH requests
* for the event type which are processed by the handleMessage method.
* The SipPublishServer uses timers to keep track of when event publication expire.
* When a timer fires, a message gets queued on the SipPublishServer which is that
* passed to handleMessage.
*/
class SipPublishServer : public OsServerTask
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
/* ============================ CREATORS ================================== */
//! Helper utility to build a basic server with default behavior
static SipPublishServer* buildBasicServer(SipUserAgent& userAgent,
const char* eventType);
//! Default SipPublishServer constructor
SipPublishServer(SipUserAgent& defaultUserAgent,
SipPublishServerEventStateMgr& defaultEventStateMgr,
SipPublishServerEventStateCompositor& defaultCompositor);
//! Destructor
virtual
~SipPublishServer();
/* ============================ MANIPULATORS ============================== */
//! Tell the publish server to support given event type
UtlBoolean enableEventType(const char* eventType,
SipUserAgent* userAgent = NULL,
SipPublishServerEventStateMgr* eventStateMgr = NULL,
SipPublishServerEventStateCompositor* compositor = NULL);
//! Tell the publish server to stop supporting given event type
UtlBoolean disableEventType(const char* eventType,
SipUserAgent*& userAgent,
SipPublishServerEventStateMgr*& eventStateMgr,
SipPublishServerEventStateCompositor*& compositor);
//! Handler for PUBLISH requests and timers
UtlBoolean handleMessage(OsMsg &eventMessage);
/* ============================ ACCESSORS ================================= */
//! Get the event state compositor for the given eventType
/*! WARNING: there is no locking of the event state compositor once it is
* returned. If the eventStateCompositor is removed via disableEventType
* and destroyed, there is no locking protection. The eventStateCompositor
* is only safe to use if the application knows that it is not going
* to get the rug pulled out from under it. Returns the default
* event state compositor if there is not an event specific state compositor.
*/
SipPublishServerEventStateCompositor*
getEventStateCompositor(const UtlString& eventType);
//! Get the event state manager for the given event type
/*! WARNING: there is no locking of the event state manager once it is
* returned. If the event state manager is removed via disableEventType
* and destroyed, there is no locking protection. The event state manager
* is only safe to use if the application knows that it is not going
* to get the rug pulled out from under it. Returns the default
* event state manager if there is not an event specific state
* manager.
*/
SipPublishServerEventStateMgr* getEventStateMgr(const UtlString& eventType);
/* ============================ INQUIRY =================================== */
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
//! Copy constructor NOT ALLOWED
SipPublishServer(const SipPublishServer& rSipPublishServer);
//! Assignment operator NOT ALLOWED
SipPublishServer& operator=(const SipPublishServer& rhs);
//! Handle PUBLISH requests
UtlBoolean handlePublish(const SipMessage& publishRequest);
//! lock for single thread write access (add/remove event handlers)
void lockForWrite();
//! unlock for use
void unlockForWrite();
//! lock for multiple-thread read access
void lockForRead();
//! unlock for use
void unlockForRead();
SipUserAgent* mpDefaultUserAgent;
SipPublishServerEventStateMgr* mpDefaultEventStateMgr;
SipPublishServerEventStateCompositor* mpDefaultCompositor;
UtlHashMap mEventDefinitions;
OsRWMutex mPublishServerMutex;
};
/* ============================ INLINE METHODS ============================ */
#endif // _SipPublishServer_h_
|