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 
		 
	
		
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
	
		
			
			
			
			
			
			2020-05-05 10:06:43 -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 
		 
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
			
			
			
			
			
			2022-01-05 10:55:13 -06: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 
		 
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
			
			
			
			
			
			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 
		 
	
		
	
		
			
			
			
			
			
			2022-03-24 12:01:32 -05:00 
		 
	
		
	
		
			
			
			
			
			
			2021-12-02 15:02:42 -06:00 
		 
	
		
			
			
			
			
			
			2021-11-15 15:28:45 -06: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