mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 14:06:27 +00:00 
			
		
		
		
	sip_to_pjsip: Write local_net, contact_acl, contact_deny, and contact_permit.
When using the migration script sip_to_pjsip.py, those keys got missing. These keys might appear several times and the function "merge_value" tried to collect those. However, because these keys have different names in sip.conf and pjsip.conf, "merge_value" was not able to find the new key name in sip.conf. This change lets "merge_value" search with the old key name in sip.conf and write with the new key name in pjsip.conf. ASTERISK-22374 Change-Id: Ie53c5278ae6f1cb8fa7e96c5289877d46981d9d2
This commit is contained in:
		| @@ -54,10 +54,11 @@ def set_value(key=None, val=None, section=None, pjsip=None, | |||||||
|  |  | ||||||
|  |  | ||||||
| def merge_value(key=None, val=None, section=None, pjsip=None, | def merge_value(key=None, val=None, section=None, pjsip=None, | ||||||
|                 nmapped=None, type='endpoint', section_to=None): |                 nmapped=None, type='endpoint', section_to=None, | ||||||
|  |                 key_to=None): | ||||||
|     """Merge values from the given section with those from the default.""" |     """Merge values from the given section with those from the default.""" | ||||||
|     def _merge_value(k, v, s, r, n): |     def _merge_value(k, v, s, r, n): | ||||||
|         merge_value(key if key else k, v, s, r, n, type, section_to) |         merge_value(key if key else k, v, s, r, n, type, section_to, key_to) | ||||||
|  |  | ||||||
|     # if no value or section return the merge_value |     # if no value or section return the merge_value | ||||||
|     # function with the enclosed key and type |     # function with the enclosed key and type | ||||||
| @@ -71,7 +72,8 @@ def merge_value(key=None, val=None, section=None, pjsip=None, | |||||||
|         sect = sip.default(section)[0] |         sect = sip.default(section)[0] | ||||||
|     # for each merged value add it to pjsip.conf |     # for each merged value add it to pjsip.conf | ||||||
|     for i in sect.get_merged(key): |     for i in sect.get_merged(key): | ||||||
|         set_value(key, i, section_to if section_to else section, |         set_value(key_to if key_to else key, i, | ||||||
|  |                   section_to if section_to else section, | ||||||
|                   pjsip, nmapped, type) |                   pjsip, nmapped, type) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -454,9 +456,9 @@ peer_map = [ | |||||||
|     ['permit',             merge_value(type='acl', section_to='acl')], |     ['permit',             merge_value(type='acl', section_to='acl')], | ||||||
|     ['deny',               merge_value(type='acl', section_to='acl')], |     ['deny',               merge_value(type='acl', section_to='acl')], | ||||||
|     ['acl',                merge_value(type='acl', section_to='acl')], |     ['acl',                merge_value(type='acl', section_to='acl')], | ||||||
|     ['contactpermit',      merge_value('contact_permit', type='acl', section_to='acl')], |     ['contactpermit',      merge_value(type='acl', section_to='acl', key_to='contact_permit')], | ||||||
|     ['contactdeny',        merge_value('contact_deny', type='acl', section_to='acl')], |     ['contactdeny',        merge_value(type='acl', section_to='acl', key_to='contact_deny')], | ||||||
|     ['contactacl',         merge_value('contact_acl', type='acl', section_to='acl')], |     ['contactacl',         merge_value(type='acl', section_to='acl', key_to='contact_acl')], | ||||||
|  |  | ||||||
| ########################### maps to transport ################################# | ########################### maps to transport ################################# | ||||||
| #        type = transport | #        type = transport | ||||||
| @@ -499,21 +501,6 @@ peer_map = [ | |||||||
| ] | ] | ||||||
|  |  | ||||||
|  |  | ||||||
| def add_localnet(section, pjsip, nmapped): |  | ||||||
|     """ |  | ||||||
|     Adds localnet values from sip.conf's general section to a transport in |  | ||||||
|     pjsip.conf. Ideally, we would have just created a template with the |  | ||||||
|     localnet sections, but because this is a script, it's not hard to add |  | ||||||
|     the same thing on to every transport. |  | ||||||
|     """ |  | ||||||
|     try: |  | ||||||
|         merge_value('local_net', sip.get('general', 'localnet')[0], 'general', |  | ||||||
|                     pjsip, nmapped, 'transport', section) |  | ||||||
|     except LookupError: |  | ||||||
|         # No localnet options configured. No biggie! |  | ||||||
|         pass |  | ||||||
|  |  | ||||||
|  |  | ||||||
| def set_transport_common(section, pjsip, nmapped): | def set_transport_common(section, pjsip, nmapped): | ||||||
|     """ |     """ | ||||||
|     sip.conf has several global settings that in pjsip.conf apply to individual |     sip.conf has several global settings that in pjsip.conf apply to individual | ||||||
| @@ -527,8 +514,8 @@ def set_transport_common(section, pjsip, nmapped): | |||||||
|     """ |     """ | ||||||
|  |  | ||||||
|     try: |     try: | ||||||
|         merge_value('local_net', sip.get('general', 'localnet')[0], 'general', |         merge_value('localnet', sip.get('general', 'localnet')[0], 'general', | ||||||
|                     pjsip, nmapped, 'transport', section) |                     pjsip, nmapped, 'transport', section, "local_net") | ||||||
|     except LookupError: |     except LookupError: | ||||||
|         # No localnet options configured. Move on. |         # No localnet options configured. Move on. | ||||||
|         pass |         pass | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user