|  | @@ -29,12 +29,14 @@ Daniel-Constantin Mierla
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          4. Exported Functions
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -              4.1. async_sleep(seconds)
 | 
	
		
			
				|  |  | +              4.1. async_route(routename, seconds)
 | 
	
		
			
				|  |  | +              4.2. async_sleep(seconds)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     List of Examples
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     1.1. Set workers parameter
 | 
	
		
			
				|  |  |     1.2. async_sleep usage
 | 
	
		
			
				|  |  | +   1.3. async_sleep usage
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Chapter 1. Admin Guide
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -52,7 +54,8 @@ Chapter 1. Admin Guide
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     4. Exported Functions
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        4.1. async_sleep(seconds)
 | 
	
		
			
				|  |  | +        4.1. async_route(routename, seconds)
 | 
	
		
			
				|  |  | +        4.2. async_sleep(seconds)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  1. Overview
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -101,9 +104,39 @@ modparam("async", "workers", 2)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  4. Exported Functions
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   4.1. async_sleep(seconds)
 | 
	
		
			
				|  |  | +   4.1. async_route(routename, seconds)
 | 
	
		
			
				|  |  | +   4.2. async_sleep(seconds)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -4.1. async_sleep(seconds)
 | 
	
		
			
				|  |  | +4.1. async_route(routename, seconds)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +   Simulate a sleep of 'seconds' and then continue the processing of SIP
 | 
	
		
			
				|  |  | +   request with the route[routename]. In case of internal errors, the
 | 
	
		
			
				|  |  | +   function returns false, otherwise the function exits the execution of
 | 
	
		
			
				|  |  | +   config at that moment (return 0 behaviour).
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +   The routename parameter can be a static string or a dynamic string
 | 
	
		
			
				|  |  | +   value with config variables.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +   The sleep parameter represent the number of seconds to suppend the
 | 
	
		
			
				|  |  | +   processing of SIP request. Maximum value is 100. The parameter can be a
 | 
	
		
			
				|  |  | +   static integer or a varaible holding an integer.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +   Since the SIP request handling is resumed in another process,
 | 
	
		
			
				|  |  | +   practically the config file execution state is lost. Therefore beware
 | 
	
		
			
				|  |  | +   that the execution of config after resume will end once the
 | 
	
		
			
				|  |  | +   route[routename] is finished.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +   Example 1.2. async_sleep usage
 | 
	
		
			
				|  |  | +...
 | 
	
		
			
				|  |  | +async_route("RESUME", "4");
 | 
	
		
			
				|  |  | +...
 | 
	
		
			
				|  |  | +route[RESUME] {
 | 
	
		
			
				|  |  | +   send_reply("404", "Not found");
 | 
	
		
			
				|  |  | +   exit;
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +...
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +4.2. async_sleep(seconds)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     Simulate a sleep of 'seconds' and then continue the processing of SIP
 | 
	
		
			
				|  |  |     request with the next action. In case of internal errors, the function
 | 
	
	
		
			
				|  | @@ -119,7 +152,7 @@ modparam("async", "workers", 2)
 | 
	
		
			
				|  |  |     that the execution of config after resume will end once the route block
 | 
	
		
			
				|  |  |     where async_sleep() is called is finished.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   Example 1.2. async_sleep usage
 | 
	
		
			
				|  |  | +   Example 1.3. async_sleep usage
 | 
	
		
			
				|  |  |  ...
 | 
	
		
			
				|  |  |  async_sleep("4");
 | 
	
		
			
				|  |  |  send_reply("404", "Not found");
 |