Conditionally install EPEL if needed
The current behavior of the hardening role is to install the epel-release package on all deployments. This patch changes the logic to only install the EPEL repository if the deployer has asked for ClamAV to be installed. The patch also provides an option to disable the installation of EPEL entirely using a variable. Closes-Bug: 1702167 Change-Id: I9c5e6048f95636faf2a6d71ac9217ba69ca41296
This commit is contained in:
		 Major Hayden
					Major Hayden
				
			
				
					committed by
					
						 Andy McCrae
						Andy McCrae
					
				
			
			
				
	
			
			
			 Andy McCrae
						Andy McCrae
					
				
			
						parent
						
							ff7d7668df
						
					
				
				
					commit
					a64c833a71
				
			| @@ -28,6 +28,12 @@ cache_timeout: 600 | |||||||
| # Options are 'present' and 'latest' | # Options are 'present' and 'latest' | ||||||
| security_package_state: present | security_package_state: present | ||||||
|  |  | ||||||
|  | ## EPEL | ||||||
|  | # Set the following variable to `no` to prevent the EPEL repository from being | ||||||
|  | # installed by the role. This may prevent certain packages from installing, | ||||||
|  | # such as ClamAV. | ||||||
|  | security_epel_install_repository: yes | ||||||
|  |  | ||||||
| ############################################################################### | ############################################################################### | ||||||
| #   ____  _   _ _____ _        __     ____ _____ ___ ____ | #   ____  _   _ _____ _        __     ____ _____ ___ ____ | ||||||
| #  |  _ \| | | | ____| |      / /_   / ___|_   _|_ _/ ___| | #  |  _ \| | | | ____| |      / /_   / ___|_   _|_ _/ ___| | ||||||
|   | |||||||
| @@ -18,3 +18,9 @@ variable: | |||||||
| .. code-block:: yaml | .. code-block:: yaml | ||||||
|  |  | ||||||
|     security_enable_virus_scanner: yes |     security_enable_virus_scanner: yes | ||||||
|  |  | ||||||
|  | .. warning:: | ||||||
|  |  | ||||||
|  |     The ClamAV packages are provided in the EPEL repository. Setting the | ||||||
|  |     ``security_enable_virus_scanner`` will also cause the EPEL repository to | ||||||
|  |     be installed by the role. | ||||||
|   | |||||||
| @@ -0,0 +1,16 @@ | |||||||
|  | --- | ||||||
|  | upgrade: | ||||||
|  |   - | | ||||||
|  |     The EPEL repository is only installed and configured when the deployer sets | ||||||
|  |     ``security_enable_virus_scanner`` to ``yes``. This allows the ClamAV | ||||||
|  |     packages to be installed. If ``security_enable_virus_scanner`` is set to | ||||||
|  |     ``no`` (the default), the EPEL repository will not be added. | ||||||
|  |  | ||||||
|  |     See | ||||||
|  |     `Bug 1702167 <https://bugs.launchpad.net/openstack-ansible/+bug/1702167>`_ | ||||||
|  |     for more details. | ||||||
|  |   - | | ||||||
|  |     Deployers now have the option to prevent the EPEL repository from being | ||||||
|  |     installed by the role. Setting ``security_epel_install_repository`` to | ||||||
|  |     ``no`` prevents EPEL from being installed. This setting may prevent certain | ||||||
|  |     packages from installing, such as ClamAV. | ||||||
| @@ -52,11 +52,4 @@ | |||||||
|     tags: |     tags: | ||||||
|       - always |       - always | ||||||
|  |  | ||||||
|   - name: Install EPEL repository |  | ||||||
|     yum: |  | ||||||
|       name: epel-release |  | ||||||
|       state: "{{ security_package_state }}" |  | ||||||
|     when: |  | ||||||
|       - ansible_pkg_mgr == 'yum' |  | ||||||
|  |  | ||||||
|   - include: "{{ stig_version }}stig/main.yml" |   - include: "{{ stig_version }}stig/main.yml" | ||||||
|   | |||||||
| @@ -13,6 +13,13 @@ | |||||||
| # See the License for the specific language governing permissions and | # See the License for the specific language governing permissions and | ||||||
| # limitations under the License. | # limitations under the License. | ||||||
|  |  | ||||||
|  |   - name: Install EPEL repository | ||||||
|  |     yum: | ||||||
|  |       name: epel-release | ||||||
|  |       state: "{{ security_package_state }}" | ||||||
|  |     when: | ||||||
|  |       - ansible_pkg_mgr == 'yum' | ||||||
|  |  | ||||||
|   - include: apt.yml |   - include: apt.yml | ||||||
|     static: no |     static: no | ||||||
|     when: ansible_pkg_mgr == 'apt' |     when: ansible_pkg_mgr == 'apt' | ||||||
|   | |||||||
| @@ -65,6 +65,19 @@ | |||||||
|   tags: |   tags: | ||||||
|     - always |     - always | ||||||
|  |  | ||||||
|  | # NOTE(mhayden): EPEL is only needed for the clamav packages. We should only | ||||||
|  | # install EPEL if the deployer asked for clamav to be installed. | ||||||
|  | - name: Install EPEL repository | ||||||
|  |   yum: | ||||||
|  |     name: epel-release | ||||||
|  |     state: "{{ security_package_state }}" | ||||||
|  |   when: | ||||||
|  |     - ansible_pkg_mgr == 'yum' | ||||||
|  |     - security_epel_install_repository | bool | ||||||
|  |     - security_enable_virus_scanner | bool | ||||||
|  |   tags: | ||||||
|  |     - always | ||||||
|  |  | ||||||
| # Package installations and removals must come first so that configuration | # Package installations and removals must come first so that configuration | ||||||
| # changes can be made later. | # changes can be made later. | ||||||
| - include: packages.yml | - include: packages.yml | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user