mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 13:56:09 -07:00 
			
		
		
		
	kernel_blacklist: bugfix (#7382)
* kernel_blacklist: bugfix
* add fix + changelog frag
* skip aix,freebsd,macos,osx in integration test
* Update changelogs/fragments/7382-kernel-blacklist-bugfix.yml
Co-authored-by: Felix Fontein <felix@fontein.de>
---------
Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit 33133f3ba9)
Co-authored-by: Alexei Znamensky <103110+russoz@users.noreply.github.com>
		
	
			
		
			
				
	
	
		
			119 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/python
 | |
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| # Copyright (c) 2021, Alexei Znamensky (@russoz) <russoz@gmail.com>
 | |
| # Copyright (c) 2013, Matthias Vogelgesang <matthias.vogelgesang@gmail.com>
 | |
| # GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| # SPDX-License-Identifier: GPL-3.0-or-later
 | |
| 
 | |
| from __future__ import absolute_import, division, print_function
 | |
| __metaclass__ = type
 | |
| 
 | |
| DOCUMENTATION = '''
 | |
| ---
 | |
| module: kernel_blacklist
 | |
| author:
 | |
|     - Matthias Vogelgesang (@matze)
 | |
| short_description: Blacklist kernel modules
 | |
| description:
 | |
|     - Add or remove kernel modules from blacklist.
 | |
| extends_documentation_fragment:
 | |
|     - community.general.attributes
 | |
| attributes:
 | |
|     check_mode:
 | |
|         support: full
 | |
|     diff_mode:
 | |
|         support: full
 | |
| options:
 | |
|     name:
 | |
|         type: str
 | |
|         description:
 | |
|             - Name of kernel module to black- or whitelist.
 | |
|         required: true
 | |
|     state:
 | |
|         type: str
 | |
|         description:
 | |
|             - Whether the module should be present in the blacklist or absent.
 | |
|         choices: [ absent, present ]
 | |
|         default: present
 | |
|     blacklist_file:
 | |
|         type: str
 | |
|         description:
 | |
|             - If specified, use this blacklist file instead of
 | |
|               C(/etc/modprobe.d/blacklist-ansible.conf).
 | |
|         default: /etc/modprobe.d/blacklist-ansible.conf
 | |
| '''
 | |
| 
 | |
| EXAMPLES = '''
 | |
| - name: Blacklist the nouveau driver module
 | |
|   community.general.kernel_blacklist:
 | |
|     name: nouveau
 | |
|     state: present
 | |
| '''
 | |
| 
 | |
| import os
 | |
| import re
 | |
| 
 | |
| from ansible_collections.community.general.plugins.module_utils.module_helper import StateModuleHelper
 | |
| 
 | |
| 
 | |
| class Blacklist(StateModuleHelper):
 | |
|     output_params = ('name', 'state')
 | |
|     module = dict(
 | |
|         argument_spec=dict(
 | |
|             name=dict(type='str', required=True),
 | |
|             state=dict(type='str', default='present', choices=['absent', 'present']),
 | |
|             blacklist_file=dict(type='str', default='/etc/modprobe.d/blacklist-ansible.conf'),
 | |
|         ),
 | |
|         supports_check_mode=True,
 | |
|     )
 | |
| 
 | |
|     def __init_module__(self):
 | |
|         self.pattern = re.compile(r'^blacklist\s+{0}$'.format(re.escape(self.vars.name)))
 | |
|         self.vars.filename = self.vars.blacklist_file
 | |
|         self.vars.set('file_exists', os.path.exists(self.vars.filename), output=False, change=True)
 | |
|         if not self.vars.file_exists:
 | |
|             with open(self.vars.filename, 'a'):
 | |
|                 pass
 | |
|             self.vars.file_exists = True
 | |
|             self.vars.set('lines', [], change=True, diff=True)
 | |
|         else:
 | |
|             with open(self.vars.filename) as fd:
 | |
|                 self.vars.set('lines', [x.rstrip() for x in fd.readlines()], change=True, diff=True)
 | |
|         self.vars.set('is_blacklisted', self._is_module_blocked(), change=True)
 | |
| 
 | |
|     def _is_module_blocked(self):
 | |
|         for line in self.vars.lines:
 | |
|             stripped = line.strip()
 | |
|             if stripped.startswith('#'):
 | |
|                 continue
 | |
|             if self.pattern.match(stripped):
 | |
|                 return True
 | |
|         return False
 | |
| 
 | |
|     def state_absent(self):
 | |
|         if not self.vars.is_blacklisted:
 | |
|             return
 | |
|         self.vars.is_blacklisted = False
 | |
|         self.vars.lines = [line for line in self.vars.lines if not self.pattern.match(line.strip())]
 | |
| 
 | |
|     def state_present(self):
 | |
|         if self.vars.is_blacklisted:
 | |
|             return
 | |
|         self.vars.is_blacklisted = True
 | |
|         self.vars.lines = self.vars.lines + ['blacklist %s' % self.vars.name]
 | |
| 
 | |
|     def __quit_module__(self):
 | |
|         if self.has_changed() and not self.module.check_mode:
 | |
|             bkp = self.module.backup_local(self.vars.filename)
 | |
|             with open(self.vars.filename, "w") as fd:
 | |
|                 fd.writelines(["{0}\n".format(x) for x in self.vars.lines])
 | |
|             self.module.add_cleanup_file(bkp)
 | |
| 
 | |
| 
 | |
| def main():
 | |
|     Blacklist.execute()
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     main()
 |