Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Firewall technology related rules per service and package change logic according to interactive profile variable #11818

Conversation

teacup-on-rockingchair
Copy link
Contributor

@teacup-on-rockingchair teacup-on-rockingchair commented Apr 14, 2024

Description:

  • Make sure that behaviour of rules about nftables,iptables and firewalld are mutually exclusive and the default behaviour of the checks and remediations is based on external interactive variable, that is part of the profile definition

Rationale:

  • Add oval macro to check external variable vs expected value
  • Add variable to set default firewall technology used
  • Set relevant values for SLE platforms
  • Templates for pkg installed/removed and svc enabled/disabled, guarded by ext varaiable
  • The idea is the oval checks and remediation to check provided external variable, and thus honour if really to check/install/remove certain package or service
  • Enable nftable service on SLE only if active firewall technology is set to be nftables
  • Disable nftable service on SLE only if active firewall technology is set to be firewalld or iptables
  • Removing nftable package on SLE makes sense only if active firewall technology is set to be firewalld or iptables
  • Installing iptables package on SLE only if active firewall technology is set to be iptables
  • Enable iptables service on SLE only if active firewall technology is set to be iptables
  • Disable firewalld service on SLE only if active firewall technology is set to be nftables or iptables
  • Removing package on SLE makes sense only if active firewall technology is set to be nftables or iptables
  • Enable firewalld service on SLE only if active firewall technology is set to be firewalld
  • Installing firewalld package on SLE only if active firewall technology is set to be firewalld

Review Hints:

  • For now the proposed change is applied to SLE platforms only, and if proves to be a good approach can distribute to other platforms also
  • The use case would be that the user will have in its profile defined default firewall technology, one of iptables,nftables,ufw, firewalld ,and if the system has been modified a non-default option for that, one can use scap-workbench or similar tool, or define a new alternative profile to the original one (CIS is currently the one having conflicting rules ) , or via command line arguments of the oscap tool, if that is the weapon of choice to run checks and remediations.

@teacup-on-rockingchair teacup-on-rockingchair added Ansible Ansible remediation update. OVAL OVAL update. Related to the systems assessments. Bash Bash remediation update. SLES SUSE Linux Enterprise Server product related. New Template Issues or pull requests related to new Templates. labels Apr 14, 2024
@openshift-ci openshift-ci bot added the do-not-merge/work-in-progress Used by openshift-ci bot. label Apr 14, 2024
Copy link

openshift-ci bot commented Apr 14, 2024

Skipping CI for Draft Pull Request.
If you want CI signal for your change, please convert it to an actual PR.
You can still manually trigger a test run with /test all

Copy link

Start a new ephemeral environment with changes proposed in this pull request:

rhel8 (from CTF) Environment (using Fedora as testing environment)
Open in Gitpod

Fedora Testing Environment
Open in Gitpod

Oracle Linux 8 Environment
Open in Gitpod

Copy link

github-actions bot commented Apr 14, 2024

🤖 A k8s content image for this PR is available at:
ghcr.io/complianceascode/k8scontent:11818
This image was built from commit: f2480f3

Click here to see how to deploy it

If you alread have Compliance Operator deployed:
utils/build_ds_container.py -i ghcr.io/complianceascode/k8scontent:11818

Otherwise deploy the content and operator together by checking out ComplianceAsCode/compliance-operator and:
CONTENT_IMAGE=ghcr.io/complianceascode/k8scontent:11818 make deploy-local

@jan-cerny jan-cerny changed the title Firewall technology related rules per service and package change logic accprding to interactive profile variable Firewall technology related rules per service and package change logic according to interactive profile variable Apr 15, 2024
@teacup-on-rockingchair teacup-on-rockingchair marked this pull request as ready for review April 15, 2024 15:30
@teacup-on-rockingchair teacup-on-rockingchair requested a review from a team as a code owner April 15, 2024 15:30
@openshift-ci openshift-ci bot removed the do-not-merge/work-in-progress Used by openshift-ci bot. label Apr 15, 2024
@teacup-on-rockingchair teacup-on-rockingchair marked this pull request as draft April 16, 2024 14:29
@openshift-ci openshift-ci bot added the do-not-merge/work-in-progress Used by openshift-ci bot. label Apr 16, 2024
@teacup-on-rockingchair teacup-on-rockingchair marked this pull request as ready for review April 22, 2024 12:22
@openshift-ci openshift-ci bot removed the do-not-merge/work-in-progress Used by openshift-ci bot. label Apr 22, 2024
@teacup-on-rockingchair
Copy link
Contributor Author

/test all

@teacup-on-rockingchair teacup-on-rockingchair added this to the 0.1.73 milestone Apr 30, 2024
@vojtapolasek vojtapolasek modified the milestones: 0.1.73, 0.1.74 Apr 30, 2024
@marcusburghardt
Copy link
Member

/packit build

@teacup-on-rockingchair teacup-on-rockingchair force-pushed the firewall_by_profile_variable branch from 6188277 to fc100a9 Compare May 2, 2024 10:49
@openshift-merge-robot openshift-merge-robot added the needs-rebase Used by openshift-ci bot. label May 9, 2024
@dodys
Copy link
Contributor

dodys commented May 10, 2024

should we change this pr to work across different vendors?
@marcusburghardt @Mab879 @Xeicker

@Xeicker
Copy link
Contributor

Xeicker commented May 16, 2024

should we change this pr to work across different vendors? @marcusburghardt @Mab879 @Xeicker

For the moment it is not necessary for Oracle Linux

@teacup-on-rockingchair teacup-on-rockingchair force-pushed the firewall_by_profile_variable branch from fc100a9 to 87ba124 Compare May 21, 2024 03:40
@openshift-merge-robot openshift-merge-robot removed the needs-rebase Used by openshift-ci bot. label May 21, 2024
@marcusburghardt marcusburghardt self-assigned this May 31, 2024
@Mab879 Mab879 removed this from the 0.1.74 milestone Jul 29, 2024
@marcusburghardt marcusburghardt removed their assignment Jan 10, 2025
@marcusburghardt
Copy link
Member

I removed myself as assignee as, unfortunately, I won't be able to review/test it again for the next few weeks.

Copy link
Member

@Mab879 Mab879 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, for the late review.

Hopefully we can get this moving along again.

@Mab879 Mab879 self-assigned this Jan 17, 2025
Copy link

codeclimate bot commented Jan 21, 2025

Code Climate has analyzed commit 8f0fdfe and detected 6 issues on this pull request.

Here's the issue category breakdown:

Category Count
Duplication 6

The test coverage on the diff in this pull request is 100.0% (50% is the threshold).

This pull request will bring the total coverage in the repository to 61.9% (0.0% change).

View more on Code Climate.

Copy link
Member

@Mab879 Mab879 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Waving the Automatus Tests as they pass locally.

Waving the Code Climate issues as I don't think they are worth solving.

Overriding CODEOWNERS since @teacup-on-rockingchair cannot merge his own PRs.

Thanks @teacup-on-rockingchair working on this for all this time.

@Mab879 Mab879 merged commit 4016027 into ComplianceAsCode:master Jan 21, 2025
103 of 109 checks passed
{{{ bash_instantiate_variables(VARIABLE) }}}

{{% if OPERATION == "pattern match" %}}
if [[ "{{{ VALUE }}}" =~ ${{{ VARIABLE }}} ]]; then
Copy link
Contributor

@mpurg mpurg Jan 24, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@teacup-on-rockingchair I think the operation here should be flipped.
The implementation searches for VARIABLE regex inside VALUE, instead of searching for VALUE regex in VARIABLE.
If VALUE=firewalld|nftables, then it will match when VARIABLE is set to any substring of VALUE, or an empty string, or regex special characters like ..

mpurg added a commit to mpurg/ComplianceAsCode that referenced this pull request Jan 27, 2025
This change modifies the firewall package/service rules to use the templates
`..._guard_var` introduced in ComplianceAsCode#11818 to selectively install the firewall
that is chosen by the var_network_filtering_service

It also fixes the platform applicability on Ubuntu 24.04 since it
both required firewalld and required that conflicting services
be disabled when installing packages. This interfered with the
logic introduced in the new templates and could result in a
package/service not be installed/enabled.

For example, if the user selected 'nftables' as their firewall
using the new template and variable, the rule package_nftables_installed
would still be marked as not applicable because the ufw service is enabled
by default on some installations. The proposed solution removes the
applicability check and installs the package depending only on the choice of
var_network_filtering_service, irrespective of the status of the ufw service.
mpurg added a commit to mpurg/ComplianceAsCode that referenced this pull request Jan 27, 2025
The variable is used to select the desired timesync service
(systemd-timesync vs chrony) in package/service install/enable
rules when using _guard_var templates.

Analogous to var_network_filtering_service introduced in ComplianceAsCode#11818
mpurg added a commit to mpurg/ComplianceAsCode that referenced this pull request Jan 27, 2025
The variable is used to select the desired timesync service
(systemd-timesync vs chrony) in package/service install/enable
rules when using _guard_var templates.

Analogous to var_network_filtering_service introduced in ComplianceAsCode#11818
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Ansible Ansible remediation update. Bash Bash remediation update. New Template Issues or pull requests related to new Templates. OVAL OVAL update. Related to the systems assessments. SLES SUSE Linux Enterprise Server product related.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants