mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 21:14:00 -07:00 
			
		
		
		
	[PR #9106/105ae056 backport][stable-9] bugfix - Prevent passwordstore lookup to create subkey when create == false (#9779)
bugfix - Prevent passwordstore lookup to create subkey when create == false (#9106)
Fixes #9105
Apply suggestion
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit 105ae0566a)
Co-authored-by: Manuel Luzarreta <mluzarreta.pro@pm.me>
	
	
This commit is contained in:
		
					parent
					
						
							
								1a0a44d179
							
						
					
				
			
			
				commit
				
					
						382c0a4af6
					
				
			
		
					 2 changed files with 10 additions and 4 deletions
				
			
		|  | @ -0,0 +1,2 @@ | |||
| bugfixes: | ||||
|   - passwordstore lookup plugin - fix subkey creation even when ``create=false`` (https://github.com/ansible-collections/community.general/issues/9105, https://github.com/ansible-collections/community.general/pull/9106). | ||||
|  | @ -578,16 +578,20 @@ class LookupModule(LookupBase): | |||
|         for term in terms: | ||||
|             self.parse_params(term)   # parse the input into paramvals | ||||
|             with self.opt_lock('readwrite'): | ||||
|                 if self.check_pass():     # password exists | ||||
|                     if self.paramvals['overwrite']: | ||||
|                 if self.check_pass():     # password file exists | ||||
|                     if self.paramvals['overwrite']:  # if "overwrite", always update password | ||||
|                         with self.opt_lock('write'): | ||||
|                             result.append(self.update_password()) | ||||
|                     elif self.paramvals["subkey"] != "password" and not self.passdict.get(self.paramvals['subkey']):  # password exists but not the subkey | ||||
|                     elif ( | ||||
|                         self.paramvals["subkey"] != "password" | ||||
|                         and not self.passdict.get(self.paramvals["subkey"]) | ||||
|                         and self.paramvals["missing"] == "create" | ||||
|                     ):  # target is a subkey, this subkey is not in passdict BUT missing == create | ||||
|                         with self.opt_lock('write'): | ||||
|                             result.append(self.update_password()) | ||||
|                     else: | ||||
|                         result.append(self.get_passresult()) | ||||
|                 else:                     # password does not exist | ||||
|                 else:  # password does not exist | ||||
|                     if self.paramvals['missing'] == 'create': | ||||
|                         with self.opt_lock('write'): | ||||
|                             if self.locked == 'write' and self.check_pass():  # lookup password again if under write lock | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue