docs: Document Python TLS requirements (#12276)

* 🔧 Add simple test script

* 📝 Add documentation

* 🔧 It works, use it

* 🔧 Make the linter happy

* 🔧 Check on bootstrap

* Trivial copyediting

s/operation system/operating system/
This commit is contained in:
Felix Rieseberg 2018-05-16 23:19:49 +02:00 committed by Shelley Vohr
parent b160093b91
commit e8735cc005
4 changed files with 69 additions and 2 deletions

View file

@ -7,6 +7,19 @@ Follow the guidelines below for building Electron on Linux.
* At least 25GB disk space and 8GB RAM. * At least 25GB disk space and 8GB RAM.
* Python 2.7.x. Some distributions like CentOS 6.x still use Python 2.6.x * Python 2.7.x. Some distributions like CentOS 6.x still use Python 2.6.x
so you may need to check your Python version with `python -V`. so you may need to check your Python version with `python -V`.
Please also ensure that your system and Python version support at least TLS 1.2.
For a quick test, run the following script:
```sh
$ python ./script/check-tls.py
```
If the script returns that your configuration is using an outdated security
protocol, use your system's package manager to update Python to the latest
version in the 2.7.x branch. Alternatively, visit https://www.python.org/downloads/
for detailed instructions.
* Node.js. There are various ways to install Node. You can download * Node.js. There are various ways to install Node. You can download
source code from [nodejs.org](https://nodejs.org) and compile it. source code from [nodejs.org](https://nodejs.org) and compile it.
Doing so permits installing Node on your own home directory as a standard user. Doing so permits installing Node on your own home directory as a standard user.

View file

@ -7,8 +7,26 @@ Follow the guidelines below for building Electron on macOS.
* macOS >= 10.11.6 * macOS >= 10.11.6
* [Xcode](https://developer.apple.com/technologies/tools/) >= 8.2.1 * [Xcode](https://developer.apple.com/technologies/tools/) >= 8.2.1
* [node.js](https://nodejs.org) (external) * [node.js](https://nodejs.org) (external)
* Python 2.7 with support for TLS 1.2
If you are using the Python downloaded by Homebrew, you also need to install ## Python
Please also ensure that your system and Python version support at least TLS 1.2.
This depends on both your version of macOS and Python. For a quick test, run:
```sh
$ python ./script/check-tls.py
```
If the script returns that your configuration is using an outdated security
protocol, you can either update macOS to High Sierra or install a new version
of Python 2.7.x. To upgrade Python, use [Homebrew](https://brew.sh/):
```sh
$ brew install python@2 && brew link python@2 --force
```
If you are using Python as provided by Homebrew, you also need to install
the following Python modules: the following Python modules:
* [pyobjc](https://pythonhosted.org/pyobjc/install.html) * [pyobjc](https://pythonhosted.org/pyobjc/install.html)

View file

@ -12,7 +12,7 @@ from lib.config import BASE_URL, PLATFORM, MIPS64EL_SYSROOT_URL, \
is_verbose_mode, get_target_arch is_verbose_mode, get_target_arch
from lib.util import execute, execute_stdout, get_electron_version, \ from lib.util import execute, execute_stdout, get_electron_version, \
scoped_cwd, download, update_node_modules scoped_cwd, download, update_node_modules
from tls import check_tls
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__))) SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
VENDOR_DIR = os.path.join(SOURCE_ROOT, 'vendor') VENDOR_DIR = os.path.join(SOURCE_ROOT, 'vendor')
@ -31,6 +31,8 @@ def main():
if sys.platform == 'cygwin': if sys.platform == 'cygwin':
update_win32_python() update_win32_python()
check_tls(args.verbose)
update_submodules() update_submodules()
libcc_source_path = args.libcc_source_path libcc_source_path = args.libcc_source_path

34
script/tls.py Normal file
View file

@ -0,0 +1,34 @@
#!/usr/bin/env python
import json
import urllib2
import sys
def check_tls(verbose):
response = json.load(urllib2.urlopen('https://www.howsmyssl.com/a/check'))
tls = response['tls_version']
if sys.platform == "linux" or sys.platform == "linux2":
tutorial = "./docs/development/build-instructions-linux.md"
elif sys.platform == "darwin":
tutorial = "./docs/development/build-instructions-osx.md"
elif sys.platform == "win32":
tutorial = "./docs/development/build-instructions-windows.md"
else:
tutorial = "build instructions for your operating system" \
+ "in ./docs/development/"
if tls == "TLS 1.0":
print "Your system/python combination is using an outdated security" \
+ "protocol and will not be able to compile Electron. Please see " \
+ tutorial + "." \
+ "for instructions on how to update Python."
sys.exit(1)
else:
if verbose:
print "Your Python is using " + tls + ", which is sufficient for" \
+ "building Electron."
if __name__ == '__main__':
check_tls(True)
sys.exit(0)