-
Notifications
You must be signed in to change notification settings - Fork 706
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add new rule system_boot_in_fips_mode
- Loading branch information
Showing
9 changed files
with
95 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
30 changes: 30 additions & 0 deletions
30
linux_os/guide/system/software/integrity/fips/system_boot_in_fips_mode/oval/shared.xml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
<def-group> | ||
<definition class="compliance" id="{{{ rule_id }}}" version="1"> | ||
{{{ oval_metadata("The system must be booted with fips=1 and /proc/cmdline must not contain fips=0") }}} | ||
<criteria operator="AND"> | ||
<criterion comment="FIPS mode is enabled" test_ref="test_{{{ rule_id }}}_mode_exists" /> | ||
<criterion comment="FIPS mode is not disabled" test_ref="test_{{{ rule_id }}}_not_disabled" /> | ||
</criteria> | ||
</definition> | ||
|
||
<ind:textfilecontent54_test check="all" check_existence="all_exist" comment="FIPS mode is enabled" id="test_{{{ rule_id }}}_mode_exists" version="1"> | ||
<ind:object object_ref="obj_{{{ rule_id }}}_mode_exists" /> | ||
</ind:textfilecontent54_test> | ||
|
||
<ind:textfilecontent54_test check="all" check_existence="none_exist" id="test_{{{ rule_id }}}_not_disabled" version="1" comment="FIPS mode isn't disable"> | ||
<ind:object object_ref="obj_{{{ rule_id }}}_not_disabled" /> | ||
</ind:textfilecontent54_test> | ||
|
||
<ind:textfilecontent54_object id="obj_{{{ rule_id }}}_mode_exists" version="1"> | ||
<ind:filepath>/proc/cmdline</ind:filepath> | ||
<ind:pattern operation="pattern match">.+fips*=1.+</ind:pattern> | ||
<ind:instance datatype="int">1</ind:instance> | ||
</ind:textfilecontent54_object> | ||
|
||
<ind:textfilecontent54_object id="obj_{{{ rule_id }}}_not_disabled" version="1"> | ||
<ind:filepath>/proc/cmdline</ind:filepath> | ||
<ind:pattern operation="pattern match">.+fips*=0.+</ind:pattern> | ||
<ind:instance datatype="int">1</ind:instance> | ||
</ind:textfilecontent54_object> | ||
|
||
</def-group> |
55 changes: 55 additions & 0 deletions
55
linux_os/guide/system/software/integrity/fips/system_boot_in_fips_mode/rule.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
documentation_complete: true | ||
|
||
title: 'Verify that the system was booted with fips=1' | ||
|
||
description: |- | ||
On a system where FIPS 14032 mode is enabled, the system must be booted with the | ||
<tt>fips=1</tt> kernel argument. | ||
To verify FIPS mode, run the following command: | ||
<pre>cat /proc/cmdline</pre> | ||
rationale: |- | ||
Use of weak or untested encryption algorithms undermines the purposes of utilizing encryption to | ||
protect data. The operating system must implement cryptographic modules adhering to the higher | ||
standards approved by the federal government since this provides assurance they have been tested | ||
and validated. | ||
severity: high | ||
|
||
identifiers: | ||
cce@rhel10: CCE-86247-4 | ||
|
||
references: | ||
disa: CCI-002450 | ||
nist: SC-12(2),SC-12(3),SC-13 | ||
srg: SRG-OS-000396-GPOS-00176,SRG-OS-000478-GPOS-00223 | ||
|
||
ocil_clause: 'thee system is not booted with fips=1' | ||
|
||
ocil: |- | ||
To verify that system is booted with <tt>fips=1</tt> run the following command: | ||
$ cat /proc/cmdline | ||
The output must contain <tt>fips=1</tt> | ||
warnings: | ||
- general: |- | ||
To configure the OS to run in FIPS 140-3 mode, the kernel parameter "fips=1" needs to be added during its installation. | ||
Enabling FIPS mode on a preexisting system involves a number of modifications to it and therefore is not supported. | ||
- regulatory: |- | ||
System Crypto Modules must be provided by a vendor that undergoes | ||
FIPS-140 certifications. | ||
FIPS-140 is applicable to all Federal agencies that use | ||
cryptographic-based security systems to protect sensitive information | ||
in computer and telecommunication systems (including voice systems) as | ||
defined in Section 5131 of the Information Technology Management Reform | ||
Act of 1996, Public Law 104-106. This standard shall be used in | ||
designing and implementing cryptographic modules that Federal | ||
departments and agencies operate or are operated for them under | ||
contract. See <b>{{{ weblink(link="https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.140-3.pdf") }}}</b> | ||
To meet this, the system has to have cryptographic software provided by | ||
a vendor that has undergone this certification. This means providing | ||
documentation, test results, design information, and independent third | ||
party review by an accredited lab. While open source software is | ||
capable of meeting this, it does not meet FIPS-140 unless the vendor | ||
submits to this process. |
3 changes: 3 additions & 0 deletions
3
linux_os/guide/system/software/integrity/fips/system_boot_in_fips_mode/tests/default.pass.sh
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
#!/bin/bash | ||
|
||
echo '' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters