2021-05-24 20:06:00 +08:00
|
|
|
#! /usr/bin/env perl
|
2023-09-07 16:59:15 +08:00
|
|
|
# Copyright 2021-2023 The OpenSSL Project Authors. All Rights Reserved.
|
2021-05-24 20:06:00 +08:00
|
|
|
#
|
|
|
|
# Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
|
|
# this file except in compliance with the License. You can obtain a copy
|
|
|
|
# in the file LICENSE in the source distribution or at
|
|
|
|
# https://www.openssl.org/source/license.html
|
|
|
|
|
|
|
|
use Getopt::Long;
|
|
|
|
|
2023-04-18 09:11:17 +08:00
|
|
|
# Module options for pedantic FIPS mode
|
|
|
|
# self_test_onload happens if install_mac isn't included, don't add it below
|
2021-05-24 20:06:00 +08:00
|
|
|
my $conditional_errors = 1;
|
|
|
|
my $security_checks = 1;
|
2023-07-05 17:02:02 +08:00
|
|
|
my $ems_check = 1;
|
2024-07-17 08:35:37 +08:00
|
|
|
my $no_short_mac = 1;
|
2024-07-31 12:56:44 +08:00
|
|
|
my $key_check = 1;
|
2023-07-05 17:02:02 +08:00
|
|
|
my $drgb_no_trunc_dgst = 1;
|
2024-07-29 10:42:58 +08:00
|
|
|
my $digest_check = 1;
|
2024-07-04 09:59:43 +08:00
|
|
|
my $dsa_sign_disabled = 1;
|
2024-07-22 15:24:53 +08:00
|
|
|
my $tdes_encrypt_disabled = 1;
|
2024-08-01 11:45:08 +08:00
|
|
|
my $pkcs15_pad_disable = 1;
|
2024-08-07 10:24:36 +08:00
|
|
|
my $rsa_pss_saltlen_check = 1;
|
2024-07-29 08:16:30 +08:00
|
|
|
my $rsa_sign_x931_pad_disabled = 1;
|
2024-06-02 19:34:13 +08:00
|
|
|
my $kdf_key_check = 1;
|
2024-07-26 15:28:51 +08:00
|
|
|
my $pbkdf2_lower_bound_check = 1;
|
2024-08-08 14:56:22 +08:00
|
|
|
my $ec_cofactor_check = 1;
|
2023-04-18 09:11:17 +08:00
|
|
|
|
|
|
|
my $activate = 1;
|
2024-07-04 09:59:43 +08:00
|
|
|
my $version = 1;
|
2021-05-24 20:06:00 +08:00
|
|
|
my $mac_key;
|
|
|
|
my $module_name;
|
|
|
|
my $section_name = "fips_sect";
|
|
|
|
|
|
|
|
GetOptions("key=s" => \$mac_key,
|
|
|
|
"module=s" => \$module_name,
|
|
|
|
"section_name=s" => \$section_name)
|
|
|
|
or die "Error when getting command line arguments";
|
|
|
|
|
|
|
|
my $mac_keylen = length($mac_key);
|
|
|
|
|
|
|
|
use Digest::SHA qw(hmac_sha256_hex);
|
|
|
|
my $module_size = [ stat($module_name) ]->[7];
|
|
|
|
|
|
|
|
open my $fh, "<:raw", $module_name or die "Trying to open $module_name: $!";
|
|
|
|
read $fh, my $data, $module_size or die "Trying to read $module_name: $!";
|
|
|
|
close $fh;
|
|
|
|
|
|
|
|
# Calculate HMAC-SHA256 in hex, and split it into a list of two character
|
|
|
|
# chunks, and join the chunks with colons.
|
|
|
|
my @module_mac
|
|
|
|
= ( uc(hmac_sha256_hex($data, pack("H$mac_keylen", $mac_key))) =~ m/../g );
|
|
|
|
my $module_mac = join(':', @module_mac);
|
|
|
|
|
|
|
|
print <<_____;
|
|
|
|
[$section_name]
|
|
|
|
activate = $activate
|
2024-07-04 09:59:43 +08:00
|
|
|
install-version = $version
|
2021-05-24 20:06:00 +08:00
|
|
|
conditional-errors = $conditional_errors
|
|
|
|
security-checks = $security_checks
|
2024-07-22 15:24:53 +08:00
|
|
|
module-mac = $module_mac
|
2023-06-30 09:03:56 +08:00
|
|
|
tls1-prf-ems-check = $ems_check
|
2024-07-17 08:35:37 +08:00
|
|
|
no-short-mac = $no_short_mac
|
2024-07-31 12:56:44 +08:00
|
|
|
hmac-key-check = $key_check
|
2023-06-30 09:03:56 +08:00
|
|
|
drbg-no-trunc-md = $drgb_no_trunc_dgst
|
2024-07-29 10:42:58 +08:00
|
|
|
signature-digest-check = $digest_check
|
2024-07-04 09:59:43 +08:00
|
|
|
dsa-sign-disabled = $dsa_sign_disabled
|
2024-07-29 10:42:58 +08:00
|
|
|
hkdf-digest-check = $digest_check
|
|
|
|
tls13-kdf-digest-check = $digest_check
|
|
|
|
tls1-prf-digest-check = $digest_check
|
|
|
|
sshkdf-digest-check = $digest_check
|
|
|
|
sskdf-digest-check = $digest_check
|
|
|
|
x963kdf-digest-check = $digest_check
|
2024-07-22 15:24:53 +08:00
|
|
|
tdes-encrypt-disabled = $tdes_encrypt_disabled
|
2024-08-01 11:45:08 +08:00
|
|
|
rsa-pkcs15-padding-disabled = $pkcs15_pad_disable
|
2024-08-07 10:24:36 +08:00
|
|
|
rsa-pss-saltlen-check = $rsa_pss_saltlen_check
|
2024-07-29 08:16:30 +08:00
|
|
|
rsa-sign-x931-pad-disabled = $rsa_sign_x931_pad_disabled
|
2024-06-02 19:34:13 +08:00
|
|
|
hkdf-key-check = $kdf_key_check
|
2024-08-05 13:47:27 +08:00
|
|
|
kbkdf-key-check = $kdf_key_check
|
2024-06-02 19:34:13 +08:00
|
|
|
tls13-kdf-key-check = $kdf_key_check
|
|
|
|
tls1-prf-key-check = $kdf_key_check
|
|
|
|
sshkdf-key-check = $kdf_key_check
|
|
|
|
sskdf-key-check = $kdf_key_check
|
|
|
|
x963kdf-key-check = $kdf_key_check
|
2024-07-26 15:28:51 +08:00
|
|
|
pbkdf2-lower-bound-check = $pbkdf2_lower_bound_check
|
2024-08-08 14:56:22 +08:00
|
|
|
ecdh-cofactor-check = $ec_cofactor_check
|
2021-05-24 20:06:00 +08:00
|
|
|
_____
|