mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 02:43:41 +00:00 
			
		
		
		
	 dde4f63a54
			
		
	
	
		dde4f63a54
		
	
	
	
	
		
			
			Also provide a sample Install Certificates command script to install a set of root certificates from the third-party certifi module.
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| /Library/Frameworks/Python.framework/Versions/@PYVER@/bin/python@PYVER@ << "EOF"
 | |
| 
 | |
| # 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.python.org/pypi/certifi
 | |
| 
 | |
| import os
 | |
| import os.path
 | |
| import ssl
 | |
| import stat
 | |
| import subprocess
 | |
| import sys
 | |
| 
 | |
| 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 )
 | |
| 
 | |
| def main():
 | |
|     openssl_dir, openssl_cafile = os.path.split(
 | |
|         ssl.get_default_verify_paths().openssl_cafile)
 | |
| 
 | |
|     print(" -- pip install --upgrade certifi")
 | |
|     subprocess.check_call([sys.executable,
 | |
|         "-E", "-s", "-m", "pip", "install", "--upgrade", "certifi"])
 | |
| 
 | |
|     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")
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     main()
 | |
| EOF
 |