Don't do reinvite if both parties talk diffrent codecs
[asterisk/asterisk.git] / channels / h323 / ast_h323.h
1 /*
2  * ast_h323.h
3  *
4  * OpenH323 Channel Driver for ASTERISK PBX.
5  *                      By Jeremy McNamara
6  *                      For The NuFone Network 
7  * 
8  * This code has been derived from code created by
9  *              Michael Manousos and Mark Spencer
10  *
11  * This file is part of the chan_h323 driver for Asterisk
12  *
13  * chan_h323 is free software; you can redistribute it and/or modify
14  * it under the terms of the GNU General Public License as published by
15  * the Free Software Foundation; either version 2 of the License, or
16  * (at your option) any later version. 
17  *
18  * chan_h323 is distributed WITHOUT ANY WARRANTY; without even 
19  * the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
20  * PURPOSE. See the GNU General Public License for more details. 
21  *
22  * You should have received a copy of the GNU General Public License
23  * along with this program; if not, write to the Free Software
24  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 
25  *
26  * Version Info: $Id$ 
27  */
28
29
30 #include <ptlib.h>
31 #include <h323.h>
32 #include <h323pdu.h>
33 #include <mediafmt.h>
34 #include <lid.h>
35
36 #include <list>
37 #include <string>
38 #include <algorithm>
39
40 #include "chan_h323.h"
41
42 /**  These need to be redefined here because the C++
43          side of this driver is blind to the asterisk headers */
44         
45 /*! G.723.1 compression */
46 #define AST_FORMAT_G723_1       (1 << 0)
47 /*! GSM compression */
48 #define AST_FORMAT_GSM          (1 << 1)
49 /*! Raw mu-law data (G.711) */
50 #define AST_FORMAT_ULAW         (1 << 2)
51 /*! Raw A-law data (G.711) */
52 #define AST_FORMAT_ALAW         (1 << 3)
53 /*! MPEG-2 layer 3 */
54 #define AST_FORMAT_MP3          (1 << 4)
55 /*! ADPCM (whose?) */
56 #define AST_FORMAT_ADPCM        (1 << 5)
57 /*! Raw 16-bit Signed Linear (8000 Hz) PCM */
58 #define AST_FORMAT_SLINEAR      (1 << 6)
59 /*! LPC10, 180 samples/frame */
60 #define AST_FORMAT_LPC10        (1 << 7)
61 /*! G.729A audio */
62 #define AST_FORMAT_G729A        (1 << 8)
63 /*! SpeeX Free Compression */
64 #define AST_FORMAT_SPEEX        (1 << 9)
65 /*! ILBC Free Codec */
66 #define AST_FORMAT_ILBC         (1 << 10)
67
68 /**This class describes the G.723.1 codec capability.
69  */
70 class H323_G7231Capability : public H323AudioCapability
71 {
72     PCLASSINFO(H323_G7231Capability, H323AudioCapability);
73   public:
74     H323_G7231Capability(
75       BOOL annexA = TRUE  /// Enable Annex A silence insertion descriptors
76     );
77     Comparison Compare(const PObject & obj) const;
78
79     PObject * Clone() const;
80   
81         virtual H323Codec * CreateCodec(
82       H323Codec::Direction direction  /// Direction in which this instance runs
83     ) const;
84
85         unsigned GetSubType() const;
86     PString GetFormatName() const;
87     BOOL OnSendingPDU(
88       H245_AudioCapability & pdu,  /// PDU to set information on
89       unsigned packetSize          /// Packet size to use in capability
90     ) const;
91
92     BOOL OnReceivedPDU(
93       const H245_AudioCapability & pdu,  /// PDU to get information from
94       unsigned & packetSize              /// Packet size to use in capability
95     );
96   
97   protected:
98     BOOL annexA;
99 };
100
101 class MyH323EndPoint : public H323EndPoint {
102
103         PCLASSINFO(MyH323EndPoint, H323EndPoint);
104
105         public:
106
107         int MakeCall(const PString &, PString &, unsigned int *, unsigned int, char *);
108         BOOL ClearCall(const PString &);
109
110         void OnClosedLogicalChannel(H323Connection &, const H323Channel &);
111         void OnConnectionEstablished(H323Connection &, const PString &);
112         void OnConnectionCleared(H323Connection &, const PString &);
113         H323Connection * CreateConnection(unsigned, void *);
114         void SendUserTone(const PString &, char);
115         H323Capabilities GetCapabilities(void);
116         BOOL OnConnectionForwarded(H323Connection &, const PString &, const H323SignalPDU &);
117  
118         BOOL ForwardConnection(H323Connection &, const PString &, const H323SignalPDU &);
119
120         PStringArray SupportedPrefixes; 
121         
122     void SetEndpointTypeInfo( H225_EndpointType & info ) const;
123     void SetGateway(void);
124
125 };
126
127   
128 class MyH323Connection : public H323Connection {
129
130         PCLASSINFO(MyH323Connection, H323Connection);
131
132         public:
133         MyH323Connection(MyH323EndPoint &, unsigned, unsigned);
134         ~MyH323Connection();
135
136         H323Channel * CreateRealTimeLogicalChannel(const H323Capability &, H323Channel::Directions, unsigned, 
137                                                                                            const H245_H2250LogicalChannelParameters *);
138         H323Connection::AnswerCallResponse OnAnswerCall(const PString &, const H323SignalPDU &, H323SignalPDU &);
139         void OnReceivedReleaseComplete(const H323SignalPDU &);
140         BOOL OnAlerting(const H323SignalPDU &, const PString &);
141         BOOL OnSendReleaseComplete(H323SignalPDU &);
142         BOOL OnReceivedSignalSetup(const H323SignalPDU &);
143         BOOL OnReceivedFacility(const H323SignalPDU &);
144         BOOL OnSendSignalSetup(H323SignalPDU &);
145         BOOL OnStartLogicalChannel(H323Channel &);
146         BOOL OnClosingLogicalChannel(H323Channel &);    
147         void SendUserInputTone(char, unsigned);
148         void OnUserInputTone(char, unsigned, unsigned, unsigned);
149         void OnUserInputString(const PString &value);
150
151         PString sourceAliases;
152         PString destAliases;
153         PString sourceE164;
154         PString destE164;
155
156         PIPSocket::Address externalIpAddress;   // IP address of media server
157     PIPSocket::Address remoteIpAddress;         // IP Address of remote endpoint
158         WORD                       externalPort;                // local media server Data port (control is dataPort+1)
159         WORD                       remotePort;                  // remote endpoint Data port (control is dataPort+1)
160         WORD                       sessionId;
161         BOOL                       bridging;                    // Used to help determine which IP to use
162 };
163
164
165 #if 0
166 class MyGatekeeperServer : public H323GatekeeperServer
167 {
168     PCLASSINFO(MyGatekeeperServer, H323GatekeeperServer);
169   public:
170     MyGatekeeperServer(MyH323EndPoint & ep);
171
172     // Overrides
173     virtual H323GatekeeperCall * CreateCall(
174       const OpalGloballyUniqueID & callIdentifier,
175       H323GatekeeperCall::Direction direction
176     );
177     virtual BOOL TranslateAliasAddressToSignalAddress(
178       const H225_AliasAddress & alias,
179       H323TransportAddress & address
180     );
181
182     // new functions
183     BOOL Initialise();
184
185   private:
186     class RouteMap : public PObject {
187         PCLASSINFO(RouteMap, PObject);
188       public:
189         RouteMap(
190           const PString & alias,
191           const PString & host
192         );
193         RouteMap(
194           const RouteMap & map
195         ) : alias(map.alias), regex(map.alias), host(map.host) { }
196
197         void PrintOn(
198           ostream & strm
199         ) const;
200
201         BOOL IsValid() const;
202
203         BOOL IsMatch(
204           const PString & alias
205         ) const;
206
207         const H323TransportAddress & GetHost() const { return host; }
208
209       private:
210         PString              alias;
211         PRegularExpression   regex;
212         H323TransportAddress host;
213     };
214     PList<RouteMap> routes;
215
216     PMutex reconfigurationMutex;
217 };
218
219 #endif
220
221 /**
222  * The MyProcess is a necessary descendant PProcess class so that the H323EndPoint 
223  * objected to be created from within that class. (Who owns main() problem). 
224  */
225 class MyProcess : public PProcess {
226
227         PCLASSINFO(MyProcess, PProcess);
228     
229         public:
230         MyProcess();
231         ~MyProcess();
232
233         void Main(); 
234         
235         
236 };
237
238
239 /** 
240  * This class handles the termination of a call.
241  * Note that OpenH323 Library requires that the termination
242  * of a call should be done inside a separate thread of execution.
243  */
244 class ClearCallThread : public PThread {
245
246         PCLASSINFO(ClearCallThread, PThread);
247
248         public:
249         ClearCallThread(const char *tc);
250         ~ClearCallThread();    
251         
252         void Main();
253         
254         protected:
255         PString token;
256 };
257
258