liveMedia/include/ServerMediaSession.hh

Go to the documentation of this file.
00001 /**********
00002 This library is free software; you can redistribute it and/or modify it under
00003 the terms of the GNU Lesser General Public License as published by the
00004 Free Software Foundation; either version 2.1 of the License, or (at your
00005 option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.)
00006 
00007 This library is distributed in the hope that it will be useful, but WITHOUT
00008 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
00009 FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for
00010 more details.
00011 
00012 You should have received a copy of the GNU Lesser General Public License
00013 along with this library; if not, write to the Free Software Foundation, Inc.,
00014 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301  USA
00015 **********/
00016 // "liveMedia"
00017 // Copyright (c) 1996-2012 Live Networks, Inc.  All rights reserved.
00018 // A data structure that represents a session that consists of
00019 // potentially multiple (audio and/or video) sub-sessions
00020 // (This data structure is used for media *streamers* - i.e., servers.
00021 //  For media receivers, use "MediaSession" instead.)
00022 // C++ header
00023 
00024 #ifndef _SERVER_MEDIA_SESSION_HH
00025 #define _SERVER_MEDIA_SESSION_HH
00026 
00027 #ifndef _MEDIA_HH
00028 #include "Media.hh"
00029 #endif
00030 #ifndef _FRAMED_SOURCE_HH
00031 #include "FramedSource.hh"
00032 #endif
00033 #ifndef _GROUPEID_HH
00034 #include "GroupEId.hh"
00035 #endif
00036 #ifndef _RTP_INTERFACE_HH
00037 #include "RTPInterface.hh" // for ServerRequestAlternativeByteHandler
00038 #endif
00039 
00040 class ServerMediaSubsession; // forward
00041 
00042 class ServerMediaSession: public Medium {
00043 public:
00044   static ServerMediaSession* createNew(UsageEnvironment& env,
00045                                        char const* streamName = NULL,
00046                                        char const* info = NULL,
00047                                        char const* description = NULL,
00048                                        Boolean isSSM = False,
00049                                        char const* miscSDPLines = NULL);
00050 
00051   virtual ~ServerMediaSession();
00052 
00053   static Boolean lookupByName(UsageEnvironment& env,
00054                               char const* mediumName,
00055                               ServerMediaSession*& resultSession);
00056 
00057   char* generateSDPDescription(); // based on the entire session
00058       // Note: The caller is responsible for freeing the returned string
00059 
00060   char const* streamName() const { return fStreamName; }
00061 
00062   Boolean addSubsession(ServerMediaSubsession* subsession);
00063 
00064   void testScaleFactor(float& scale); // sets "scale" to the actual supported scale
00065   float duration() const;
00066     // a result == 0 means an unbounded session (the default)
00067     // a result < 0 means: subsession durations differ; the result is -(the largest)
00068     // a result > 0 means: this is the duration of a bounded session
00069 
00070   unsigned referenceCount() const { return fReferenceCount; }
00071   void incrementReferenceCount() { ++fReferenceCount; }
00072   void decrementReferenceCount() { if (fReferenceCount > 0) --fReferenceCount; }
00073   Boolean& deleteWhenUnreferenced() { return fDeleteWhenUnreferenced; }
00074 
00075 protected:
00076   ServerMediaSession(UsageEnvironment& env, char const* streamName,
00077                      char const* info, char const* description,
00078                      Boolean isSSM, char const* miscSDPLines);
00079   // called only by "createNew()"
00080 
00081 private: // redefined virtual functions
00082   virtual Boolean isServerMediaSession() const;
00083 
00084 private:
00085   Boolean fIsSSM;
00086 
00087   // Linkage fields:
00088   friend class ServerMediaSubsessionIterator;
00089   ServerMediaSubsession* fSubsessionsHead;
00090   ServerMediaSubsession* fSubsessionsTail;
00091   unsigned fSubsessionCounter;
00092 
00093   char* fStreamName;
00094   char* fInfoSDPString;
00095   char* fDescriptionSDPString;
00096   char* fMiscSDPLines;
00097   struct timeval fCreationTime;
00098   unsigned fReferenceCount;
00099   Boolean fDeleteWhenUnreferenced;
00100 };
00101 
00102 
00103 class ServerMediaSubsessionIterator {
00104 public:
00105   ServerMediaSubsessionIterator(ServerMediaSession& session);
00106   virtual ~ServerMediaSubsessionIterator();
00107 
00108   ServerMediaSubsession* next(); // NULL if none
00109   void reset();
00110 
00111 private:
00112   ServerMediaSession& fOurSession;
00113   ServerMediaSubsession* fNextPtr;
00114 };
00115 
00116 
00117 class ServerMediaSubsession: public Medium {
00118 public:
00119   virtual ~ServerMediaSubsession();
00120 
00121   unsigned trackNumber() const { return fTrackNumber; }
00122   char const* trackId();
00123   virtual char const* sdpLines() = 0;
00124   virtual void getStreamParameters(unsigned clientSessionId, // in
00125                                    netAddressBits clientAddress, // in
00126                                    Port const& clientRTPPort, // in
00127                                    Port const& clientRTCPPort, // in
00128                                    int tcpSocketNum, // in (-1 means use UDP, not TCP)
00129                                    unsigned char rtpChannelId, // in (used if TCP)
00130                                    unsigned char rtcpChannelId, // in (used if TCP)
00131                                    netAddressBits& destinationAddress, // in out
00132                                    u_int8_t& destinationTTL, // in out
00133                                    Boolean& isMulticast, // out
00134                                    Port& serverRTPPort, // out
00135                                    Port& serverRTCPPort, // out
00136                                    void*& streamToken // out
00137                                    ) = 0;
00138   virtual void startStream(unsigned clientSessionId, void* streamToken,
00139                            TaskFunc* rtcpRRHandler,
00140                            void* rtcpRRHandlerClientData,
00141                            unsigned short& rtpSeqNum,
00142                            unsigned& rtpTimestamp,
00143                            ServerRequestAlternativeByteHandler* serverRequestAlternativeByteHandler,
00144                            void* serverRequestAlternativeByteHandlerClientData) = 0;
00145   virtual void pauseStream(unsigned clientSessionId, void* streamToken);
00146   virtual void seekStream(unsigned clientSessionId, void* streamToken, double& seekNPT, double streamDuration, u_int64_t& numBytes);
00147      // "streamDuration", if >0.0, specifies how much data to stream, past "seekNPT".  (If <=0.0, all remaining data is streamed.)
00148      // "numBytes" returns the size (in bytes) of the data to be streamed, or 0 if unknown or unlimited.
00149   virtual void setStreamScale(unsigned clientSessionId, void* streamToken, float scale);
00150   virtual FramedSource* getStreamSource(void* streamToken);
00151   virtual void deleteStream(unsigned clientSessionId, void*& streamToken);
00152 
00153   virtual void testScaleFactor(float& scale); // sets "scale" to the actual supported scale
00154   virtual float duration() const;
00155     // returns 0 for an unbounded session (the default)
00156     // returns > 0 for a bounded session
00157 
00158   // The following may be called by (e.g.) SIP servers, for which the
00159   // address and port number fields in SDP descriptions need to be non-zero:
00160   void setServerAddressAndPortForSDP(netAddressBits addressBits,
00161                                      portNumBits portBits);
00162 
00163 protected: // we're a virtual base class
00164   ServerMediaSubsession(UsageEnvironment& env);
00165 
00166   char const* rangeSDPLine() const;
00167       // returns a string to be delete[]d
00168 
00169   ServerMediaSession* fParentSession;
00170   netAddressBits fServerAddressForSDP;
00171   portNumBits fPortNumForSDP;
00172 
00173 private:
00174   friend class ServerMediaSession;
00175   friend class ServerMediaSubsessionIterator;
00176   ServerMediaSubsession* fNext;
00177 
00178   unsigned fTrackNumber; // within an enclosing ServerMediaSession
00179   char const* fTrackId;
00180 };
00181 
00182 #endif

Generated on Thu Feb 2 23:51:30 2012 for live by  doxygen 1.5.2