diff options
author | NIIBE Yutaka <[email protected]> | 2023-05-11 09:51:33 +0000 |
---|---|---|
committer | NIIBE Yutaka <[email protected]> | 2023-05-11 09:51:33 +0000 |
commit | 3274893224d6ef9ae2480ae724243d5574273b38 (patch) | |
tree | 42c3b5a0f2deb53690477e555be04be1cec4be4e /sm/certchain.c | |
parent | dirmngr: Remove casting which is not needed any more. (diff) | |
parent | Prepare new development cycle (diff) | |
download | gnupg-gniibe/t6275.tar.gz gnupg-gniibe/t6275.zip |
Merge branch 'master' into gniibe/t6275gniibe/t6275
Diffstat (limited to '')
-rw-r--r-- | sm/certchain.c | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/sm/certchain.c b/sm/certchain.c index 7b782190b..84dbed696 100644 --- a/sm/certchain.c +++ b/sm/certchain.c @@ -307,6 +307,7 @@ allowed_ca (ctrl_t ctrl, static int check_cert_policy (ksba_cert_t cert, int listmode, estream_t fplist) { + static int no_policy_file; gpg_error_t err; char *policies; estream_t fp; @@ -341,12 +342,24 @@ check_cert_policy (ksba_cert_t cert, int listmode, estream_t fplist) return 0; } - fp = es_fopen (opt.policy_file, "r"); + if (no_policy_file) + { + /* Avoid trying to open the policy file if we already know that + * it does not exist. */ + fp = NULL; + gpg_err_set_errno (ENOENT); + } + else + fp = es_fopen (opt.policy_file, "r"); if (!fp) { - if (opt.verbose || errno != ENOENT) + if ((opt.verbose || errno != ENOENT) && !no_policy_file) log_info (_("failed to open '%s': %s\n"), opt.policy_file, strerror (errno)); + + if (errno == ENOENT) + no_policy_file = 1; + xfree (policies); /* With no critical policies this is only a warning */ if (!any_critical) @@ -361,6 +374,8 @@ check_cert_policy (ksba_cert_t cert, int listmode, estream_t fplist) return gpg_error (GPG_ERR_NO_POLICY_MATCH); } + /* FIXME: Cache the policy file content. */ + for (;;) { int c; |