/usr/include/opal/iax2/receiver.h is in libopal-dev 3.10.10~dfsg-2.1ubuntu3.
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 | /*
*
*
* Inter Asterisk Exchange 2
*
* The entity which receives all packets for all calls.
*
* Open Phone Abstraction Library (OPAL)
*
* Copyright (c) 2005 Indranet Technologies Ltd.
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Open Phone Abstraction Library.
*
* The Initial Developer of the Original Code is Indranet Technologies Ltd.
*
* The author of this code is Derek J Smithies
*
* $Revision: 24606 $
* $Author: dereksmithies $
* $Date: 2010-07-28 22:51:05 -0500 (Wed, 28 Jul 2010) $
*/
#ifndef OPAL_IAX2_RECEIVER_H
#define OPAL_IAX2_RECEIVER_H
#ifndef _PTLIB_H
#include <ptlib.h>
#endif
#include <opal/buildopts.h>
#if OPAL_IAX2
#include <ptlib/sockets.h>
#ifdef P_USE_PRAGMA
#pragma interface
#endif
class IAX2EndPoint;
class IAX2Frame;
class IAX2FrameList;
class IAX2PacketIdList;
#include <iax2/frame.h>
/**Manage the reception of etherenet packets on the specified port.
All received packets are handed to the appropriate connection.
A separate thread is used to wait on the ethernet port*/
class IAX2Receiver : public PThread
{
PCLASSINFO(IAX2Receiver, PThread);
public:
/**@name Constructors/destructors*/
//@{
/**Construct a receiver, given references to the endpoint and socket*/
IAX2Receiver(IAX2EndPoint & _newEndpoint, PUDPSocket & _newSocket);
/**Destroy the receiver*/
~IAX2Receiver();
//@}
/**@name general worker methods*/
//@{
/*The method which the receiver thread invokes*/
virtual void Main();
/**Close down this thread in a civilised fashion, by sending an empty packet
to the PUDPSocket of this protocol. The Receiver will receive this
packet, and check the close down flag, and so realise it is time to close
down. */
virtual void Terminate();
/**Sit in here, waiting for data on the socket*/
PBoolean ReadNetworkSocket();
/**We have just read a frame from the network. This is a good
IAX2Frame. Put it on the queue of frames to be processed by the
IAX2EndPoint. The IAX2EndPoint will give this frame to the
appropriate IAXConnection. Since this frame could be encrypted,
and we do not have access to the keys (only the IAX2Connection
has the keys, we cannot do anymore with the frame). Indeed, we
are the receiving thread, and must put all our time into reading
from the socket, not processing the packets. */
void AddNewReceivedFrame(IAX2Frame *newFrame);
/**Report how many frames are in the receive queue, waiting for extraction*/
PINDEX GetSize() { return fromNetworkFrames.GetSize(); }
//@}
protected:
/**Global variable which holds the application specific data */
IAX2EndPoint &endpoint;
/**Socket that is used to receive all network data from */
PUDPSocket & sock;
/**The act of processing a header will (inevitably) create additional
frames as trunked frames are split up */
IAX2FrameList fromNetworkFrames;
/**Flag to indicate if this receiver thread should keep listening for network data */
PBoolean keepGoing;
};
#endif // OPAL_IAX2
#endif // OPAL_IAX2_RECEIVER_H
/* The comment below is magic for those who use emacs to edit this file.
* With the comment below, the tab key does auto indent to 2 spaces.
*
* Local Variables:
* mode:c
* c-basic-offset:2
* End:
*/
|