basicswap/bin/install_certifi.py

55 lines
1.3 KiB
Python
Raw Permalink Normal View History

2022-06-25 20:10:31 +00:00
# install_certifi.py
#
# sample script to install or update a set of default Root Certificates
# for the ssl module. Uses the certificates provided by the certifi package:
# https://pypi.org/project/certifi/
import os
import os.path
import ssl
import stat
import subprocess
import sys
2024-11-15 16:52:19 +00:00
STAT_0o775 = (
stat.S_IRUSR
| stat.S_IWUSR
| stat.S_IXUSR
| stat.S_IRGRP
| stat.S_IWGRP
| stat.S_IXGRP
| stat.S_IROTH
| stat.S_IXOTH
)
2022-06-25 20:10:31 +00:00
def main():
openssl_dir, openssl_cafile = os.path.split(
2024-11-15 16:52:19 +00:00
ssl.get_default_verify_paths().openssl_cafile
)
2022-06-25 20:10:31 +00:00
print(" -- pip install --upgrade certifi")
2024-11-15 16:52:19 +00:00
subprocess.check_call(
[sys.executable, "-E", "-s", "-m", "pip", "install", "--upgrade", "certifi"]
)
2022-06-25 20:10:31 +00:00
import certifi
# change working directory to the default SSL directory
os.chdir(openssl_dir)
relpath_to_certifi_cafile = os.path.relpath(certifi.where())
print(" -- removing any existing file or link")
try:
os.remove(openssl_cafile)
except FileNotFoundError:
pass
print(" -- creating symlink to certifi certificate bundle")
os.symlink(relpath_to_certifi_cafile, openssl_cafile)
print(" -- setting permissions")
os.chmod(openssl_cafile, STAT_0o775)
print(" -- update complete")
2024-11-15 16:52:19 +00:00
if __name__ == "__main__":
2022-06-25 20:10:31 +00:00
main()