Naveen Albert a2799554d2 
	
	
	pbx_functions.c: Manually update ast_str strlen. ... 
			When ast_func_read2 is used to read a function using
its read function (as opposed to a native ast_str read2
function), the result is copied directly by the function
into the ast_str buffer. As a result, the ast_str length
remains initialized to 0, which is a bug because this is
not the real string length.
This can cascade and have issues elsewhere, such as when
reading substrings of functions that only register read
as opposed to read2 callbacks. In this case, since reading
ast_str_strlen returns 0, the returned substring is empty
as opposed to the actual substring. This has caused
the ast_str family of functions to behave inconsistently
and erroneously, in contrast to the pbx_variables substitution
functions which work correctly.
This fixes this issue by manually updating the ast_str length
when the result is copied directly into the ast_str buffer.
Additionally, an assertion and a unit test that previously
exposed these issues are added, now that the issue is fixed.
ASTERISK-29966 #close
Change-Id: I4e2dba41410f9d4dff61c995d2ca27718248e07f 
		
	 
		2022-07-26 10:48:10 -05:00 
	 
	
	
	
		 
	
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2020-07-20 11:37:48 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2018-12-07 09:06:08 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-01-05 09:34:49 -06:00 
		 
	
		
			
			
			
			
			
			2020-05-05 10:06:43 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2020-05-05 10:06:43 -05:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-12 07:45:19 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2020-06-02 11:35:07 -05:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
			
			
			
			
			
			2019-09-23 07:35:48 -04:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-02-25 14:14:22 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2018-06-19 15:02:52 -05:00 
		 
	
		
			
			
			
			
			
			2020-04-06 10:23:20 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-06-27 10:42:29 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-07-12 07:45:19 -05:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2022-07-14 08:18:51 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-02-23 13:27:49 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-05-19 21:28:32 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-12 07:45:19 -05:00 
		 
	
		
			
			
			
			
			
			2018-03-01 13:13:55 -06:00 
		 
	
		
			
			
			
			
			
			2022-01-05 11:27:04 -06:00 
		 
	
		
			
			
			
			
			
			2021-08-03 07:15:10 -05:00 
		 
	
		
			
			
			
			
			
			2018-10-19 17:33:05 -04:00 
		 
	
		
			
			
			
			
			
			2021-09-02 15:13:03 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-07 08:22:43 -05:00 
		 
	
		
			
			
			
			
			
			2022-03-23 17:04:44 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-05-05 08:15:50 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2020-04-15 13:56:40 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-07 08:22:43 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-18 12:35:49 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-06-27 10:42:29 -05:00 
		 
	
		
			
			
			
			
			
			2020-03-13 09:58:59 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
			
			
			
			
			
			2020-06-10 09:33:28 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2020-04-28 13:05:55 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2022-01-05 12:24:25 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2019-03-11 11:39:35 -03:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2019-11-18 08:30:45 -06:00 
		 
	
		
			
			
			
			
			
			2022-07-08 10:25:30 -05:00 
		 
	
		
			
			
			
			
			
			2018-03-14 05:20:12 -04:00 
		 
	
		
			
			
			
			
			
			2022-06-27 10:42:29 -05:00 
		 
	
		
			
			
			
			
			
			2022-04-26 18:46:15 -05:00 
		 
	
		
			
			
			
			
			
			2021-06-24 08:21:35 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2020-09-15 14:37:21 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2018-10-19 17:33:05 -04:00 
		 
	
		
			
			
			
			
			
			2021-01-27 10:04:32 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2018-03-01 13:13:55 -06:00 
		 
	
		
			
			
			
			
			
			2018-03-01 13:13:55 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-15 09:58:12 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2020-11-03 15:32:33 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2020-01-02 15:51:37 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-20 12:40:01 -05:00 
		 
	
		
			
			
			
			
			
			2021-10-28 08:58:44 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2018-05-20 13:55:26 +02:00 
		 
	
		
	
		
			
			
			
			
			
			2022-06-02 12:20:23 -05:00 
		 
	
		
			
			
			
			
			
			2018-10-19 12:34:08 -04:00 
		 
	
		
			
			
			
			
			
			2020-10-12 10:50:26 -05:00 
		 
	
		
			
			
			
			
			
			2022-03-23 18:10:44 -05:00 
		 
	
		
			
			
			
			
			
			2022-03-24 12:01:32 -05:00 
		 
	
		
			
			
			
			
			
			2022-01-05 10:55:13 -06:00 
		 
	
		
			
			
			
			
			
			2022-01-05 11:39:48 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2022-01-05 10:55:13 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-19 09:42:19 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-20 09:48:12 -05:00 
		 
	
		
	
		
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2019-01-28 12:26:58 -07:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-30 13:20:16 -05:00 
		 
	
		
			
			
			
			
			
			2018-05-21 11:03:10 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2019-03-11 11:39:35 -03:00 
		 
	
		
			
			
			
			
			
			2022-06-27 10:42:29 -05:00 
		 
	
		
			
			
			
			
			
			2022-06-27 10:42:29 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-26 10:48:10 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
	
		
			
			
			
			
			
			2021-08-06 09:19:38 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-07-26 10:48:10 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-13 17:17:59 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2018-07-26 14:29:18 -05:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2019-03-11 11:39:35 -03:00 
		 
	
		
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-06-30 16:28:18 -05:00 
		 
	
		
			
			
			
			
			
			2022-01-21 10:05:48 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2019-03-11 11:39:35 -03:00 
		 
	
		
	
		
			
			
			
			
			
			2019-11-18 11:05:24 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
	
		
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2019-02-04 14:40:35 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-11-18 13:25:54 -06:00 
		 
	
		
			
			
			
			
			
			2019-03-11 11:39:35 -03:00 
		 
	
		
			
			
			
			
			
			2021-11-18 13:25:54 -06:00 
		 
	
		
			
			
			
			
			
			2022-05-19 21:28:32 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-13 09:00:04 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
			
			
			
			
			
			2018-12-07 08:59:00 -05:00 
		 
	
		
			
			
			
			
			
			2022-05-09 07:48:40 -05:00 
		 
	
		
			
			
			
			
			
			2019-03-11 11:39:35 -03:00 
		 
	
		
			
			
			
			
			
			2022-01-05 11:39:48 -06:00 
		 
	
		
			
			
			
			
			
			2020-05-08 13:44:08 -05:00 
		 
	
		
			
			
			
			
			
			2020-09-11 10:41:15 -06:00 
		 
	
		
			
			
			
			
			
			2018-03-13 16:24:06 -04:00 
		 
	
		
			
			
			
			
			
			2021-10-28 08:58:44 -05:00 
		 
	
		
			
			
			
			
			
			2022-05-09 08:21:58 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2022-02-14 16:18:40 -06:00 
		 
	
		
			
			
			
			
			
			2022-01-05 09:41:35 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-09-09 06:48:40 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 10:38:23 -06:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
			
			
			
			
			
			2022-03-24 12:01:32 -05:00 
		 
	
		
			
			
			
			
			
			2018-01-03 17:23:36 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06:00 
		 
	
		
			
			
			
			
			
			2017-12-22 09:23:22 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2020-07-28 09:45:17 -05:00 
		 
	
		
			
			
			
			
			
			2022-07-07 08:22:43 -05:00 
		 
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2022-07-07 08:22:43 -05:00 
		 
	
		
			
			
			
			
			
			2021-11-29 08:49:55 -06:00