123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622 |
- #! /usr/bin/env perl
- # Copyright 2015-2024 The OpenSSL Project Authors. All Rights Reserved.
- #
- # 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 strict;
- use warnings;
- use OpenSSL::Test::Utils;
- use OpenSSL::Test qw/:DEFAULT srctop_file/;
- setup("test_req");
- plan tests => 109;
- require_ok(srctop_file('test', 'recipes', 'tconversion.pl'));
- my @certs = qw(test certs);
- # What type of key to generate?
- my @req_new;
- if (disabled("rsa")) {
- @req_new = ("-newkey", "dsa:".srctop_file("apps", "dsa512.pem"));
- } else {
- @req_new = ("-new");
- note("There should be a 2 sequences of .'s and some +'s.");
- note("There should not be more that at most 80 per line");
- }
- # Prevent MSys2 filename munging for arguments that look like file paths but
- # aren't
- $ENV{MSYS2_ARG_CONV_EXCL} = "/CN=";
- # Check for duplicate -addext parameters, and one "working" case.
- my @addext_args = ( "openssl", "req", "-new", "-out", "testreq.pem",
- "-key", srctop_file(@certs, "ee-key.pem"),
- "-config", srctop_file("test", "test.cnf"), @req_new );
- my $val = "subjectAltName=DNS:example.com";
- my $val1 = "subjectAltName=otherName:1.2.3.4;UTF8:test,email:info\@example.com";
- my $val2 = " " . $val;
- my $val3 = $val;
- $val3 =~ s/=/ =/;
- ok( run(app([@addext_args, "-addext", $val])));
- ok( run(app([@addext_args, "-addext", $val1])));
- $val1 =~ s/UTF8/XXXX/; # execute the error handling in do_othername
- ok(!run(app([@addext_args, "-addext", $val1])));
- ok(!run(app([@addext_args, "-addext", $val, "-addext", $val])));
- ok(!run(app([@addext_args, "-addext", $val, "-addext", $val2])));
- ok(!run(app([@addext_args, "-addext", $val, "-addext", $val3])));
- ok(!run(app([@addext_args, "-addext", $val2, "-addext", $val3])));
- ok(run(app([@addext_args, "-addext", "SXNetID=1:one, 2:two, 3:three"])));
- ok(run(app([@addext_args, "-addext", "subjectAltName=dirName:dirname_sec"])));
- # If a CSR is provided with neither of -key or -CA/-CAkey, this should fail.
- ok(!run(app(["openssl", "req", "-x509",
- "-in", srctop_file(@certs, "x509-check.csr"),
- "-out", "testreq.pem"])));
- subtest "generating alt certificate requests with RSA" => sub {
- plan tests => 3;
- SKIP: {
- skip "RSA is not supported by this OpenSSL build", 2
- if disabled("rsa");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-section", "altreq",
- "-new", "-out", "testreq-rsa.pem", "-utf8",
- "-key", srctop_file("test", "testrsa.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-rsa.pem", "-noout"])),
- "Verifying signature on request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-section", "altreq",
- "-verify", "-in", "testreq-rsa.pem", "-noout"])),
- "Verifying signature on request");
- }
- };
- subtest "generating certificate requests with RSA" => sub {
- plan tests => 8;
- SKIP: {
- skip "RSA is not supported by this OpenSSL build", 2
- if disabled("rsa");
- ok(!run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsa.pem", "-utf8",
- "-key", srctop_file("test", "testrsa.pem"),
- "-keyform", "DER"])),
- "Checking that mismatching keyform fails");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsa.pem", "-utf8",
- "-key", srctop_file("test", "testrsa.pem"),
- "-keyform", "PEM"])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-rsa.pem", "-noout"])),
- "Verifying signature on request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-modulus", "-in", "testreq-rsa.pem", "-noout"])),
- "Printing a modulus of the request key");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq_withattrs_pem.pem", "-utf8",
- "-key", srctop_file("test", "testrsa_withattrs.pem")])),
- "Generating request from a key with extra attributes - PEM");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq_withattrs_pem.pem", "-noout"])),
- "Verifying signature on request from a key with extra attributes - PEM");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq_withattrs_der.pem", "-utf8",
- "-key", srctop_file("test", "testrsa_withattrs.der"),
- "-keyform", "DER"])),
- "Generating request from a key with extra attributes - PEM");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq_withattrs_der.pem", "-noout"])),
- "Verifying signature on request from a key with extra attributes - PEM");
- }
- };
- subtest "generating certificate requests with RSA-PSS" => sub {
- plan tests => 12;
- SKIP: {
- skip "RSA is not supported by this OpenSSL build", 2
- if disabled("rsa");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapss.pem", "-utf8",
- "-key", srctop_file("test", "testrsapss.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-rsapss.pem", "-noout"])),
- "Verifying signature on request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapss2.pem", "-utf8",
- "-sigopt", "rsa_padding_mode:pss",
- "-sigopt", "rsa_pss_saltlen:-1",
- "-key", srctop_file("test", "testrsapss.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-rsapss2.pem", "-noout"])),
- "Verifying signature on request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapssmand.pem", "-utf8",
- "-sigopt", "rsa_padding_mode:pss",
- "-key", srctop_file("test", "testrsapssmandatory.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-rsapssmand.pem", "-noout"])),
- "Verifying signature on request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapssmand2.pem", "-utf8",
- "-sigopt", "rsa_pss_saltlen:100",
- "-key", srctop_file("test", "testrsapssmandatory.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-rsapssmand2.pem", "-noout"])),
- "Verifying signature on request");
- ok(!run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapss3.pem", "-utf8",
- "-sigopt", "rsa_padding_mode:pkcs1",
- "-key", srctop_file("test", "testrsapss.pem")])),
- "Generating request with expected failure");
- ok(!run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapss3.pem", "-utf8",
- "-sigopt", "rsa_pss_saltlen:-5",
- "-key", srctop_file("test", "testrsapss.pem")])),
- "Generating request with expected failure");
- ok(!run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapssmand3.pem", "-utf8",
- "-sigopt", "rsa_pss_saltlen:10",
- "-key", srctop_file("test", "testrsapssmandatory.pem")])),
- "Generating request with expected failure");
- ok(!run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-rsapssmand3.pem", "-utf8",
- "-sha256",
- "-key", srctop_file("test", "testrsapssmandatory.pem")])),
- "Generating request with expected failure");
- }
- };
- subtest "generating certificate requests with DSA" => sub {
- plan tests => 2;
- SKIP: {
- skip "DSA is not supported by this OpenSSL build", 2
- if disabled("dsa");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-dsa.pem", "-utf8",
- "-key", srctop_file("test", "testdsa.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-dsa.pem", "-noout"])),
- "Verifying signature on request");
- }
- };
- subtest "generating certificate requests with ECDSA" => sub {
- plan tests => 2;
- SKIP: {
- skip "ECDSA is not supported by this OpenSSL build", 2
- if disabled("ec");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-ec.pem", "-utf8",
- "-key", srctop_file("test", "testec-p256.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-ec.pem", "-noout"])),
- "Verifying signature on request");
- }
- };
- subtest "generating certificate requests with Ed25519" => sub {
- plan tests => 2;
- SKIP: {
- skip "Ed25519 is not supported by this OpenSSL build", 2
- if disabled("ecx");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-ed25519.pem", "-utf8",
- "-key", srctop_file("test", "tested25519.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-ed25519.pem", "-noout"])),
- "Verifying signature on request");
- }
- };
- subtest "generating certificate requests with Ed448" => sub {
- plan tests => 2;
- SKIP: {
- skip "Ed448 is not supported by this OpenSSL build", 2
- if disabled("ecx");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-out", "testreq-ed448.pem", "-utf8",
- "-key", srctop_file("test", "tested448.pem")])),
- "Generating request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-ed448.pem", "-noout"])),
- "Verifying signature on request");
- }
- };
- subtest "generating certificate requests" => sub {
- plan tests => 2;
- ok(run(app(["openssl", "req", "-config", srctop_file("test", "test.cnf"),
- "-key", srctop_file(@certs, "ee-key.pem"),
- @req_new, "-out", "testreq.pem"])),
- "Generating request");
- ok(run(app(["openssl", "req", "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq.pem", "-noout"])),
- "Verifying signature on request");
- };
- subtest "generating SM2 certificate requests" => sub {
- plan tests => 4;
- SKIP: {
- skip "SM2 is not supported by this OpenSSL build", 4
- if disabled("sm2");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-key", srctop_file(@certs, "sm2.key"),
- "-sigopt", "distid:1234567812345678",
- "-out", "testreq-sm2.pem", "-sm3"])),
- "Generating SM2 certificate request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-sm2.pem", "-noout",
- "-vfyopt", "distid:1234567812345678", "-sm3"])),
- "Verifying signature on SM2 certificate request");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-new", "-key", srctop_file(@certs, "sm2.key"),
- "-sigopt", "hexdistid:DEADBEEF",
- "-out", "testreq-sm2.pem", "-sm3"])),
- "Generating SM2 certificate request with hex id");
- ok(run(app(["openssl", "req",
- "-config", srctop_file("test", "test.cnf"),
- "-verify", "-in", "testreq-sm2.pem", "-noout",
- "-vfyopt", "hexdistid:DEADBEEF", "-sm3"])),
- "Verifying signature on SM2 certificate request");
- }
- };
- my @openssl_args = ("req", "-config", srctop_file("apps", "openssl.cnf"));
- run_conversion('req conversions',
- "testreq.pem");
- run_conversion('req conversions -- testreq2',
- srctop_file("test", "testreq2.pem"));
- sub run_conversion {
- my $title = shift;
- my $reqfile = shift;
- subtest $title => sub {
- run(app(["openssl", @openssl_args,
- "-in", $reqfile, "-inform", "p",
- "-noout", "-text"],
- stderr => "req-check.err", stdout => undef));
- open DATA, "req-check.err";
- SKIP: {
- plan skip_all => "skipping req conversion test for $reqfile"
- if grep /Unknown Public Key/, map { s/\R//; } <DATA>;
- tconversion( -type => 'req', -in => $reqfile,
- -args => [ @openssl_args ] );
- }
- close DATA;
- unlink "req-check.err";
- done_testing();
- };
- }
- # Test both generation and verification of certs w.r.t. RFC 5280 requirements
- my $ca_cert; # will be set below
- sub generate_cert {
- my $cert = shift @_;
- my $ss = $cert =~ m/self-signed/;
- my $is_ca = $cert =~ m/CA/;
- my $cn = $is_ca ? "CA" : "EE";
- my $ca_key = srctop_file(@certs, "ca-key.pem");
- my $key = $is_ca ? $ca_key : srctop_file(@certs, "ee-key.pem");
- my @cmd = ("openssl", "req", "-config", "", "-x509",
- "-subj", "/CN=$cn", @_, "-out", $cert);
- push(@cmd, ("-key", $key)) if $ss;
- push(@cmd, ("-CA", $ca_cert, "-CAkey", $ca_key)) unless $ss;
- ok(run(app([@cmd])), "generate $cert");
- }
- sub has_keyUsage {
- my $cert = shift @_;
- my $expect = shift @_;
- cert_contains($cert, "Key Usage", $expect);
- }
- sub strict_verify {
- my $cert = shift @_;
- my $expect = shift @_;
- my $trusted = shift @_;
- $trusted = $cert unless $trusted;
- ok(run(app(["openssl", "verify", "-x509_strict", "-trusted", $trusted,
- "-partial_chain", $cert])) == $expect,
- "strict verify allow $cert");
- }
- my @v3_ca = ("-addext", "basicConstraints = critical,CA:true",
- "-addext", "keyUsage = keyCertSign");
- my $SKID_AKID = "subjectKeyIdentifier,authorityKeyIdentifier";
- # # SKID
- my $cert = "self-signed_default_SKID_no_explicit_exts.pem";
- generate_cert($cert);
- has_version($cert, 3);
- has_SKID($cert, 1); # SKID added, though no explicit extensions given
- has_AKID($cert, 0);
- my $cert = "self-signed_v3_CA_hash_SKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "subjectKeyIdentifier = hash");
- has_SKID($cert, 1); # explicit hash SKID
- $cert = "self-signed_v3_CA_no_SKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "subjectKeyIdentifier = none");
- cert_ext_has_n_different_lines($cert, 0, $SKID_AKID); # no SKID and no AKID
- #TODO strict_verify($cert, 0);
- $cert = "self-signed_v3_CA_given_SKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "subjectKeyIdentifier = 45");
- cert_contains($cert, "Subject Key Identifier: 45 ", 1); # given SKID
- strict_verify($cert, 1);
- # AKID of self-signed certs
- $cert = "self-signed_v1_CA_no_KIDs.pem";
- generate_cert($cert, "-x509v1");
- has_version($cert, 1);
- cert_ext_has_n_different_lines($cert, 0, $SKID_AKID); # no SKID and no AKID
- #TODO strict_verify($cert, 1); # self-signed v1 root cert should be accepted as CA
- $ca_cert = "self-signed_v3_CA_default_SKID.pem"; # will also be used below
- generate_cert($ca_cert, @v3_ca);
- has_SKID($ca_cert, 1); # default SKID
- has_AKID($ca_cert, 0); # no default AKID
- strict_verify($ca_cert, 1);
- $cert = "self-signed_v3_CA_no_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = none");
- has_AKID($cert, 0); # forced no AKID
- $cert = "self-signed_v3_CA_explicit_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid");
- has_AKID($cert, 0); # for self-signed cert, AKID suppressed and not forced
- $cert = "self-signed_v3_CA_forced_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid:always");
- cert_ext_has_n_different_lines($cert, 3, $SKID_AKID); # forced AKID, AKID == SKID
- strict_verify($cert, 1);
- $cert = "self-signed_v3_CA_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer");
- has_AKID($cert, 0); # suppressed AKID since not forced
- $cert = "self-signed_v3_CA_forced_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer:always");
- cert_contains($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # forced issuer AKID
- $cert = "self-signed_v3_CA_nonforced_keyid_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid, issuer");
- has_AKID($cert, 0); # AKID not present because not forced and cert self-signed
- $cert = "self-signed_v3_CA_keyid_forced_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid, issuer:always");
- cert_contains($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # issuer AKID forced, with keyid not forced
- $cert = "self-signed_v3_CA_forced_keyid_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid:always, issuer");
- has_AKID($cert, 1); # AKID with keyid forced
- cert_contains($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 0); # no issuer AKID
- $cert = "self-signed_v3_CA_forced_keyid_forced_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid:always, issuer:always");
- cert_contains($cert, "Authority Key Identifier: keyid(:[0-9A-Fa-f]{2})+ DirName:/CN=CA serial:", 1); # AKID with keyid and issuer forced
- $cert = "self-signed_v3_EE_wrong_keyUsage.pem";
- generate_cert($cert, "-addext", "keyUsage = keyCertSign");
- #TODO strict_verify($cert, 1); # should be accepted because RFC 5280 does not apply
- # AKID of self-issued but not self-signed certs
- $cert = "self-issued_x509_v3_CA_default_KIDs.pem";
- ok(run(app([("openssl", "x509", "-copy_extensions", "copy",
- "-req", "-in", srctop_file(@certs, "ext-check.csr"),
- "-key", srctop_file(@certs, "ca-key.pem"),
- "-force_pubkey", srctop_file("test", "testrsapub.pem"),
- "-out", $cert)])), "generate using x509: $cert");
- cert_contains($cert, "Issuer: CN=test .*? Subject: CN=test", 1);
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- strict_verify($cert, 1);
- $cert = "self-issued_v3_CA_default_KIDs.pem";
- generate_cert($cert, "-addext", "keyUsage = dataEncipherment",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_contains($cert, "Issuer: CN=CA .*? Subject: CN=CA", 1);
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- strict_verify($cert, 1);
- $cert = "self-issued_v3_CA_no_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = none",
- "-in", srctop_file(@certs, "x509-check.csr"));
- has_version($cert, 3);
- has_SKID($cert, 1); # SKID added, though no explicit extensions given
- has_AKID($cert, 0);
- strict_verify($cert, 1);
- $cert = "self-issued_v3_CA_explicit_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = keyid",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- strict_verify($cert, 1);
- $cert = "self-issued_v3_CA_forced_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = keyid:always",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- $cert = "self-issued_v3_CA_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_contains($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # just issuer AKID
- $cert = "self-issued_v3_CA_forced_issuer_AKID.pem";
- generate_cert($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer:always",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_contains($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # just issuer AKID
- $cert = "self-issued_v3_CA_keyid_issuer_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = keyid, issuer",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID, not forced
- $cert = "self-issued_v3_CA_keyid_forced_issuer_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = keyid, issuer:always",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_ext_has_n_different_lines($cert, 6, $SKID_AKID); # SKID != AKID, with forced issuer
- $cert = "self-issued_v3_CA_forced_keyid_and_issuer_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = keyid:always, issuer:always",
- "-in", srctop_file(@certs, "x509-check.csr"));
- cert_ext_has_n_different_lines($cert, 6, $SKID_AKID); # SKID != AKID, both forced
- # AKID of not self-issued certs
- $cert = "regular_v3_EE_default_KIDs_no_other_exts.pem";
- generate_cert($cert, "-key", srctop_file(@certs, "ee-key.pem"));
- has_version($cert, 3);
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- $cert = "regular_v3_EE_default_KIDs.pem";
- generate_cert($cert, "-addext", "keyUsage = dataEncipherment",
- "-key", srctop_file(@certs, "ee-key.pem"));
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- strict_verify($cert, 1, $ca_cert);
- $cert = "regular_v3_EE_copied_exts_default_KIDs.pem";
- generate_cert($cert, "-copy_extensions", "copy",
- "-in", srctop_file(@certs, "ext-check.csr"));
- cert_ext_has_n_different_lines($cert, 4, $SKID_AKID); # SKID != AKID
- strict_verify($cert, 1);
- $cert = "v3_EE_no_AKID.pem";
- generate_cert($cert, "-addext", "authorityKeyIdentifier = none",
- "-key", srctop_file(@certs, "ee-key.pem"));
- has_SKID($cert, 1);
- has_AKID($cert, 0);
- strict_verify($cert, 0, $ca_cert);
- # Key Usage
- $cert = "self-signed_CA_no_keyUsage.pem";
- generate_cert($cert, "-in", srctop_file(@certs, "ext-check.csr"));
- has_keyUsage($cert, 0);
- $cert = "self-signed_CA_with_keyUsages.pem";
- generate_cert($cert, "-in", srctop_file(@certs, "ext-check.csr"),
- "-copy_extensions", "copy");
- has_keyUsage($cert, 1);
- # Generate cert using req with '-modulus'
- ok(run(app(["openssl", "req", "-x509", "-new", "-days", "365",
- "-key", srctop_file("test", "testrsa.pem"),
- "-config", srctop_file('test', 'test.cnf'),
- "-out", "testreq-cert.pem",
- "-modulus"])), "cert req creation - with -modulus");
- # Verify cert
- ok(run(app(["openssl", "x509", "-in", "testreq-cert.pem",
- "-noout", "-text"])), "cert verification");
- # Generate cert with explicit start and end dates
- my %today = (strftime("%Y-%m-%d", gmtime) => 1);
- my $cert = "self-signed_explicit_date.pem";
- ok(run(app(["openssl", "req", "-x509", "-new", "-text",
- "-config", srctop_file('test', 'test.cnf'),
- "-key", srctop_file("test", "testrsa.pem"),
- "-not_before", "today",
- "-not_after", "today",
- "-out", $cert]))
- && ++$today{strftime("%Y-%m-%d", gmtime)}
- && (grep { defined $today{$_} } get_not_before_date($cert))
- && (grep { defined $today{$_} } get_not_after_date($cert)), "explicit start and end dates");
|