Skip to content
This repository has been archived by the owner on Dec 31, 2024. It is now read-only.

Commit

Permalink
add option to enable FIPS on the NSS DB.
Browse files Browse the repository at this point in the history
  • Loading branch information
itewk committed Jun 17, 2014
1 parent 91e5c91 commit 602fae0
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 7 deletions.
10 changes: 9 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@ nsstools::create { '/etc/dirsrv/slapd-ldap1':
mode => '0660',
password => 'example',
manage_certdir => false,
enable_fips => false,
}
nsstools::add_cert_and_key{ 'Server-Cert':
Expand Down Expand Up @@ -128,7 +129,8 @@ nsstools::create { <title>:
group => undef,
mode => '0600',
certdir_mode => '0700',
manage_certdir => true
manage_certdir => true,
enable_fips => false,
}
```

Expand Down Expand Up @@ -175,6 +177,12 @@ nsstools::create { <title>:

`String` Defaults to: `0700`

* `enable_fips`

`Boolean` Defaults to: `true`

If `true` enables FIPS compliance mode on the NSS DB.

### `add_cert`

Insert a certificate into an existing NSS database.
Expand Down
27 changes: 21 additions & 6 deletions manifests/create.pp
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
# $mode - optional - defaults to '0600'
# $certdir_mode - optional - defaults to '0700'
# $manage_certdir - optional - defaults to true
# $enable_fips - optional - defaults to false
#
# Actions:
# creates a new NSS database, consisting of 4 files:
Expand All @@ -25,7 +26,8 @@
# group => 'root',
# mode => '0600',
# certdir_mode => '0700',
# manage_certdir => true
# manage_certdir => true,
# enable_fips => false,
# }
#
#
Expand All @@ -36,7 +38,8 @@
$group = undef,
$mode = '0600',
$certdir_mode = '0700',
$manage_certdir = true
$manage_certdir = true,
$enable_fips = false,
) {
include nsstools

Expand All @@ -47,6 +50,7 @@
validate_string($mode)
validate_string($certdir_mode)
validate_bool($manage_certdir)
validate_bool($enable_fips)

if $manage_certdir {
file { $certdir:
Expand All @@ -62,7 +66,8 @@
$require_certdir = undef
}

file { "${certdir}/nss-password.txt":
$_password_file = "${certdir}/nss-password.txt"
file { $_password_file:
ensure => file,
owner => $owner,
group => $group,
Expand All @@ -81,17 +86,27 @@
group => $group,
mode => $mode,
require => [
File["${certdir}/nss-password.txt"],
File[$_password_file],
Exec["create_nss_db_${title}"],
],
}

exec { "create_nss_db_${title}":
command => "/usr/bin/certutil -N -d ${certdir} -f ${certdir}/nss-password.txt",
command => "/usr/bin/certutil -N -d ${certdir} -f ${_password_file}",
creates => ["${certdir}/cert8.db", "${certdir}/key3.db", "${certdir}/secmod.db"],
require => [
File["${certdir}/nss-password.txt"],
File[$_password_file],
Class['nsstools'],
]
}

if $enable_fips {
# enable fips mode on the NSS DB after DB creation
exec { "enable_fips_mode_${title}":
command => "/usr/bin/modutil -fips true -dbdir ${certdir} -force",
unless => "/usr/bin/modutil -chkfips true -dbdir ${certdir}",
subscribe => [Exec["create_nss_db_${title}"],],
refreshonly => true,
}
}
}

0 comments on commit 602fae0

Please sign in to comment.