This file is indexed.

/usr/include/sipxtapi/rtcp/NetworkChannel.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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
//
// Copyright (C) 2006-2013 SIPez LLC.  All rights reserved.
//
// 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 _INC_NETWORKCHANNEL_H_
#define _INC_NETWORKCHANNEL_H_

#include "rtcp/RtcpConfig.h"

#ifdef PINGTEL_OSSOCKET
#include "os/OsSocket.h"
#endif

#if defined(_WIN32)
#include <winsock2.h>
#elif defined(_VXWORKS)
#include <sockLib.h>
#include <ioLib.h>
typedef struct sockaddr_in SOCKADDR_IN;
#define SOCKET_ERROR    ERROR
#elif defined(__pingtel_on_posix__)
#include <unistd.h>
#include <netinet/in.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
typedef struct sockaddr_in SOCKADDR_IN;
typedef struct sockaddr SOCKADDR;
#define SOCKET_ERROR    (-1)
#else
#error Unsupported target platform.
#endif

//  Includes
#include "BaseClass.h"
#include "INetworkChannel.h"
#include "INetworkSource.h"
#include "INetworkRender.h"
#include "INetDispatch.h"



class CNetworkChannel : public CBaseClass,
                        public INetworkSource,
                        public INetworkRender
{


public:

#ifndef PINGTEL_OSSOCKET


/*|><|***********************************************************************
 Name:          CNetworkChannel constructor

 Description:   Performs initial construction on CNetworkChannel class in
                addition to setting internal properties.

 Returns:       None.
 ***********************************************************************|><|*/
    CNetworkChannel(INetDispatch *piNetDispatch=NULL, unsigned short usPort=0);

#else

/*|><|***********************************************************************
 Name:          CNetworkChannel constructor

 Description:   An alternate constructor defined to handle use of Pingtel's
                OSSocket object.  In this mode, this object acts as a simple
                wrapper that calls the Pingtel OSSocket object's Write method
                whenever Send() is called.  The OSSocket has already been
                initialized by external logic and is operational when passed.

 Returns:       None.
 ***********************************************************************|><|*/
    CNetworkChannel(OsSocket & rOsSocket);
#endif

/*|><|***********************************************************************
 Name:          CNetworkChannel destructor

 Description:   Performs final destruction on CNetworkChannel class.

 Returns:       None.
 ***********************************************************************|><|*/
    ~CNetworkChannel(void);


/*|><|***********************************************************************
 Name:          Initialize

 Description:   A polymorphic method that handles the creation and
                initialization of an inbound or outbound connectionless
                datagram channels.  This method shall create and open the
                datagram channel in addition to binding it to establish a
                local port ID.

 Returns:       bool.
 ***********************************************************************|><|*/
    virtual bool Initialize(void);


/*|><|***********************************************************************
 Name:          CNetworkChannel::Open

 Description:   A polymorphic method that manages the creation and
                of an inbound or outbound connectionless datagram channel.

 Returns:       bool.
 ***********************************************************************|><|*/
    virtual bool Open(int iAddressType, int iSocketType, int iProtocol);


/*|><|***********************************************************************
 Name:          Connect

 Description:   A polymorphic method that manages the connection of an inbound
                or outbound connectionless datagram channels over TCP/IP.
                This is a non-blocking call.

 Returns:       bool.
 ***********************************************************************|><|*/
    virtual bool  Connect(unsigned char *puchIPAddress=NULL,
                                                unsigned short usPortID=0);

/*|><|***********************************************************************
 Name:          Receive

 Description:   A polymorphic method that processes any receive events
                associated with a channel.  This version of receive shall
                handle inbound data on either a connectionless channel.

 Returns:       int.
 ***********************************************************************|><|*/
    virtual int  Receive(unsigned char * puchBuffer, unsigned long ulRxBytes);

/*|><|***********************************************************************
 Name:          Dispatch

 Description:   A method that takes a data transmission forwarded by the
                Receive() method and routes it to the appopriate receiver.

 Returns:       None.
 ***********************************************************************|><|*/
    virtual void  Dispatch(unsigned char * puchBuffer,
                                              unsigned long ulBytesRecvd);

/*|><|***********************************************************************
 Name:          Send

 Description: A private method that takes a data transmission delivered by the
              StreamClient's DataReceived() callback and sends it the
              associated channel socket for transmission to the respective FE.
              The Send() method also contains some conditionally compiled logic
              to collect statistics regarding packets being sent.

 Returns:       bool.
 ***********************************************************************|><|*/
    virtual int  Send(unsigned char * puchDataBuffer,
                                               unsigned long ulBytesToSend);

    virtual int getSocketDescriptor(void);
    virtual int getSocketPort(void);
/*|><|***********************************************************************
 Name:          Close

 Description:   Amethod that closes a connectionless datagram channel.

 Returns:       bool.
 ***********************************************************************|><|*/
    virtual bool  Close(void);


/*|><|***********************************************************************
 Name:          GetSocket

 Description:   An IChannel interface method that retrieves the socket handle
                associated with a given channel.

 Returns:       unsigned int.
 ***********************************************************************|><|*/
    unsigned int  GetSocket(void)     { return m_hSocket; }

/*|><|***********************************************************************
 Name:          GetPort

 Description:   An IChannel interface method that retrieves the port ID
                associated with a given channel.

 Returns:       unsigned short.
 ***********************************************************************|><|*/
    unsigned short    GetPort(void)    { return m_ipLocal.sin_port; }


/*|><|***********************************************************************
 Name:          IsOpened

 Description:   An IChannel interface method that returns a flag identifying
                whether a channel has been opened.

 Returns:       None.
 ***********************************************************************|><|*/
    bool    IsOpened(void)      { return((bool)m_fFlags.bfOpen); }

/*|><|***********************************************************************
 Name:          IsConnected

 Description:   An IChannel interface method that returns a flag identifying
                whether a channel has been connected.

 Returns:       None.
 ***********************************************************************|><|*/
    bool    IsConnected(void)   { return((bool)m_fFlags.bfConnected); }

/**
 *
 * Macro Name:  DECLARE_IBASE_M
 *
 *
 * Inputs:      None
 *
 * Outputs:     None
 *
 * Returns:     None
 *
 * Description: This implements the IBaseClass functions used and exposed by
 *              derived classes.
 *
 * Usage Notes:
 *
 *
 */
DECLARE_IBASE_M

private:    // Private Member Functions

/*|><|***********************************************************************
 Name:          Bind

 Description:   A polymorphic method that manages the creation and
                of an inbound or outbound connectionless datagram channels.

 Returns:       bool.
 ***********************************************************************|><|*/
    virtual bool  Bind(SOCKADDR_IN *lpAddr=NULL);


/*|><|***********************************************************************
 Name:          GetNewPort

 Description:   A private method that generates a new port ID from a pool
                reserved for communication.
                The pool starts at ID 5000 and continues to 7000.  When 7000
                is reached, it wraps back to 5000.

 Returns:       unsigned short.
 ***********************************************************************|><|*/
    static unsigned short  GetNewPort(void);


/*|><|***********************************************************************
 Name:          GetRemoteAddress

 Description:   A private method that returns  the SOCKADDR_IN structure
                provided by the caller with information identifying the
                connected FE.

 Returns:       None.
 ***********************************************************************|><|*/
    void  GetRemoteAddress( SOCKADDR_IN *lpAddr );

/*|><|***********************************************************************
 Name:          SetRemoteAddress

 Description:   A private method that loads the SOCKADDR_IN structure
                maintained as a channel property with the information provided
                by the caller.

 Returns:       None.
 ***********************************************************************|><|*/
    void  SetRemoteAddress( SOCKADDR_IN *lpAddr );


private:

    CRITICAL_SECTION m_csChannelSynchronized;
    INetDispatch    *m_piNetDispatch;
    int              m_hSocket;          // Socket

    SOCKADDR_IN      m_ipLocal;          // Local address:port
    SOCKADDR_IN      m_ipRemote;         // Remote address:port

    struct tagChannelFlags              // State/Status flags
    {
        unsigned short  bfOpen           : 1;   // TRUE if socket is open
        unsigned short  bfDirection      : 2;
                                     // 01=Rx, 10=Tx, 11=bidirectional
        unsigned short  bfReliable       : 1;
                                     // Is the channel a reliable channel
        unsigned short  bfBound          : 1;   // TRUE if socket is bound
        unsigned short  bfConnectPending : 1;   // Connection pending
        unsigned short  bfConnected      : 1;   // TRUE if socket is connected
        unsigned short  bfConnectFailed  : 1;
                                     // TRUE if the connection request failed
        unsigned short  bfListening      : 1;   // Socket is listening
        unsigned short  bfEnableRecv     : 1;   // Enable receiving of data
    } m_fFlags;

#ifdef PINGTEL_OSSOCKET
// Extension to allow the Network Channel object to be used as a wrapper
// for a Pingtel OS Socket object
    OsSocket & m_rOsSocket;
#endif

};




#endif