| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Asterisk -- An open source telephony toolkit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2010, Digium, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See http://www.asterisk.org for more information about
 | 
					
						
							|  |  |  |  * the Asterisk project. Please do not directly contact | 
					
						
							|  |  |  |  * any of the maintainers of this project for assistance; | 
					
						
							|  |  |  |  * the project provides a web site, mailing lists and IRC | 
					
						
							|  |  |  |  * channels for your use. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software, distributed under the terms of | 
					
						
							|  |  |  |  * the GNU General Public License Version 2. See the LICENSE file | 
					
						
							|  |  |  |  * at the top of the source tree. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \file | 
					
						
							|  |  |  |  * \brief sip request response parser header file | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _SIP_REQRESP_H
 | 
					
						
							|  |  |  | #define _SIP_REQRESP_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 20:57:42 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief parses a URI in its components. | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \note | 
					
						
							|  |  |  |  * - Multiple scheme's can be specified ',' delimited. ex: "sip:,sips:" | 
					
						
							|  |  |  |  * - If a component is not requested, do not split around it. This means | 
					
						
							| 
									
										
										
										
											2010-07-08 22:08:07 +00:00
										 |  |  |  *   that if we don't have domain, we cannot split name:pass. | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  |  * - It is safe to call with ret_name, pass, domain, port pointing all to | 
					
						
							|  |  |  |  *   the same place. | 
					
						
							| 
									
										
										
										
											2010-02-10 23:13:49 +00:00
										 |  |  |  * - If no secret parameter is provided, ret_name will return with both parts, user:secret | 
					
						
							|  |  |  |  * - If no port parameter is provided, domain will return with both parts, domain:port | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  |  * - This function overwrites the the uri string. | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * \retval 0 on success | 
					
						
							|  |  |  |  * \retval -1 on error. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \verbatim | 
					
						
							|  |  |  |  * general form we are expecting is sip:user:password;user-parameters@host:port;uri-parameters?headers | 
					
						
							|  |  |  |  * \endverbatim | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-07-08 22:08:07 +00:00
										 |  |  | int parse_uri(char *uri, const char *scheme, char **ret_name, char **pass, | 
					
						
							|  |  |  | 	      char **domain, char **transport); | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 16:04:16 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief parses a URI in to all of its components and any trailing residue | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 on success | 
					
						
							|  |  |  |  * \retval -1 on error. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-07-08 22:08:07 +00:00
										 |  |  | int parse_uri_full(char *uri, const char *scheme, char **user, char **pass, | 
					
						
							|  |  |  | 		   char **domain, struct uriparams *params, char **headers, | 
					
						
							|  |  |  | 		   char **residue); | 
					
						
							| 
									
										
										
										
											2010-04-09 16:04:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 20:57:42 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief  Get caller id name from SIP headers, copy into output buffer | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-02-07 20:57:42 +00:00
										 |  |  |  * \retval input string pointer placed after display-name field if possible | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | const char *get_calleridname(const char *input, char *output, size_t outputsize); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-15 15:45:02 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief  Get name and number from sip header | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note name and number point to malloced memory on return and must be | 
					
						
							|  |  |  |  * freed. If name or number is not found, they will be returned as NULL. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int get_name_and_number(const char *hdr, char **name, char **number); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! \brief Pick out text in brackets from character string
 | 
					
						
							|  |  |  |  * \return pointer to terminated stripped string | 
					
						
							|  |  |  |  * \param tmp input string that will be modified | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Examples: | 
					
						
							|  |  |  |  * \verbatim | 
					
						
							|  |  |  |  * "foo" <bar>	valid input, returns bar | 
					
						
							|  |  |  |  *  foo returns the whole string | 
					
						
							|  |  |  |  * < "foo ... >	returns the string between brackets | 
					
						
							|  |  |  |  * < "foo...    bogus (missing closing bracket), returns the whole string | 
					
						
							|  |  |  |  * \endverbatim | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | char *get_in_brackets(char *tmp); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 16:04:16 +00:00
										 |  |  | /*! \brief Get text in brackets and any trailing residue
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 1 no brackets so got all | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int get_in_brackets_full(char *tmp, char **out, char **residue); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*! \brief Parse the ABNF structure
 | 
					
						
							|  |  |  |  * name-andor-addr = name-addr / addr-spec | 
					
						
							|  |  |  |  * into its components and return any trailing message-header parameters | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-07-08 22:08:07 +00:00
										 |  |  | int parse_name_andor_addr(char *uri, const char *scheme, char **name, | 
					
						
							|  |  |  | 			  char **user, char **pass, char **domain, | 
					
						
							|  |  |  | 			  struct uriparams *params, char **headers, | 
					
						
							|  |  |  | 			  char **remander); | 
					
						
							| 
									
										
										
										
											2010-04-09 16:04:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*! \brief Parse all contact header contacts
 | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 1 all contacts (star) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int get_comma(char *parse, char **out); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int parse_contact_header(char *contactheader, struct contactliststruct *contactlist); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 20:57:42 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief register request parsing tests | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  | void sip_request_parser_register_tests(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 20:57:42 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief unregister request parsing tests | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  | void sip_request_parser_unregister_tests(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 18:38:47 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief Parse supported header in incoming packet | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \details This function parses through the options parameters and | 
					
						
							|  |  |  |  * builds a bit field representing all the SIP options in that field. When an | 
					
						
							|  |  |  |  * item is found that is not supported, it is copied to the unsupported | 
					
						
							|  |  |  |  * out buffer. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param option list | 
					
						
							|  |  |  |  * \param unsupported out buffer (optional) | 
					
						
							|  |  |  |  * \param unsupported out buffer length (optional) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | unsigned int parse_sip_options(const char *options, char *unsupported, size_t unsupported_len); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:33:52 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief Compare two URIs as described in RFC 3261 Section 19.1.4 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param input1 First URI | 
					
						
							|  |  |  |  * \param input2 Second URI | 
					
						
							|  |  |  |  * \retval 0 URIs match | 
					
						
							|  |  |  |  * \retval nonzero URIs do not match or one or both is malformed | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int sip_uri_cmp(const char *input1, const char *input2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief initialize request and response parser data | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 Success | 
					
						
							|  |  |  |  * \retval -1 Failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int sip_reqresp_parser_init(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief Free resources used by request and response parser | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void sip_reqresp_parser_exit(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-26 19:59:03 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2011-01-26 20:43:27 +00:00
										 |  |  |  * \brief Parse a Via header | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This function parses the Via header and processes it according to section | 
					
						
							|  |  |  |  * 18.2 of RFC 3261 and RFC 3581. Since we don't have a transport layer, we | 
					
						
							|  |  |  |  * only care about the maddr and ttl parms.  The received and rport params are | 
					
						
							|  |  |  |  * not parsed. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note This function fails to parse some odd combinations of SWS in parameter | 
					
						
							|  |  |  |  * lists. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \code | 
					
						
							|  |  |  |  * VIA syntax. RFC 3261 section 25.1 | 
					
						
							|  |  |  |  * Via               =  ( "Via" / "v" ) HCOLON via-parm *(COMMA via-parm) | 
					
						
							|  |  |  |  * via-parm          =  sent-protocol LWS sent-by *( SEMI via-params ) | 
					
						
							|  |  |  |  * via-params        =  via-ttl / via-maddr | 
					
						
							|  |  |  |  *                   / via-received / via-branch | 
					
						
							|  |  |  |  *                   / via-extension | 
					
						
							|  |  |  |  * via-ttl           =  "ttl" EQUAL ttl | 
					
						
							|  |  |  |  * via-maddr         =  "maddr" EQUAL host | 
					
						
							|  |  |  |  * via-received      =  "received" EQUAL (IPv4address / IPv6address) | 
					
						
							|  |  |  |  * via-branch        =  "branch" EQUAL token | 
					
						
							|  |  |  |  * via-extension     =  generic-param | 
					
						
							|  |  |  |  * sent-protocol     =  protocol-name SLASH protocol-version | 
					
						
							|  |  |  |  *                   SLASH transport | 
					
						
							|  |  |  |  * protocol-name     =  "SIP" / token | 
					
						
							|  |  |  |  * protocol-version  =  token | 
					
						
							|  |  |  |  * transport         =  "UDP" / "TCP" / "TLS" / "SCTP" | 
					
						
							|  |  |  |  *                   / other-transport | 
					
						
							|  |  |  |  * sent-by           =  host [ COLON port ] | 
					
						
							|  |  |  |  * ttl               =  1*3DIGIT ; 0 to 255 | 
					
						
							|  |  |  |  * \endcode | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct sip_via *parse_via(const char *header); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * \brief Free parsed Via data. | 
					
						
							| 
									
										
										
										
											2010-07-26 19:59:03 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-01-26 20:43:27 +00:00
										 |  |  | void free_via(struct sip_via *v); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												-----Changes -----
New files
- channels/sip/sip.h – A new header for shared #define, enum, and struct
  definitions.
- channels/sip/include/sip_utils.h – sip util functions shared among
  the all the sip APIs
- channels/sip/include/config_parser.h – sip config-parser API
- channels/sip/config_parser.c  – Contains sip.conf parsing helper functions
  with unit tests.
- channels/sip/include/reqresp_parser.h – sip request response parser API
- channels/sip/reqresp_parser.c – Contains sip request and response parsing
  helper functions with unit tests.
New Unit Tests 
- sip_parse_uri_test
- sip_parse_host_test
- sip_parse_register_line_test
Code Refactoring
- All reusable #define, enum, and struct definitions were moved out of chan_sip.c
  into sip.h. During this process formatting changes were made to comments
  in both sip.h and chan_sip.c in order to better adhere to the coding guidelines.
- The beginnings of three new sip APIs, sip-utils.h, config-parser.h,
  reqresp-parser.h using existing chan_sip.c functions.
- parse_uri() and get_calleridname() were moved from chan_sip.c to request-parser.c
  along with unit tests for both functions.
- sip_parse_host() and sip_parse_register_line() were moved from chan_sip.c to
  config-parser.c along with unit tests for both functions.
Changes to parse_uri()
-removal of the options parameter.  It was never used and did not behave correctly.
-additional check for [?header] field. When this field was present, the transport
 type was not being set correctly.
----- Overview -----
This patch is introduced with the hope that unit tests for all our sip parsing
functions will be written soon.  chan_sip is a huge file, and with the addition of
each unit test chan_sip is going to grow larger and harder to maintain.  I'm proposing
we begin refactoring chan_sip, starting with the parsing functions.  With each parsing
function we move into a separate helper file, a unit test should accompany it.  I've 
attempted to lay down the ground work for this change by creating two new parser
helper files (config-parser.c and reqresp-parser.c) and moving all shared structs,
enums, and defines from chan_sip.c into a shared sip.h file.  We can't verify everything
in Asterisk using unit tests, but string parsing is one area where unit tests make
the most sense.  By beginning to restructure the code in this way, chan_sip not only
becomes less bloated, but Asterisk as a whole will become more stable.
Review: https://reviewboard.asterisk.org/r/477/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@244597 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2010-02-03 20:33:32 +00:00
										 |  |  | #endif
 |