~ubuntu-branches/ubuntu/vivid/sflphone/vivid

« back to all changes in this revision

Viewing changes to daemon/libs/pjproject/pjsip/include/pjsip/sip_parser.h

  • Committer: Package Import Robot
  • Author(s): Mark Purcell
  • Date: 2013-06-30 11:40:56 UTC
  • mfrom: (4.1.18 saucy-proposed)
  • Revision ID: package-import@ubuntu.com-20130630114056-0np50jkyqo6vnmii
Tags: 1.2.3-2
* changeset_r92d62cfc54732bbbcfff2b1d36c096b120b981a5.diff 
  - fixes automatic endian detection 
* Update Vcs: fixes vcs-field-not-canonical

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* $Id: sip_parser.h 3553 2011-05-05 06:14:19Z nanang $ */
2
 
/* 
3
 
 * Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com)
4
 
 * Copyright (C) 2003-2008 Benny Prijono <benny@prijono.org>
5
 
 *
6
 
 * This program is free software; you can redistribute it and/or modify
7
 
 * it under the terms of the GNU General Public License as published by
8
 
 * the Free Software Foundation; either version 2 of the License, or
9
 
 * (at your option) any later version.
10
 
 *
11
 
 * This program is distributed in the hope that it will be useful,
12
 
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 
 * GNU General Public License for more details.
15
 
 *
16
 
 * You should have received a copy of the GNU General Public License
17
 
 * along with this program; if not, write to the Free Software
18
 
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA 
19
 
 */
20
 
#ifndef __PJSIP_SIP_PARSER_H__
21
 
#define __PJSIP_SIP_PARSER_H__
22
 
 
23
 
/**
24
 
 * @file sip_parser.h
25
 
 * @brief SIP Message Parser
26
 
 */
27
 
 
28
 
#include <pjsip/sip_msg.h>
29
 
#include <pjlib-util/scanner.h>
30
 
#include <pj/list.h>
31
 
 
32
 
PJ_BEGIN_DECL
33
 
 
34
 
/**
35
 
 * @defgroup PJSIP_PARSER Parser
36
 
 * @ingroup PJSIP_MSG
37
 
 * @brief Message and message elements parsing.
38
 
 * @{
39
 
 */
40
 
 
41
 
/**
42
 
 * URI Parsing options.
43
 
 */
44
 
enum
45
 
{
46
 
    /** If this option is specified, function #pjsip_parse_uri will return
47
 
     *  the URI object as pjsip_name_addr instead of the corresponding
48
 
     *  URI object.
49
 
     */
50
 
    PJSIP_PARSE_URI_AS_NAMEADDR = 1,
51
 
 
52
 
    /** If this option is specified, function #pjsip_parse_uri and other
53
 
     *  internal functions that this function calls will parse URI according
54
 
     *  to convention for parsing From/To/Contact header. For example, when 
55
 
     *  the URI is not enclosed in brackets ("<" and ">"), all parameters 
56
 
     *  are treated as header parameters (not URI parameters).
57
 
     */
58
 
    PJSIP_PARSE_URI_IN_FROM_TO_HDR = 2
59
 
};
60
 
 
61
 
/**
62
 
 * Parser syntax error exception value.
63
 
 */
64
 
extern int PJSIP_SYN_ERR_EXCEPTION;
65
 
 
66
 
/**
67
 
 * This structure is used to get error reporting from parser.
68
 
 */
69
 
typedef struct pjsip_parser_err_report
70
 
{
71
 
    /** Standard header fields. */
72
 
    PJ_DECL_LIST_MEMBER(struct pjsip_parser_err_report);
73
 
    int         except_code;    /**< Error exception (e.g. PJSIP_SYN_ERR_EXCEPTION) */
74
 
    int         line;           /**< Line number. */
75
 
    int         col;            /**< Column number. */
76
 
    pj_str_t    hname;          /**< Header name, if any. */
77
 
} pjsip_parser_err_report;
78
 
 
79
 
 
80
 
/**
81
 
 * Parsing context, the default argument for parsing functions.
82
 
 */
83
 
typedef struct pjsip_parse_ctx
84
 
{
85
 
    pj_scanner      *scanner;   /**< The scanner.       */
86
 
    pj_pool_t       *pool;      /**< The pool.          */
87
 
    pjsip_rx_data   *rdata;     /**< Optional rdata.    */
88
 
} pjsip_parse_ctx;
89
 
 
90
 
 
91
 
/**
92
 
 * Type of function to parse header. The parsing function must follow these
93
 
 * specification:
94
 
 *   - It must not modify the input text.
95
 
 *   - The hname and HCOLON has been parsed prior to invoking the handler.
96
 
 *   - It returns the header instance on success.
97
 
 *   - For error reporting, it must throw PJSIP_SYN_ERR_EXCEPTION exception 
98
 
 *     instead of just returning NULL. 
99
 
 *     When exception is thrown, the return value is ignored.
100
 
 *   - It must read the header separator after finished reading the header
101
 
 *     body. The separator types are described below, and if they don't exist,
102
 
 *     exception must be thrown. Header separator can be a:
103
 
 *      - newline, such as when the header is part of a SIP message.
104
 
 *      - ampersand, such as when the header is part of an URI.
105
 
 *      - for the last header, these separator is optional since parsing
106
 
 *        can be terminated when seeing EOF.
107
 
 */
108
 
typedef pjsip_hdr* (pjsip_parse_hdr_func)(pjsip_parse_ctx *context);
109
 
 
110
 
/**
111
 
 * Type of function to parse URI scheme.
112
 
 * Most of the specification of header parser handler (pjsip_parse_hdr_func)
113
 
 * also applies here (except the separator part).
114
 
 */
115
 
typedef void* (pjsip_parse_uri_func)(pj_scanner *scanner, pj_pool_t *pool,
116
 
                                     pj_bool_t parse_params);
117
 
 
118
 
/**
119
 
 * Register header parser handler. The parser handler MUST follow the 
120
 
 * specification of header parser handler function. New registration 
121
 
 * overwrites previous registration with the same name.
122
 
 *
123
 
 * @param hname         The header name.
124
 
 * @param hshortname    The short header name or NULL.
125
 
 * @param fptr          The pointer to function to parser the header.
126
 
 *
127
 
 * @return              PJ_SUCCESS if success, or the appropriate error code.
128
 
 */
129
 
PJ_DECL(pj_status_t) pjsip_register_hdr_parser( const char *hname,
130
 
                                                const char *hshortname,
131
 
                                                pjsip_parse_hdr_func *fptr);
132
 
 
133
 
/**
134
 
 * Unregister previously registered header parser handler.
135
 
 * All the arguments MUST exactly equal to the value specified upon 
136
 
 * registration of the handler.
137
 
 *
138
 
 * @param hname         The header name registered.
139
 
 * @param hshortname    The short header name registered, or NULL.
140
 
 * @param fptr          Previously registered function to parse the header.
141
 
 *
142
 
 * @return              zero if unregistration was successfull.
143
 
 */
144
 
PJ_DECL(pj_status_t) pjsip_unregister_hdr_parser( const char *hname,
145
 
                                                  const char *hshortname,
146
 
                                                  pjsip_parse_hdr_func *fptr);
147
 
 
148
 
/**
149
 
 * Register URI scheme parser handler.
150
 
 *
151
 
 * @param scheme        The URI scheme registered.
152
 
 * @param func          The URI parser function.
153
 
 *
154
 
 * @return              zero on success.
155
 
 */
156
 
PJ_DECL(pj_status_t) pjsip_register_uri_parser( char *scheme,
157
 
                                                pjsip_parse_uri_func *func);
158
 
 
159
 
/**
160
 
 * Unregister URI scheme parser handler.
161
 
 * All the arguments MUST exactly equal to the value specified upon 
162
 
 * registration of the handler.
163
 
 *
164
 
 * @param scheme        The URI scheme as registered previously.
165
 
 * @param func          The function handler as registered previously.
166
 
 *
167
 
 * @return              zero if the registration was successfull.
168
 
 */
169
 
PJ_DECL(pj_status_t) pjsip_unregister_uri_parser( const char *scheme,
170
 
                                                  pjsip_parse_uri_func *func);
171
 
 
172
 
/**
173
 
 * Parse an URI in the input and return the correct instance of URI.
174
 
 *
175
 
 * @param pool          The pool to get memory allocations.
176
 
 * @param buf           The input buffer, which MUST be NULL terminated.
177
 
 * @param size          The length of the string (not counting NULL terminator).
178
 
 * @param options       If no options are given (value is zero), the object 
179
 
 *                      returned is dependent on the syntax of the URI, 
180
 
 *                      eg. basic SIP URL, TEL URL, or name address. 
181
 
 *                      If option PJSIP_PARSE_URI_AS_NAMEADDR is given,
182
 
 *                      then the returned object is always name address object,
183
 
 *                      with the relevant URI object contained in the name 
184
 
 *                      address object.
185
 
 * @return              The URI or NULL when failed. No exception is thrown by 
186
 
 *                      this function (or any public parser functions).
187
 
 */
188
 
PJ_DECL(pjsip_uri*) pjsip_parse_uri( pj_pool_t *pool, 
189
 
                                     char *buf, pj_size_t size,
190
 
                                     unsigned options);
191
 
 
192
 
/**
193
 
 * Parse SIP status line.
194
 
 *
195
 
 * @param buf           Text buffer to parse, which MUST be NULL terminated.
196
 
 * @param size          The size of the buffer, excluding the NULL character.
197
 
 * @param status_line   Structure to receive the parsed elements.
198
 
 *
199
 
 * @return              PJ_SUCCESS if a status line is parsed successfully.
200
 
 */
201
 
PJ_DECL(pj_status_t) pjsip_parse_status_line(char *buf, pj_size_t size,
202
 
                                             pjsip_status_line *status_line);
203
 
 
204
 
 
205
 
/**
206
 
 * Parse a packet buffer and build a full SIP message from the packet. This
207
 
 * function parses all parts of the message, including request/status line,
208
 
 * all headers, and the message body. The message body however is only 
209
 
 * treated as a text block, ie. the function will not try to parse the content
210
 
 * of the body.
211
 
 *
212
 
 * @param pool          The pool to allocate memory.
213
 
 * @param buf           The input buffer, which MUST be NULL terminated.
214
 
 * @param size          The length of the string (not counting NULL terminator).
215
 
 * @param err_list      If this parameter is not NULL, then the parser will
216
 
 *                      put error messages during parsing in this list.
217
 
 *
218
 
 * @return              The message or NULL when failed. No exception is thrown
219
 
 *                      by this function (or any public parser functions).
220
 
 */
221
 
PJ_DECL(pjsip_msg *) pjsip_parse_msg( pj_pool_t *pool, 
222
 
                                      char *buf, pj_size_t size,
223
 
                                      pjsip_parser_err_report *err_list);
224
 
 
225
 
 
226
 
/**
227
 
 * Parse a packet buffer and build a rdata. The resulting message will be
228
 
 * stored in \c msg field in the \c rdata. This behaves pretty much like
229
 
 * #pjsip_parse_msg(), except that it will also initialize the header fields
230
 
 * in the \c rdata.
231
 
 *
232
 
 * This function is normally called by the transport layer.
233
 
 *
234
 
 * @param buf           The input buffer, which MUST be NULL terminated.
235
 
 * @param size          The length of the string (not counting NULL terminator).
236
 
 * @param rdata         The receive data buffer to store the message and
237
 
 *                      its elements.
238
 
 *
239
 
 * @return              The message inside the rdata if successfull, or NULL.
240
 
 */
241
 
PJ_DECL(pjsip_msg *) pjsip_parse_rdata( char *buf, pj_size_t size,
242
 
                                        pjsip_rx_data *rdata );
243
 
 
244
 
/**
245
 
 * Check incoming packet to see if a (probably) valid SIP message has been 
246
 
 * received.
247
 
 *
248
 
 * @param buf           The input buffer, which must be NULL terminated.
249
 
 * @param size          The buffer size.
250
 
 * @param is_datagram   Put non-zero if transport is datagram oriented.
251
 
 * @param msg_size      [out] If message is valid, this parameter will contain
252
 
 *                      the size of the SIP message (including body, if any).
253
 
 *
254
 
 * @return              PJ_SUCCESS if a message is found, or an error code.
255
 
 */
256
 
PJ_DECL(pj_status_t) pjsip_find_msg(const char *buf, 
257
 
                                    pj_size_t size, 
258
 
                                    pj_bool_t is_datagram, 
259
 
                                    pj_size_t *msg_size);
260
 
 
261
 
/**
262
 
 * Parse the content of a header and return the header instance.
263
 
 * This function parses the content of a header (ie. part after colon) according
264
 
 * to the expected name, and will return the correct instance of header.
265
 
 *
266
 
 * @param pool          Pool to allocate memory for the header.
267
 
 * @param hname         Header name which is used to find the correct function
268
 
 *                      to parse the header.
269
 
 * @param line          Header content, which must be NULL terminated.
270
 
 * @param size          The length of the string (not counting NULL terminator,
271
 
 *                      if any).
272
 
 * @param parsed_len    If the value is not NULL, then upon return the function
273
 
 *                      will fill the pointer with the length of the string
274
 
 *                      that has been parsed. This is usefull for two purposes,
275
 
 *                      one is when the string may contain more than one header
276
 
 *                      lines, and two when an error happen the value can
277
 
 *                      pinpoint the location of the error in the buffer.
278
 
 *
279
 
 * @return              The instance of the header if parsing was successful,
280
 
 *                      or otherwise a NULL pointer will be returned.
281
 
 */
282
 
PJ_DECL(void*) pjsip_parse_hdr( pj_pool_t *pool, const pj_str_t *hname,
283
 
                                char *line, pj_size_t size,
284
 
                                int *parsed_len);
285
 
 
286
 
/**
287
 
 * Parse header line(s). Multiple headers can be parsed by this function.
288
 
 * When there are multiple headers, the headers MUST be separated by either
289
 
 * a newline (as in SIP message) or ampersand mark (as in URI). This separator
290
 
 * is optional for the last header.
291
 
 *
292
 
 * @param pool          The pool.
293
 
 * @param input         The input text to parse, which must be NULL terminated.
294
 
 * @param size          The text length.
295
 
 * @param hlist         The header list to store the parsed headers.
296
 
 *                      This list must have been initialized before calling 
297
 
 *                      this function.
298
 
 * @param options       Specify 1 here to make parsing stop when error is
299
 
 *                      encountered when parsing the header. Otherwise the
300
 
 *                      error is silently ignored and parsing resumes to the
301
 
 *                      next line.
302
 
 * @return              zero if successfull, or -1 if error is encountered. 
303
 
 *                      Upon error, the \a hlist argument MAY contain 
304
 
 *                      successfully parsed headers.
305
 
 */
306
 
PJ_DECL(pj_status_t) pjsip_parse_headers( pj_pool_t *pool, char *input,
307
 
                                          pj_size_t size, pjsip_hdr *hlist,
308
 
                                          unsigned options);
309
 
 
310
 
 
311
 
/**
312
 
 * @}
313
 
 */
314
 
 
315
 
 
316
 
#ifdef _MSC_VER
317
 
#   pragma warning(push)
318
 
#   pragma warning(disable:4510) // default constructor could not be generated
319
 
#   pragma warning(disable:4512) // assignment operator could not be generated
320
 
#   pragma warning(disable:4610) // user defined constructor required
321
 
#endif
322
 
 
323
 
/**
324
 
 * Parser constants. @see pjsip_parser_const()
325
 
 */
326
 
typedef struct pjsip_parser_const_t
327
 
{
328
 
    const pj_str_t pjsip_USER_STR;      /**< "user" string constant.    */
329
 
    const pj_str_t pjsip_METHOD_STR;    /**< "method" string constant   */
330
 
    const pj_str_t pjsip_TRANSPORT_STR; /**< "transport" string const.  */
331
 
    const pj_str_t pjsip_MADDR_STR;     /**< "maddr" string const.      */
332
 
    const pj_str_t pjsip_LR_STR;        /**< "lr" string const.         */
333
 
    const pj_str_t pjsip_SIP_STR;       /**< "sip" string constant.     */
334
 
    const pj_str_t pjsip_SIPS_STR;      /**< "sips" string constant.    */
335
 
    const pj_str_t pjsip_TEL_STR;       /**< "tel" string constant.     */
336
 
    const pj_str_t pjsip_BRANCH_STR;    /**< "branch" string constant.  */
337
 
    const pj_str_t pjsip_TTL_STR;       /**< "ttl" string constant.     */
338
 
    const pj_str_t pjsip_RECEIVED_STR;  /**< "received" string const.   */
339
 
    const pj_str_t pjsip_Q_STR;         /**< "q" string constant.       */
340
 
    const pj_str_t pjsip_EXPIRES_STR;   /**< "expires" string constant. */
341
 
    const pj_str_t pjsip_TAG_STR;       /**< "tag" string constant.     */
342
 
    const pj_str_t pjsip_RPORT_STR;     /**< "rport" string const.      */
343
 
 
344
 
    pj_cis_t pjsip_HOST_SPEC;           /**< For scanning host part.    */
345
 
    pj_cis_t pjsip_DIGIT_SPEC;          /**< Decimal digits             */
346
 
    pj_cis_t pjsip_ALPHA_SPEC;          /**< Alpha (A-Z, a-z)           */
347
 
    pj_cis_t pjsip_ALNUM_SPEC;          /**< Decimal + Alpha.           */
348
 
    pj_cis_t pjsip_TOKEN_SPEC;          /**< Token.                     */
349
 
    pj_cis_t pjsip_TOKEN_SPEC_ESC;      /**< Token without '%' character */
350
 
    pj_cis_t pjsip_VIA_PARAM_SPEC;      /**< Via param is token + ":" for
351
 
                                             IPv6.                      */
352
 
    pj_cis_t pjsip_VIA_PARAM_SPEC_ESC;  /**< .. as above without '%'    */
353
 
    pj_cis_t pjsip_HEX_SPEC;            /**< Hexadecimal digits.        */
354
 
    pj_cis_t pjsip_PARAM_CHAR_SPEC;     /**< For scanning pname (or pvalue
355
 
                                             when it's  not quoted.) in URI */
356
 
    pj_cis_t pjsip_PARAM_CHAR_SPEC_ESC; /**< Variant without the escape ('%')
357
 
                                             char                       */
358
 
    pj_cis_t pjsip_HDR_CHAR_SPEC;       /**< Chars in hname/havalue in URL. */
359
 
    pj_cis_t pjsip_HDR_CHAR_SPEC_ESC;   /**< Variant without the escape ('%')
360
 
                                             char                       */
361
 
    pj_cis_t pjsip_PROBE_USER_HOST_SPEC;/**< Hostname characters.       */
362
 
    pj_cis_t pjsip_PASSWD_SPEC;         /**< Password.                  */
363
 
    pj_cis_t pjsip_PASSWD_SPEC_ESC;     /**< Variant without the escape ('%')
364
 
                                             char                       */
365
 
    pj_cis_t pjsip_USER_SPEC;           /**< User */
366
 
    pj_cis_t pjsip_USER_SPEC_ESC;       /**< Variant without the escape ('%')
367
 
                                             char                       */
368
 
    pj_cis_t pjsip_USER_SPEC_LENIENT;   /**< User, with additional '#' char */
369
 
    pj_cis_t pjsip_USER_SPEC_LENIENT_ESC;/**< pjsip_USER_SPEC_ESC with '#' */
370
 
    pj_cis_t pjsip_NOT_NEWLINE;         /**< For eating up header, basically
371
 
                                             any chars except newlines or 
372
 
                                             zero.                      */
373
 
    pj_cis_t pjsip_NOT_COMMA_OR_NEWLINE;/**< Array elements.            */
374
 
    pj_cis_t pjsip_DISPLAY_SPEC;        /**< Used when searching for display
375
 
                                             name.                      */
376
 
    pj_cis_t pjsip_OTHER_URI_CONTENT;   /**< Generic URI content.       */
377
 
 
378
 
} pjsip_parser_const_t;
379
 
 
380
 
#ifdef _MSC_VER
381
 
#   pragma warning(pop)
382
 
#endif
383
 
 
384
 
 
385
 
/**
386
 
 * Get parser constants.
387
 
 */
388
 
PJ_DECL(const pjsip_parser_const_t*) pjsip_parser_const(void);
389
 
 
390
 
 
391
 
/*
392
 
 * Parser utilities.
393
 
 */
394
 
enum
395
 
{
396
 
    PJSIP_PARSE_REMOVE_QUOTE = 1
397
 
};
398
 
 
399
 
/* Parse parameter in header (matching the character as token) */
400
 
PJ_DECL(void) pjsip_parse_param_imp(pj_scanner *scanner, pj_pool_t *pool,
401
 
                                    pj_str_t *pname, pj_str_t *pvalue,
402
 
                                    unsigned opt);
403
 
/* Parse parameter in URL (matching the character as paramchar) */
404
 
PJ_DECL(void) pjsip_parse_uri_param_imp(pj_scanner *scanner, pj_pool_t *pool,
405
 
                                        pj_str_t *pname, pj_str_t *pvalue,
406
 
                                        unsigned opt);
407
 
PJ_DECL(void) pjsip_concat_param_imp(pj_str_t *param, pj_pool_t *pool, 
408
 
                                     const pj_str_t *pname, 
409
 
                                     const pj_str_t *pvalue, 
410
 
                                     int sepchar);
411
 
PJ_DECL(void) pjsip_parse_end_hdr_imp ( pj_scanner *scanner );
412
 
 
413
 
PJ_END_DECL
414
 
 
415
 
#endif  /* __PJSIP_SIP_PARSER_H__ */
416