2024-02-26 13:52:55 +01:00
|
|
|
# Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: MPL-2.0
|
|
|
|
#
|
|
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
# file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
|
|
|
#
|
|
|
|
# See the COPYRIGHT file distributed with this work for additional
|
|
|
|
# information regarding copyright ownership.
|
|
|
|
|
|
|
|
import os
|
|
|
|
import re
|
2024-02-28 10:44:58 +01:00
|
|
|
from typing import Optional
|
2024-02-26 13:52:55 +01:00
|
|
|
|
|
|
|
from .. import log
|
|
|
|
|
|
|
|
|
|
|
|
OPENSSL_VARS = {
|
2024-02-28 10:44:58 +01:00
|
|
|
"OPENSSL_CONF": os.getenv("OPENSSL_CONF", None),
|
|
|
|
"SOFTHSM2_CONF": os.getenv("SOFTHSM2_CONF", None),
|
|
|
|
"SOFTHSM2_MODULE": None,
|
|
|
|
"ENGINE_ARG": None,
|
2024-02-26 13:52:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2024-02-28 10:44:58 +01:00
|
|
|
def parse_openssl_config(path: Optional[str]):
|
2024-05-06 18:04:46 +02:00
|
|
|
if path is None or not os.path.exists(path):
|
2024-02-28 10:44:58 +01:00
|
|
|
OPENSSL_VARS["ENGINE_ARG"] = None
|
|
|
|
OPENSSL_VARS["SOFTHSM2_MODULE"] = None
|
|
|
|
os.environ.pop("ENGINE_ARG", None)
|
|
|
|
os.environ.pop("SOFTHSM2_MODULE", None)
|
2024-02-26 13:52:55 +01:00
|
|
|
return
|
2024-05-06 18:04:46 +02:00
|
|
|
assert os.path.isfile(path), f"{path} exists, but it's not a file"
|
2024-02-28 10:44:58 +01:00
|
|
|
|
2024-02-26 13:52:55 +01:00
|
|
|
regex = re.compile(r"([^=]+)=(.*)")
|
|
|
|
log.debug(f"parsing openssl config: {path}")
|
|
|
|
with open(path, "r", encoding="utf-8") as conf:
|
|
|
|
for line in conf:
|
|
|
|
res = regex.match(line)
|
|
|
|
if res:
|
|
|
|
key = res.group(1).strip()
|
|
|
|
val = res.group(2).strip()
|
|
|
|
if key == "engine_id":
|
|
|
|
OPENSSL_VARS["ENGINE_ARG"] = f"-E {val}"
|
|
|
|
os.environ["ENGINE_ARG"] = f"-E {val}"
|
|
|
|
log.debug("ENGINE_ARG set to {OPENSSL_VARS['ENGINE_ARG']}")
|
|
|
|
elif key in ["MODULE_PATH", "pkcs11-module-path"]:
|
|
|
|
OPENSSL_VARS["SOFTHSM2_MODULE"] = val
|
|
|
|
os.environ["SOFTHSM2_MODULE"] = val
|
|
|
|
log.debug(
|
|
|
|
"SOFTHSM2_MODULE set to {OPENSSL_VARS['SOFTHSM2_MODULE']}"
|
|
|
|
)
|